Merge "Bug 391523 - Revise getSelectionInfo...() in IToolBehaviorProvider"
diff --git a/examples/org.eclipse.graphiti.doc/resources/docu/advanced/Patterns.htm b/examples/org.eclipse.graphiti.doc/resources/docu/advanced/Patterns.htm
index ba80018..b9dfcb9 100644
--- a/examples/org.eclipse.graphiti.doc/resources/docu/advanced/Patterns.htm
+++ b/examples/org.eclipse.graphiti.doc/resources/docu/advanced/Patterns.htm
@@ -328,5 +328,28 @@
 		what you would also need to implement for the features of a
 		connection.
 	</p>
+	<div id="idpatterns"></div>
+	<h2>ID Patterns</h2>
+	<p>
+		ID patterns are a special kind of pattern that allow clients to easily
+		tag parts of their shapes (both <i>PictogramElements</i> and <i>GraphicsAlgorithms</i>)
+		with IDs. These IDs are simple strings that can in other methods of
+		the pattern be used to identify the shape. The ID pattern base class
+		itself already does that to a wide extend; on e.g. layout or update
+		the pattern checks if the affected shape has an ID and if yes
+		delegates to a special ID Pattern method that can use the passed ID
+		information and simply do the intended job without having to care
+		about finding the shape or checking the relevance of the shape first.
+		This makes client coding much shorter and effective and spares clients
+		the tedious writing of such boilerplate code.
+	</p>
+	<p>The are two examples for ID Patterns within the Graphiti
+		Filesystem example: <i>File</i> objects are a basic example of the ID pattern
+		usage, while <i>Folder</i>s are a more advanced example that also shows
+		nesting a list of children (files in the example).</p>
+	<p class="Note"><b>Note:</b> The ID Pattern type is still experimental, the API
+		might still evolve and/or change without prior notice! Nevertheless,
+		we try to keep the API stable and encourage you to use this new
+		pattern type and give feedback.</p>
 </body>
 </html>
diff --git a/examples/org.eclipse.graphiti.doc/resources/docu/examples/Filesystem.htm b/examples/org.eclipse.graphiti.doc/resources/docu/examples/Filesystem.htm
new file mode 100644
index 0000000..37fe84e
--- /dev/null
+++ b/examples/org.eclipse.graphiti.doc/resources/docu/examples/Filesystem.htm
@@ -0,0 +1,50 @@
+<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
+<html>
+
+<head>
+<meta content="text/html; charset=utf-8" http-equiv="Content-Type">
+<title>Filesystem Example</title>
+<link href="../book.css" rel="Stylesheet" type="text/css">
+<link href="../code.css" rel="Stylesheet" type="text/css">
+</head>
+
+<body>
+
+	<h1>Filesystem Example</h1>
+	<p>
+		The filesystem example provided along with the SDK download of
+		Graphiti illustrates how one can use patterns for building Graphiti
+		editors. It registers an editor for this that allows the user to
+		create a filesystem with files and folders. Most of the functionality
+		is build using <a href="../advanced/Patterns.htm">patterns</a> and <a
+			href="../advanced/Patterns.htm#idpatterns">ID patterns</a>.
+	</p>
+	<img alt="Screensshot of Filesystem Example Editor"
+		src="images/FilesystemEditor.png" width="600px">
+	<h2>Filesystem Example Plugin</h2>
+	<p>
+		The example plugin <i>org.eclipse.graphiti.examples.filesystem</i> is
+		available as executable but also as source in the SDK download and
+		within our repository under the examples folder. While the example is
+		easy enough for quickly understanding it, it allows to demonstrate
+		some features of Graphiti that are not explained in the tutorial.
+	</p>
+	<h2>EMF Model</h2>
+	<p>
+		The examples plugin <i>org.eclipse.graphiti.examples.filesystem.mm</i>
+		contains a small EMF model to define the filesystem model.
+	</p>
+	<img alt="The EMF model defined for the Filesystem Example"
+		src="images/FilesystemModel.png" width="600px">
+	<h2>Special Graphiti Features</h2>
+	<p>The following special Graphiti features are shown in the
+		Filesystem example:</p>
+	<ul>
+		<li>The filesystem object itself is implemented using Graphiti
+			patterns.</li>
+		<li>The file object is a simple example of a Graphiti ID pattern.</li>
+		<li>The folder object is a more advanced example for a Graphiti
+			ID pattern using nesting of a list of objects.</li>
+	</ul>
+</body>
+</html>
diff --git a/examples/org.eclipse.graphiti.doc/resources/docu/examples/Tutorial.htm b/examples/org.eclipse.graphiti.doc/resources/docu/examples/Tutorial.htm
new file mode 100644
index 0000000..534320d
--- /dev/null
+++ b/examples/org.eclipse.graphiti.doc/resources/docu/examples/Tutorial.htm
@@ -0,0 +1,27 @@
+<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
+<html>
+
+<head>
+<meta content="text/html; charset=utf-8" http-equiv="Content-Type">
+<title>Tutorial</title>
+<link href="../book.css" rel="Stylesheet" type="text/css">
+<link href="../code.css" rel="Stylesheet" type="text/css">
+</head>
+
+<body>
+
+	<h1>Tutorial</h1>
+	<p>The tutorial example provided along with the SDK download of
+		Graphiti contains the final version of the Graphiti editor that is
+		created in the Graphiti tutorial.</p>
+	<h2>Tutorial Plugin</h2>
+	<p>
+		The example plugin <i>org.eclipse.graphiti.examples.tutorial</i> is
+		available as executable but also as source in the SDK download and
+		within our repository under the examples folder.
+	</p>
+	<h2>EMF Model</h2>
+	<p>The tutorial uses the ECore model itself as domain model.
+		Therefore there is no special model defined here.</p>
+</body>
+</html>
diff --git a/examples/org.eclipse.graphiti.doc/resources/docu/examples/images/FilesystemEditor.png b/examples/org.eclipse.graphiti.doc/resources/docu/examples/images/FilesystemEditor.png
new file mode 100644
index 0000000..3ef749d
--- /dev/null
+++ b/examples/org.eclipse.graphiti.doc/resources/docu/examples/images/FilesystemEditor.png
Binary files differ
diff --git a/examples/org.eclipse.graphiti.doc/resources/docu/examples/images/FilesystemModel.png b/examples/org.eclipse.graphiti.doc/resources/docu/examples/images/FilesystemModel.png
new file mode 100644
index 0000000..bcc3930
--- /dev/null
+++ b/examples/org.eclipse.graphiti.doc/resources/docu/examples/images/FilesystemModel.png
Binary files differ
diff --git a/examples/org.eclipse.graphiti.doc/toc.xml b/examples/org.eclipse.graphiti.doc/toc.xml
index 9f214ed..498e24e 100644
--- a/examples/org.eclipse.graphiti.doc/toc.xml
+++ b/examples/org.eclipse.graphiti.doc/toc.xml
Binary files differ
diff --git a/plugins/org.eclipse.graphiti.pattern/src/org/eclipse/graphiti/pattern/AbstractPattern.java b/plugins/org.eclipse.graphiti.pattern/src/org/eclipse/graphiti/pattern/AbstractPattern.java
index 8afe75d..aad5d41 100644
--- a/plugins/org.eclipse.graphiti.pattern/src/org/eclipse/graphiti/pattern/AbstractPattern.java
+++ b/plugins/org.eclipse.graphiti.pattern/src/org/eclipse/graphiti/pattern/AbstractPattern.java
@@ -881,10 +881,10 @@
 	 * .
 	 * 
 	 * @param value
-	 *            The new vlue to check
+	 *            The new value to check
 	 * @param context
 	 *            A context object describing the direct edit request.
-	 * @return <code>null</code> in case of a vlid value, a string describing
+	 * @return <code>null</code> in case of a valid value, a string describing
 	 *         the reason for being not valid otherwise.
 	 */
 	public String checkValueValid(String value, IDirectEditingContext context) {
@@ -999,7 +999,7 @@
 
 	/**
 	 * Provides the initial value for display in the newly opened text editing
-	 * UI component. Corresponds to the methdo
+	 * UI component. Corresponds to the method
 	 * {@link AbstractDirectEditingFeature#getInitialValue(IDirectEditingContext)}
 	 * . The default implementation always returns an empty string.
 	 * 
diff --git a/plugins/org.eclipse.graphiti.pattern/src/org/eclipse/graphiti/pattern/id/IdLayoutContext.java b/plugins/org.eclipse.graphiti.pattern/src/org/eclipse/graphiti/pattern/id/IdLayoutContext.java
index 5cb593b..6aba3b8 100644
--- a/plugins/org.eclipse.graphiti.pattern/src/org/eclipse/graphiti/pattern/id/IdLayoutContext.java
+++ b/plugins/org.eclipse.graphiti.pattern/src/org/eclipse/graphiti/pattern/id/IdLayoutContext.java
@@ -20,6 +20,13 @@
 import org.eclipse.graphiti.mm.pictograms.PictogramElement;

 

 /**

+ * This class represents a special {@link LayoutContext} suitable for usage

+ * within an {@link IdPattern}. Besides the usual {@link LayoutContext} options

+ * this context object also stores the associated {@link GraphicsAlgorithm} for

+ * the {@link PictogramElement} of the context and the root

+ * {@link PictogramElement} of the pattern. The latter may be of use for easier

+ * finding a certain child within a pattern representation.

+ * 

  * @since 0.10

  * @experimental This API is in an experimental state and should be used by

  *               clients only with care, as it not final and can be removed or

@@ -30,6 +37,20 @@
 	private GraphicsAlgorithm graphicsAlgorithm;

 	private PictogramElement rootPictogramElement;

 

+	/**

+	 * Creates a new {@link IdLayoutContext} instance holding the given

+	 * pictogram model instances.

+	 * 

+	 * @param pictogramElement

+	 *            The {@link PictogramElement} that shall be layouted, see

+	 *            {@link LayoutContext}.

+	 * @param graphicsAlgorithm

+	 *            The associated {@link GraphicsAlgorithm} for the

+	 *            {@link PictogramElement}

+	 * @param rootPictogramElement

+	 *            The root pictogram element, this is the one that holds the ID

+	 *            property for the pattern

+	 */

 	public IdLayoutContext(PictogramElement pictogramElement, GraphicsAlgorithm graphicsAlgorithm,

 			PictogramElement rootPictogramElement) {

 		super(pictogramElement);

@@ -37,18 +58,42 @@
 		this.rootPictogramElement = rootPictogramElement;

 	}

 

+	/**

+	 * Returns the stored {@link GraphicsAlgorithm}.

+	 * 

+	 * @return The instance of the {@link GraphicsAlgorithm} for the

+	 *         {@link PictogramElement} to layout.

+	 */

 	public GraphicsAlgorithm getGraphicsAlgorithm() {

 		return graphicsAlgorithm;

 	}

 

+	/**

+	 * Sets a new {@link GraphicsAlgorithm} for the {@link PictogramElement} to

+	 * layout.

+	 * 

+	 * @param graphicsAlgorithm

+	 *            The new instance to set.

+	 */

 	public void setGraphicsAlgorithm(GraphicsAlgorithm graphicsAlgorithm) {

 		this.graphicsAlgorithm = graphicsAlgorithm;

 	}

 

+	/**

+	 * Returns the stored root {@link PictogramElement}.

+	 * 

+	 * @return The instance of the root {@link PictogramElement}.

+	 */

 	public PictogramElement getRootPictogramElement() {

 		return rootPictogramElement;

 	}

 

+	/**

+	 * Sets a new root {@link PictogramElement}.

+	 * 

+	 * @param rootPictogramElement

+	 *            The new instance to set.

+	 */

 	public void setRootPictogramElement(PictogramElement rootPictogramElement) {

 		this.rootPictogramElement = rootPictogramElement;

 	}

diff --git a/plugins/org.eclipse.graphiti.pattern/src/org/eclipse/graphiti/pattern/id/IdPattern.java b/plugins/org.eclipse.graphiti.pattern/src/org/eclipse/graphiti/pattern/id/IdPattern.java
index 456225b..ee6692d 100644
--- a/plugins/org.eclipse.graphiti.pattern/src/org/eclipse/graphiti/pattern/id/IdPattern.java
+++ b/plugins/org.eclipse.graphiti.pattern/src/org/eclipse/graphiti/pattern/id/IdPattern.java
@@ -23,7 +23,9 @@
 import org.eclipse.graphiti.features.context.IUpdateContext;

 import org.eclipse.graphiti.features.context.impl.LayoutContext;

 import org.eclipse.graphiti.features.context.impl.UpdateContext;

+import org.eclipse.graphiti.features.impl.AbstractDirectEditingFeature;

 import org.eclipse.graphiti.features.impl.Reason;

+import org.eclipse.graphiti.func.IDirectEditing;

 import org.eclipse.graphiti.mm.Property;

 import org.eclipse.graphiti.mm.PropertyContainer;

 import org.eclipse.graphiti.mm.algorithms.GraphicsAlgorithm;

@@ -841,13 +843,39 @@
 	 * Direct editing functionality

 	 */

 

+	/**

+	 * The Graphiti framework calls this method to decide which UI to show up

+	 * for direct editing. Corresponds to the method

+	 * {@link AbstractDirectEditingFeature#getEditingType()}. The default

+	 * implementation return {@link IDirectEditing#TYPE_NONE}, other valid type

+	 * are defined by the TYPE_* constants in {@link IDirectEditing}.

+	 * 

+	 * @return The desired editing type

+	 */

 	@Override

 	public int getEditingType() {

 		// TODO how to use different editing types for different parts of the

 		// pattern? No context to identify id...

-		return TYPE_TEXT;

+		return super.getEditingType();

 	}

 

+	/**

+	 * Clients can override this method to indicate that the pattern allows

+	 * direct editing for the shape described in the passed

+	 * {@link IDirectEditingContext}, but the recommended method to override for

+	 * {@link IdPattern} is

+	 * {@link #canDirectEdit(IDirectEditingContext, String)}. Corresponds to the

+	 * method

+	 * {@link AbstractDirectEditingFeature#canDirectEdit(IDirectEditingContext)}

+	 * . The default implementation checks if the pattern is responsible for the

+	 * shape and an ID is set; in that case it delegates to

+	 * {@link #canDirectEdit(IDirectEditingContext, String)}.

+	 * 

+	 * @param context

+	 *            A context object describing the direct edit request.

+	 * @return <code>true</code> in case direct editing shall be allowed,

+	 *         <code>false</code> otherwise.

+	 */

 	@Override

 	public boolean canDirectEdit(IDirectEditingContext context) {

 		PictogramElement pictogramElement = context.getPictogramElement();

@@ -868,10 +896,37 @@
 		return false;

 	}

 

+	/**

+	 * Clients can override this method to indicate that the pattern allows

+	 * direct editing for the shape described in the passed

+	 * {@link IDirectEditingContext} holding the given ID. Corresponds to the

+	 * method

+	 * {@link AbstractDirectEditingFeature#canDirectEdit(IDirectEditingContext)}

+	 * . The default implementation simply returns <code>false</code>.

+	 * 

+	 * @param context

+	 *            A context object describing the direct edit request.

+	 * @param id

+	 *            The ID to check direct editing for

+	 * @return <code>true</code> in case direct editing shall be allowed,

+	 *         <code>false</code> otherwise.

+	 */

 	protected boolean canDirectEdit(IDirectEditingContext context, String id) {

 		return false;

 	}

 

+	/**

+	 * Provides the initial value for display in the newly opened text editing

+	 * UI component. Corresponds to the method

+	 * {@link AbstractDirectEditingFeature#getInitialValue(IDirectEditingContext)}

+	 * . The default implementation checks if the pattern is responsible for the

+	 * shape and an ID is set; in that case it delegates to

+	 * {@link #getInitialValue(IDirectEditingContext, String)}.

+	 * 

+	 * @param context

+	 *            A context object describing the direct edit request.

+	 * @return The initial string value to be displayed for editing by the user.

+	 */

 	@Override

 	public String getInitialValue(IDirectEditingContext context) {

 		PictogramElement pictogramElement = context.getPictogramElement();

@@ -889,13 +944,44 @@
 				}

 			}

 		}

-		return null;

+		return "";

 	}

 

+	/**

+	 * Provides the initial value for display in the newly opened text editing

+	 * UI component. Corresponds to the method

+	 * {@link AbstractDirectEditingFeature#getInitialValue(IDirectEditingContext)}

+	 * . The default implementation always returns an empty string.

+	 * 

+	 * @param context

+	 *            A context object describing the direct edit request.

+	 * @param id

+	 *            The ID of the shape to get the initial value for

+	 * @return The initial string value to be displayed for editing by the user.

+	 */

 	protected String getInitialValue(IDirectEditingContext context, String id) {

-		return null;

+		return "";

 	}

 

+	/**

+	 * This method will be called by the framework to check if the passed String

+	 * is valid as new value for the shape. This method's response time should

+	 * be small since the method is queried after each change of the value in

+	 * the direct edit UI. In case of a not valid value, the returned string

+	 * shall indicate the reason why the value is not valid. Corresponds to the

+	 * method

+	 * {@link AbstractDirectEditingFeature#checkValueValid(String, IDirectEditingContext)}

+	 * . The default implementation checks if the pattern is responsible for the

+	 * shape and an ID is set; in that case it delegates to

+	 * {@link #checkValueValid(String, IDirectEditingContext, String)}.

+	 * 

+	 * @param value

+	 *            The new value to check

+	 * @param context

+	 *            A context object describing the direct edit request.

+	 * @return <code>null</code> in case of a valid value, a string describing

+	 *         the reason for being not valid otherwise.

+	 */

 	@Override

 	public String checkValueValid(String value, IDirectEditingContext context) {

 		PictogramElement pictogramElement = context.getPictogramElement();

@@ -916,10 +1002,43 @@
 		return null;

 	}

 

+	/**

+	 * This method will be called by the framework to check if the passed String

+	 * is valid as new value for the shape. This method's response time should

+	 * be small since the method is queried after each change of the value in

+	 * the direct edit UI. The default implementation simply returns null to

+	 * indicate that all values are valid. In case of a not valid value, the

+	 * returned string shall indicate the reason why the value is not valid.

+	 * Corresponds to the method

+	 * {@link AbstractDirectEditingFeature#checkValueValid(String, IDirectEditingContext)}

+	 * .

+	 * 

+	 * @param value

+	 *            The new value to check

+	 * @param context

+	 *            A context object describing the direct edit request.

+	 * @param id

+	 *            The ID of the shape to check the value for

+	 * @return <code>null</code> in case of a valid value, a string describing

+	 *         the reason for being not valid otherwise.

+	 */

 	protected String checkValueValid(String value, IDirectEditingContext context, String id) {

 		return null;

 	}

 

+	/**

+	 * Set the new value after direct editing is finished. The value comes from

+	 * the text editing UI component. Corresponds to the method

+	 * {@link AbstractDirectEditingFeature#setValue(String, IDirectEditingContext)}

+	 * . The default implementation checks if the pattern is responsible for the

+	 * shape and an ID is set; in that case it delegates to

+	 * {@link #setValue(String, IDirectEditingContext, String)}.

+	 * 

+	 * @param value

+	 *            The new value to be set

+	 * @param context

+	 *            A context object describing the direct edit request.

+	 */

 	@Override

 	public void setValue(String value, IDirectEditingContext context) {

 		PictogramElement pictogramElement = context.getPictogramElement();

@@ -939,6 +1058,19 @@
 		}

 	}

 

+	/**

+	 * Set the new value after direct editing is finished. The value comes from

+	 * the text editing UI component. Corresponds to the method

+	 * {@link AbstractDirectEditingFeature#setValue(String, IDirectEditingContext)}

+	 * . The default implementation does nothing.

+	 * 

+	 * @param value

+	 *            The new value to be set

+	 * @param context

+	 *            A context object describing the direct edit request.

+	 * @param id

+	 *            The ID of the shape to set the value for

+	 */

 	protected void setValue(String value, IDirectEditingContext context, String id) {

 	}

 }

diff --git a/plugins/org.eclipse.graphiti.pattern/src/org/eclipse/graphiti/pattern/id/IdUpdateContext.java b/plugins/org.eclipse.graphiti.pattern/src/org/eclipse/graphiti/pattern/id/IdUpdateContext.java
index 9a32cb0..22c3e34 100644
--- a/plugins/org.eclipse.graphiti.pattern/src/org/eclipse/graphiti/pattern/id/IdUpdateContext.java
+++ b/plugins/org.eclipse.graphiti.pattern/src/org/eclipse/graphiti/pattern/id/IdUpdateContext.java
@@ -20,6 +20,14 @@
 import org.eclipse.graphiti.mm.pictograms.PictogramElement;

 

 /**

+ * This class represents a special {@link UpdateContext} suitable for usage

+ * within an {@link IdPattern}. Besides the usual {@link UpdateContext} options

+ * this context object also stores the associated {@link GraphicsAlgorithm} for

+ * the {@link PictogramElement} of the context, the root

+ * {@link PictogramElement} of the pattern and the linked domain object. The

+ * second may be of use for easier finding a certain child within a pattern

+ * representation.

+ * 

  * @since 0.10

  * @experimental This API is in an experimental state and should be used by

  *               clients only with care, as it not final and can be removed or

@@ -31,6 +39,23 @@
 	private PictogramElement rootPictogramElement;

 	private Object domainObject;

 

+	/**

+	 * Creates a new {@link IdUpdateContext} instance holding the given

+	 * pictogram model instances and domain object instance.

+	 * 

+	 * @param pictogramElement

+	 *            The {@link PictogramElement} that shall be updated, see

+	 *            {@link UpdateContext}.

+	 * @param graphicsAlgorithm

+	 *            The associated {@link GraphicsAlgorithm} for the

+	 *            {@link PictogramElement}

+	 * @param rootPictogramElement

+	 *            The root pictogram element, this is the one that holds the ID

+	 *            property for the pattern

+	 * @param domainObject

+	 *            The domain object that is linked with the pattern root

+	 *            pictogram element.

+	 */

 	public IdUpdateContext(PictogramElement pictogramElement, GraphicsAlgorithm graphicsAlgorithm,

 			PictogramElement rootPictogramElement, Object domainObject) {

 		super(pictogramElement);

@@ -39,6 +64,11 @@
 		this.setDomainObject(domainObject);

 	}

 

+	/**

+	 * Returns the stored {@link PictogramElement}.

+	 * 

+	 * @return The instance of the {@link PictogramElement} to layout.

+	 */

 	@Override

 	public PictogramElement getPictogramElement() {

 		/*

@@ -49,26 +79,61 @@
 		return super.getPictogramElement();

 	}

 

+	/**

+	 * Returns the stored {@link GraphicsAlgorithm}.

+	 * 

+	 * @return The instance of the {@link GraphicsAlgorithm} for the

+	 *         {@link PictogramElement} to update.

+	 */

 	public GraphicsAlgorithm getGraphicsAlgorithm() {

 		return graphicsAlgorithm;

 	}

 

+	/**

+	 * Sets a new {@link GraphicsAlgorithm} for the {@link PictogramElement} to

+	 * update.

+	 * 

+	 * @param graphicsAlgorithm

+	 *            The new instance to set.

+	 */

 	public void setGraphicsAlgorithm(GraphicsAlgorithm graphicsAlgorithm) {

 		this.graphicsAlgorithm = graphicsAlgorithm;

 	}

 

+	/**

+	 * Returns the stored root {@link PictogramElement}.

+	 * 

+	 * @return The instance of the root {@link PictogramElement}.

+	 */

 	public PictogramElement getRootPictogramElement() {

 		return rootPictogramElement;

 	}

 

+	/**

+	 * Sets a new root {@link PictogramElement}.

+	 * 

+	 * @param rootPictogramElement

+	 *            The new instance to set.

+	 */

 	public void setRootPictogramElement(PictogramElement rootPictogramElement) {

 		this.rootPictogramElement = rootPictogramElement;

 	}

 

+	/**

+	 * Returns the stored domain object instance.

+	 * 

+	 * @return The stored instance of the domain object.

+	 */

 	public Object getDomainObject() {

 		return domainObject;

 	}

 

+	/**

+	 * Sets a new domain object instance.

+	 * 

+	 * @param domainObject

+	 *            The new instance to set.

+	 */

 	public void setDomainObject(Object domainObject) {

 		this.domainObject = domainObject;

 	}