diff options
author | mkersten <mkersten> | 2003-08-06 21:28:08 +0000 |
---|---|---|
committer | mkersten <mkersten> | 2003-08-06 21:28:08 +0000 |
commit | 9e7ceffb06b794ec4e990e639f33af225e697acf (patch) | |
tree | ce7a56a544f7f0f4ad2dc1f49f7dbec1fe7b7bc4 | |
parent | 5edccbfaeb8bb4dc5b34d553267365ae3c7eda41 (diff) | |
download | aspectj-9e7ceffb06b794ec4e990e639f33af225e697acf.tar.gz aspectj-9e7ceffb06b794ec4e990e639f33af225e697acf.zip |
Fixed bugs:
40943: Binary weaving should copy non-Java resources from "-inja...
36071: 1.1 rc1 should copy resources similar to java compiler
40826: ajbrowser does not report errors properly
40774: task list icons don't show in ajbrowser
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; } |