From 1e9ca71a253b099a3b3ed8ec17994d8be1f24995 Mon Sep 17 00:00:00 2001 From: wisberg Date: Thu, 3 Aug 2006 17:20:06 +0000 Subject: bug 143903 - doc rewriting of javac tasks to support iajc via build.compiler --- docs/devGuideDB/antsupport.xml | 25 +++++++++++++++++++++---- 1 file changed, 21 insertions(+), 4 deletions(-) (limited to 'docs/devGuideDB') diff --git a/docs/devGuideDB/antsupport.xml b/docs/devGuideDB/antsupport.xml index 445c37e48..79b0d99a4 100644 --- a/docs/devGuideDB/antsupport.xml +++ b/docs/devGuideDB/antsupport.xml @@ -951,10 +951,12 @@ This CompilerAdapter can be used in javac task calls by setting the build.compiler property. This enables users to to easily switch between the Javac and AspectJ - compilers. - However, the Javac task's pruning of source files prevents the - adapter from doing a correct compile in some cases, - so use AjcTask where possible. + compilers. However, because there are differences in source file + handling between the Javac task and the ajc compiler, not all + Javac task invocations can be turned over to iajc. However, ajc can + compile anything that Javac can, so it should be possible for any + given compile job to restate the Javac task in a way that can be + handled by iajc/ajc. Sample of compiler adapter @@ -1007,6 +1009,21 @@ ]]> + The Javac task does special handling of source files that + can interfere with ajc. It removes any files that are not out-of-date + with respect to the corresponding .class files. But ajc requires all + source files, since an aspect may affect a source file that is not out + of date. (For a solution to this, see the build.compiler.clean + property described below.) Conversely, developers sometimes specify a source directory + to javac, and let it search for files for types it cannot find. + AspectJ will not do this kind of searching under the source directory + (since the programmer needs to control which sources are affected). + (Don't confuse the source directory used by Javac with the source root + used by ajc; if you specify a source root to ajc, it will compile + any source file under that source root (without exception or filtering).) + To replace source dir searching in Javac, use an Ant filter to specify + the source files. + -- cgit v1.2.3