diff options
author | Kenji Hosokawa <khosokawa@jp.adit-jv.com> | 2021-08-03 18:42:39 +0900 |
---|---|---|
committer | Kenji Hosokawa <khosokawa@jp.adit-jv.com> | 2021-08-06 19:32:38 +0900 |
commit | be4f78978faba3d3ceb88df02a7f93a2e09ff1e0 (patch) | |
tree | 1f3f1a96251ac4f655c8a96fc33d5d4ee779cd06 /rba.tool.editor.ui/src/rba/tool/editor/ui/resource | |
parent | 71ca7c6cab863767ef30c8bd05b2bbfda8731cb5 (diff) |
Initial commit
Bug-AGL: SPEC-4033
Signed-off-by: Kenji Hosokawa <khosokawa@jp.adit-jv.com>
Diffstat (limited to 'rba.tool.editor.ui/src/rba/tool/editor/ui/resource')
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; + } +} |