summaryrefslogtreecommitdiffstats
path: root/docs
diff options
context:
space:
mode:
authorwisberg <wisberg>2004-04-02 11:07:41 +0000
committerwisberg <wisberg>2004-04-02 11:07:41 +0000
commite5ab0a5339aa52fe4a3810f18476806b65c0f222 (patch)
treefb518943cfb0a7a6eb9f7c316a6b0f4cd69b10ff /docs
parent5c519477cbd4825b9b5683a0f24c244a5f65f86a (diff)
downloadaspectj-e5ab0a5339aa52fe4a3810f18476806b65c0f222.tar.gz
aspectj-e5ab0a5339aa52fe4a3810f18476806b65c0f222.zip
Jan's 4/2 bug 50932 patch
Diffstat (limited to 'docs')
-rw-r--r--docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/adapter/aspectj/Main.java6
-rw-r--r--docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/facade/aspectj/Decoration.java44
-rw-r--r--docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/facade/aspectj/FacadePolicyEnforcement.java65
-rw-r--r--docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/facade/aspectj/Main.java44
-rw-r--r--docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/facade/aspectj/OutputFacade.java79
-rw-r--r--docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/facade/aspectj/RegularScreen.java52
-rw-r--r--docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/facade/aspectj/StringTransformer.java56
-rw-r--r--docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/facade/java/Main.java4
-rw-r--r--docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/factoryMethod/aspectj/AlternateLabelCreatorImplementation.java62
-rw-r--r--docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/factoryMethod/aspectj/CreatorImplementation.java1
-rw-r--r--docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/observer/aspectj/ColorObserver.java2
-rw-r--r--docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/observer/aspectj/CoordinateObserver.java2
-rw-r--r--docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/observer/aspectj/Main.java2
-rw-r--r--docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/observer/aspectj/Point.java26
-rw-r--r--docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/observer/aspectj/Screen.java2
-rw-r--r--docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/observer/aspectj/ScreenObserver.java2
-rw-r--r--docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/observer/java/ChangeObserver.java4
-rw-r--r--docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/observer/java/ChangeSubject.java10
-rw-r--r--docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/observer/java/Main.java19
-rw-r--r--docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/observer/java/Point.java26
-rw-r--r--docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/observer/java/Screen.java10
-rw-r--r--docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/patternLibrary/StrategyProtocol.java2
22 files changed, 459 insertions, 61 deletions
diff --git a/docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/adapter/aspectj/Main.java b/docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/adapter/aspectj/Main.java
index c544be6ed..3ffc6a083 100644
--- a/docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/adapter/aspectj/Main.java
+++ b/docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/adapter/aspectj/Main.java
@@ -59,10 +59,12 @@ package ca.ubc.cs.spl.aspectPatterns.examples.adapter.aspectj;
public class Main {
/**
- * the Adaptee in the scenario
+ * the Adaptee in the scenario. Note that our adaptee can be used as a
+ * Writer because of the <code>declare parents</code> statement in the
+ * aspect.
*/
- private static SystemOutPrinter adaptee;
+ private static Writer adaptee;
/**
* Implements the driver.
diff --git a/docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/facade/aspectj/Decoration.java b/docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/facade/aspectj/Decoration.java
new file mode 100644
index 000000000..c6d59e657
--- /dev/null
+++ b/docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/facade/aspectj/Decoration.java
@@ -0,0 +1,44 @@
+package ca.ubc.cs.spl.aspectPatterns.examples.facade.aspectj;
+
+/* -*- Mode: Java; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*-
+ *
+ * This file is part of the design patterns project at UBC
+ *
+ * The contents of this file are subject to the Mozilla Public License
+ * Version 1.1 (the "License"); you may not use this file except in
+ * compliance with the License. You may obtain a copy of the License at
+ * either http://www.mozilla.org/MPL/ or http://aspectj.org/MPL/.
+ *
+ * Software distributed under the License is distributed on an "AS IS" basis,
+ * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
+ * for the specific language governing rights and limitations under the
+ * License.
+ *
+ * The Original Code is ca.ubc.cs.spl.aspectPatterns.
+ *
+ * For more details and the latest version of this code, please see:
+ * http://www.cs.ubc.ca/labs/spl/projects/aodps.html
+ *
+ * Contributor(s):
+ */
+
+/**
+ * Implements a static method that returns a decorator string.
+ *
+ * @author Jan Hannemann
+ * @author Gregor Kiczales
+ * @version 1.11, 03/29/04
+ */
+
+public class Decoration {
+
+ /**
+ * Provides a decorator string consisting of stars ("*").
+ *
+ * @returns a decorator string made up of stars
+ */
+
+ public static String getDecoration() {
+ return "*******************************************";
+ }
+} \ No newline at end of file
diff --git a/docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/facade/aspectj/FacadePolicyEnforcement.java b/docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/facade/aspectj/FacadePolicyEnforcement.java
new file mode 100644
index 000000000..815793fd5
--- /dev/null
+++ b/docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/facade/aspectj/FacadePolicyEnforcement.java
@@ -0,0 +1,65 @@
+/* -*- Mode: Java; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*-
+ *
+ * This file is part of the design patterns project at UBC
+ *
+ * The contents of this file are subject to the Mozilla Public License
+ * Version 1.1 (the "License"); you may not use this file except in
+ * compliance with the License. You may obtain a copy of the License at
+ * either http://www.mozilla.org/MPL/ or http://aspectj.org/MPL/.
+ *
+ * Software distributed under the License is distributed on an "AS IS" basis,
+ * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
+ * for the specific language governing rights and limitations under the
+ * License.
+ *
+ * The Original Code is ca.ubc.cs.spl.aspectPatterns.
+ *
+ * For more details and the latest version of this code, please see:
+ * http://www.cs.ubc.ca/labs/spl/projects/aodps.html
+ *
+ * Contributor(s):
+ */
+
+package ca.ubc.cs.spl.aspectPatterns.examples.facade.aspectj;
+
+/**
+ * Enforces the encapsulation of the Facade by declaring a compile-time
+ * warning if the <i>subsystem</i> is accessed from any other class but the
+ * facade. We use <code>declare warning</code> here, but <code>declare error
+ * </code> can also be used.
+ *
+ * Instead of protecting the encapsulated subsystem against (only) mehod
+ * calls, other pointcut types (or combinations) could be used to achieve
+ * different effects.
+ *
+ * @author Jan Hannemann
+ * @author Gregor Kiczales
+ * @version 1.11, 03/29/04
+ */
+
+public aspect FacadePolicyEnforcement {
+
+ /**
+ * Enumerates all calls to encapsulated methods. It is of course easier
+ * to define this pointcut if the encapsulated subsystem is in a separate
+ * package, and the protected classes do not have to be enumerated.
+ */
+
+ pointcut callsToEncapsulatedMethods():
+ call(* (Decoration || RegularScreen || StringTransformer).*(..));
+
+ /**
+ * Defines what constitutes legal accesses to the protected subsystem.
+ */
+
+ pointcut facade(): within(OutputFacade);
+
+ /**
+ * Whenever a method in the encapsulated susbsystem is called, a compile
+ * time warning gets created - except if the method call comes from the
+ * <i>Facade</i>
+ */
+
+ declare warning: callsToEncapsulatedMethods() && !facade():
+ "Calling encapsulated method directly - use Facade methods instead";
+}
diff --git a/docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/facade/aspectj/Main.java b/docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/facade/aspectj/Main.java
index 9d761685a..06e5ce34c 100644
--- a/docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/facade/aspectj/Main.java
+++ b/docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/facade/aspectj/Main.java
@@ -29,24 +29,48 @@ package ca.ubc.cs.spl.aspectPatterns.examples.facade.aspectj;
* subsystem. Facade defines a higher-level interface that makes the
* subsystem easier to use.</i><p>
*
- * <p><i>This is the AspectJ version.</i><p>
+ * The <i>subsystem</i> consists of three classes that provide low-level
+ * string manipulation and output functionality: <code>RegularScreen</code>,
+ * <code>Decoration</code>, and <code>StringTransformer</code>. The <i>Facade
+ * </i> class <code>OutputFacade</code> procides a higher-level interface
+ * to output strings. This class calls methods on that higer-level interface.
+ *
+ * * <p><i>This is the AspectJ version.</i><p>
*
* For this pattern, both Java and AspectJ implementations are identical.
- * The pattern introduces no crosscutting and is not abstractable. The
- * java implementation is not duplicated here: All this class does is to
- * print a message explaining that the versions are identical.
+ * The pattern introduces no crosscutting and is not abstractable. However,
+ * this example illustrates that AspectJ can be used to enforce the facade's
+ * encapsulation of the subsystem in question. Both <code>declare warning
+ * </code> and <code>declare error</code> can be used to that effect.
*
* @author Jan Hannemann
* @author Gregor Kiczales
- * @version 1.1, 02/11/04
+ * @version 1.11, 03/29/04
*/
public class Main {
- public static void main(String[] args) {
- System.out.println("For this pattern, the AspectJ implementation ");
- System.out.println("is identical to the Java implementation. It is ");
- System.out.println("not duplicated here. ");
- }
+ /**
+ * Tests the higher-level interface of <code>OutputFacade</code>.
+ *
+ * @param args Command-line parameters, ignored here
+ */
+
+ public static void main(String[] args) {
+ OutputFacade facade = new OutputFacade();
+
+ System.out.println("Testing regular Facade access...");
+ facade.printDecoration();
+
+ facade.printNormal("Facade: this is normal printing");
+ facade.printFancy ("Facade: this is fancy printing");
+
+ System.out.println("\nCircumventing Facade encapsulation...");
+
+ // Note that the compiler warning caused by the next line is
+ // intentional. See FacadePolicyEnforcement for details.
+ RegularScreen.print("It works, but should create a compiler warning");
+ System.out.println();
+ }
} \ No newline at end of file
diff --git a/docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/facade/aspectj/OutputFacade.java b/docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/facade/aspectj/OutputFacade.java
new file mode 100644
index 000000000..676e9e27b
--- /dev/null
+++ b/docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/facade/aspectj/OutputFacade.java
@@ -0,0 +1,79 @@
+package ca.ubc.cs.spl.aspectPatterns.examples.facade.aspectj;
+
+/* -*- Mode: Java; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*-
+ *
+ * This file is part of the design patterns project at UBC
+ *
+ * The contents of this file are subject to the Mozilla Public License
+ * Version 1.1 (the "License"); you may not use this file except in
+ * compliance with the License. You may obtain a copy of the License at
+ * either http://www.mozilla.org/MPL/ or http://aspectj.org/MPL/.
+ *
+ * Software distributed under the License is distributed on an "AS IS" basis,
+ * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
+ * for the specific language governing rights and limitations under the
+ * License.
+ *
+ * The Original Code is ca.ubc.cs.spl.aspectPatterns.
+ *
+ * For more details and the latest version of this code, please see:
+ * http://www.cs.ubc.ca/labs/spl/projects/aodps.html
+ *
+ * Contributor(s):
+ */
+
+/**
+ * Implements the <i>Facade</i> role in the pattern by providing a
+ * higher-level interface to the operations provided by
+ * <code>RegularScreen</code>, <code>Decoration</code>,
+ * and <code>StringTransformer</code>.
+ *
+ * @author Jan Hannemann
+ * @author Gregor Kiczales
+ * @version 1.11, 03/29/04
+ */
+
+public class OutputFacade {
+
+ /**
+ * Prints a string using <code>RegularScreen</code>.
+ *
+ * @param s the string to print
+ */
+
+ public void printNormal(String s) {
+ RegularScreen.print(s);
+ RegularScreen.newline();
+ }
+
+ /**
+ * Prints a two versions of string with decorations
+ * using <code>RegularScreen</code> and <code>Decoration</code>.
+ *
+ * @param s the string to print
+ */
+
+ public void printFancy(String s) {
+ printDecoration();
+
+ RegularScreen.print(StringTransformer.transformToUpper(s+" (uppercase)"));
+ RegularScreen.newline();
+
+ printDecoration();
+
+ RegularScreen.print(StringTransformer.transformToLower(s+" (lowercase)"));
+ RegularScreen.newline();
+
+ printDecoration();
+ }
+
+ /**
+ * Prints a decorator string.
+ */
+
+ public void printDecoration() {
+ RegularScreen.print(Decoration.getDecoration());
+ RegularScreen.newline();
+ RegularScreen.newline();
+ }
+} \ No newline at end of file
diff --git a/docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/facade/aspectj/RegularScreen.java b/docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/facade/aspectj/RegularScreen.java
new file mode 100644
index 000000000..bbd623afe
--- /dev/null
+++ b/docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/facade/aspectj/RegularScreen.java
@@ -0,0 +1,52 @@
+package ca.ubc.cs.spl.aspectPatterns.examples.facade.aspectj;
+
+/* -*- Mode: Java; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*-
+ *
+ * This file is part of the design patterns project at UBC
+ *
+ * The contents of this file are subject to the Mozilla Public License
+ * Version 1.1 (the "License"); you may not use this file except in
+ * compliance with the License. You may obtain a copy of the License at
+ * either http://www.mozilla.org/MPL/ or http://aspectj.org/MPL/.
+ *
+ * Software distributed under the License is distributed on an "AS IS" basis,
+ * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
+ * for the specific language governing rights and limitations under the
+ * License.
+ *
+ * The Original Code is ca.ubc.cs.spl.aspectPatterns.
+ *
+ * For more details and the latest version of this code, please see:
+ * http://www.cs.ubc.ca/labs/spl/projects/aodps.html
+ *
+ * Contributor(s):
+ */
+
+/**
+ * Implements a low-level interface for printing to System.out.
+ *
+ * @author Jan Hannemann
+ * @author Gregor Kiczales
+ * @version 1.11, 03/29/04
+ */
+
+public class RegularScreen {
+
+ /**
+ * Prints a string to System.out.
+ *
+ * @param s the string to print
+ */
+
+ public static void print(String s) {
+ System.out.print(s);
+ }
+
+ /**
+ * Prints a newline to System.out.
+ */
+
+ public static void newline() {
+ System.out.println();
+ }
+} \ No newline at end of file
diff --git a/docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/facade/aspectj/StringTransformer.java b/docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/facade/aspectj/StringTransformer.java
new file mode 100644
index 000000000..a1f5eafba
--- /dev/null
+++ b/docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/facade/aspectj/StringTransformer.java
@@ -0,0 +1,56 @@
+package ca.ubc.cs.spl.aspectPatterns.examples.facade.aspectj;
+
+/* -*- Mode: Java; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*-
+ *
+ * This file is part of the design patterns project at UBC
+ *
+ * The contents of this file are subject to the Mozilla Public License
+ * Version 1.1 (the "License"); you may not use this file except in
+ * compliance with the License. You may obtain a copy of the License at
+ * either http://www.mozilla.org/MPL/ or http://aspectj.org/MPL/.
+ *
+ * Software distributed under the License is distributed on an "AS IS" basis,
+ * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
+ * for the specific language governing rights and limitations under the
+ * License.
+ *
+ * The Original Code is ca.ubc.cs.spl.aspectPatterns.
+ *
+ * For more details and the latest version of this code, please see:
+ * http://www.cs.ubc.ca/labs/spl/projects/aodps.html
+ *
+ * Contributor(s):
+ */
+
+/**
+ * Implements basic string manipulation facilities.
+ *
+ * @author Jan Hannemann
+ * @author Gregor Kiczales
+ * @version 1.11, 03/29/04
+ */
+
+public class StringTransformer {
+
+ /**
+ * Transforms a string to upper case
+ *
+ * @param s the string to transform
+ * @returns the transformed string
+ */
+
+ public static String transformToUpper(String s) {
+ return s.toUpperCase();
+ }
+
+ /**
+ * Transforms a string to lower case
+ *
+ * @param s the string to transform
+ * @returns the transformed string
+ */
+
+ public static String transformToLower(String s) {
+ return s.toLowerCase();
+ }
+} \ No newline at end of file
diff --git a/docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/facade/java/Main.java b/docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/facade/java/Main.java
index 471babb90..36d7c0b4c 100644
--- a/docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/facade/java/Main.java
+++ b/docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/facade/java/Main.java
@@ -39,13 +39,15 @@ package ca.ubc.cs.spl.aspectPatterns.examples.facade.java;
*
* @author Jan Hannemann
* @author Gregor Kiczales
- * @version 1.1, 02/11/04
+ * @version 1.11, 04/29/04
*/
public class Main {
/**
* Tests the higher-level interface of <code>OutputFacade</code>.
+ *
+ * @param args Command-line parameters, ignored here
*/
public static void main(String[] args) {
diff --git a/docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/factoryMethod/aspectj/AlternateLabelCreatorImplementation.java b/docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/factoryMethod/aspectj/AlternateLabelCreatorImplementation.java
new file mode 100644
index 000000000..d8966e882
--- /dev/null
+++ b/docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/factoryMethod/aspectj/AlternateLabelCreatorImplementation.java
@@ -0,0 +1,62 @@
+package ca.ubc.cs.spl.aspectPatterns.examples.factoryMethod.aspectj;
+
+/* -*- Mode: Java; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*-
+ *
+ * This file is part of the design patterns project at UBC
+ *
+ * The contents of this file are subject to the Mozilla Public License
+ * Version 1.1 (the "License"); you may not use this file except in
+ * compliance with the License. You may obtain a copy of the License at
+ * either http://www.mozilla.org/MPL/ or http://aspectj.org/MPL/.
+ *
+ * Software distributed under the License is distributed on an "AS IS" basis,
+ * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
+ * for the specific language governing rights and limitations under the
+ * License.
+ *
+ * The Original Code is ca.ubc.cs.spl.aspectPatterns.
+ *
+ * For more details and the latest version of this code, please see:
+ * http://www.cs.ubc.ca/labs/spl/projects/aodps.html
+ *
+ * Contributor(s):
+ */
+
+import javax.swing.JLabel;
+import javax.swing.JComponent;
+/**
+ * This aspect changes the behavior of a <i>Factory Method</i> using
+ * <code>around</code> advice. With this approach it is possible to
+ * have the factories create different products depending on the
+ * aspects woven into the project. For example, this could be used
+ * as a very basic approach to software configuration management.
+ *
+ * In this case, two slightly different label products are produced,
+ * depending on whether this aspect is woven into the system or not.
+ *
+ * @author Jan Hannemann
+ * @author Gregor Kiczales
+ * @version 1.11, 04/01/04
+ */
+
+public aspect AlternateLabelCreatorImplementation {
+
+ /**
+ * Describes the factory method for which we want to
+ * modify the product
+ */
+
+ pointcut labelCreation():
+ execution(JComponent LabelCreator.createComponent());
+
+ /**
+ * Creates the product, modifies it and passes the
+ * modified product on.
+ */
+
+ JComponent around(): labelCreation() {
+ JLabel label = (JLabel) proceed();
+ label.setText("This is an alternate JLabel");
+ return label;
+ }
+} \ No newline at end of file
diff --git a/docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/factoryMethod/aspectj/CreatorImplementation.java b/docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/factoryMethod/aspectj/CreatorImplementation.java
index 0e3692e72..0b8669cfc 100644
--- a/docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/factoryMethod/aspectj/CreatorImplementation.java
+++ b/docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/factoryMethod/aspectj/CreatorImplementation.java
@@ -34,6 +34,7 @@ import java.awt.Point;
* method <code>showFrame()</code>. The implementation is attached to the
* <code>GUIComponentCreator</code> interface. With this approach,
* <i>GUIComponentCreator</i> does not have to be an abstract class.
+ *
*
* @author Jan Hannemann
* @author Gregor Kiczales
diff --git a/docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/observer/aspectj/ColorObserver.java b/docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/observer/aspectj/ColorObserver.java
index 5f06c7070..44af56c27 100644
--- a/docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/observer/aspectj/ColorObserver.java
+++ b/docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/observer/aspectj/ColorObserver.java
@@ -31,7 +31,7 @@ import ca.ubc.cs.spl.aspectPatterns.patternLibrary.ObserverProtocol;
*
* @author Jan Hannemann
* @author Gregor Kiczales
- * @version 1.1, 02/13/04
+ * @version 1.11, 04/01/04
*/
public aspect ColorObserver extends ObserverProtocol{
diff --git a/docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/observer/aspectj/CoordinateObserver.java b/docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/observer/aspectj/CoordinateObserver.java
index 5b843e4ad..ea5c9635c 100644
--- a/docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/observer/aspectj/CoordinateObserver.java
+++ b/docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/observer/aspectj/CoordinateObserver.java
@@ -30,7 +30,7 @@ import ca.ubc.cs.spl.aspectPatterns.patternLibrary.ObserverProtocol;
*
* @author Jan Hannemann
* @author Gregor Kiczales
- * @version 1.1, 02/13/04
+ * @version 1.11, 04/01/04
*/
public aspect CoordinateObserver extends ObserverProtocol{
diff --git a/docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/observer/aspectj/Main.java b/docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/observer/aspectj/Main.java
index ee36569a7..1e57db172 100644
--- a/docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/observer/aspectj/Main.java
+++ b/docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/observer/aspectj/Main.java
@@ -50,7 +50,7 @@ import java.awt.Color;
*
* @author Jan Hannemann
* @author Gregor Kiczales
- * @version 1.1, 02/13/04
+ * @version 1.11, 04/01/04
*/
public class Main {
diff --git a/docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/observer/aspectj/Point.java b/docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/observer/aspectj/Point.java
index 908dc6d3e..0709e59e5 100644
--- a/docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/observer/aspectj/Point.java
+++ b/docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/observer/aspectj/Point.java
@@ -29,7 +29,7 @@ import java.awt.Color;
*
* @author Jan Hannemann
* @author Gregor Kiczales
- * @version 1.1, 02/13/04
+ * @version 1.11, 04/01/04
*/
public class Point {
@@ -68,7 +68,9 @@ public class Point {
* @return the current x-coordinate
*/
- public int getX() { return x; }
+ public int getX() {
+ return x;
+ }
/**
* Returns the point's current y-coordinate.
@@ -76,7 +78,9 @@ public class Point {
* @return the current y-coordinate
*/
- public int getY() { return y; }
+ public int getY() {
+ return y;
+ }
/**
* Sets the current x-coordinate.
@@ -84,7 +88,9 @@ public class Point {
* @param x the new x-coordinate
*/
- public void setX(int x) { this.x=x; }
+ public void setX(int x) {
+ this.x = x;
+ }
/**
* Sets the current y-coordinate.
@@ -92,7 +98,9 @@ public class Point {
* @param y the new y-coordinate
*/
- public void setY(int y) { this.y=y; }
+ public void setY(int y) {
+ this.y = y;
+ }
/**
* Returns the point's current color.
@@ -100,7 +108,9 @@ public class Point {
* @return the current color
*/
- public Color getColor() { return color; }
+ public Color getColor() {
+ return color;
+ }
/**
* Sets the current color.
@@ -108,5 +118,7 @@ public class Point {
* @param color the new color
*/
- public void setColor(Color color) { this.color=color; }
+ public void setColor(Color color) {
+ this.color=color;
+ }
}
diff --git a/docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/observer/aspectj/Screen.java b/docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/observer/aspectj/Screen.java
index bad74f3fa..13c1bd9bc 100644
--- a/docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/observer/aspectj/Screen.java
+++ b/docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/observer/aspectj/Screen.java
@@ -28,7 +28,7 @@ package ca.ubc.cs.spl.aspectPatterns.examples.observer.aspectj;
*
* @author Jan Hannemann
* @author Gregor Kiczales
- * @version 1.1, 02/13/04
+ * @version 1.11, 04/01/04
*/
public class Screen {
diff --git a/docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/observer/aspectj/ScreenObserver.java b/docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/observer/aspectj/ScreenObserver.java
index ce5405797..1ee361928 100644
--- a/docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/observer/aspectj/ScreenObserver.java
+++ b/docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/observer/aspectj/ScreenObserver.java
@@ -31,7 +31,7 @@ import ca.ubc.cs.spl.aspectPatterns.patternLibrary.ObserverProtocol;
*
* @author Jan Hannemann
* @author Gregor Kiczales
- * @version 1.1, 02/13/04
+ * @version 1.11, 04/01/04
*/
public aspect ScreenObserver extends ObserverProtocol{
diff --git a/docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/observer/java/ChangeObserver.java b/docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/observer/java/ChangeObserver.java
index 073156b72..21a7d58ff 100644
--- a/docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/observer/java/ChangeObserver.java
+++ b/docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/observer/java/ChangeObserver.java
@@ -27,7 +27,7 @@ package ca.ubc.cs.spl.aspectPatterns.examples.observer.java;
*
* @author Jan Hannemann
* @author Gregor Kiczales
- * @version 1.1, 02/13/04
+ * @version 1.11, 04/01/04
*/
public interface ChangeObserver {
@@ -39,5 +39,5 @@ public interface ChangeObserver {
* @param s the <i>Subject</i> triggering the update
*/
- public void update(ChangeSubject s);
+ public void refresh(ChangeSubject s);
} \ No newline at end of file
diff --git a/docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/observer/java/ChangeSubject.java b/docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/observer/java/ChangeSubject.java
index 60fb491b8..221cb53a0 100644
--- a/docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/observer/java/ChangeSubject.java
+++ b/docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/observer/java/ChangeSubject.java
@@ -28,7 +28,7 @@ package ca.ubc.cs.spl.aspectPatterns.examples.observer.java;
*
* @author Jan Hannemann
* @author Gregor Kiczales
- * @version 1.1, 02/13/04
+ * @version 1.11, 04/01/04
*/
public interface ChangeSubject {
@@ -36,18 +36,18 @@ public interface ChangeSubject {
/**
* Attaches an <i>Observer</i> to this <i>Subject</i>.
*
- * @param o the <i>Observer</i> to attach
+ * @param o the <i>Observer</i> to add
*/
- public void attach(ChangeObserver o);
+ public void addObserver(ChangeObserver o);
/**
* Detaches an <i>Observer</i> from this <i>Subject</i>.
*
- * @param o the <i>Observer</i> to detach
+ * @param o the <i>Observer</i> to remove
*/
- public void detach(ChangeObserver o);
+ public void removeObserver(ChangeObserver o);
/**
* Notifies all <i>Observer</i>s.
diff --git a/docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/observer/java/Main.java b/docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/observer/java/Main.java
index fbd1bc0a3..8cfac7b4b 100644
--- a/docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/observer/java/Main.java
+++ b/docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/observer/java/Main.java
@@ -75,12 +75,7 @@ import java.awt.Color;
*
* @author Jan Hannemann
* @author Gregor Kiczales
- * @version 1.1, 02/13/04
- *
- * @see Point
- * @see Adaptee
- * @see Observer
- * @see Subject
+ * @version 1.11, 04/01/04
*/
public class Main {
@@ -119,14 +114,14 @@ public class Main {
System.out.println("- s3 and s4 observe coordinate changes to p");
System.out.println("- s5 observes s2's and s4's display() method");
- p.attach(s1);
- p.attach(s2);
+ p.addObserver(s1);
+ p.addObserver(s2);
- p.attach(s3);
- p.attach(s4);
+ p.addObserver(s3);
+ p.addObserver(s4);
- s2.attach(s5);
- s4.attach(s5);
+ s2.addObserver(s5);
+ s4.addObserver(s5);
System.out.println("Changing p's color:");
diff --git a/docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/observer/java/Point.java b/docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/observer/java/Point.java
index 94060fce1..2a4322bb3 100644
--- a/docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/observer/java/Point.java
+++ b/docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/observer/java/Point.java
@@ -31,7 +31,7 @@ import java.util.Iterator;
*
* @author Jan Hannemann
* @author Gregor Kiczales
- * @version 1.1, 02/13/04
+ * @version 1.11, 04/01/04
*/
public class Point implements ChangeSubject {
@@ -65,8 +65,8 @@ public class Point implements ChangeSubject {
*/
public Point(int x, int y, Color color) {
- this.x=x;
- this.y=y;
+ this.x = x;
+ this.y = y;
this.color=color;
this.observers = new HashSet();
}
@@ -77,7 +77,9 @@ public class Point implements ChangeSubject {
* @return the current x-coordinate
*/
- public int getX() { return x; }
+ public int getX() {
+ return x;
+ }
/**
* Returns the point's current y-coordinate.
@@ -85,7 +87,9 @@ public class Point implements ChangeSubject {
* @return the current y-coordinate
*/
- public int getY() { return y; }
+ public int getY() {
+ return y;
+ }
/**
* Sets the current x-coordinate.
@@ -94,7 +98,7 @@ public class Point implements ChangeSubject {
*/
public void setX(int x) {
- this.x=x;
+ this.x = x;
notifyObservers();
}
@@ -105,7 +109,7 @@ public class Point implements ChangeSubject {
*/
public void setY(int y) {
- this.y=y;
+ this.y = y;
notifyObservers();
}
@@ -124,7 +128,7 @@ public class Point implements ChangeSubject {
*/
public void setColor(Color color) {
- this.color=color;
+ this.color = color;
notifyObservers();
}
@@ -135,7 +139,7 @@ public class Point implements ChangeSubject {
* @param o the <i>Observer</i> to attach
*/
- public void attach(ChangeObserver o) {
+ public void addObserver(ChangeObserver o) {
this.observers.add(o);
}
@@ -145,7 +149,7 @@ public class Point implements ChangeSubject {
* @param o the <i>Observer</i> to detach
*/
- public void detach(ChangeObserver o) {
+ public void removeObserver(ChangeObserver o) {
this.observers.remove(o);
}
@@ -155,7 +159,7 @@ public class Point implements ChangeSubject {
public void notifyObservers() {
for (Iterator e = observers.iterator() ; e.hasNext() ;) {
- ((ChangeObserver)e.next()).update(this);
+ ((ChangeObserver)e.next()).refresh(this);
}
}
}
diff --git a/docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/observer/java/Screen.java b/docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/observer/java/Screen.java
index 9259d01a7..1860b477b 100644
--- a/docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/observer/java/Screen.java
+++ b/docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/examples/observer/java/Screen.java
@@ -31,7 +31,7 @@ import java.util.Iterator;
*
* @author Jan Hannemann
* @author Gregor Kiczales
- * @version 1.1, 02/13/04
+ * @version 1.11, 04/01/04
*/
public class Screen implements ChangeSubject, ChangeObserver {
@@ -79,7 +79,7 @@ public class Screen implements ChangeSubject, ChangeObserver {
* @param o the <i>Observer</i> to attach
*/
- public void attach(ChangeObserver o) {
+ public void addObserver(ChangeObserver o) {
this.observers.add(o);
}
@@ -89,7 +89,7 @@ public class Screen implements ChangeSubject, ChangeObserver {
* @param o the <i>Observer</i> to detach
*/
- public void detach(ChangeObserver o) {
+ public void removeObserver(ChangeObserver o) {
this.observers.remove(o);
}
@@ -99,7 +99,7 @@ public class Screen implements ChangeSubject, ChangeObserver {
public void notifyObservers() {
for (Iterator e = observers.iterator() ; e.hasNext() ;) {
- ((ChangeObserver)e.next()).update(this);
+ ((ChangeObserver)e.next()).refresh(this);
}
}
@@ -113,7 +113,7 @@ public class Screen implements ChangeSubject, ChangeObserver {
* @param s the <i>Subject</i> triggering the update
*/
- public void update(ChangeSubject s) {
+ public void refresh(ChangeSubject s) {
String subjectTypeName = s.getClass().getName();
subjectTypeName = subjectTypeName.substring(
subjectTypeName.lastIndexOf(".")+1, subjectTypeName.length());
diff --git a/docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/patternLibrary/StrategyProtocol.java b/docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/patternLibrary/StrategyProtocol.java
index 8ce60f4fc..0e3291460 100644
--- a/docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/patternLibrary/StrategyProtocol.java
+++ b/docs/sandbox/ubc-design-patterns/src/ca/ubc/cs/spl/aspectPatterns/patternLibrary/StrategyProtocol.java
@@ -32,7 +32,7 @@ import java.util.Hashtable;
* given <i>Context</i>.
*
* It is also possible (although not shown here) to provide abstract
- * pointcust for setting or removing <i>Strategy</i>s from
+ * pointcuts for setting or removing <i>Strategy</i>s from
* <i>Context</>s. This would allow <i>Client</i> implementations
* to be free of pattern code. For an example of how to do that,
* see the implementation of the abstract CommandProtocol aspect.