summaryrefslogtreecommitdiffstats
path: root/rba.tool.editor.ui/src/rba/tool/editor/ui/resource
diff options
context:
space:
mode:
Diffstat (limited to 'rba.tool.editor.ui/src/rba/tool/editor/ui/resource')
-rw-r--r--rba.tool.editor.ui/src/rba/tool/editor/ui/resource/RBADocumentResourceSetProvider.xtend27
-rw-r--r--rba.tool.editor.ui/src/rba/tool/editor/ui/resource/RBAModelResourceSetProvider.xtend37
-rw-r--r--rba.tool.editor.ui/src/rba/tool/editor/ui/resource/RBAModelResourceUIServiceProvider.xtend36
3 files changed, 100 insertions, 0 deletions
diff --git a/rba.tool.editor.ui/src/rba/tool/editor/ui/resource/RBADocumentResourceSetProvider.xtend b/rba.tool.editor.ui/src/rba/tool/editor/ui/resource/RBADocumentResourceSetProvider.xtend
new file mode 100644
index 0000000..33cd0dc
--- /dev/null
+++ b/rba.tool.editor.ui/src/rba/tool/editor/ui/resource/RBADocumentResourceSetProvider.xtend
@@ -0,0 +1,27 @@
+package rba.tool.editor.ui.resource
+
+import com.google.inject.Singleton
+import org.eclipse.core.resources.IProject
+import org.eclipse.emf.ecore.resource.ResourceSet
+import org.eclipse.swt.widgets.Display
+import org.eclipse.xtext.ui.resource.SimpleResourceSetProvider
+import rba.tool.editor.ui.editor.model.manager.ResourceManagerUI
+import rba.tool.editor.ui.util.UnitOfProgressUtil
+
+@Singleton
+class RBADocumentResourceSetProvider extends SimpleResourceSetProvider {
+
+ override get(IProject project) {
+ val ResourceSet result = super.get(project);
+ if(project !== null) {
+ Display.getDefault().asyncExec(new Runnable() {
+ override run() {
+ if(ResourceManagerUI.INSTANCE.currentProject === null) {
+ UnitOfProgressUtil.doProjectSwitchProgress(project, false);
+ }
+ }
+ });
+ }
+ return result;
+ }
+}
diff --git a/rba.tool.editor.ui/src/rba/tool/editor/ui/resource/RBAModelResourceSetProvider.xtend b/rba.tool.editor.ui/src/rba/tool/editor/ui/resource/RBAModelResourceSetProvider.xtend
new file mode 100644
index 0000000..5c4a6dd
--- /dev/null
+++ b/rba.tool.editor.ui/src/rba/tool/editor/ui/resource/RBAModelResourceSetProvider.xtend
@@ -0,0 +1,37 @@
+package rba.tool.editor.ui.resource
+
+import com.google.inject.Singleton
+import java.util.concurrent.ConcurrentHashMap
+import org.eclipse.core.resources.IProject
+import org.eclipse.emf.ecore.resource.ResourceSet
+import org.eclipse.xtext.ui.resource.SimpleResourceSetProvider
+
+@Singleton
+class RBAModelResourceSetProvider extends SimpleResourceSetProvider {
+
+ private ConcurrentHashMap<IProject, ResourceSet> projectXtextResourceSetMap = new ConcurrentHashMap<IProject, ResourceSet>();
+
+ override get(IProject project) {
+ val ResourceSet result = super.get(project);
+ if(project !== null) {
+ if(projectXtextResourceSetMap.containsKey(project)) {
+ projectXtextResourceSetMap.remove(project);
+ }
+ projectXtextResourceSetMap.put(project, result);
+ }
+ return result;
+ }
+
+ def public ResourceSet getResourceSet(IProject project) {
+ if(project === null) {
+ return get(project);
+ } else {
+ return projectXtextResourceSetMap.get(project) ?: get(project);
+ }
+ }
+
+ def public void setResourceSet(IProject project, ResourceSet resourceSet) {
+ projectXtextResourceSetMap.put(project, resourceSet);
+ }
+
+}
diff --git a/rba.tool.editor.ui/src/rba/tool/editor/ui/resource/RBAModelResourceUIServiceProvider.xtend b/rba.tool.editor.ui/src/rba/tool/editor/ui/resource/RBAModelResourceUIServiceProvider.xtend
new file mode 100644
index 0000000..fb795a1
--- /dev/null
+++ b/rba.tool.editor.ui/src/rba/tool/editor/ui/resource/RBAModelResourceUIServiceProvider.xtend
@@ -0,0 +1,36 @@
+package rba.tool.editor.ui.resource
+
+import com.google.inject.Inject
+import org.eclipse.core.resources.IFile
+import org.eclipse.core.resources.IStorage
+import org.eclipse.core.resources.IWorkspace
+import org.eclipse.emf.common.util.URI
+import org.eclipse.xtext.resource.IResourceServiceProvider
+import org.eclipse.xtext.ui.resource.DefaultResourceUIServiceProvider
+import rba.tool.editor.ui.wizard.ExtendRBAModelProjectCreator
+
+class RBAModelResourceUIServiceProvider extends DefaultResourceUIServiceProvider {
+
+ @Inject private IWorkspace workspace;
+
+ @Inject private ExtendRBAModelProjectCreator projectCreator;
+
+ @Inject public new(IResourceServiceProvider delegate) {
+ super(delegate)
+ }
+
+ override canHandle(URI uri, IStorage storage) {
+ if(!super.canHandle(uri, storage)) {
+ return false;
+ }
+ if(workspace !== null) {
+ if(storage instanceof IFile) {
+ val folderName = URI.decode(if(uri.segmentCount > 3) uri.segment(2) else null);
+ if(!projectCreator.modelFolderName.equals(folderName)) {
+ return false;
+ }
+ }
+ }
+ return true;
+ }
+}