X-Git-Url: https://gerrit.simantics.org/r/gitweb?a=blobdiff_plain;ds=inline;f=bundles%2Forg.simantics.ui%2Fsrc%2Forg%2Fsimantics%2Fui%2Fworkbench%2Fe4%2FE4ResourceEditorSupport.java;h=fa32b38b10af6945ee75b82aa66f2faab3381879;hb=refs%2Fchanges%2F69%2F1969%2F7;hp=77716f9384410e3dadb422cce6b3b7d03cda211d;hpb=969bd23cab98a79ca9101af33334000879fb60c5;p=simantics%2Fplatform.git
diff --git a/bundles/org.simantics.ui/src/org/simantics/ui/workbench/e4/E4ResourceEditorSupport.java b/bundles/org.simantics.ui/src/org/simantics/ui/workbench/e4/E4ResourceEditorSupport.java
index 77716f938..fa32b38b1 100644
--- a/bundles/org.simantics.ui/src/org/simantics/ui/workbench/e4/E4ResourceEditorSupport.java
+++ b/bundles/org.simantics.ui/src/org/simantics/ui/workbench/e4/E4ResourceEditorSupport.java
@@ -1,170 +1,170 @@
-/*******************************************************************************
- * Copyright (c) 2007, 2013 Association for Decentralized Information Management
- * in Industry THTH ry.
- * All rights reserved. This program and the accompanying materials
- * are made available under the terms of the Eclipse Public License v1.0
- * which accompanies this distribution, and is available at
- * http://www.eclipse.org/legal/epl-v10.html
- *
- * Contributors:
- * VTT Technical Research Centre of Finland - initial API and implementation
- * Semantum Oy - issue #4384
- *******************************************************************************/
-package org.simantics.ui.workbench.e4;
-
-import org.eclipse.ui.PlatformUI;
-import org.simantics.Simantics;
-import org.simantics.db.ReadGraph;
-import org.simantics.db.Resource;
-import org.simantics.db.common.procedure.adapter.ListenerAdapter;
-import org.simantics.db.common.request.ParametrizedRead;
-import org.simantics.db.common.request.TernaryRead;
-import org.simantics.db.exception.DatabaseException;
-import org.simantics.ui.workbench.IResourceEditorInput;
-import org.simantics.utils.datastructures.map.Tuple;
-import org.simantics.utils.ui.ExceptionUtils;
-import org.simantics.utils.ui.SWTUtils;
-
-/**
- * A helper class for adding input validation and reaction to input invalidation
- * to an E4 (editor) part that uses Simantics database {@link Resource}s as its
- * input.
- *
- *
- * Only useful with E4ResourceEditorBase extending part implementations.
- *
- * @author Tuukka Lehtonen
- */
-public class E4ResourceEditorSupport {
-
- private E4ResourceEditorBase editor;
-
- private ParametrizedRead inputValidator;
-
- private InputListener inputListener;
-
- public E4ResourceEditorSupport(E4ResourceEditorBase editor) {
- this(editor, null);
- }
-
- public E4ResourceEditorSupport(E4ResourceEditorBase editor, ParametrizedRead inputValidator) {
- this.editor = editor;
- this.inputValidator = inputValidator;
- }
-
- public void dispose() {
- deactivateValidation();
- inputValidator = null;
- editor = null;
- }
-
- protected boolean isDisposed() {
- return editor == null;
- }
-
- public synchronized void activateValidation() {
- if (isDisposed())
- throw new IllegalStateException(this + " is disposed");
- if (inputListener != null)
- return;
-
- E4ResourceEditorBase e = editor;
- inputListener = new InputListener();
- Simantics.getSession().asyncRequest(new InputEvaluator(e.getPart().getElementId(), e.getResourceInput(), inputValidator), inputListener);
- }
-
- public synchronized void deactivateValidation() {
- if (isDisposed())
- throw new IllegalStateException(this + " is disposed");
- if (inputListener == null)
- return;
- inputListener.dispose();
- }
-
- static enum InputState {
- VALID,
- INVALID,
- NON_EXISTENT;
-
- public static InputState parse(boolean exists, boolean valid) {
- if (!exists)
- return NON_EXISTENT;
- return valid ? VALID : INVALID;
- }
- }
-
- static class Evaluation extends Tuple {
- public Evaluation(String editorElementId, InputState state) {
- super(editorElementId, state);
- }
-
- public String getEditorElementId() {
- return (String) getField(0);
- }
-
- public InputState getInputState() {
- return (InputState) getField(1);
- }
- }
-
- public static class InputEvaluator extends TernaryRead, Evaluation> {
-
- public InputEvaluator(String editorElementId, IResourceEditorInput input, ParametrizedRead inputValidator) {
- super(editorElementId, input, inputValidator);
- }
-
- @Override
- public Evaluation perform(ReadGraph graph) throws DatabaseException {
- //System.out.println(this + ": checking input " + parameter + ", " + parameter2);
- IResourceEditorInput i = parameter2;
- boolean exists = i.exists(graph);
- boolean valid = exists && parameter3 != null
- ? graph.syncRequest(parameter3.get(i))
- : exists;
- InputState state = InputState.parse(exists, valid);
- Evaluation eval = new Evaluation(parameter, state);
- //System.out.println(this + ": validation evaluation: " + eval);
- return eval;
- }
- }
-
- private static class InputListener extends ListenerAdapter {
-
- private boolean disposed = false;
-
- public void dispose() {
- disposed = true;
- }
-
- @Override
- public void execute(Evaluation evaluation) {
- //System.out.println("InputListener: " + evaluation);
- switch (evaluation.getInputState()) {
- case VALID:
- break;
-
- case INVALID:
- case NON_EXISTENT:
- scheduleEditorClose(evaluation.getEditorElementId());
- break;
- }
- }
-
- @Override
- public void exception(Throwable t) {
- ExceptionUtils.logError("E4ResourceEditorSupport.InputListener received an unexpected exception.", t);
- }
-
- @Override
- public boolean isDisposed() {
- return disposed;
- }
- }
-
- private static void scheduleEditorClose(String editorElementId) {
- SWTUtils.asyncExec(PlatformUI.getWorkbench().getDisplay(), () -> {
- E4WorkbenchUtils.closeEditor(editorElementId);
- });
- }
-
-}
+/*******************************************************************************
+ * Copyright (c) 2007, 2013 Association for Decentralized Information Management
+ * in Industry THTH ry.
+ * All rights reserved. This program and the accompanying materials
+ * are made available under the terms of the Eclipse Public License v1.0
+ * which accompanies this distribution, and is available at
+ * http://www.eclipse.org/legal/epl-v10.html
+ *
+ * Contributors:
+ * VTT Technical Research Centre of Finland - initial API and implementation
+ * Semantum Oy - issue #4384
+ *******************************************************************************/
+package org.simantics.ui.workbench.e4;
+
+import org.eclipse.ui.PlatformUI;
+import org.simantics.Simantics;
+import org.simantics.db.ReadGraph;
+import org.simantics.db.Resource;
+import org.simantics.db.common.procedure.adapter.ListenerAdapter;
+import org.simantics.db.common.request.ParametrizedRead;
+import org.simantics.db.common.request.TernaryRead;
+import org.simantics.db.exception.DatabaseException;
+import org.simantics.ui.workbench.IResourceEditorInput;
+import org.simantics.utils.datastructures.map.Tuple;
+import org.simantics.utils.ui.ExceptionUtils;
+import org.simantics.utils.ui.SWTUtils;
+
+/**
+ * A helper class for adding input validation and reaction to input invalidation
+ * to an E4 (editor) part that uses Simantics database {@link Resource}s as its
+ * input.
+ *
+ *
+ * Only useful with E4ResourceEditorBase extending part implementations.
+ *
+ * @author Tuukka Lehtonen
+ */
+public class E4ResourceEditorSupport {
+
+ private E4ResourceEditorBase editor;
+
+ private ParametrizedRead inputValidator;
+
+ private InputListener inputListener;
+
+ public E4ResourceEditorSupport(E4ResourceEditorBase editor) {
+ this(editor, null);
+ }
+
+ public E4ResourceEditorSupport(E4ResourceEditorBase editor, ParametrizedRead inputValidator) {
+ this.editor = editor;
+ this.inputValidator = inputValidator;
+ }
+
+ public void dispose() {
+ deactivateValidation();
+ inputValidator = null;
+ editor = null;
+ }
+
+ protected boolean isDisposed() {
+ return editor == null;
+ }
+
+ public synchronized void activateValidation() {
+ if (isDisposed())
+ throw new IllegalStateException(this + " is disposed");
+ if (inputListener != null)
+ return;
+
+ E4ResourceEditorBase e = editor;
+ inputListener = new InputListener();
+ Simantics.getSession().asyncRequest(new InputEvaluator(e.getPart().getElementId(), e.getResourceInput(), inputValidator), inputListener);
+ }
+
+ public synchronized void deactivateValidation() {
+ if (isDisposed())
+ throw new IllegalStateException(this + " is disposed");
+ if (inputListener == null)
+ return;
+ inputListener.dispose();
+ }
+
+ static enum InputState {
+ VALID,
+ INVALID,
+ NON_EXISTENT;
+
+ public static InputState parse(boolean exists, boolean valid) {
+ if (!exists)
+ return NON_EXISTENT;
+ return valid ? VALID : INVALID;
+ }
+ }
+
+ static class Evaluation extends Tuple {
+ public Evaluation(String editorElementId, InputState state) {
+ super(editorElementId, state);
+ }
+
+ public String getEditorElementId() {
+ return (String) getField(0);
+ }
+
+ public InputState getInputState() {
+ return (InputState) getField(1);
+ }
+ }
+
+ public static class InputEvaluator extends TernaryRead, Evaluation> {
+
+ public InputEvaluator(String editorElementId, IResourceEditorInput input, ParametrizedRead inputValidator) {
+ super(editorElementId, input, inputValidator);
+ }
+
+ @Override
+ public Evaluation perform(ReadGraph graph) throws DatabaseException {
+ //System.out.println(this + ": checking input " + parameter + ", " + parameter2);
+ IResourceEditorInput i = parameter2;
+ boolean exists = i.exists(graph);
+ boolean valid = exists && parameter3 != null
+ ? graph.syncRequest(parameter3.get(i))
+ : exists;
+ InputState state = InputState.parse(exists, valid);
+ Evaluation eval = new Evaluation(parameter, state);
+ //System.out.println(this + ": validation evaluation: " + eval);
+ return eval;
+ }
+ }
+
+ private static class InputListener extends ListenerAdapter {
+
+ private boolean disposed = false;
+
+ public void dispose() {
+ disposed = true;
+ }
+
+ @Override
+ public void execute(Evaluation evaluation) {
+ //System.out.println("InputListener: " + evaluation);
+ switch (evaluation.getInputState()) {
+ case VALID:
+ break;
+
+ case INVALID:
+ case NON_EXISTENT:
+ scheduleEditorClose(evaluation.getEditorElementId());
+ break;
+ }
+ }
+
+ @Override
+ public void exception(Throwable t) {
+ ExceptionUtils.logError("E4ResourceEditorSupport.InputListener received an unexpected exception.", t);
+ }
+
+ @Override
+ public boolean isDisposed() {
+ return disposed;
+ }
+ }
+
+ private static void scheduleEditorClose(String editorElementId) {
+ SWTUtils.asyncExec(PlatformUI.getWorkbench().getDisplay(), () -> {
+ E4WorkbenchUtils.closeEditor(editorElementId);
+ });
+ }
+
+}