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/RBAModelResourceUIServiceProvider.xtend | |
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/RBAModelResourceUIServiceProvider.xtend')
-rw-r--r-- | rba.tool.editor.ui/src/rba/tool/editor/ui/resource/RBAModelResourceUIServiceProvider.xtend | 36 |
1 files changed, 36 insertions, 0 deletions
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; + } +} |