aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--org.aspectj.ajdt.core/src/org/aspectj/ajdt/internal/core/builder/AjBuildConfig.java9
-rw-r--r--org.aspectj.ajdt.core/src/org/aspectj/ajdt/internal/core/builder/AjBuildManager.java8
-rw-r--r--testing/src/org/aspectj/testing/ajde/CompileCommand.java5
-rw-r--r--weaver/src/org/aspectj/weaver/bcel/BcelWeaver.java64
4 files changed, 72 insertions, 14 deletions
diff --git a/org.aspectj.ajdt.core/src/org/aspectj/ajdt/internal/core/builder/AjBuildConfig.java b/org.aspectj.ajdt.core/src/org/aspectj/ajdt/internal/core/builder/AjBuildConfig.java
index 872936b27..7eedd3e1c 100644
--- a/org.aspectj.ajdt.core/src/org/aspectj/ajdt/internal/core/builder/AjBuildConfig.java
+++ b/org.aspectj.ajdt.core/src/org/aspectj/ajdt/internal/core/builder/AjBuildConfig.java
@@ -41,6 +41,7 @@ public class AjBuildConfig { // XXX needs bootclasspath?
private List/*File*/ sourceRoots = new ArrayList();
private List/*File*/ files = new ArrayList();
private List/*File*/ inJars = new ArrayList();
+ private Map/*String->File*/ sourcePathResources = new HashMap();
private List/*File*/ aspectpath = new ArrayList();
private List/*String*/ classpath = new ArrayList();
private Map javaOptions = new HashMap();
@@ -193,6 +194,10 @@ public class AjBuildConfig { // XXX needs bootclasspath?
return inJars;
}
+ public Map getSourcePathResources() {
+ return sourcePathResources;
+ }
+
public void setOutputJar(File outputJar) {
this.outputJar = outputJar;
}
@@ -420,4 +425,8 @@ public class AjBuildConfig { // XXX needs bootclasspath?
}
}
+ public void setSourcePathResources(Map map) {
+ sourcePathResources = map;
+ }
+
}
diff --git a/org.aspectj.ajdt.core/src/org/aspectj/ajdt/internal/core/builder/AjBuildManager.java b/org.aspectj.ajdt.core/src/org/aspectj/ajdt/internal/core/builder/AjBuildManager.java
index 436fda9d0..ab0551dbe 100644
--- a/org.aspectj.ajdt.core/src/org/aspectj/ajdt/internal/core/builder/AjBuildManager.java
+++ b/org.aspectj.ajdt.core/src/org/aspectj/ajdt/internal/core/builder/AjBuildManager.java
@@ -221,6 +221,14 @@ public class AjBuildManager {
bcelWeaver.addJarFile(inJar, buildConfig.getOutputDir());
}
+ if (buildConfig.getSourcePathResources() != null) {
+ for (Iterator i = buildConfig.getSourcePathResources().keySet().iterator(); i.hasNext(); ) {
+ // File resource = (File)i.next();
+ String resource = (String)i.next();
+ bcelWeaver.addResource(resource, (File)buildConfig.getSourcePathResources().get(resource), buildConfig.getOutputDir());
+ // bcelWeaver.addResource(resource, buildConfig.getOutputDir());
+ }
+ }
//check for org.aspectj.runtime.JoinPoint
bcelWorld.resolve("org.aspectj.lang.JoinPoint");
}
diff --git a/testing/src/org/aspectj/testing/ajde/CompileCommand.java b/testing/src/org/aspectj/testing/ajde/CompileCommand.java
index 529eabf64..fa8fb7d99 100644
--- a/testing/src/org/aspectj/testing/ajde/CompileCommand.java
+++ b/testing/src/org/aspectj/testing/ajde/CompileCommand.java
@@ -383,4 +383,9 @@ class ProjectProperties implements ProjectPropertiesAdapter {
log(s);
return null;
}
+
+ public Map getSourcePathResources() {
+ return null;
+ }
+
}
diff --git a/weaver/src/org/aspectj/weaver/bcel/BcelWeaver.java b/weaver/src/org/aspectj/weaver/bcel/BcelWeaver.java
index 445ee75ec..b3fc0a0e9 100644
--- a/weaver/src/org/aspectj/weaver/bcel/BcelWeaver.java
+++ b/weaver/src/org/aspectj/weaver/bcel/BcelWeaver.java
@@ -47,6 +47,7 @@ public class BcelWeaver implements IWeaver {
private Map sourceJavaClasses = new HashMap(); /* String -> UnwovenClassFile */
private List addedClasses = new ArrayList(); /* List<UnovenClassFile> */
private List deletedTypenames = new ArrayList(); /* List<String> */
+ private List resources = new ArrayList(); /* String -> byte[] */
private boolean needToReweaveWorld = false;
private List shadowMungerList = null; // setup by prepareForWeave
@@ -112,38 +113,46 @@ public class BcelWeaver implements IWeaver {
*/
public void addJarFile(File inFile, File outDir) throws IOException {
needToReweaveWorld = true;
- //System.err.println("adding jar: " + inFile);
ZipInputStream inStream = new ZipInputStream(new FileInputStream(inFile)); //??? buffered
while (true) {
ZipEntry entry = inStream.getNextEntry();
if (entry == null) break;
- if (entry.isDirectory() || !entry.getName().endsWith(".class")) {
- continue; //??? need to pass other things along untouched
-// outStream.putNextEntry(entry);
-// outStream.write(Utility.getByteArray(inStream));
-// outStream.closeEntry();
-// return;
- }
- //System.err.println("adding class: " + entry.getName());
-
byte[] bytes = FileUtil.readAsByteArray(inStream);
String filename = entry.getName();
- UnwovenClassFile classFile = new UnwovenClassFile(new File(outDir, filename).getAbsolutePath(), bytes);
+
+ if (filename.endsWith(".class")) {
+ UnwovenClassFile classFile = new UnwovenClassFile(new File(outDir, filename).getAbsolutePath(), bytes);
+ this.addClassFile(classFile);
+ }
+ else if (!entry.isDirectory()) {
+ UnwovenClassFile resourceFile = new UnwovenClassFile(filename, bytes);
+ addResource(resourceFile);
+ }
+
inStream.closeEntry();
- this.addClassFile(classFile);
}
inStream.close();
}
-
+
+ public void addResource(String name, File inPath, File outDir) throws IOException {
+ BufferedInputStream inStream = new BufferedInputStream(new FileInputStream(inPath));
+ byte[] bytes = new byte[(int)inPath.length()];
+ inStream.read(bytes);
+ UnwovenClassFile resourceFile = new UnwovenClassFile(new File(outDir, name).getAbsolutePath(), bytes);
+ addResource(resourceFile);
+ inStream.close();
+ }
/** Should be addOrReplace
*/
public void addClassFile(UnwovenClassFile classFile) {
addedClasses.add(classFile);
- sourceJavaClasses.put(classFile.getClassName(), classFile);
+ if (null != sourceJavaClasses.put(classFile.getClassName(), classFile)) {
+// throw new RuntimeException(classFile.getClassName());
+ }
world.addSourceObjectType(classFile.getJavaClass());
}
@@ -154,6 +163,10 @@ public class BcelWeaver implements IWeaver {
world.deleteSourceObjectType(TypeX.forName(typename));
}
+ public void addResource (UnwovenClassFile resourceFile) {
+ resources.add(resourceFile);
+ }
+
// ---- weave preparation
public void prepareForWeave() {
@@ -194,6 +207,8 @@ public class BcelWeaver implements IWeaver {
BufferedOutputStream os = FileUtil.makeOutputStream(file);
this.zipOutputStream = new ZipOutputStream(os);
dumpUnwoven();
+ /* BUG 40943*/
+ dumpResourcesOutJar();
zipOutputStream.close(); //this flushes and closes the acutal file
}
@@ -204,8 +219,25 @@ public class BcelWeaver implements IWeaver {
UnwovenClassFile classFile = (UnwovenClassFile)i.next();
dumpUnchanged(classFile);
}
+ dumpResourcesToOutPath();
}
+ private void dumpResourcesToOutPath() throws IOException {
+ Iterator i = resources.iterator();
+ while (i.hasNext()) {
+ UnwovenClassFile res = (UnwovenClassFile)i.next();
+ dumpUnchanged(res);
+ }
+ }
+
+ /* BUG #40943 */
+ public void dumpResourcesOutJar() throws IOException {
+ Iterator i = resources.iterator();
+ while (i.hasNext()) {
+ UnwovenClassFile res = (UnwovenClassFile)i.next();
+ writeZipEntry(res.getFilename(),res.getBytes());
+ }
+ }
// ---- weaving
@@ -213,6 +245,8 @@ public class BcelWeaver implements IWeaver {
OutputStream os = FileUtil.makeOutputStream(file);
this.zipOutputStream = new ZipOutputStream(os);
Collection c = weave();
+ /* BUG 40943*/
+ dumpResourcesOutJar();
zipOutputStream.close(); //this flushes and closes the acutal file
return c;
}
@@ -286,6 +320,8 @@ public class BcelWeaver implements IWeaver {
addedClasses = new ArrayList();
deletedTypenames = new ArrayList();
+ dumpResourcesToOutPath();
+
return wovenClassNames;
}