Title: Adaptive AspectOriented Programming in AspectJ
1Adaptive Aspect-Oriented Programming in AspectJ
- Karl J. Lieberherr
- Northeastern University
- Joint work of Demeter Research Group
2Overview
- What is adaptive programming?
- Examples in AspectJ. What is behind adaptiveness
in AspectJ? - Why we need more adaptiveness in AspectJ.
- DAJ a simple adaptive add-on to AspectJ.
- Abstraction behind more adaptiveness
- LoD in AspectJ (adapts to any Java program)
- Conclusions
3Adaptive?
- A program is adaptive if it changes its behavior
according to its context. - Adaptive programs Concurrency policy,
Distribution policy, Logging Aspect, Adaptive
Method, Law of Demeter Checker in AspectJ - Possible contexts
- Java program or its execution tree
- UML class diagram or object diagram
4What is the role of adaptive features in AOP
- They become increasingly more important as AOP is
applied to larger problems. - Encapsulating an aspect without abstracting over
the relevant join points leads to brittle code. - AspectJ has many adaptive features but more is
needed.
5Adaptive Aspects
AspectJ team slide
abstract public aspect RemoteExceptionLogging
abstract pointcut logPoint() after()
throwing (RemoteException e) logPoint()
log.println(Remote call failed in
thisJoinPoint.toString()
( e ).)
abstract
public aspect MyRMILogging extends
RemoteExceptionLogging pointcut logPoint()
call( RegistryServer..(..))
call(private RMIMessageBrokerImpl..(..))
6A Different Kind of Adaptive Aspect
AspectJ team slide
abstract aspect CapabilityChecking pointcut
invocations(Caller c) this(c) call(void
Service.doService(String)) pointcut
workPoints(Worker w) target(w) call(void
Worker.doTask(Task)) pointcut
perCallerWork(Caller c, Worker w)
cflow(invocations(c)) workPoints(w) before
(Caller c, Worker w) perCallerWork(c, w)
w.checkCapabilities(c)
7A more complex adaptive aspectLaw of Demeter
Checker (Object Form)
- aspect Check
- after() Any.MethodCall
- // call ( (..))
- // check whether
- // thisJoinPoint.getTarget()
- // is a preferred supplier
- // object
8Observation 1
- Many AspectJ programs are adaptive (designed for
a family of Java programs) - Context Java program or its execution tree
(lexical joinpoints or dynamic join points) - Features enabling adaptiveness
- , .. (wildcards)
- cflow, (graph transitivity)
- this(s), target(s), args(a), call (),
(inheritance as wild card) - pc(Object s, Object t)
- this(s) target(t) call( f )
9Observation 2
- Want to improve the adaptive capabilities of
AspectJ AspectJ still leads to tangling and
duplication.
10Overview
- What is adaptive programming?
- Examples in AspectJ. What is behind adaptiveness
in AspectJ? - Why we need more adaptiveness in AspectJ.
- DAJ a simple adaptive add-on to AspectJ.
- Abstraction behind more adaptiveness
- LoD in AspectJ
- Conclusions
11Listing files in a FileSystem
f
root
FileName
FileSystem
CompoundFile
contents
first
File_PList
NonEmpty_File_PList
next
it
CompoundFile
parent
f
contents
12- public aspect FileSystemTraversals
- public void CompoundFile.listAll()
- FileLister v new FileLister()
- eachFile(v)
- void CompoundFile.eachFile()
- if (contents ! null)
- eachFile_crossing_contents(newTokens)
-
- void CompoundFile.
- eachFile_crossing_contents()
- this.contents.eachFile(tokens)
-
- // much more
13Example of an Adaptive Method in AspectJ (DAJ)
- aspect FileSystemTraversals
- declare traversal
- void listAll()
- "from CompoundFile to File"
- (FileLister)
-
14http//daj.sourceforge.net/
- DAJ gives you
- the power of AspectJ and
- the beauty of DJ and
- the convenience of DemeterJ
- all at once without having to learn a new
programming language other than AspectJ and a
schema notation (Java Data Binding) .
15Another Adaptive Method
- aspect FileSystemTraversals
- declare strategy eachFile
- "intersect(from CompoundFile to File,
- down)"
- declare traversal void listAll()
- eachFile(FileLister)
- declare strategy down "from
- bypassing -gt ,parent, to "
-
16What To Do
High-level AspectJ advice using dynamic join
points!
- class FileLister
- Stack path new Stack()
- void before(File file)
- path.push(file.name)
- void after(File file)
- System.out.print(" .")
- Iterator it path.iterator() it.next()
- while (it.hasNext())
- System.out.print("/" it.next())
- System.out.println()
- path.pop()
-
17Ordinary Java Class
- class Main
- public static void main(String args)
- FileSystem fs FileSystem.parse(new
File(args0)) - Commands script Commands.parse(new
File(args1)) - script.interpret(fs.root)
- System.out.println(" Status of File System
") - fs.root.listAll()
-
-
18Domain-specific aspect languages
- What is a good infrastructure for this?
- Goes back to the theme of Crista domain-specific
aspect languages.
19DAJ
- What is new for the AspectJ programmer
- Two additional declarations
- declare strategy including intersection
- declare traversal
- Object structure and language aspect
- class dictionary files
20range of AOP languages
means of join points
JPM
join points
identifying
specifying semantics at
AspectJ dynamic JPM
points in execution call, get, set
signaturesw/ wildcards other properties of JPs
advice
add members
signatures
class members
static JPM
- DemeterJ, DAJ
- dynamic JPM
- static JPM 1
- static JPM 2
-
- static JPM 3
when traversal reaches object or edge class
members class members class members
visitor method signatures traversal spec. s class
graph g class names class graph
visitor method bodies s g (result traversal
implementation) add members class graph with
tokensgrammar (result parsing and printing
implementation)
21Overview
- What is adaptive programming?
- Examples in AspectJ. What is behind adaptiveness
in AspectJ? - Why we need more adaptiveness in AspectJ.
- DAJ a simple adaptive add-on to AspectJ.
- Abstraction behind more adaptiveness
- LoD in AspectJ
- Conclusions
22A General Graph-based Adaptive Mechanism
- Three layers of graphs Bottom, Middle, Top
- Bottom layer trees to select subtrees guided by
top layer. Each bottom layer tree has a graph
from the - Middle layer associated with it that contains
meta-information about the bottom layer tree.
Acts as an abstraction barrier between the top
and bottom layers. Used to reduce search space. - Top layer graph is basically a subgraph of the
transitive closure of the middle layer graph,
decorated with additional information attached to
the edges.
23Top graph subgraph of transitive closure of
middle layer
B
A
C
Middle graph Abstraction barrier
B
A
C
Bottom tree select subtrees
B
c1C c2C c3C
A
24Graph-based adaptiveness
- The call graph application (AspectJ)
- Top computational pattern,
- Middle static call graph,
- Bottom call tree.
- The standard application (Demeter)
- Top strategy graph,
- Middle class graph,
- Bottom object trees.
25Call graph example
jp_lock call(R.lock()) jp_write
call(R.write()) jp_unlock call(R.unlock()) jp_re
ad call(R.read()) jps1 from jp_start to
jp_lock, jp_write, jp_unlock, jp_read jps2
from jp_start bypassing jp_lock,
jp_write, jp_unlock, jp_read to
jp_lock, jp_write, jp_unlock, jp_read jps1
jps2.
26Overview
- What is adaptive programming?
- Examples in AspectJ. What is behind adaptiveness
in AspectJ? - Why we need more adaptiveness in AspectJ.
- DAJ a simple adaptive add-on to AspectJ.
- Abstraction behind more adaptiveness
- LoD in AspectJ
- Conclusions
27Aspects and lexical join points
- Going to the roots of the Northeastern branch of
AOP Law of Demeter. - Closing the circle Write an ultimately adaptive
program in AspectJ - Works with all Java programs
- Checks the object-form of the Law of Demeter
talk only to your friends
28Instrumentation of Java programs with Aspects
Aspect framework
Aspect Diagram
Supplier
ImmediatePartBin
TargetBinStack
ArgumentBin
Checker
LocallyConstructedBin
uses pointcuts
ReturnValueBin
Requirements
Statistics
GlobalPreferredBin
Good Separation of Concerns in Law of Demeter
Checker
29Explanation
- The bin aspects collect potential preferred
supplier objects that represent good coupling in
the context of a method body. - The Checker aspect checks each method call
whether the receiver is a preferred supplier
object. - The Statistics aspect counts events generated by
the Checker aspect.
30Law of Demeter(Join Point Form)
- JPT(ID)
- lttargetgt ID
- ltargsgt List(ID)
- ltchildrengt List(JPT)
- ltretgt ID.
- List(S) S.
31JPT(ID) lttargetgt ID ltargsgt List(ID)
ltchildrengt List(JPT) ltretgt ID. List(S) S.
E
target t2 args a1,a2
target t2 ret r1
J r1.foo1() a1.bar() t2.foo2() r3.foo2()
target null ret r3
32Generic Law of Demeter(Join Point Form)
- Definition 1 The LoD_JPF requires that for each
join point J, target(J) is a potential preferred
supplier of J. - Definition 2 The set of potential preferred
suppliers to a join point J, child to the
enclosing join point E, is the union of the
objects in the following sets
33Generic Law of Demeter(Join Point Form)
- Argument rule the args of the enclosing join
point E, including the target - Associated rule the associated values of E the
ret values of the children of E before J whose
target is the target of E or whose target is null.
34aspect LoD extends Violation pointcut
LoD_JPF() //LoD definition ArgumentRule()
AssociatedRule() pointcut ArgumentRule()
if(thisEnclosingJoinPoint.getArgs()
.contains(thisJoinPoint.getTarget()) pointcut
AssociatedRule() if(thisEnclosingJoinPoint
.hasSelfishChild(thisJoinPoint
.getTarget()))
35Pseudo Aspect
- LoD is a pseudo'' aspect because it cannot run
in the current implementation of AspectJ, which
doesn't allow declare warning to be defined on
any pointcut with an if expression.
36Join Point Form
- The pointcuts ArgumentRule and AssociatedRule
select the good'' join points. - ArgumentRule selects those join points whose
target is one of the arguments of the enclosing
join point
37Join Point Form
- AssociatedRule selects those join points whose
target is in the set of locally returned ID's,
and the ID's created in the siblings of the
current node.
38Map Dynamic Object Form (DOF) to LoD_JPF
- We use LoD_JPF pointcut to check DOF
- Dynamic join point model is mapped to JPT.
- Object is mapped to ID.
- Method invocations are mapped to JPF join points.
The enclosing join point is the parent in the
control flow.
39Map Lexical Class Form (LCF) to LoD_JPF
- We use LoD_JPF to check LCF as follows.
- Lexical join point model is mapped to JPT.
Lexical join points are nodes in the abstract
syntax tree - Class is mapped to ID.
- Join points are signatures of call sites. The
enclosing join point is the signature of the
method in which the call site resides. To run
the aspect, a suitable ordering has to be given
to the elements of children - all constructor calls, followed by local method
calls, followed by the other join points.
40AspectJ code
- In AOSD 2003 paper with David Lorenz and
Pengcheng Wu - DOF AspectJ works well. Program uses most
adaptive ingredients of AspectJ , cflow, this,
target, etc. - LCF AspectJ cannot do it. We sketch how to add
statically executable advice to AspectJ.
41package lawOfDemeter public abstract class Any
public pointcut scope() !within(lawOfDemeter.
.) !cflow(withincode( lawOfDemeter..(..)
)) public pointcut StaticInitialization()
scope() staticinitialization() public
pointcut MethodCallSite() scope() call(
(..)) public pointcut ConstructorCall()
scope() call(.new (..)) public
pointcut MethodExecution() scope()
execution( (..)) public pointcut
ConstructorExecution() scope()
execution(.new (..)) public pointcut
Execution() ConstructorExecution()
MethodExecution() public pointcut
MethodCall(Object thiz, Object target)
MethodCallSite() this(thiz)
target(target)
42Class Any continued
public pointcut SelfCall(Object thiz,
Object target) MethodCall(thiz, target)
if(thiz target) public pointcut
StaticCall() scope() call(static
(..)) public pointcut Set(Object value)
scope() set( .) args(value)
public pointcut Initialization() scope()
initialization(.new(..))
43package lawOfDemeter.objectform import
java.util. abstract class ObjectSupplier
protected boolean containsValue(Object
supplier) return targets.containsValue(suppli
er) protected void add(Object key,Object
value) targets.put(key,value)
protected void addValue(Object supplier)
add(supplier,supplier) protected void
addAll(Object suppliers) for(int i0 ilt
suppliers.length i) addValue(suppliersi
) private IdentityHashMap targets
new IdentityHashMap()
44package lawOfDemeter.objectform public aspect
Pertarget extends ObjectSupplier
pertarget(Any.Initialization()) before(Object
value) Any.Set(value) add(fieldIdentity(thi
sJoinPointStaticPart), value) public
boolean contains(Object target) return
super.containsValue(target)
Percflow.aspectOf().containsValue(target)
private String fieldIdentity(JoinPoint.StaticPart
sp) private static HashMap fieldNames
new HashMap()
45package lawOfDemeter.objectform aspect Check
private pointcut IgnoreCalls() call(
java...(..)) private pointcut
IgnoreTargets() get(static java...)
after() returning(Object o)IgnoreTargets()
ignoredTargets.put(o,o) after(Object
thiz,Object target) Any.MethodCall(thiz,
target) !IgnoreCalls() if
(!ignoredTargets.containsKey(target)
!Pertarget.aspectOf(thiz).contains(target))
System.out.println( " !! LoD Object
Violation !! " thisJoinPointStaticPart/
/ at(thisJoinPointStaticPart)//)
private IdentityHashMap ignoredTargets
new IdentityHashMap()
46package lawOfDemeter.objectform aspect Percflow
extends ObjectSupplier percflow(Any.Execution()
Any.Initialization()) before()
Any.Execution() addValue(thisJoinPoint.get
This()) addAll(thisJoinPoint.getArgs())
after() returning (Object result)
Any.SelfCall(Object,Object)
Any.StaticCall() Any.ConstructorCall()
addValue(result)
47Conclusions
- Aspects and adaptiveness must work closely
together to achieve best results. Crosscutting is
closely linked to adaptiveness. - AspectJ and DemeterJ have been very well
integrated (DAJ on Source Forge). - AP is a specialization of AOP and AOP is a
specialization of AP. It goes both ways. - AspectJ is a really useful language but we are a
little concerned about how difficult it was to
debug the Law of Demeter checkers.
482003 Boston, MA
49A
O
S
D
2003 Boston, MA
50City ltroutesgt List(BusRoute) ltflightsgt
List(Flight). BusRoute ltcitiesgt
List(City). Flight ltcitiesgt List(City). City
routes BusRoute cities City (routes BusRoute
cities City) City -gt BusRoute bypassing
City BusRoute -gt City bypassing City source
City target City
51Ordinary Java Class
- class Main
- public static void main(String args)
- FileSystem fs FileSystem.parse(new
File(args0)) - Commands script Commands.parse(new
File(args1)) - script.interpret(fs.root)
- System.out.println(" Status of File System
") - fs.root.listAll()
-
-
52Domain-specific aspect languages
- What is a good infrastructure for this?
- Goes back to the old theme of Crista
domain-specific aspect languages.
53Aspect-Oriented Programmingwith Extensible
Plugins
- How can we integrate numerous domain specific
aspect languages? - Idea Use AspectJ as basic aspect language and
translate domain specific aspect languages to
AspectJ. - Case study Redo DAJ in this style.
- Macneil.Shonle_at_Sun.COM
54Interfaces of Aspects
- For functionality
- Expects
- Provides
- For join points
- Import
- Export
55Kinds of Aspects
Everything reduced to classes and AspectJ aspects
- Class Dictionary Aspect
- Traversal Aspect
- Traversal Advice Aspect
- AspectJ Aspect
- Class
56Kinds of Aspects
Provide and expect Something executable
Import and export Join points Dynamic/lexical
- Class Dictionary Aspect
- Imports nothing (is a sink)
- Exports class graph nodes and edges
- Expects nothing (is a sink)
- Provides parser, numerous traversal advice
(print, copy, display, check, equal) - Traversal Aspect
- Imports class graph nodes and edges
- Exports dynamic join points during traversal
- Expects traversal advice
- Provides (adaptive) methods
57Kinds of Aspects
Provide and expect Something executable
Import and export Join points Dynamic/lexical
- Traversal Advice Aspect
- Imports object graph slice nodes and edges
- Exports dynamic join points during visitor
methods - Expects methods
- Provides visitor methods (advice)
- AspectJ Aspect
- Imports class graph nodes, dynamic join points
- Exports dynamic join points during advice
- Expects abstract methods and pointcuts
- Provides advice, introductions
58ClassDictionary Aspect
Join point examples
- aspect FileSys ClassDictionary
- FileSystem ltrootgt CompoundFile EOF.
- File SimpleFile CompoundFile common
- ltnamegt Ident.
- SimpleFile "simple".
- CompoundFile "compound" ltcontentsgt
- FileList ltparentgt CompoundFile.
- FileList "(" File ")".
EBNF
59Traversal Aspect
- aspect FileSystemTraversals Traversal
- declare strategy eachFile "intersect(from
- CompoundFile to File, down)"
- declare traversal
- void listAll() eachFile(FileLister)
- declare strategy down "from bypassing -gt
- ,parent, to "
- declare strategy up "from bypassing -gt
- ,contents, to "
-
Happens to be AspectJ code
60Need for Glue
- The class dictionary aspect and traversal aspect.
Use name mapping - CompoundFile, File, parent, content
- Need to check whether there is a path from
CompoundFile to File in the class graph that is
exported from the class dictionary aspect.
61Glue Aspect
- aspect FileSystemMethods Cd_Traversal
- default name map
- // FileSys.CompoundFile
- // FileSystemTraversals.CompoundFile
- // etc.
-
62AspectJ Aspect
- aspect FileSystemMethods AspectJ
- File CompoundFile.getFile(Ident name)
- for (Iterator it
- contents.iterator() it.hasNext())
- File file (File) it.next()
- if (file.name.equals(name))
- return file
-
- return null
-
-
63Traversal Advice Aspect
- aspect FileLister TraversalAdvice
- Stack path new Stack()
- void before(File file)
- path.push(file.name)
- void after(File file)
- System.out.print(" .")
- Iterator it path.iterator() it.next()
- while (it.hasNext())
- System.out.print("/" it.next())
- System.out.println()
- path.pop()
-
Happens to be a Java class
64LoD for Fred (D. Orleans)
Fred (AOSD 02) simplest AOP language decision
points, branches
- The set of potential preferred suppliers to a
message-send expression M in the body of a branch
B is the union of the objects in the following
sets - the argument list A of the decision point E that
caused the invocation of B - the associated values of E, that is,
- the results of message-send expressions M' in the
body of B before M whose argument lists A'
intersect with A - instances that were created in the control flow
of the body of B before M.
65(No Transcript)
66Meta classes Classes Pathsets Object
trees Subtrees from A Nodes Edges
Meta aspects Aspects Aspect object tree Subtrees
Meta program Program Join point trees Join point
trees Subtrees cflow Nodes , .., Edges
lexical
dynamic
67Meta aspects Aspects Aspect graph Aspect object
tree Subtrees
Meta program Program Lexical call graph Join
point trees Join point trees Dynamic call
graph Subtrees cflow Nodes , .., Edges
Meta classes Classes Class graph Pathsets Object
trees Subtrees from A Nodes Edges
lexical
dynamic
Reflection connections CR, AR Aspect extent
duration of method call, object only context
object paper.