X-Git-Url: https://gerrit.simantics.org/r/gitweb?a=blobdiff_plain;f=bundles%2Forg.simantics.fileimport.ui%2Fsrc%2Forg%2Fsimantics%2Ffileimport%2Fui%2FImportFileHandler.java;h=1bdcd15757985cd2ef14366630fc6499414f4aa0;hb=7bc4de702166fe57dd45b7f161847e6d21d83bb4;hp=3da6858a3f35ef51021632aab00ecfb95d07cb2d;hpb=0ae2b770234dfc3cbb18bd38f324125cf0faca07;p=simantics%2Fplatform.git diff --git a/bundles/org.simantics.fileimport.ui/src/org/simantics/fileimport/ui/ImportFileHandler.java b/bundles/org.simantics.fileimport.ui/src/org/simantics/fileimport/ui/ImportFileHandler.java index 3da6858a3..1bdcd1575 100644 --- a/bundles/org.simantics.fileimport.ui/src/org/simantics/fileimport/ui/ImportFileHandler.java +++ b/bundles/org.simantics.fileimport.ui/src/org/simantics/fileimport/ui/ImportFileHandler.java @@ -1,30 +1,38 @@ - package org.simantics.fileimport.ui; import java.nio.file.Paths; import java.util.Map; import java.util.Optional; +import java.util.function.Consumer; import javax.inject.Named; +import org.eclipse.core.runtime.IAdaptable; import org.eclipse.e4.core.di.annotations.CanExecute; import org.eclipse.e4.core.di.annotations.Execute; import org.eclipse.e4.ui.services.IServiceConstants; +import org.eclipse.jface.viewers.ISelection; +import org.eclipse.jface.viewers.StructuredSelection; import org.eclipse.swt.SWT; import org.eclipse.swt.widgets.FileDialog; import org.eclipse.swt.widgets.Shell; +import org.simantics.db.Resource; import org.simantics.fileimport.FileImportService; +import org.slf4j.Logger; +import org.slf4j.LoggerFactory; public class ImportFileHandler { + private static final Logger LOGGER = LoggerFactory.getLogger(ImportFileHandler.class); + @CanExecute public boolean canExecute() { return !FileImportService.supportedExtensionsWithFilters().isEmpty(); } @Execute - public void execute(@Named(IServiceConstants.ACTIVE_SHELL) Shell shell) { - + public void execute(@Named(IServiceConstants.ACTIVE_SELECTION) ISelection selection, + @Named(IServiceConstants.ACTIVE_SHELL) Shell shell) { Map extensions = FileImportService.supportedExtensionsWithFilters(); String[] filterExtensions = (String[]) extensions.keySet().toArray(new String[extensions.keySet().size()]); String[] filterNames = (String[]) extensions.values().toArray(new String[extensions.values().size()]); @@ -32,18 +40,33 @@ public class ImportFileHandler { // Sanity check for (int i = 0; i < filterExtensions.length; i++) { String extension = filterExtensions[i]; - if (!extension.startsWith("*.")) { - System.err.println("Invalid extension filter provied: " + extension); + if (!extension.startsWith("*.")) { //$NON-NLS-1$ + System.err.println("Invalid extension filter provied: " + extension); //$NON-NLS-1$ } } FileDialog dialog = new FileDialog(shell, SWT.OPEN); - dialog.setText("Choose File"); + dialog.setText(Messages.ImportFileHandler_ChooseFile); dialog.setFilterExtensions(filterExtensions); dialog.setFilterNames(filterNames); final String fileName = dialog.open(); if (fileName == null) return; - FileImportService.performFileImport(Paths.get(fileName), Optional.empty()); + + Resource selectedResource = null; + try { + if(selection instanceof StructuredSelection) { + StructuredSelection structuredSelection = (StructuredSelection)selection; + Object elem = structuredSelection.getFirstElement(); + IAdaptable a = (IAdaptable)elem; + selectedResource = a.getAdapter(Resource.class); + } + } catch(NullPointerException | ClassCastException npe) { + LOGGER.warn("Failed to find selection, passing null to file importer", npe); //$NON-NLS-1$ + } + + FileImportService.performFileImport(Paths.get(fileName), Optional.of(selectedResource), Optional.of((Consumer) t -> { + LOGGER.error("Could not import file " + fileName, t); //$NON-NLS-1$ + })); } } \ No newline at end of file