From 5b3a1f2d3bffe5a79e344b55087fb161541a4301 Mon Sep 17 00:00:00 2001 From: Tuukka Lehtonen Date: Mon, 6 Mar 2017 23:44:51 +0200 Subject: [PATCH] Added org.simantics.views.text[.ontology] for modelled source viewers For now, SWTMarkupSourceViewer is hardcoded for mediawiki markup. The new plug-ins are included in org.simantics.views.swt.feature. Also: * removed useless old code SG loader code from org.simantics.views.swt * started using SLF4J in org.simantics.document.ui refs #7066 Change-Id: Id3d058d676072ccff5898c013cf3353a5a54dce9 --- .../META-INF/MANIFEST.MF | 1 + .../graph.tg | Bin 16604 -> 16635 bytes .../graph/DocumentUI.pgraph | 15 +- .../META-INF/MANIFEST.MF | 7 +- .../simantics/document/ui/function/All.java | 34 ++-- .../views/swt/loader/ButtonLoader.java.keep | 36 ---- .../views/swt/loader/CComboLoader.java.keep | 36 ---- .../views/swt/loader/ComboLoader.java.keep | 36 ---- .../swt/loader/CompositeLoader.java.keep | 36 ---- .../views/swt/loader/ExplorerLoader.java.keep | 109 ----------- .../views/swt/loader/LabelLoader.java.keep | 34 ---- .../loader/ScrolledCompositeLoader.java.keep | 32 ---- .../swt/loader/TabFolderLoader.java.keep | 75 -------- .../views/swt/loader/TextLoader.java.keep | 39 ---- .../swt/loader/TrackedTextLoader.java.keep | 75 -------- .../.classpath | 7 + .../.project | 34 ++++ .../.settings/org.eclipse.jdt.core.prefs | 7 + .../META-INF/MANIFEST.MF | 9 + .../build.properties | 6 + .../graph.tg | Bin 0 -> 695 bytes .../graph/TextViews.pgraph | 7 + bundles/org.simantics.views.text/.classpath | 7 + bundles/org.simantics.views.text/.project | 28 +++ .../.settings/org.eclipse.jdt.core.prefs | 7 + .../META-INF/MANIFEST.MF | 20 +++ bundles/org.simantics.views.text/adapters.xml | 23 +++ .../org.simantics.views.text/build.properties | 6 + bundles/org.simantics.views.text/plugin.xml | 45 +++++ .../views/text/internal/Activator.java | 63 +++++++ .../text/internal/SWTMarkupSourceViewer.java | 119 ++++++++++++ .../text/internal/TextViewerConstants.java | 36 ++++ .../text/internal/TextViewerUndoHandler.java | 169 ++++++++++++++++++ bundles/pom.xml | 2 + .../feature.xml | 16 +- 35 files changed, 632 insertions(+), 544 deletions(-) delete mode 100644 bundles/org.simantics.views.swt/src/org/simantics/views/swt/loader/ButtonLoader.java.keep delete mode 100644 bundles/org.simantics.views.swt/src/org/simantics/views/swt/loader/CComboLoader.java.keep delete mode 100644 bundles/org.simantics.views.swt/src/org/simantics/views/swt/loader/ComboLoader.java.keep delete mode 100644 bundles/org.simantics.views.swt/src/org/simantics/views/swt/loader/CompositeLoader.java.keep delete mode 100644 bundles/org.simantics.views.swt/src/org/simantics/views/swt/loader/ExplorerLoader.java.keep delete mode 100644 bundles/org.simantics.views.swt/src/org/simantics/views/swt/loader/LabelLoader.java.keep delete mode 100644 bundles/org.simantics.views.swt/src/org/simantics/views/swt/loader/ScrolledCompositeLoader.java.keep delete mode 100644 bundles/org.simantics.views.swt/src/org/simantics/views/swt/loader/TabFolderLoader.java.keep delete mode 100644 bundles/org.simantics.views.swt/src/org/simantics/views/swt/loader/TextLoader.java.keep delete mode 100644 bundles/org.simantics.views.swt/src/org/simantics/views/swt/loader/TrackedTextLoader.java.keep create mode 100644 bundles/org.simantics.views.text.ontology/.classpath create mode 100644 bundles/org.simantics.views.text.ontology/.project create mode 100644 bundles/org.simantics.views.text.ontology/.settings/org.eclipse.jdt.core.prefs create mode 100644 bundles/org.simantics.views.text.ontology/META-INF/MANIFEST.MF create mode 100644 bundles/org.simantics.views.text.ontology/build.properties create mode 100644 bundles/org.simantics.views.text.ontology/graph.tg create mode 100644 bundles/org.simantics.views.text.ontology/graph/TextViews.pgraph create mode 100644 bundles/org.simantics.views.text/.classpath create mode 100644 bundles/org.simantics.views.text/.project create mode 100644 bundles/org.simantics.views.text/.settings/org.eclipse.jdt.core.prefs create mode 100644 bundles/org.simantics.views.text/META-INF/MANIFEST.MF create mode 100644 bundles/org.simantics.views.text/adapters.xml create mode 100644 bundles/org.simantics.views.text/build.properties create mode 100644 bundles/org.simantics.views.text/plugin.xml create mode 100644 bundles/org.simantics.views.text/src/org/simantics/views/text/internal/Activator.java create mode 100644 bundles/org.simantics.views.text/src/org/simantics/views/text/internal/SWTMarkupSourceViewer.java create mode 100644 bundles/org.simantics.views.text/src/org/simantics/views/text/internal/TextViewerConstants.java create mode 100644 bundles/org.simantics.views.text/src/org/simantics/views/text/internal/TextViewerUndoHandler.java diff --git a/bundles/org.simantics.document.ui.ontology/META-INF/MANIFEST.MF b/bundles/org.simantics.document.ui.ontology/META-INF/MANIFEST.MF index e1ef05947..dc11fa0e3 100644 --- a/bundles/org.simantics.document.ui.ontology/META-INF/MANIFEST.MF +++ b/bundles/org.simantics.document.ui.ontology/META-INF/MANIFEST.MF @@ -6,6 +6,7 @@ Bundle-Version: 1.1.0.qualifier Bundle-Vendor: Semantum Oy Require-Bundle: org.simantics.layer0, org.simantics.views.ontology;bundle-version="1.1.0", + org.simantics.views.text.ontology;bundle-version="1.0.0", org.simantics.modeling.ontology;bundle-version="1.1.0", org.simantics.scenegraph.ontology;bundle-version="1.0.0", org.simantics.document.ontology;bundle-version="1.1.0", diff --git a/bundles/org.simantics.document.ui.ontology/graph.tg b/bundles/org.simantics.document.ui.ontology/graph.tg index 66fea40388122bceab20c2c2a1b2f110e3a5154e..8ef6e047fd28d54ce23586151a80cfc152bfcecc 100644 GIT binary patch literal 16635 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 VIEWS = +TEXTVIEWS = SG = DOC = ACT = @@ -40,11 +41,6 @@ UI.WikitextContribution.View : VIEWS.Composite @L0.list _ : VIEWS.Composite VIEWS.Composite.layout _ : VIEWS.RowLayout - //VIEWS.RowLayout.type VIEWS.Control.Style.Constant.Horizontal - //VIEWS.RowLayout.spacing 0 - //VIEWS.RowLayout.justify true - //VIEWS.RowLayout.pack true - //VIEWS.RowLayout.wrap true VIEWS.Control.layoutData _ : VIEWS.GridLayout.GridData VIEWS.GridLayout.GridData.horizontalGrab true SG.Node.children _ : L0.List @@ -159,7 +155,7 @@ UI.WikitextContribution.View : VIEWS.Composite VIEWS.Composite.layout _ : VIEWS.GridLayout SG.Node.children _ : L0.List @L0.list - UI.WikitextContribution.View.Text : VIEWS.StyledText + UI.WikitextContribution.View.Text : TEXTVIEWS.MarkupSourceViewer @VIEWS.Control.style4 VIEWS.Control.Style.Constant.Multi VIEWS.Control.Style.Constant.Border VIEWS.Control.Style.Constant.VScroll VIEWS.Control.Style.Constant.HScroll VIEWS.TextContainer.text UI.Functions.selectedDocumentPart : L0.Function L0.HasValueType "String" @@ -200,13 +196,6 @@ UI.Sash : VIEWS.SashForm VIEWS.SashForm.orientation VIEWS.SashForm.Vertical SG.Node.children _ : L0.List @L0.list -// UI.Scroll : VIEWS.ScrolledComposite - // VIEWS.Control.layoutData - // _ : VIEWS.GridLayout.GridData - // VIEWS.GridLayout.GridData.horizontalGrab true - // VIEWS.GridLayout.GridData.verticalGrab true - // SG.Node.children _ : L0.List - // @L0.list UI.Browser : VIEWS.Browser VIEWS.Control.layoutData _ : VIEWS.GridLayout.GridData diff --git a/bundles/org.simantics.document.ui/META-INF/MANIFEST.MF b/bundles/org.simantics.document.ui/META-INF/MANIFEST.MF index 5d0115b16..fa2877b11 100644 --- a/bundles/org.simantics.document.ui/META-INF/MANIFEST.MF +++ b/bundles/org.simantics.document.ui/META-INF/MANIFEST.MF @@ -7,6 +7,7 @@ Bundle-Activator: org.simantics.document.ui.Activator Bundle-Vendor: Semantum Oy Require-Bundle: org.eclipse.ui, org.eclipse.core.runtime, + org.simantics.views;bundle-version="1.1.0", org.simantics.views.swt;bundle-version="1.0.0", org.simantics.document.ontology;bundle-version="1.0.0", org.simantics.document.ui.ontology;bundle-version="1.0.0", @@ -14,12 +15,9 @@ Require-Bundle: org.eclipse.ui, org.simantics.modeling.ontology;bundle-version="1.1.0", org.simantics.scenegraph.ontology;bundle-version="1.0.0", org.simantics.document;bundle-version="1.0.0", - org.eclipse.mylyn.wikitext.mediawiki.core;bundle-version="1.5.2", - org.eclipse.mylyn.wikitext.core;bundle-version="1.5.1", org.simantics.wiki.ui;bundle-version="1.1.0", org.simantics.browsing.ui;bundle-version="1.1.0", org.simantics.selectionview;bundle-version="1.0.0", - org.simantics.views;bundle-version="1.1.0", org.simantics.utils.thread.swt;bundle-version="1.1.0", org.simantics.browsing.ui.model;bundle-version="1.0.0";visibility:=reexport, org.simantics.graphfile;bundle-version="0.1.0", @@ -29,7 +27,8 @@ Require-Bundle: org.eclipse.ui, org.simantics.annotation.ontology;bundle-version="1.0.0", org.simantics.annotation.ui;bundle-version="1.0.0", org.eclipse.ui.editors;bundle-version="3.9.0", - org.eclipse.jface.text + org.eclipse.jface.text, + org.slf4j.api;bundle-version="1.7.2" Bundle-RequiredExecutionEnvironment: JavaSE-1.8 Bundle-ActivationPolicy: lazy Export-Package: org.simantics.document.ui, diff --git a/bundles/org.simantics.document.ui/src/org/simantics/document/ui/function/All.java b/bundles/org.simantics.document.ui/src/org/simantics/document/ui/function/All.java index 76b5abe95..effe30cd9 100644 --- a/bundles/org.simantics.document.ui/src/org/simantics/document/ui/function/All.java +++ b/bundles/org.simantics.document.ui/src/org/simantics/document/ui/function/All.java @@ -1,5 +1,5 @@ /******************************************************************************* - * Copyright (c) 2012 Association for Decentralized Information Management in + * Copyright (c) 2012, 2017 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 @@ -8,6 +8,7 @@ * * Contributors: * VTT Technical Research Centre of Finland - initial API and implementation + * Semantum Oy - (#7066) introducing logger & refactoring *******************************************************************************/ package org.simantics.document.ui.function; @@ -38,7 +39,6 @@ import org.simantics.db.WriteGraph; import org.simantics.db.common.request.ReadRequest; import org.simantics.db.common.request.UnaryRead; import org.simantics.db.common.request.WriteRequest; -import org.simantics.db.common.utils.Logger; import org.simantics.db.common.utils.NameUtils; import org.simantics.db.common.utils.RequestUtil; import org.simantics.db.exception.DatabaseException; @@ -68,10 +68,14 @@ import org.simantics.ui.workbench.ResourceEditorInput2; import org.simantics.ui.workbench.action.DefaultActions; import org.simantics.utils.threads.SWTThread; import org.simantics.utils.ui.workbench.WorkbenchUtils; +import org.slf4j.Logger; +import org.slf4j.LoggerFactory; public class All { + private static final Logger LOGGER = LoggerFactory.getLogger(All.class); + private static boolean createDocument(WriteGraph graph, Resource resource, Resource model) throws DatabaseException { Layer0 L0 = Layer0.getInstance(graph); @@ -187,6 +191,7 @@ public class All { if(document == null) return; RemoverUtil.remove(graph, document); + graph.markUndoPoint(); } @@ -318,12 +323,12 @@ public class All { @Override public void perform(WriteGraph graph) throws DatabaseException { - Variable selection = resolveEditSelection(graph, context, "..../Scroll/Browser#edited"); - if (selection != null) + if (selection != null) { selection.setValue(graph, (String)value, Bindings.STRING); - else { - System.err.println("no selection for resource : " + resource + ", Variable context : " + context + ", value : " + value); + graph.markUndoPoint(); + } else { + LOGGER.error("No selection for resource : " + resource + ", Variable context : " + context + ", value : " + value); } } @@ -743,19 +748,12 @@ public class All { String editorId = CSSEditor.EDITOR_ID; RVI rvi = null; - PlatformUI.getWorkbench().getDisplay().asyncExec(new Runnable() { - - @Override - public void run() { - - try { - WorkbenchUtils.openEditor(editorId, new ResourceEditorInput2(editorId, root, root, rvi)); - } catch (PartInitException e) { - Logger.defaultLogError(e); - } - + PlatformUI.getWorkbench().getDisplay().asyncExec(() -> { + try { + WorkbenchUtils.openEditor(editorId, new ResourceEditorInput2(editorId, root, root, rvi)); + } catch (PartInitException e) { + LOGGER.error("Failed to open CSS editor for root " + root, e); } - }); } diff --git a/bundles/org.simantics.views.swt/src/org/simantics/views/swt/loader/ButtonLoader.java.keep b/bundles/org.simantics.views.swt/src/org/simantics/views/swt/loader/ButtonLoader.java.keep deleted file mode 100644 index 388fa8678..000000000 --- a/bundles/org.simantics.views.swt/src/org/simantics/views/swt/loader/ButtonLoader.java.keep +++ /dev/null @@ -1,36 +0,0 @@ -package org.simantics.views.swt.loader; - -import org.simantics.db.Resource; -import org.simantics.db.exception.DatabaseException; -import org.simantics.db.layer0.variable.Variable; -import org.simantics.scenegraph.ParentNode; -import org.simantics.scenegraph.loader.ScenegraphLoader; -import org.simantics.views.ontology.ViewsResources; -import org.simantics.views.swt.client.base.ISWTViewNode; -import org.simantics.views.swt.client.impl.SWTButton; - -public class ButtonLoader implements ScenegraphLoader { - - final private Resource configuration; - - public ButtonLoader(Resource configuration) { - this.configuration = configuration; - } - - @Override - public ISWTViewNode create(ParentNode parent, Variable context) throws DatabaseException { - - SWTButton node = parent.addNode(SWTButton.class); - - node.setLayoutData(LoaderUtils.getGridData(configuration)); - node.setStyle(LoaderUtils.getStyle(configuration)); - - LoaderUtils.listen(configuration, context, ViewsResources.URIs.TextContainer_HasText, node.getTextFunction()); - LoaderUtils.listen(configuration, context, ViewsResources.URIs.Button_Modifier, node.getModifierFunction()); - LoaderUtils.listen(configuration, context, ViewsResources.URIs.Button_HasImage, node.getImageFunction()); - - return node; - - } - -} diff --git a/bundles/org.simantics.views.swt/src/org/simantics/views/swt/loader/CComboLoader.java.keep b/bundles/org.simantics.views.swt/src/org/simantics/views/swt/loader/CComboLoader.java.keep deleted file mode 100644 index f9a53451f..000000000 --- a/bundles/org.simantics.views.swt/src/org/simantics/views/swt/loader/CComboLoader.java.keep +++ /dev/null @@ -1,36 +0,0 @@ -package org.simantics.views.swt.loader; - -import org.simantics.db.Resource; -import org.simantics.db.exception.DatabaseException; -import org.simantics.db.layer0.variable.Variable; -import org.simantics.scenegraph.ParentNode; -import org.simantics.scenegraph.loader.ScenegraphLoader; -import org.simantics.views.ontology.ViewsResources; -import org.simantics.views.swt.client.base.ISWTViewNode; -import org.simantics.views.swt.client.impl.SWTCCombo; - -public class CComboLoader implements ScenegraphLoader { - - final private Resource configuration; - - public CComboLoader(Resource configuration) { - this.configuration = configuration; - } - - @Override - public ISWTViewNode create(ParentNode parent, Variable context) throws DatabaseException { - - SWTCCombo node = parent.addNode(SWTCCombo.class); - - node.setLayoutData(LoaderUtils.getGridData(configuration)); - node.setStyle(LoaderUtils.getStyle(configuration)); - - LoaderUtils.listen(configuration, context, ViewsResources.URIs.Combo_AvailableItems, node.getAvailableFunction()); - LoaderUtils.listen(configuration, context, ViewsResources.URIs.Combo_SelectedItem, node.getSelectionFunction()); - LoaderUtils.listen(configuration, context, ViewsResources.URIs.Combo_Modifier, node.getModifierFunction()); - - return node; - - } - -} diff --git a/bundles/org.simantics.views.swt/src/org/simantics/views/swt/loader/ComboLoader.java.keep b/bundles/org.simantics.views.swt/src/org/simantics/views/swt/loader/ComboLoader.java.keep deleted file mode 100644 index 036ce94f8..000000000 --- a/bundles/org.simantics.views.swt/src/org/simantics/views/swt/loader/ComboLoader.java.keep +++ /dev/null @@ -1,36 +0,0 @@ -package org.simantics.views.swt.loader; - -import org.simantics.db.Resource; -import org.simantics.db.exception.DatabaseException; -import org.simantics.db.layer0.variable.Variable; -import org.simantics.scenegraph.ParentNode; -import org.simantics.scenegraph.loader.ScenegraphLoader; -import org.simantics.views.ontology.ViewsResources; -import org.simantics.views.swt.client.base.ISWTViewNode; -import org.simantics.views.swt.client.impl.SWTCombo; - -public class ComboLoader implements ScenegraphLoader { - - final private Resource configuration; - - public ComboLoader(Resource configuration) { - this.configuration = configuration; - } - - @Override - public ISWTViewNode create(ParentNode parent, Variable context) throws DatabaseException { - - SWTCombo node = parent.addNode(SWTCombo.class); - - node.setLayoutData(LoaderUtils.getGridData(configuration)); - node.setStyle(LoaderUtils.getStyle(configuration)); - - LoaderUtils.listen(configuration, context, ViewsResources.URIs.Combo_AvailableItems, node.getAvailableFunction()); - LoaderUtils.listen(configuration, context, ViewsResources.URIs.Combo_SelectedItem, node.getSelectionFunction()); - LoaderUtils.listen(configuration, context, ViewsResources.URIs.Combo_Modifier, node.getModifierFunction()); - - return node; - - } - -} diff --git a/bundles/org.simantics.views.swt/src/org/simantics/views/swt/loader/CompositeLoader.java.keep b/bundles/org.simantics.views.swt/src/org/simantics/views/swt/loader/CompositeLoader.java.keep deleted file mode 100644 index 846df84ef..000000000 --- a/bundles/org.simantics.views.swt/src/org/simantics/views/swt/loader/CompositeLoader.java.keep +++ /dev/null @@ -1,36 +0,0 @@ -package org.simantics.views.swt.loader; - -import org.simantics.datatypes.literal.RGB; -import org.simantics.db.Resource; -import org.simantics.db.exception.DatabaseException; -import org.simantics.db.layer0.variable.Variable; -import org.simantics.scenegraph.ParentNode; -import org.simantics.scenegraph.loader.ScenegraphLoader; -import org.simantics.views.ontology.ViewsResources; -import org.simantics.views.swt.client.base.ISWTViewNode; -import org.simantics.views.swt.client.impl.SWTComposite; - -public class CompositeLoader implements ScenegraphLoader { - - final private Resource configuration; - - public CompositeLoader(Resource configuration) { - this.configuration = configuration; - } - - @Override - public ISWTViewNode create(ParentNode parent, Variable context) throws DatabaseException { - - SWTComposite node = parent.addNode(SWTComposite.class); - - LoaderUtils.listen(configuration, context, ViewsResources.URIs.Control_HasBackground, RGB.Integer.BINDING, node.getBackgroundFunction()); - - node.setLayoutData(LoaderUtils.getGridData(configuration)); - node.setLayout(LoaderUtils.getLayout(configuration)); - node.setStyle(LoaderUtils.getStyle(configuration)); - - return node; - - } - -} diff --git a/bundles/org.simantics.views.swt/src/org/simantics/views/swt/loader/ExplorerLoader.java.keep b/bundles/org.simantics.views.swt/src/org/simantics/views/swt/loader/ExplorerLoader.java.keep deleted file mode 100644 index a767ed970..000000000 --- a/bundles/org.simantics.views.swt/src/org/simantics/views/swt/loader/ExplorerLoader.java.keep +++ /dev/null @@ -1,109 +0,0 @@ -package org.simantics.views.swt.loader; - -import org.eclipse.swt.SWT; -import org.eclipse.swt.widgets.Event; -import org.eclipse.swt.widgets.Listener; -import org.eclipse.swt.widgets.TreeItem; -import org.simantics.browsing.ui.BuiltinKeys; -import org.simantics.browsing.ui.NodeContext; -import org.simantics.databoard.Bindings; -import org.simantics.db.ReadGraph; -import org.simantics.db.Resource; -import org.simantics.db.VirtualGraph; -import org.simantics.db.WriteGraph; -import org.simantics.db.common.request.ResourceRead; -import org.simantics.db.common.request.WriteRequest; -import org.simantics.db.exception.DatabaseException; -import org.simantics.db.layer0.util.Simantics; -import org.simantics.db.layer0.variable.Variable; -import org.simantics.scenegraph.ParentNode; -import org.simantics.scenegraph.loader.ScenegraphLoader; -import org.simantics.views.ViewUtils; -import org.simantics.views.ontology.ViewsResources; -import org.simantics.views.swt.client.base.ISWTViewNode; -import org.simantics.views.swt.client.impl.SWTExplorer; - -public class ExplorerLoader implements ScenegraphLoader { - - final private Resource configuration; - - public ExplorerLoader(Resource configuration) { - this.configuration = configuration; - } - - @Override - public ISWTViewNode create(ParentNode parent, final Variable context) throws DatabaseException { - - SWTExplorer node = parent.addNode(SWTExplorer.class); - - node.setStyle(LoaderUtils.getStyle(configuration)); - - String browseContextURI = Simantics.getSession().sync(new ResourceRead(configuration) { - - @Override - public String perform(ReadGraph graph) throws DatabaseException { - ViewsResources VIEW = ViewsResources.getInstance(graph); - Resource browseContext = graph.getSingleObject(resource, VIEW.Explorer_BrowseContext); - return graph.getURI(browseContext); - } - - }); - - node.setBrowseContextURI(browseContextURI); - - node.setLayoutData(LoaderUtils.getGridData(configuration)); - - node.setColumns(LoaderUtils.getColumns(configuration)); - - LoaderUtils.listen(configuration, context, ViewsResources.URIs.Explorer_InputTransformation, node.getInputFunction()); - - LoaderUtils.listen(configuration, context, ViewsResources.URIs.Explorer_HasColumnsVisible, node.getColumnsVisibleFunction()); - - Listener selectionListener = Simantics.getSession().sync(new ResourceRead(configuration) { - - @Override - public Listener perform(ReadGraph graph) throws DatabaseException { - ViewsResources VIEW = ViewsResources.getInstance(graph); - Resource listener = graph.getPossibleObject(resource, VIEW.Explorer_SelectionListener); - if(listener == null) return null; - return graph.adapt(listener, Listener.class); - } - - }); - - if(selectionListener != null) node.addListenerToControl(SWT.Selection, selectionListener); - - node.addListenerToControl(SWT.Selection, new Listener() { - - @Override - public void handleEvent(Event event) { - - TreeItem item = (TreeItem)event.item; -// Tree tree = item.getParent(); -// GraphExplorer explorer = (GraphExplorer)tree.getData("GraphExplorer"); -// final Resource runtimeDiagram = (Resource)explorer.getRoot().getConstant(BuiltinKeys.INPUT); -// final boolean checked = item.getChecked(); - NodeContext nc = (NodeContext)item.getData(); - Object obj = nc.getConstant(BuiltinKeys.INPUT); - - if (obj instanceof Variable) { - final Variable var = (Variable) obj; - Simantics.getSession().async(new WriteRequest(Simantics.getSession().getService(VirtualGraph.class)) { - @Override - public void perform(WriteGraph graph) throws DatabaseException { - ViewsResources VIEW = ViewsResources.getInstance(graph); - System.err.println("setParameter " + context.getURI(graph) + " -> " + var.getURI(graph)); - ViewUtils.setParameter(graph, context, VIEW.Explorer_Selection, var.getURI(graph), Bindings.STRING); - } - }); - } - } - - }); - - return node; - - } - -} - diff --git a/bundles/org.simantics.views.swt/src/org/simantics/views/swt/loader/LabelLoader.java.keep b/bundles/org.simantics.views.swt/src/org/simantics/views/swt/loader/LabelLoader.java.keep deleted file mode 100644 index 53aa17f2c..000000000 --- a/bundles/org.simantics.views.swt/src/org/simantics/views/swt/loader/LabelLoader.java.keep +++ /dev/null @@ -1,34 +0,0 @@ -package org.simantics.views.swt.loader; - -import org.simantics.db.Resource; -import org.simantics.db.exception.DatabaseException; -import org.simantics.db.layer0.variable.Variable; -import org.simantics.scenegraph.ParentNode; -import org.simantics.scenegraph.loader.ScenegraphLoader; -import org.simantics.views.ontology.ViewsResources; -import org.simantics.views.swt.client.base.ISWTViewNode; -import org.simantics.views.swt.client.impl.SWTLabel; - -public class LabelLoader implements ScenegraphLoader { - - final private Resource configuration; - - public LabelLoader(Resource configuration) { - this.configuration = configuration; - } - - @Override - public ISWTViewNode create(ParentNode parent, Variable context) throws DatabaseException { - - SWTLabel node = parent.addNode(SWTLabel.class); - - node.setLayoutData(LoaderUtils.getGridData(configuration)); - node.setStyle(LoaderUtils.getStyle(configuration)); - - LoaderUtils.listen(configuration, context, ViewsResources.URIs.TextContainer_HasText, node.getTextFunction()); - - return node; - - } - -} diff --git a/bundles/org.simantics.views.swt/src/org/simantics/views/swt/loader/ScrolledCompositeLoader.java.keep b/bundles/org.simantics.views.swt/src/org/simantics/views/swt/loader/ScrolledCompositeLoader.java.keep deleted file mode 100644 index 66dcb2844..000000000 --- a/bundles/org.simantics.views.swt/src/org/simantics/views/swt/loader/ScrolledCompositeLoader.java.keep +++ /dev/null @@ -1,32 +0,0 @@ -package org.simantics.views.swt.loader; - -import org.simantics.db.Resource; -import org.simantics.db.exception.DatabaseException; -import org.simantics.db.layer0.variable.Variable; -import org.simantics.scenegraph.ParentNode; -import org.simantics.scenegraph.loader.ScenegraphLoader; -import org.simantics.views.swt.client.base.ISWTViewNode; -import org.simantics.views.swt.client.impl.SWTScrolledComposite; - -public class ScrolledCompositeLoader implements ScenegraphLoader { - - final private Resource configuration; - - public ScrolledCompositeLoader(Resource configuration) { - this.configuration = configuration; - } - - @Override - public ISWTViewNode create(ParentNode parent, Variable context) throws DatabaseException { - - SWTScrolledComposite node = parent.addNode(SWTScrolledComposite.class); - - node.setLayoutData(LoaderUtils.getGridData(configuration)); - node.setLayout(LoaderUtils.getLayout(configuration)); - node.setStyle(LoaderUtils.getStyle(configuration)); - - return node; - - } - -} diff --git a/bundles/org.simantics.views.swt/src/org/simantics/views/swt/loader/TabFolderLoader.java.keep b/bundles/org.simantics.views.swt/src/org/simantics/views/swt/loader/TabFolderLoader.java.keep deleted file mode 100644 index 4c6cdf059..000000000 --- a/bundles/org.simantics.views.swt/src/org/simantics/views/swt/loader/TabFolderLoader.java.keep +++ /dev/null @@ -1,75 +0,0 @@ -package org.simantics.views.swt.loader; - -import java.util.Collection; -import java.util.HashSet; -import java.util.Set; - -import org.eclipse.swt.custom.CTabItem; -import org.eclipse.swt.widgets.Composite; -import org.eclipse.swt.widgets.Control; -import org.simantics.db.ReadGraph; -import org.simantics.db.Resource; -import org.simantics.db.common.request.UniqueRead; -import org.simantics.db.exception.DatabaseException; -import org.simantics.db.layer0.util.Simantics; -import org.simantics.db.layer0.variable.Variable; -import org.simantics.db.layer0.variable.Variables; -import org.simantics.scenegraph.ParentNode; -import org.simantics.scenegraph.loader.ScenegraphLoader; -import org.simantics.views.swt.client.base.ISWTViewNode; -import org.simantics.views.swt.client.impl.SWTTabFolder; - -public class TabFolderLoader implements ScenegraphLoader { - - final private Resource configuration; - - public TabFolderLoader(Resource configuration) { - this.configuration = configuration; - } - - @Override - public ISWTViewNode create(ParentNode parent, Variable context) throws DatabaseException { - - SWTTabFolder node = parent.addNode(SWTTabFolder.class); - - final Collection children = LoaderUtils.getChildren(configuration); - - String[] names = Simantics.getSession().sync(new UniqueRead() { - - @Override - public String[] perform(ReadGraph graph) throws DatabaseException { - - String[] result = new String[children.size()]; - - int index = 0; - for(Variable child : children) { - result[index++] = child.getPropertyValue(graph, Variables.LABEL); - } - - return result; - - } - - }); - - node.setTabNames(names); - - return node; - - } - - Set getControls(CTabItem item) { - HashSet result = new HashSet(); - forControl(item.getControl(), result); - return result; - } - - void forControl(Control control, HashSet controls) { - controls.add(control); - if(control instanceof Composite) { - Composite composite = (Composite)control; - for(Control child : composite.getChildren()) forControl(child, controls); - } - } - -} diff --git a/bundles/org.simantics.views.swt/src/org/simantics/views/swt/loader/TextLoader.java.keep b/bundles/org.simantics.views.swt/src/org/simantics/views/swt/loader/TextLoader.java.keep deleted file mode 100644 index 01417152b..000000000 --- a/bundles/org.simantics.views.swt/src/org/simantics/views/swt/loader/TextLoader.java.keep +++ /dev/null @@ -1,39 +0,0 @@ -package org.simantics.views.swt.loader; - -import org.simantics.datatypes.literal.Font; -import org.simantics.datatypes.literal.RGB; -import org.simantics.db.Resource; -import org.simantics.db.exception.DatabaseException; -import org.simantics.db.layer0.variable.Variable; -import org.simantics.scenegraph.ParentNode; -import org.simantics.scenegraph.loader.ScenegraphLoader; -import org.simantics.views.ontology.ViewsResources; -import org.simantics.views.swt.client.base.ISWTViewNode; -import org.simantics.views.swt.client.impl.SWTText; - -public class TextLoader implements ScenegraphLoader { - - final private Resource configuration; - - public TextLoader(Resource configuration) { - this.configuration = configuration; - } - - @Override - public ISWTViewNode create(ParentNode parent, Variable context) throws DatabaseException { - - SWTText node = parent.addNode(SWTText.class); - - node.setLayoutData(LoaderUtils.getGridData(configuration)); - node.setStyle(LoaderUtils.getStyle(configuration)); - - LoaderUtils.listen(configuration, context, ViewsResources.URIs.TextContainer_HasText, node.getTextFunction()); - LoaderUtils.listen(configuration, context, ViewsResources.URIs.Control_HasBackground, RGB.Integer.BINDING, node.getBackgroundFunction()); - LoaderUtils.listen(configuration, context, ViewsResources.URIs.Control_HasForeground, RGB.Integer.BINDING, node.getForegroundFunction()); - LoaderUtils.listen(configuration, context, ViewsResources.URIs.Control_HasFont, Font.BINDING, node.getFontFunction()); - - return node; - - } - -} diff --git a/bundles/org.simantics.views.swt/src/org/simantics/views/swt/loader/TrackedTextLoader.java.keep b/bundles/org.simantics.views.swt/src/org/simantics/views/swt/loader/TrackedTextLoader.java.keep deleted file mode 100644 index 699f8ee68..000000000 --- a/bundles/org.simantics.views.swt/src/org/simantics/views/swt/loader/TrackedTextLoader.java.keep +++ /dev/null @@ -1,75 +0,0 @@ -package org.simantics.views.swt.loader; - -import org.simantics.databoard.Bindings; -import org.simantics.datatypes.literal.Font; -import org.simantics.datatypes.literal.RGB; -import org.simantics.db.Resource; -import org.simantics.db.VirtualGraph; -import org.simantics.db.WriteGraph; -import org.simantics.db.common.request.WriteRequest; -import org.simantics.db.exception.DatabaseException; -import org.simantics.db.layer0.util.Simantics; -import org.simantics.db.layer0.variable.Variable; -import org.simantics.scenegraph.ParentNode; -import org.simantics.scenegraph.loader.ScenegraphLoader; -import org.simantics.utils.ui.widgets.TrackedModifyEvent; -import org.simantics.utils.ui.widgets.TrackedModifyListener; -import org.simantics.views.ViewUtils; -import org.simantics.views.ontology.ViewsResources; -import org.simantics.views.swt.client.base.ISWTViewNode; -import org.simantics.views.swt.client.impl.SWTTrackedText; - -public class TrackedTextLoader implements ScenegraphLoader { - - final private Resource configuration; - - public TrackedTextLoader(Resource configuration) { - this.configuration = configuration; - } - - @Override - public ISWTViewNode create(ParentNode parent, final Variable context) throws DatabaseException { - - SWTTrackedText node = parent.addNode(SWTTrackedText.class); - - node.setLayoutData(LoaderUtils.getGridData(configuration)); - node.setStyle(LoaderUtils.getStyle(configuration)); - - LoaderUtils.listen(configuration, context, ViewsResources.URIs.TextContainer_HasText, node.getTextFunction()); - LoaderUtils.listen(configuration, context, ViewsResources.URIs.Control_HasForeground, RGB.Integer.BINDING, node.getForegroundFunction()); - LoaderUtils.listen(configuration, context, ViewsResources.URIs.TrackedText_HasInvalidBackground, RGB.Integer.BINDING, node.getInvalidBackgroundFunction()); - LoaderUtils.listen(configuration, context, ViewsResources.URIs.TrackedText_HasInactiveBackground, RGB.Integer.BINDING, node.getInactiveBackgroundFunction()); - LoaderUtils.listen(configuration, context, ViewsResources.URIs.TrackedText_HasHoverBackground, RGB.Integer.BINDING, node.getHoverBackgroundFunction()); - LoaderUtils.listen(configuration, context, ViewsResources.URIs.TrackedText_HasEditingBackground, RGB.Integer.BINDING, node.getEditingBackgroundFunction()); - LoaderUtils.listen(configuration, context, ViewsResources.URIs.Control_HasFont, Font.BINDING, node.getFontFunction()); - - LoaderUtils.listen(configuration, context, ViewsResources.URIs.TextReceiver_Modifier, node.getModifierFunction()); - LoaderUtils.listen(configuration, context, ViewsResources.URIs.TextReceiver_Validator, node.getValidatorFunction()); - - node.addModifyListener(new TrackedModifyListener() { - - @Override - public void modifyText(TrackedModifyEvent e) { - - final String text = e.getText(); - - Simantics.getSession().async(new WriteRequest(Simantics.getSession().getService(VirtualGraph.class)) { - - @Override - public void perform(WriteGraph graph) throws DatabaseException { - ViewsResources VIEW = ViewsResources.getInstance(graph); - System.err.println("setParameter " + context.getURI(graph) + " -> " + text); - ViewUtils.setParameter(graph, context, VIEW.TrackedText_Content, text, Bindings.STRING); - } - - }); - - } - - }); - - return node; - - } - -} diff --git a/bundles/org.simantics.views.text.ontology/.classpath b/bundles/org.simantics.views.text.ontology/.classpath new file mode 100644 index 000000000..b862a296d --- /dev/null +++ b/bundles/org.simantics.views.text.ontology/.classpath @@ -0,0 +1,7 @@ + + + + + + + diff --git a/bundles/org.simantics.views.text.ontology/.project b/bundles/org.simantics.views.text.ontology/.project new file mode 100644 index 000000000..7750c6c9d --- /dev/null +++ b/bundles/org.simantics.views.text.ontology/.project @@ -0,0 +1,34 @@ + + + org.simantics.views.text.ontology + + + + + + org.simantics.graph.builder + + + + + org.eclipse.jdt.core.javabuilder + + + + + org.eclipse.pde.ManifestBuilder + + + + + org.eclipse.pde.SchemaBuilder + + + + + + org.eclipse.pde.PluginNature + org.eclipse.jdt.core.javanature + org.simantics.graph.nature + + diff --git a/bundles/org.simantics.views.text.ontology/.settings/org.eclipse.jdt.core.prefs b/bundles/org.simantics.views.text.ontology/.settings/org.eclipse.jdt.core.prefs new file mode 100644 index 000000000..295926d96 --- /dev/null +++ b/bundles/org.simantics.views.text.ontology/.settings/org.eclipse.jdt.core.prefs @@ -0,0 +1,7 @@ +eclipse.preferences.version=1 +org.eclipse.jdt.core.compiler.codegen.inlineJsrBytecode=enabled +org.eclipse.jdt.core.compiler.codegen.targetPlatform=1.8 +org.eclipse.jdt.core.compiler.compliance=1.8 +org.eclipse.jdt.core.compiler.problem.assertIdentifier=error +org.eclipse.jdt.core.compiler.problem.enumIdentifier=error +org.eclipse.jdt.core.compiler.source=1.8 diff --git a/bundles/org.simantics.views.text.ontology/META-INF/MANIFEST.MF b/bundles/org.simantics.views.text.ontology/META-INF/MANIFEST.MF new file mode 100644 index 000000000..6d858cb04 --- /dev/null +++ b/bundles/org.simantics.views.text.ontology/META-INF/MANIFEST.MF @@ -0,0 +1,9 @@ +Manifest-Version: 1.0 +Bundle-ManifestVersion: 2 +Bundle-Name: http://www.simantics.org/TextViews +Bundle-SymbolicName: org.simantics.views.text.ontology +Bundle-Version: 1.0.0.qualifier +Bundle-Vendor: Semantum Oy +Require-Bundle: org.simantics.layer0, + org.simantics.views.ontology;bundle-version="1.2.0" +Bundle-RequiredExecutionEnvironment: JavaSE-1.8 diff --git a/bundles/org.simantics.views.text.ontology/build.properties b/bundles/org.simantics.views.text.ontology/build.properties new file mode 100644 index 000000000..fb164279d --- /dev/null +++ b/bundles/org.simantics.views.text.ontology/build.properties @@ -0,0 +1,6 @@ +source.. = src/ +output.. = bin/ +bin.includes = META-INF/,\ + .,\ + graph.tg +src.includes = graph/ diff --git a/bundles/org.simantics.views.text.ontology/graph.tg b/bundles/org.simantics.views.text.ontology/graph.tg new file mode 100644 index 0000000000000000000000000000000000000000..5c3d7dba6219d63b5ba990859133a54545587c39 GIT binary patch literal 695 zcmah{TW-QI5Der&2&Auj6hW^*D;22~RYCo?U;(Saj%=rCPT$TtM3k>uS|>9*JGR%3 z_ePY5AP9PhV8GL9#JM4>E3=`wu9WLDozb@=Wu;bj$T;C?%u^<}q?~k;Y|8krQ$OvT zT9Ym9q=Hnd5lc@air%$$7j=;mNAhb#t|{BU^a)!qN)#8$q!b40d;fD)x-5B>RvV`a zb*_vv>x82tirNkP(&S4N)&D1mz098*o4-CCp!)*$d^d0Fx}I2h6ll!GPPEx06@{G7 z*XZPjq}txkCQ~pe)6w0lFrQVq@@?ld8PFlS^@g4N0VrcC%vP=`Xv +VIEWS = + +TEXTVIEWS = : L0.Ontology + @L0.new + +TEXTVIEWS.MarkupSourceViewer + + + + + + diff --git a/bundles/org.simantics.views.text/.project b/bundles/org.simantics.views.text/.project new file mode 100644 index 000000000..f3bb00f2b --- /dev/null +++ b/bundles/org.simantics.views.text/.project @@ -0,0 +1,28 @@ + + + org.simantics.views.text + + + + + + org.eclipse.jdt.core.javabuilder + + + + + org.eclipse.pde.ManifestBuilder + + + + + org.eclipse.pde.SchemaBuilder + + + + + + org.eclipse.pde.PluginNature + org.eclipse.jdt.core.javanature + + diff --git a/bundles/org.simantics.views.text/.settings/org.eclipse.jdt.core.prefs b/bundles/org.simantics.views.text/.settings/org.eclipse.jdt.core.prefs new file mode 100644 index 000000000..295926d96 --- /dev/null +++ b/bundles/org.simantics.views.text/.settings/org.eclipse.jdt.core.prefs @@ -0,0 +1,7 @@ +eclipse.preferences.version=1 +org.eclipse.jdt.core.compiler.codegen.inlineJsrBytecode=enabled +org.eclipse.jdt.core.compiler.codegen.targetPlatform=1.8 +org.eclipse.jdt.core.compiler.compliance=1.8 +org.eclipse.jdt.core.compiler.problem.assertIdentifier=error +org.eclipse.jdt.core.compiler.problem.enumIdentifier=error +org.eclipse.jdt.core.compiler.source=1.8 diff --git a/bundles/org.simantics.views.text/META-INF/MANIFEST.MF b/bundles/org.simantics.views.text/META-INF/MANIFEST.MF new file mode 100644 index 000000000..6e60a5a19 --- /dev/null +++ b/bundles/org.simantics.views.text/META-INF/MANIFEST.MF @@ -0,0 +1,20 @@ +Manifest-Version: 1.0 +Bundle-ManifestVersion: 2 +Bundle-Name: Modelled Text Viewer UI Controls +Bundle-SymbolicName: org.simantics.views.text;singleton:=true +Bundle-Version: 1.0.0.qualifier +Bundle-Activator: org.simantics.views.text.internal.Activator +Bundle-Vendor: Semantum Oy +Require-Bundle: org.eclipse.ui, + org.eclipse.ui.editors;bundle-version="3.9.0", + org.eclipse.core.runtime, + org.eclipse.jface.text;bundle-version="3.10.0", + org.eclipse.mylyn.wikitext.core;bundle-version="2.7.0", + org.eclipse.mylyn.wikitext.mediawiki.core;bundle-version="2.7.0", + org.eclipse.mylyn.wikitext.ui;bundle-version="2.7.0", + org.eclipse.mylyn.wikitext.mediawiki.ui;bundle-version="2.7.0", + org.simantics.views;bundle-version="1.1.0", + org.simantics.views.swt;bundle-version="1.0.0", + org.simantics.views.swt.client;bundle-version="1.0.0" +Bundle-RequiredExecutionEnvironment: JavaSE-1.8 +Bundle-ActivationPolicy: lazy diff --git a/bundles/org.simantics.views.text/adapters.xml b/bundles/org.simantics.views.text/adapters.xml new file mode 100644 index 000000000..c6dbeee60 --- /dev/null +++ b/bundles/org.simantics.views.text/adapters.xml @@ -0,0 +1,23 @@ + + + + + + + + + org.simantics.views.text.internal.SWTMarkupSourceViewer + + + + diff --git a/bundles/org.simantics.views.text/build.properties b/bundles/org.simantics.views.text/build.properties new file mode 100644 index 000000000..1ec5e34ca --- /dev/null +++ b/bundles/org.simantics.views.text/build.properties @@ -0,0 +1,6 @@ +source.. = src/ +output.. = bin/ +bin.includes = META-INF/,\ + .,\ + adapters.xml,\ + plugin.xml diff --git a/bundles/org.simantics.views.text/plugin.xml b/bundles/org.simantics.views.text/plugin.xml new file mode 100644 index 000000000..d2c90910a --- /dev/null +++ b/bundles/org.simantics.views.text/plugin.xml @@ -0,0 +1,45 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/bundles/org.simantics.views.text/src/org/simantics/views/text/internal/Activator.java b/bundles/org.simantics.views.text/src/org/simantics/views/text/internal/Activator.java new file mode 100644 index 000000000..e0ee562ff --- /dev/null +++ b/bundles/org.simantics.views.text/src/org/simantics/views/text/internal/Activator.java @@ -0,0 +1,63 @@ +/******************************************************************************* + * Copyright (c) 2017 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: + * Semantum Oy - initial API and implementation + *******************************************************************************/ +package org.simantics.views.text.internal; + +import org.eclipse.ui.plugin.AbstractUIPlugin; +import org.osgi.framework.BundleContext; + +/** + * The activator class controls the plug-in life cycle + * @author Tuukka Lehtonen + * @since 1.28.0 + */ +public class Activator extends AbstractUIPlugin { + + // The plug-in ID + public static final String PLUGIN_ID = "org.simantics.views.text"; //$NON-NLS-1$ + + // The shared instance + private static Activator plugin; + + /** + * The constructor + */ + public Activator() { + } + + /* + * (non-Javadoc) + * @see org.eclipse.ui.plugin.AbstractUIPlugin#start(org.osgi.framework.BundleContext) + */ + public void start(BundleContext context) throws Exception { + super.start(context); + plugin = this; + } + + /* + * (non-Javadoc) + * @see org.eclipse.ui.plugin.AbstractUIPlugin#stop(org.osgi.framework.BundleContext) + */ + public void stop(BundleContext context) throws Exception { + plugin = null; + super.stop(context); + } + + /** + * Returns the shared instance + * + * @return the shared instance + */ + public static Activator getDefault() { + return plugin; + } + +} diff --git a/bundles/org.simantics.views.text/src/org/simantics/views/text/internal/SWTMarkupSourceViewer.java b/bundles/org.simantics.views.text/src/org/simantics/views/text/internal/SWTMarkupSourceViewer.java new file mode 100644 index 000000000..756dfe21a --- /dev/null +++ b/bundles/org.simantics.views.text/src/org/simantics/views/text/internal/SWTMarkupSourceViewer.java @@ -0,0 +1,119 @@ +/******************************************************************************* + * Copyright (c) 2017 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: + * Semantum Oy - (#7066) initial API and implementation + *******************************************************************************/ +package org.simantics.views.text.internal; + +import org.eclipse.jface.text.Document; +import org.eclipse.mylyn.wikitext.core.parser.markup.MarkupLanguage; +import org.eclipse.mylyn.wikitext.mediawiki.core.MediaWikiLanguage; +import org.eclipse.mylyn.wikitext.ui.editor.MarkupSourceViewer; +import org.eclipse.mylyn.wikitext.ui.editor.MarkupSourceViewerConfiguration; +import org.eclipse.mylyn.wikitext.ui.editor.ShowInTargetBridge; +import org.eclipse.swt.SWT; +import org.eclipse.swt.custom.StyledText; +import org.eclipse.swt.events.SelectionEvent; +import org.eclipse.swt.events.SelectionListener; +import org.eclipse.swt.graphics.Point; +import org.eclipse.swt.widgets.Composite; +import org.eclipse.ui.services.IServiceLocator; +import org.eclipse.ui.swt.IFocusService; +import org.simantics.views.ViewUtils; +import org.simantics.views.swt.client.base.SingleSWTViewNode; + +/** + * @author Tuukka Lehtonen + * @since 1.28.0 + */ +public class SWTMarkupSourceViewer extends SingleSWTViewNode { + + private static final long serialVersionUID = 3034624586096417826L; + + private MarkupSourceViewer viewer; + private boolean textInitialized = false; + + @Override + public void createControls(Composite parent) { + MarkupLanguage language = new MediaWikiLanguage(); + viewer = new MarkupSourceViewer(parent, null, style | SWT.WRAP, language); + viewer.setEditable(false); + MarkupSourceViewerConfiguration configuration = new MarkupSourceViewerConfiguration(Activator.getDefault().getPreferenceStore()); + configuration.setMarkupLanguage(language); + configuration.setShowInTarget(new ShowInTargetBridge(viewer)); + viewer.configure(configuration); + viewer.setDocument(new Document(text != null ? text : "")); + control = viewer.getTextWidget(); + control.setData(TextViewerConstants.KEY_UNDO_MANAGER, viewer.getUndoManager()); + control.setEnabled(false); + + setProperties(); + + // Allow undo/redo handler to be bound to this text editor's focus + IServiceLocator locator = getSite(); + if (locator != null) { + IFocusService focusService = locator.getService(IFocusService.class); + if (focusService != null) { + focusService.addFocusTracker(control, TextViewerConstants.CONTEXT_IN_TEXT_VIEWER); + } + } + + control.addSelectionListener(new SelectionListener() { + @Override + public void widgetSelected(SelectionEvent e) { + ViewUtils.setWorkbenchSelection(viewer.getSelection()); + } + @Override + public void widgetDefaultSelected(SelectionEvent e) { + widgetSelected(e); + } + }); + } + + @Override + public void synchronizeText(String text) { + this.text = text; + if (text != null) { + // Try to keep the vertical scroll position of the text widget + int caretOffset = control.getCaretOffset(); + int charCount = control.getCharCount(); + int topIndex = viewer.getTopIndex(); + int diff = text.length() - charCount; + int newCaretOffset = Math.max(0, Math.min(caretOffset + diff, text.length())); + + viewer.getDocument().set(text); + viewer.setTopIndex(topIndex); + control.setCaretOffset(newCaretOffset); + viewer.setEditable(true); + control.setEnabled(true); + + // Prevent text viewer undo from allowing the + // user to undo the text viewer back to empty. + if (!textInitialized) { + viewer.getUndoManager().reset(); + textInitialized = true; + } + } else { + textInitialized = false; + viewer.setEditable(false); + control.setEnabled(false); + viewer.getDocument().set(""); + viewer.getUndoManager().reset(); + } + } + + public String readText() { + return viewer.getDocument().get(); + } + + public Point readSelection() { + return control.getSelection(); + } + +} \ No newline at end of file diff --git a/bundles/org.simantics.views.text/src/org/simantics/views/text/internal/TextViewerConstants.java b/bundles/org.simantics.views.text/src/org/simantics/views/text/internal/TextViewerConstants.java new file mode 100644 index 000000000..2924dc3ec --- /dev/null +++ b/bundles/org.simantics.views.text/src/org/simantics/views/text/internal/TextViewerConstants.java @@ -0,0 +1,36 @@ +/******************************************************************************* + * Copyright (c) 2017 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: + * Semantum Oy - (#7066) initial API and implementation + *******************************************************************************/ +package org.simantics.views.text.internal; + +import org.eclipse.jface.text.IUndoManager; +import org.eclipse.jface.text.TextViewer; +import org.eclipse.swt.widgets.Control; + +/** + * @author Tuukka Lehtonen + * @since 1.28.0 + */ +public class TextViewerConstants { + + /** + * The UI focus control context used for enabling normal text undo/redo for + * {@link TextViewer} controls. + */ + public static final String CONTEXT_IN_TEXT_VIEWER = "inTextViewer"; + + /** + * A key used for storing an {@link IUndoManager} as data of a + * {@link Control} using {@link Control#setData(String, Object)}. + */ + public static final String KEY_UNDO_MANAGER = "undoManager"; + +} diff --git a/bundles/org.simantics.views.text/src/org/simantics/views/text/internal/TextViewerUndoHandler.java b/bundles/org.simantics.views.text/src/org/simantics/views/text/internal/TextViewerUndoHandler.java new file mode 100644 index 000000000..f1c8adeab --- /dev/null +++ b/bundles/org.simantics.views.text/src/org/simantics/views/text/internal/TextViewerUndoHandler.java @@ -0,0 +1,169 @@ +/******************************************************************************* + * Copyright (c) 2017 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: + * Semantum Oy - (#7066) initial API and implementation + *******************************************************************************/ +package org.simantics.views.text.internal; + +import java.lang.reflect.InvocationTargetException; +import java.lang.reflect.Method; +import java.util.concurrent.Callable; + +import org.eclipse.core.commands.AbstractHandler; +import org.eclipse.core.commands.ExecutionEvent; +import org.eclipse.core.commands.ExecutionException; +import org.eclipse.core.runtime.IConfigurationElement; +import org.eclipse.core.runtime.IExecutableExtension; +import org.eclipse.jface.text.IUndoManager; +import org.eclipse.jface.text.TextViewer; +import org.eclipse.swt.SWT; +import org.eclipse.swt.widgets.Control; +import org.eclipse.swt.widgets.Display; +import org.eclipse.swt.widgets.Event; +import org.eclipse.swt.widgets.Listener; + +/** + * Handles the undo/redo command for {@link TextViewer}s through + * {@link IUndoManager}. + * + *

+ * The implementation looks for an IUndoManager from the current focus control + * using the {@link TextViewerConstants#KEY_UNDO_MANAGER} data key. Its + * existence determines whether this handler {@link #isHandled()} returns + * true or false. + * + *

+ * The handler expects to receive a single string as an argument through the + * extension definitions ({@link IExecutableExtension}) that determines which + * method is invoked from IUndoManager (undo or redo). + * + *

+ * Implementation is partially copied from + * org.eclipse.ui.internal.handlers.WidgetMethodHandler. + * + * @since 1.28.0 + */ +public class TextViewerUndoHandler extends AbstractHandler implements IExecutableExtension { + + /** + * The parameters to pass to the method this handler invokes. This handler + * always passes no parameters. + */ + protected static final Class[] NO_PARAMETERS = new Class[0]; + + public TextViewerUndoHandler() { + display = Display.getCurrent(); + if (display != null) { + focusListener = new Listener() { + @Override + public void handleEvent(Event event) { + updateEnablement(); + } + }; + display.addFilter(SWT.FocusIn, focusListener); + } + } + + void updateEnablement() { + boolean rc = isHandled(); + if (rc != isEnabled()) { + setBaseEnabled(rc); + } + } + + /** + * The name of the method to be invoked by this handler. This value should + * never be null. + */ + protected String methodName; + private Listener focusListener; + private Display display; + + @Override + public Object execute(final ExecutionEvent event) throws ExecutionException { + Callable runnable = getMethodToExecute(); + if (runnable != null) { + try { + runnable.call(); + } catch (ExecutionException e) { + throw e; + } catch (Exception e) { + throw new ExecutionException("Unexpected failure executing method " + methodName + " through " + runnable); + } + } + return null; + } + + @Override + public final boolean isHandled() { + return getMethodToExecute() != null; + } + + /** + * Looks up the method on the focus control. + * + * @return The method on the focus control; null if none. + */ + protected Callable getMethodToExecute() { + Display display = Display.getCurrent(); + if (display == null) + return null; + + Control focusControl = display.getFocusControl(); + if (focusControl == null) + return null; + + IUndoManager undoManager = (IUndoManager) focusControl.getData(TextViewerConstants.KEY_UNDO_MANAGER); + if (undoManager == null) + return null; + + try { + Method method = undoManager.getClass().getMethod(methodName, NO_PARAMETERS); + if (method != null) + return runner(undoManager, method); + } catch (NoSuchMethodException e) { + // Fall through... + } + + return null; + } + + protected Callable runner(IUndoManager undoManager, Method method) { + return () -> { + try { + method.invoke(undoManager); + return true; + } catch (IllegalAccessException e) { + // The method is protected, so do nothing. + return false; + } catch (InvocationTargetException e) { + throw new ExecutionException( + "An exception occurred while executing " //$NON-NLS-1$ + + method.getName(), e + .getTargetException()); + + } + }; + } + + @Override + public void setInitializationData(IConfigurationElement config, String propertyName, Object data) { + methodName = data.toString(); + } + + @Override + public void dispose() { + if (display != null && !display.isDisposed()) { + display.removeFilter(SWT.FocusIn, focusListener); + } + display = null; + focusListener = null; + } + +} \ No newline at end of file diff --git a/bundles/pom.xml b/bundles/pom.xml index bbc378243..319859a65 100644 --- a/bundles/pom.xml +++ b/bundles/pom.xml @@ -221,6 +221,8 @@ org.simantics.views.ontology org.simantics.views.swt org.simantics.views.swt.client + org.simantics.views.text + org.simantics.views.text.ontology org.simantics.wiki.ui org.simantics.workbench org.simantics.workbench.ontology diff --git a/features/org.simantics.views.swt.feature/feature.xml b/features/org.simantics.views.swt.feature/feature.xml index 17247686e..41508ef1c 100644 --- a/features/org.simantics.views.swt.feature/feature.xml +++ b/features/org.simantics.views.swt.feature/feature.xml @@ -1,7 +1,7 @@ @@ -35,4 +35,18 @@ version="0.0.0" unpack="false"/> + + + + -- 2.43.2