X-Git-Url: https://gerrit.simantics.org/r/gitweb?p=simantics%2Fplatform.git;a=blobdiff_plain;f=bundles%2Forg.simantics.views.swt%2Fsrc%2Forg%2Fsimantics%2Fviews%2Fswt%2Floader%2FTabFolderLoader.java.keep;h=4c6cdf0599a94723e1561425f7a779e1d9fc7ee4;hp=d82c0feebd3678eba87521224053cbe18a638862;hb=894991ee53490cb8e28dd48b0da686203411324a;hpb=969bd23cab98a79ca9101af33334000879fb60c5 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 index d82c0feeb..4c6cdf059 100644 --- 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 @@ -1,75 +1,75 @@ -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); - } - } - -} +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); + } + } + +}