ch.ethz.inf.iks.jvmai.jvmdi

Java Source Code / Java Documentation
1. 6.0 JDK Core
2. 6.0 JDK Modules
3. 6.0 JDK Modules com.sun
4. 6.0 JDK Modules com.sun.java
5. 6.0 JDK Modules sun
6. 6.0 JDK Platform
7. Ajax
8. Apache Harmony Java SE
9. Aspect oriented
10. Authentication Authorization
11. Blogger System
12. Build
13. Byte Code
14. Cache
15. Chart
16. Chat
17. Code Analyzer
18. Collaboration
19. Content Management System
20. Database Client
21. Database DBMS
22. Database JDBC Connection Pool
23. Database ORM
24. Development
25. EJB Server geronimo
26. EJB Server GlassFish
27. EJB Server JBoss 4.2.1
28. EJB Server resin 3.1.5
29. ERP CRM Financial
30. ESB
31. Forum
32. GIS
33. Graphic Library
34. Groupware
35. HTML Parser
36. IDE
37. IDE Eclipse
38. IDE Netbeans
39. Installer
40. Internationalization Localization
41. Inversion of Control
42. Issue Tracking
43. J2EE
44. JBoss
45. JMS
46. JMX
47. Library
48. Mail Clients
49. Net
50. Parser
51. PDF
52. Portal
53. Profiler
54. Project Management
55. Report
56. RSS RDF
57. Rule Engine
58. Science
59. Scripting
60. Search Engine
61. Security
62. Sevlet Container
63. Source Control
64. Swing Library
65. Template Engine
66. Test Coverage
67. Testing
68. UML
69. Web Crawler
70. Web Framework
71. Web Mail
72. Web Server
73. Web Services
74. Web Services apache cxf 2.0.1
75. Web Services AXIS2
76. Wiki Engine
77. Workflow Engines
78. XML
79. XML UI
Java
Java Tutorial
Java Open Source
Jar File Download
Java Articles
Java Products
Java by API
Photoshop Tutorials
Maya Tutorials
Flash Tutorials
3ds-Max Tutorials
Illustrator Tutorials
GIMP Tutorials
C# / C Sharp
C# / CSharp Tutorial
C# / CSharp Open Source
ASP.Net
ASP.NET Tutorial
JavaScript DHTML
JavaScript Tutorial
JavaScript Reference
HTML / CSS
HTML CSS Reference
C / ANSI-C
C Tutorial
C++
C++ Tutorial
Ruby
PHP
Python
Python Tutorial
Python Open Source
SQL Server / T-SQL
SQL Server / T-SQL Tutorial
Oracle PL / SQL
Oracle PL/SQL Tutorial
PostgreSQL
SQL / MySQL
MySQL Tutorial
VB.Net
VB.Net Tutorial
Flash / Flex / ActionScript
VBA / Excel / Access / Word
XML
XML Tutorial
Microsoft Office PowerPoint 2007 Tutorial
Microsoft Office Excel 2007 Tutorial
Microsoft Office Word 2007 Tutorial
Java Source Code / Java Documentation » Byte Code » PROSE » ch.ethz.inf.iks.jvmai.jvmdi 
ch.ethz.inf.iks.jvmai.jvmdi
Contains classes and interfaces for the implementation of an aspect interface using JVMDI.

Coding conventions

Java files are coding using the standard Java style recommendations. For the native part, there are several modules:
    AspectInterfaceImpl.c
    CodeJoinPointImpl.c
    ExceptionJoinPointImpl.c
    FieldJoinPointImpl.c
    FieldModificationJoinPointImpl.c
    hmap.c
    jmd.c
    JoinPointContext.c
    JoinPointLocation.c
    util.c
Each module (e.g., FieldJoinPointImpl.c) contains 3 types of functions:
  1. internal functions. Internal functions are always prefixed by a consistent smallcaps prefix. The prefix for FieldJoinPointImpl is fjp
  2. external functions. External functions are used by other modules, are visible in the header files (e.g., in FieldJoinPointImpl.h) and are always prefixed by the CAPITALIZED module prefix. The prefix for external functions, for FieldJoinPointImpl is FJP
  3. functions implementing JNI declarations from Java. They follow the standard javah naming scheme.

Some use-cases I played to verify the correctness of the implementation

  1. a field set event is signalized by the debuggger
    - enter 'event' notification
      o enter 'FIELD_MOD_EVENT' switch case
          [ we obtain the AOP tag, call FillFromEvent]
          enter FMJP.Fill From Event
             1.enter FJP_Fill_fromEvent
    	     a) enter CodeJoinPoint.FillFromEvent
    		  - set AOP tag, set target to null,
    		  - call JoinPointContext.FillfromEvent
    			- fill JoinPointContext.depth
    			- fill JoinPointContext.state (with STATE_GOT_NOTHING)
    			- obtain JoinPointContext.location
    			- call JoinPointLocation.FillFromEvent
    			    - call JoinPointLocation.FillFromFrame
    				 -fill JoinPointLocation.executingBci
    				 -fill JoinPointLocation.executingMethod
      	     b) set FieldJoinPointImpl.field
    	     c) set FieldJoinPointImpl.value
            2. set FieldModificationJoinPoinImpl.newValue
      o  call 'AspectInterface.doOnFieldAccessJoinPoint
    
  2. a method entry event, after being dispatched, askes for 'thisValue'
    - enter CodeJoinPointImpl.getThis().
       - call JoinPointContext.getThis();
         	- state is 'GOT_NOTHING'
    	- verification whether the 'executingMethod' is static (if yes, thisObject) = null
    	- for a non-static method, getLocalValue of the slot '0'
    	   - getLocalValue checks all the types; if all typecheck fail, then 'getLocalObject'
    
  3. a method entry event, after being dispatched, asks for getArgs();
    - enter CodeJoinPointImpl.getArgs().
       - call JoinPointContext.getArgs();
         	- state is 'GOT_NOTHING'
    	- call do get localVariableInfo
    	   - init values for argValues,argSlots,argNames
    	   - call 'doGetLocalVariables' (to fill argSlots,argNames);
    	   - interate over the local variable infos and call 'getLocalValue(depth)'
    
  4. a method entry event, after being dispatched, calls 'callerJoinPoint()'
    - enter CodeJoinPointImpl.getEnclosingJoinPoint();
      - call context.callerContext();
    	- create a new Context, with depth (-1);
    	- call 'doGetCallerLocationData(newContext.lcoation,thread,depth -1);
    	  - call jpc_GetFrameId(depth -1 )
    	  - call JPL_FillFromFrame(location);
            - return the new context
      - set the target (because this will be null  by default);
    
  5. a methodentry event, after being dispatched, calls 'enclosingJoinPoint.getArgs()'
    
     -  SEE ABOVE on how the join point is created.
        - call JoinPointContext.getArgs();
         	- state is 'GOT_NOTHING' (because the context is fresh)
    	- call do get localVariableInfo
    	   - init values for argValues,argSlots,argNames
    	   - call 'doGetLocalVariables' (to fill argSlots,argNames);
    	   - interate over the local variable infos and call 'getLocalValue'
    
    
  6. an exception join point is signalled
     - ai_GetExceptionThrowWatchTag is called
       - HMAP_Get on 'aiGetExceptionThrowTable'
    
Java Source File NameTypeComment
AbsentInformationException.javaClass Exception class AbsentInformationException signals that the code running in the vm does not have certain desired code attributes (such as debugging information).
AspectInterfaceImpl.javaClass Interface AspectInterfaceImpl represents the aspect-interface to the jvmai-system. It's needed for initialization of the jvmai-system, management of joinpoint-watches and for enable or disable event-notification.

An instance of this interface can be obtained by calling the method getAspectInterface() of a jvmai-provider (class DebuggerProvider).

Implementation

The implementation of this aspect interface is based on the debugger interface of the JVM. To receive notifications from the JVM, it uses the native code available in this class.

Bugs

The JVMDI is not consistent over serveral J2SDK versions.
  • Startup ignores the openword/closed world assumption and the list of prefixes.
  • Under JDK 1.4.*, when throwing an exception within the notificaion, exception events are wrongly sent to the debugger
  • Under JDK 1.4.*, the 'GetThreadDepth' JVMDI function (name may be wrong), does not always work correclty.
CacheMap.javaClass Simple LinkedHashMap based object cache implementation.
CodeJoinPointImpl.javaClass
CodeSignatureImpl.javaClass CodeSignatureImpl class.
ControlFlow.javaClass Class ControlFlow encapsulates thread local information needed by the jvmai.
DebuggerProvider.javaClass
ExceptionCatchJoinPointImpl.javaClass
ExceptionJoinPointImpl.javaClass
FieldAccessJoinPointImpl.javaClass Class FieldAccessJoinPoint represents a joinpoint where a field is accessed.
FieldJoinPointImpl.javaClass Class FieldJoinPointImpl represents a joinpoint where a field is accessed.
FieldModificationJoinPointImpl.javaClass Class FieldModificationJoinPoint represents a joinpoint where a field is read.
FieldSignatureImpl.javaClass FieldSignatureImpl class.
HotSwapAdvancedClassWeaver.javaClass
HotSwapAdvancedClassWeaverWrapper.javaClass Wrapper for HotSwapAdvancedClassWeaver.
HotSwapAspectInterfaceImpl.javaClass HotSwapAspectInterfaceImpl class.
HotSwapClassRegister.javaClass Analyses classes and holds a register all found field accesses, field modifications, method calls, exception throws and exception catches.
HotSwapClassWeaver.javaClass
HotSwapClassWeaverWrapper.javaInterface Interface for wrappers for HotSwapClassWeaver implementations.
HotSwapConstructorJoinPointImpl.javaClass HotSwapConstructorJoinPointImpl class.
HotSwapFieldAccessJoinPointImpl.javaClass Concrete implementation of a FieldAccessJoinPoint for the hotswap advice weaving.
HotSwapFieldJoinPointImpl.javaClass Concrete implementation of a CodeJoinPoint for the Jikes RVM.
HotSwapFieldModificationJoinPointImpl.javaClass Concrete implementation of a FieldModificationJoinPoint for the hotswap advice weaving.
HotSwapFieldWeaver.javaClass Remembers the fields where a callback should be inserted.
HotSwapJoinPointImpl.javaClass HotSwap Join Points are join-points that can occur within the execution of a method.
HotSwapMethodEntryJoinPointImpl.javaClass Concrete implementation of a MethodEntryJoinPoint for the Jikes RVM.
HotSwapMethodExitJoinPointImpl.javaClass Concrete implementation of a MethodExitJoinPoint for the Jikes RVM.
HotSwapMethodJoinPointImpl.javaClass Super class for method entry/exit join points (method execution join points).
HotSwapProvider.javaClass HotSwapProvider class.
HotSwapSignatureImpl.javaClass HotSwapSignatureImpl class.
HotSwapSimpleClassWeaver.javaClass Modifies a given class to support advice execution. Container for MethodWeavers, which does the code manipulations.
HotSwapSimpleClassWeaverWrapper.javaClass Wrapper for HotSwapAdvancedClassWeaver.
InvalidObjectException.javaClass Exception class InvalidObjectException signals that a JVMDI function has received a wrong argument.
InvalidVmStateException.javaClass Exception InvalidVmStateException signals that the stack was queried at an unappropriate moment.
ItemManipulationException.javaClass Exception class ItemManipulationException signals that a joinpoint watch was set but it was already set, or, it should have been cleared but no watch existed at the specific location.
JNIUtil.javaClass Class JNIUtil provides some useful methods for working with JNI.
JoinPointContext.javaClass Class JoinPointContext encapsulates local variable info.
JoinPointLocation.javaClass Class JoinPointLocation denotes a code location: a method plus a bytecode index.
JumpFinallyVisitor.javaClass A visitor that adds a JSR instruction before each `return' instruction.
MethodExecutionJoinPointImpl.javaClass Class MethodExecutionJoinPointImpl is simply the implementation for the MethodEntry and MethodExit join point kinds.
ProseVmException.javaClass Exception class ProseVmException signals that an interla operation of the vm failed.
SignatureFormatException.javaClass Exception class SignatureFormatException signals that a string containing a jni signature is wrong formatted.
StackFrameException.javaClass Exception StackFrameException signals that the stack was queried at an unappropriate moment.
ThreadStateException.javaClass Exception class ThreadStateException signals that the state of a thread is not int he appropriate state, a wrong priority has been assigned to, etc..
UniqueIdArrayManager.javaClass Utility for managing unique ids.
www.java2java.com | Contact Us
Copyright 2009 - 12 Demo Source and Support. All rights reserved.
All other trademarks are property of their respective owners.