summaryrefslogtreecommitdiffstats
path: root/rba.tool.editor.ui/src/rba/tool/editor/ui/util
diff options
context:
space:
mode:
authorKenji Hosokawa <khosokawa@jp.adit-jv.com>2021-08-03 18:42:39 +0900
committerKenji Hosokawa <khosokawa@jp.adit-jv.com>2021-08-06 19:32:38 +0900
commitbe4f78978faba3d3ceb88df02a7f93a2e09ff1e0 (patch)
tree1f3f1a96251ac4f655c8a96fc33d5d4ee779cd06 /rba.tool.editor.ui/src/rba/tool/editor/ui/util
parent71ca7c6cab863767ef30c8bd05b2bbfda8731cb5 (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/util')
-rw-r--r--rba.tool.editor.ui/src/rba/tool/editor/ui/util/CharacterUtil.xtend10
-rw-r--r--rba.tool.editor.ui/src/rba/tool/editor/ui/util/UnitOfProgressUtil.java84
-rw-r--r--rba.tool.editor.ui/src/rba/tool/editor/ui/util/concurrent/AbstractSwitchProjectProgress.java40
-rw-r--r--rba.tool.editor.ui/src/rba/tool/editor/ui/util/concurrent/IUnitOfProgress.java18
4 files changed, 152 insertions, 0 deletions
diff --git a/rba.tool.editor.ui/src/rba/tool/editor/ui/util/CharacterUtil.xtend b/rba.tool.editor.ui/src/rba/tool/editor/ui/util/CharacterUtil.xtend
new file mode 100644
index 0000000..28cbe08
--- /dev/null
+++ b/rba.tool.editor.ui/src/rba/tool/editor/ui/util/CharacterUtil.xtend
@@ -0,0 +1,10 @@
+package rba.tool.editor.ui.util
+
+import org.eclipse.xtext.Keyword
+
+class CharacterUtil {
+
+ def public static boolean isKeywordWorthyToPropose(Keyword keyword) {
+ return keyword.getValue().length() > 1 && Character.isLetter(keyword.getValue().charAt(0));
+ }
+}
diff --git a/rba.tool.editor.ui/src/rba/tool/editor/ui/util/UnitOfProgressUtil.java b/rba.tool.editor.ui/src/rba/tool/editor/ui/util/UnitOfProgressUtil.java
new file mode 100644
index 0000000..3fd41b2
--- /dev/null
+++ b/rba.tool.editor.ui/src/rba/tool/editor/ui/util/UnitOfProgressUtil.java
@@ -0,0 +1,84 @@
+package rba.tool.editor.ui.util;
+
+import org.eclipse.core.resources.IProject;
+import org.eclipse.core.runtime.IProgressMonitor;
+import org.eclipse.core.runtime.IStatus;
+import org.eclipse.core.runtime.Status;
+import org.eclipse.core.runtime.jobs.Job;
+
+import rba.tool.editor.ui.editor.model.manager.ResourceManagerUI;
+import rba.tool.editor.ui.util.concurrent.IUnitOfProgress;
+
+public class UnitOfProgressUtil {
+
+ public static void doProjectSwitchProgress(final IProject project, final boolean showConfirmDialog) throws Exception {
+ IUnitOfProgress.Void<IProject> progress = new IUnitOfProgress.Void<IProject>() {
+ @Override
+ public void process(IProject state) throws Exception {
+ Job projectSwitchJob = new Job("[RBA Tool]- Switch Project") {
+ @Override
+ protected IStatus run(IProgressMonitor monitor) {
+ monitor.beginTask("Switch Project...", 1); //$NON-NLS-1$
+ try {
+ ResourceManagerUI.INSTANCE.switchToProject(state, monitor);
+ } catch (Exception e) {
+ e.printStackTrace();
+ return Status.CANCEL_STATUS;
+ } finally {
+ monitor.done();
+ }
+ return Status.OK_STATUS;
+ }
+
+ @Override
+ public boolean belongsTo(Object family) {
+ return IUnitOfProgress.FAMILY_UNIT_OF_PROGRESS == family;
+ }
+ };
+ projectSwitchJob.schedule();
+ }
+ };
+
+ if (ResourceManagerUI.INSTANCE.doConfirm(project, showConfirmDialog)) {
+ progress.exec(project);
+ }
+ }
+
+ public static void doProjectSwitchProgressWithRunnable(final IProject project, final boolean showConfirmDialog, final Runnable run) throws Exception {
+ IUnitOfProgress.Void<IProject> progress = new IUnitOfProgress.Void<IProject>() {
+ @Override
+ public void process(IProject state) throws Exception {
+ Job projectSwitchJob = new Job("[RBA Tool]- Switch Project") {
+ @Override
+ protected IStatus run(IProgressMonitor monitor) {
+ monitor.beginTask("Switch Project...", 1); //$NON-NLS-1$
+ try {
+ ResourceManagerUI.INSTANCE.switchToProject(state, monitor);
+ if (monitor.isCanceled()) {
+ throw new InterruptedException();
+ }
+ run.run();
+ } catch (Exception e) {
+ e.printStackTrace();
+ return Status.CANCEL_STATUS;
+ } finally {
+ monitor.done();
+ }
+ return Status.OK_STATUS;
+ }
+
+ @Override
+ public boolean belongsTo(Object family) {
+ return IUnitOfProgress.FAMILY_UNIT_OF_PROGRESS == family;
+ }
+ };
+ projectSwitchJob.schedule();
+ }
+ };
+
+ if (ResourceManagerUI.INSTANCE.doConfirm(project, showConfirmDialog)) {
+ progress.exec(project);
+ }
+ }
+
+}
diff --git a/rba.tool.editor.ui/src/rba/tool/editor/ui/util/concurrent/AbstractSwitchProjectProgress.java b/rba.tool.editor.ui/src/rba/tool/editor/ui/util/concurrent/AbstractSwitchProjectProgress.java
new file mode 100644
index 0000000..2d640d3
--- /dev/null
+++ b/rba.tool.editor.ui/src/rba/tool/editor/ui/util/concurrent/AbstractSwitchProjectProgress.java
@@ -0,0 +1,40 @@
+package rba.tool.editor.ui.util.concurrent;
+
+import org.eclipse.core.resources.IProject;
+import org.eclipse.core.runtime.IProgressMonitor;
+import org.eclipse.core.runtime.SubMonitor;
+
+import rba.tool.editor.ui.editor.model.manager.ResourceManagerUI;
+
+public abstract class AbstractSwitchProjectProgress<R, P> implements IUnitOfProgress<Object, IProject> {
+
+ private final boolean showConfirmDialog;
+
+ public AbstractSwitchProjectProgress() {
+ this(true);
+ }
+
+ public AbstractSwitchProjectProgress(boolean showConfirmDialog) {
+ this.showConfirmDialog = showConfirmDialog;
+ }
+
+ @Override
+ public R exec(IProject state) throws Exception {
+ SubMonitor progress = SubMonitor.convert(null, 6);
+ if (!ResourceManagerUI.INSTANCE.isCurrentProject(state)) {
+ if (ResourceManagerUI.INSTANCE.doConfirm(state, showConfirmDialog)) {
+ ResourceManagerUI.INSTANCE.switchToProject(state, progress.newChild(2));
+
+ if (progress.isCanceled()) {
+ throw new InterruptedException();
+ }
+ return internalExec(state, progress.newChild(4));
+ } else {
+ throw new InterruptedException();
+ }
+ }
+ return internalExec(state, progress.newChild(4));
+ }
+
+ protected abstract R internalExec(IProject state, IProgressMonitor monitor);
+}
diff --git a/rba.tool.editor.ui/src/rba/tool/editor/ui/util/concurrent/IUnitOfProgress.java b/rba.tool.editor.ui/src/rba/tool/editor/ui/util/concurrent/IUnitOfProgress.java
new file mode 100644
index 0000000..f7141b1
--- /dev/null
+++ b/rba.tool.editor.ui/src/rba/tool/editor/ui/util/concurrent/IUnitOfProgress.java
@@ -0,0 +1,18 @@
+package rba.tool.editor.ui.util.concurrent;
+
+public interface IUnitOfProgress<R, P> {
+
+ public static final Object FAMILY_UNIT_OF_PROGRESS = new Object();
+
+ R exec(P state) throws Exception;
+
+ public static abstract class Void<T> implements IUnitOfProgress<Object, T> {
+ @Override
+ public final Object exec(T state) throws Exception {
+ process(state);
+ return null;
+ }
+
+ public abstract void process(T state) throws Exception;
+ }
+}