Publication | Closed Access
A case for statically executable advice
41
Citations
7
References
2003
Year
Unknown Venue
EngineeringVerificationSoftware EngineeringSoftware AnalysisJoint Point FormExecutable AdviceFormal VerificationDependently Typed ProgrammingStatic CheckingDemeter Style TraversalsProgramming Language TheoryFormal SpecificationJoin PointsStatic AnalysisComputer ScienceStatic Program AnalysisSoftware DesignProgram AnalysisAutomated ReasoningSoftware TestingFormal MethodsSymbolic ExecutionSystem Software
We define a generic join point model for checking the Law of Demeter (LoD). Join points are trees, pointcuts are predicates over join points, and advice is checked statically similar to how declare warning is checked in AspectJ. We illustrate how the joint point form is mapped to the object and class forms of LoD, and provide an implementation in AspectJ that approximates LoD's class form by dynamically checking a particular execution using only the join points' static part. The paper proposes two ways to extend AspectJ to provide access to lexical join points directly. The first proposes statically executable advice and pointcut designators over lexical join points. The second proposes statically executable meta-advice over the exposed abstract syntax tree of the program and using Demeter style traversals to mirror AspectJ pointcuts.
| Year | Citations | |
|---|---|---|
Page 1
Page 1