AspectJ 1.1 Features
------------------------------------------------------------


------------------------------
About this document

This document contains information about the proposed features of
AspectJ 1.1.  It assumes as a baseline that AspectJ 1.1 includes all
the features of AspectJ 1.0.6.  Any feature difference, especially
incompatible changes, should be noted.  It is organized by DOWNLOAD.
Inside the tools download there are sections per feature. 

Feel free to just stick shorthand notes at the end of this file, and
move them up to the New Features (or other) section as we want.


------------------------------
OPEN ISSUES

* -sourceroots/-injars matrix completeness

* do we release ant tasks in beta?

* do we call beta alpha or alpha beta?

------------------------------
DOWNLOAD: Tools

General deliverables:  Two licence files.  A readme.  Possibly a changes.

---- runtime

Deliverable:  aspectjrt.jar

Changes:

* RUNTIME_LICENCE:  AspectjRT.jar now has a BSD-style licence [NOT BETA]

* JOINPOINT_NAMES: Added constant fields holding constant names for
  the join points.
  
* NO_COLUMN_NUMBER: thisJoinPoint.getSourceLocation().getColumn()
  is incompatible with bytecode weaving and can not be supported.
  Do we want to remove the method or make it return -1?
  
* NOT_10_BINARY_COMPATIBLE: Some modifications to classes in internal
  packages means that code built with 1.1 won't run on the 1.0 version
  of aspectjrt.jar.
  [XXX this has always been true and sounds more scary than it is.
   The readme/docs do/should always say that you need to compile and
   run with at least the same version of the runtime classes as 
   the compiler]

---- tools

Deliverable: aspectjtools.jar

* Single jar containing .class files for all components listed below.
  This will contain code under both the CPL and the MPL.

---- ajc

Deliverable:  ajc, ajc.bat

Changes: 

-- new features 
* NO_SOURCE: -source/-usejavac options are not supported [INCOMPATIBLE]  

* SOURCEROOT: -sourceroots option indicates that all source files in
  a particular directory tree should be compiled [NEW]
  This option is the only way that sourcefiles can currently be
  specified for incremental compilation on the command-line.

* BYTECODE_WEAVING: supporting bytecode-containing jar files as input
  for the compiler.  [NEW]
  * Command-line: -injars option
  Not supported in incremental mode.
  * Eclipse: not supported [BETA]
  This has a ripple effect on "code the compiler controls" issues.
  There are obfustication issues that should be discussed in the readme

* OUTJAR: supports generating a single .jar file with the results of a
  compilation, rather than separate .class files. This should be
  most useful when weaving into existing .jar files.  The resulting jar 
  file has no meta-information, just classes.  [question: compression level?]
  [NEW]

* BINARY_ASPECTS: Aspects may be compiled to a standalone bytecode
  form, and later be used in a linking/compiling phase to affect join
  points.  [NEW]
  This will only be partially working in beta1:  The front-end is not
  reading the binary aspects. [BETA]

* INCREMENTAL: incremental compilation [NEW] 
  * Command-line: interface is using -sourceroots and typing <enter>
    for an incremental recompile.  Better interfaces are possible
    in the future.
  * Eclipse: invisible
  * JBuilder/Netbeans:  ??
  * Emacs:  possibly using new command-line interface?
  * Ant: unsupported in BETA

* NORMAL_OPTIONS: now supporting many javac options ajc failed to in 1.0:  
  essentially those supported in the ECLIPSE_OPTIONS [NEW]

* ECLIPSE_OPTIONS: The eclipse compiler provides a large number of
  options for controlling its behavior, i.e. -warn:unusedLocals.  All
  of these options may be passed to the command-line ajc compiler.  Mik should 
  be bugged to get full list and description of the options [NEW]


-- features not supported yet

* NO_WEAVE: An option with unknown name that generates code but does 
  no back-end weaving [NO BETA]

* SOURCE_INFORMATION: Source file information in error messages may be
  either better or worse (depending on how well we do our eclipse
  integration, this may not happen). [INCOMPATIBLE, MINIMAL]
  JSR 45 information is not created/maintained. [BETA]  

* NO_AROUND_OPTIMIZATION: -XinlineAroundClosure not implemented.
  [INCOMPATIBLE]  No inlining at all [BETA].

* NO_CALLEE_SIDE_CALL:  Not implemented [BETA]

* OTHER_X_OPTIONS: XaddSafePrefix (not used anymore, but we make some
                   weak guarantees about this), XserializableAspects [see below]
                   XTargetNearSource [see below]
                   

-- features no longer supported
* NO_SOURCE: -preprocess/-usejavac/-nocomment/-workingdir options are 
  not supported [INCOMPATIBLE]  

* NO_STRICT_LENIENT:  The -strict/-lenient flags are no longer
  supported, since we no longer own the compiler [INCOMPATIBLE, MINIMAL]
  

* NO_PORTING: The -porting flag is no longer supported.

---- Ajdb

* NO_AJDB: Ajdb is no longer supported, shipped, talked about,
  seen, or believed to exist.  We write a nice couple of paragraphs
  about JSR 45. [INCOMPATIBLE] 


---- Ajdoc

* NO_AJDOC: Ajdoc is not provided [BETA, possibly but not certainly
  FINAL as well]

---- ajbrowser

* NO_CROSSCUTTING_STRUCTURE:  Crosscutting structure is not shown
  [BETA_ONLY]


------------------------------
DOWNLOADS: AJDE for Jbuilder, AJDE for Netbeans, AJDE for Emacs

Deliverables:  3 downloads, same as 1.0.6 (Mik, expand?)

Changes:

* NO_AJDE_INCREMENTAL_COMPILATION: the 1.1 compiler will only 
  work in batch mode [BETA_ONLY]

* NO_TARGET_NEAR_SOURCE:  -XTargetNearSource option is not supported in
  the 1.1 command-line compiler. [INCOMPATIBLE]


------------------------------
DOWNLOAD: ajc ant tasks

Deliverables:  1 download, same as 1.0.6

Changes: 
  - adding experimental taskdef based on DefaultCompilerAdapter
  - updated taskdef to use new compiler interface
  - neither support incremental mode [XXX leave ant running, touch tag file?]

------------------------------
DOWNLOAD: Source distributions

Tools Source: completely revamped, includes license for org.eclipse package
AJDE-JBuilder Source: basically the same, if aspectjtools.jar is one jar
AJDE-Netbeans Source: basically the same, if aspectjtools.jar is one jar

------------------------------
DOWNLOAD: Documentation

Deliverable: 1 or 0 downloads.  Main deliverable is fleshed-out
version of this document with outgoing links to bare or updated 1.0.6
documentation.

Changes (language changes):

* THROWS_PATTERN: Typename patterns are allowed in place of typenames 
  in throws clauses.  This is 
  http://aspectj.org/home/hugunin/features11.html#throws-patterns [NEW]

* CALLEE_SIDE_CALLS: 1.1 may pick out different callee-side call join
  points than 1.0.6 on the same code.  [INCOMPATIBLE] 

* SINGLE_INTERCLASS_TARGET: 1.1 does not allow inter-class
  declarations to be made with a TypePattern as target.  (workaround
  available, defense can be presented if asked).  [INCOMPATIBLE]

* SINGLE_TYPENAME_PATTERN_TARGET: A simple type-name pattern with no
  wildcard can match no more than one type.  The type that it matches
  is determined at compile-time.  [INCOMPATIBLE]  
  [THIS IS NO LONGER THE CASE, SO IT IS NOT DOCUMENTED AS SUCH]

* ASPECT_PRECEDENCE: Dominates is replaced/mirrored with alternate
  declare-space specification, or it's not.  (??) [INCOMPATIBLE, or
  NEW, or NOTHING]

* UNAVAILABLE_JOIN_POINTS: [INCOMPATIBLE, MINIMAL]
  * Initializer Execution join points no longer exist.  The
    information needed to pick them out doesn't exist in bytecode.
    there was not kinded pcd for it, and we're not sure anyone will
    actually notice the difference.
  * Others? (??)
  
* CONSTRUCTOR_EXECUTION_IS_BIGGER: constructor execution join points
  (of constructors which call super) include the code for instance
  initialization (the code inside the old initializer execution join
  point).  Again, the information needed to NOT include this code
  isn't available in bytecode.  This could be a big deal... before
  advice on many constructor execution join points will run before the
  dynamic initializers run. [INCOMPATIBLE]

* NEW_PCDS: Kinded PCDs are available for every kind of join
  point. This is 
  http://aspectj.org/home/hugunin/features11.html#kinded-pcds [NEW]
  * adviceExecution (spelling?)
  * preInitialization (spelling?)

* WITHIN_MEMBER_TYPES: Within of a member type (NOT a package-level
  type) such as within(pkg.Type.MemberType) is not guaranteed to pick
  out code inside anonymous and local types.  (JLS 13.1).  If anyone
  cares, we can do tests on jikes/javac/eclipse to see if we actually
  do, but this is hopefully a completely minimal issue [INCOMPATIBLE,
  MINIMAL].  It is unclear if this is a fundamental limitation of 
  bytecode weaving or if it can be fixed with further work.


Documentation caveats:

- example code not updated [XXX?]
- quick ref
- 

------------------------------
Future work

There are a number of changes that clearly would be either useful or
easy (hopefully things that are both useful and easy are already
done), but we don't plan to actually ship them in 1.1.  

* HANDLER_EXCLUDES_NON_EXCEPTIONS: (PR826)

* SUPERTYPES_TYPE_PATTERN:

* DYNAMIC_CLASSLOADER_WEAVER:

* SOURCE_WEAVING:

------------------------------
Shorthand notes

- no optimizations for per* aspects

- declare soft unimplemented [this is on the table for not doing for beta]

- privileged unimplemented [this is on the table for not doing for beta]

- declare dominates (?) [decided before beta]

- declare error/warning source locations are weaker than just missing column [BETA]


- a note for the dangerous bends section of the programming guide

  Base.m() throws IOException
  Derived.m() [no throws]
  
  call(void Base.m() throws IOException)
  --> this doesn't match new Derived().m(), but will without the throws
  
  
- The status of the -XserializableAspects flag is iceberg-like.

- Don't implement intra-type static members onto interfaces

- Don't handle introduced fields with constant values

- no crosscuting structure means no inline annotations w/ -emacssym, but speedbar still
  shows declaration tree