summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authoracolyer <acolyer>2005-03-23 16:47:55 +0000
committeracolyer <acolyer>2005-03-23 16:47:55 +0000
commit68f63508828d1c1ea7076d051cc77713625f6a03 (patch)
tree40e125609a1fbfe8423f7e439d88da6b997668c4
parentef3044a08dd1e5556c03e614ce8d799d61aaf041 (diff)
downloadaspectj-68f63508828d1c1ea7076d051cc77713625f6a03.tar.gz
aspectj-68f63508828d1c1ea7076d051cc77713625f6a03.zip
fix for Bug 84122 - Allow aspectPath to contain directories
-rw-r--r--docs/adk15ProgGuideDB/miscellaneous.xml12
-rw-r--r--org.aspectj.ajdt.core/src/org/aspectj/ajdt/ajc/BuildArgParser.java2
-rw-r--r--org.aspectj.ajdt.core/src/org/aspectj/ajdt/ajc/messages.properties2
-rw-r--r--org.aspectj.ajdt.core/src/org/aspectj/ajdt/internal/core/builder/AjState.java28
-rw-r--r--tests/options/aspectpath/MyAspect.aj5
-rw-r--r--tests/options/aspectpath/MyClass.java5
-rw-r--r--tests/src/org/aspectj/systemtest/ajc150/Ajc150Tests.java4
-rw-r--r--tests/src/org/aspectj/systemtest/ajc150/ajc150.xml12
-rw-r--r--weaver/src/org/aspectj/weaver/bcel/BcelWeaver.java57
9 files changed, 103 insertions, 24 deletions
diff --git a/docs/adk15ProgGuideDB/miscellaneous.xml b/docs/adk15ProgGuideDB/miscellaneous.xml
index 063c8b816..899ac1208 100644
--- a/docs/adk15ProgGuideDB/miscellaneous.xml
+++ b/docs/adk15ProgGuideDB/miscellaneous.xml
@@ -91,5 +91,17 @@
</sect1>
+
+ <sect1>
+ <title>Tools</title>
+
+ <sect2>
+ <title>Aspectpath</title>
+
+ <para>AspectJ 5 allows the specification of directories (containing .class files) on the aspectpath in
+ addition to jar/zip files.</para>
+ </sect2>
+
+ </sect1>
</chapter>
diff --git a/org.aspectj.ajdt.core/src/org/aspectj/ajdt/ajc/BuildArgParser.java b/org.aspectj.ajdt.core/src/org/aspectj/ajdt/ajc/BuildArgParser.java
index 0c2806acc..0f8909585 100644
--- a/org.aspectj.ajdt.core/src/org/aspectj/ajdt/ajc/BuildArgParser.java
+++ b/org.aspectj.ajdt.core/src/org/aspectj/ajdt/ajc/BuildArgParser.java
@@ -441,7 +441,7 @@ public class BuildArgParser extends Main {
while (st.hasMoreTokens()) {
String filename = st.nextToken();
File jarFile = makeFile(filename);
- if (jarFile.exists() && FileUtil.hasZipSuffix(filename)) {
+ if (jarFile.exists() && (FileUtil.hasZipSuffix(filename) || jarFile.isDirectory())) {
buildConfig.getAspectpath().add(jarFile);
} else {
showError("bad aspectpath: " + filename);
diff --git a/org.aspectj.ajdt.core/src/org/aspectj/ajdt/ajc/messages.properties b/org.aspectj.ajdt.core/src/org/aspectj/ajdt/ajc/messages.properties
index 061417143..2777b867a 100644
--- a/org.aspectj.ajdt.core/src/org/aspectj/ajdt/ajc/messages.properties
+++ b/org.aspectj.ajdt.core/src/org/aspectj/ajdt/ajc/messages.properties
@@ -22,7 +22,7 @@ AspectJ-specific options:\n\
\t-injars <jarList> use classes in <jarList> zip files as source\n\
\t (<jarList> uses classpath delimiter)\n\
\t deprecated - use inpath instead.\n\
-\t-aspectpath <list> weave aspects from <list> zip files into sources\n\
+\t-aspectpath <list> weave aspects in .class files from <list> dirs and jars/zip into sources\n\
\t (<list> uses classpath delimiter)\n\
\t-outjar <file> put output classes in zip file <file>\n\
\t-argfile <file> specify line-delimited list of source files\n\
diff --git a/org.aspectj.ajdt.core/src/org/aspectj/ajdt/internal/core/builder/AjState.java b/org.aspectj.ajdt.core/src/org/aspectj/ajdt/internal/core/builder/AjState.java
index d6bb9ffda..e5668bc32 100644
--- a/org.aspectj.ajdt.core/src/org/aspectj/ajdt/internal/core/builder/AjState.java
+++ b/org.aspectj.ajdt.core/src/org/aspectj/ajdt/internal/core/builder/AjState.java
@@ -170,24 +170,39 @@ public class AjState {
return ret;
}
+ private boolean classFileChangedInDirSinceLastBuild(File dir) {
+ File[] classFiles = FileUtil.listFiles(dir, new FileFilter(){
+
+ public boolean accept(File pathname) {
+ return pathname.getName().endsWith(".class");
+ }
+
+ });
+ for (int i = 0; i < classFiles.length; i++) {
+ long modTime = classFiles[i].lastModified();
+ if (modTime + 1000 >= lastSuccessfulBuildTime) return true;
+ }
+ return false;
+ }
+
private boolean pathChange(AjBuildConfig oldConfig, AjBuildConfig newConfig) {
boolean changed = false;
List oldClasspath = oldConfig.getClasspath();
List newClasspath = newConfig.getClasspath();
- if (changed(oldClasspath,newClasspath)) return true;
+ if (changed(oldClasspath,newClasspath,true)) return true;
List oldAspectpath = oldConfig.getAspectpath();
List newAspectpath = newConfig.getAspectpath();
- if (changed(oldAspectpath,newAspectpath)) return true;
+ if (changed(oldAspectpath,newAspectpath,true)) return true;
List oldInJars = oldConfig.getInJars();
List newInJars = newConfig.getInJars();
- if (changed(oldInJars,newInJars)) return true;
+ if (changed(oldInJars,newInJars,false)) return true;
List oldInPath = oldConfig.getInpath();
List newInPath = newConfig.getInpath();
- if (changed(oldInPath, newInPath)) return true;
+ if (changed(oldInPath, newInPath,false)) return true;
return changed;
}
- private boolean changed(List oldPath, List newPath) {
+ private boolean changed(List oldPath, List newPath, boolean checkClassFiles) {
if (oldPath == null) oldPath = new ArrayList();
if (newPath == null) newPath = new ArrayList();
if (oldPath.size() != newPath.size()) {
@@ -207,6 +222,9 @@ public class AjState {
if (f.exists() && !f.isDirectory() && (f.lastModified() >= lastSuccessfulBuildTime)) {
return true;
}
+ if (f.exists() && f.isDirectory() && checkClassFiles) {
+ return classFileChangedInDirSinceLastBuild(f);
+ }
}
return false;
}
diff --git a/tests/options/aspectpath/MyAspect.aj b/tests/options/aspectpath/MyAspect.aj
new file mode 100644
index 000000000..4b2c632d7
--- /dev/null
+++ b/tests/options/aspectpath/MyAspect.aj
@@ -0,0 +1,5 @@
+public aspect MyAspect {
+
+ declare warning : execution(* *(..)) : "a method";
+
+} \ No newline at end of file
diff --git a/tests/options/aspectpath/MyClass.java b/tests/options/aspectpath/MyClass.java
new file mode 100644
index 000000000..ef0d28767
--- /dev/null
+++ b/tests/options/aspectpath/MyClass.java
@@ -0,0 +1,5 @@
+public class MyClass {
+
+ void foo() {}
+
+} \ No newline at end of file
diff --git a/tests/src/org/aspectj/systemtest/ajc150/Ajc150Tests.java b/tests/src/org/aspectj/systemtest/ajc150/Ajc150Tests.java
index bdcc31a41..0d3b6b076 100644
--- a/tests/src/org/aspectj/systemtest/ajc150/Ajc150Tests.java
+++ b/tests/src/org/aspectj/systemtest/ajc150/Ajc150Tests.java
@@ -145,6 +145,10 @@ public class Ajc150Tests extends org.aspectj.testing.XMLBasedAjcTestCase {
runTest("varargs in constructor sig");
}
+ public void testAspectpathdirs() {
+ runTest("dirs on aspectpath");
+ }
+
// helper methods.....
public SyntheticRepository createRepos(File cpentry) {
diff --git a/tests/src/org/aspectj/systemtest/ajc150/ajc150.xml b/tests/src/org/aspectj/systemtest/ajc150/ajc150.xml
index 4ee4988f4..e92516e85 100644
--- a/tests/src/org/aspectj/systemtest/ajc150/ajc150.xml
+++ b/tests/src/org/aspectj/systemtest/ajc150/ajc150.xml
@@ -312,7 +312,7 @@
<compile files="HandlerBinding.aj" options="-1.5"/>
<run class="HandlerBinding"/>
</ajc-test>
-
+
<ajc-test dir="java5/annotations/binding" vm="1.5" title="@withincode() and call(* println(..))">
<compile files="WithinCodeBinding1.aj" options="-1.5"/>
<run class="WithinCodeBinding1"/>
@@ -2019,4 +2019,14 @@
<run class="p.q.DeathByAnnotations"/>
</ajc-test>
+
+ <!-- ============================================================== -->
+
+ <ajc-test dir="options/aspectpath" title="dirs on aspectpath">
+ <compile files="MyAspect.aj" options="-d out"/>
+ <compile files="MyClass.java" options="-aspectpath out">
+ <message kind="warning" line="3" text="a method"/>
+ </compile>
+ </ajc-test>
+
</suite> \ No newline at end of file
diff --git a/weaver/src/org/aspectj/weaver/bcel/BcelWeaver.java b/weaver/src/org/aspectj/weaver/bcel/BcelWeaver.java
index 1caa54574..3f1134b6f 100644
--- a/weaver/src/org/aspectj/weaver/bcel/BcelWeaver.java
+++ b/weaver/src/org/aspectj/weaver/bcel/BcelWeaver.java
@@ -142,10 +142,22 @@ public class BcelWeaver implements IWeaver {
public void addLibraryJarFile(File inFile) throws IOException {
- ZipInputStream inStream = new ZipInputStream(new FileInputStream(inFile)); //??? buffered
+ List addedAspects = null;
+ if (inFile.isDirectory()) {
+ addedAspects = addAspectsFromDirectory(inFile);
+ } else {
+ addedAspects = addAspectsFromJarFile(inFile);
+ }
+ for (Iterator i = addedAspects.iterator(); i.hasNext();) {
+ ResolvedTypeX aspectX = (ResolvedTypeX) i.next();
+ xcutSet.addOrReplaceAspect(aspectX);
+ }
+ }
+
+ private List addAspectsFromJarFile(File inFile) throws FileNotFoundException, IOException {
+ ZipInputStream inStream = new ZipInputStream(new FileInputStream(inFile)); //??? buffered
List addedAspects = new ArrayList();
-
while (true) {
ZipEntry entry = inStream.getNextEntry();
if (entry == null) break;
@@ -154,25 +166,38 @@ public class BcelWeaver implements IWeaver {
continue;
}
- ClassParser parser = new ClassParser(new ByteArrayInputStream(FileUtil.readAsByteArray(inStream)), entry.getName());
- JavaClass jc = parser.parse();
- inStream.closeEntry();
-
- ResolvedTypeX type = world.addSourceObjectType(jc).getResolvedTypeX();
- if (type.isAspect()) {
- addedAspects.add(type);
- }
-
+ addIfAspect(FileUtil.readAsByteArray(inStream), entry.getName(), addedAspects);
+ inStream.closeEntry();
}
-
inStream.close();
+ return addedAspects;
+ }
+
+ private List addAspectsFromDirectory(File dir) throws FileNotFoundException, IOException{
+ List addedAspects = new ArrayList();
+ File[] classFiles = FileUtil.listFiles(dir,new FileFilter(){
- for (Iterator i = addedAspects.iterator(); i.hasNext();) {
- ResolvedTypeX aspectX = (ResolvedTypeX) i.next();
- xcutSet.addOrReplaceAspect(aspectX);
+ public boolean accept(File pathname) {
+ return pathname.getName().endsWith(".class");
+ }
+
+ });
+ for (int i = 0; i < classFiles.length; i++) {
+ FileInputStream fis = new FileInputStream(classFiles[i]);
+ byte[] bytes = FileUtil.readAsByteArray(fis);
+ addIfAspect(bytes,classFiles[i].getAbsolutePath(),addedAspects);
}
+ return addedAspects;
+ }
+
+ private void addIfAspect(byte[] bytes, String name, List toList) throws IOException {
+ ClassParser parser = new ClassParser(new ByteArrayInputStream(bytes),name);
+ JavaClass jc = parser.parse();
+ ResolvedTypeX type = world.addSourceObjectType(jc).getResolvedTypeX();
+ if (type.isAspect()) {
+ toList.add(type);
+ }
}
-
// // The ANT copy task should be used to copy resources across.
// private final static boolean CopyResourcesFromInpathDirectoriesToOutput=false;