summaryrefslogtreecommitdiffstats
path: root/taskdefs
diff options
context:
space:
mode:
Diffstat (limited to 'taskdefs')
-rw-r--r--taskdefs/src/org/aspectj/tools/ant/taskdefs/Ajdoc.java1414
-rw-r--r--taskdefs/src/org/aspectj/tools/ant/taskdefs/aspectjTaskdefs.properties1
-rw-r--r--taskdefs/testsrc/org/aspectj/tools/ant/taskdefs/AjdocTest.java32
3 files changed, 729 insertions, 718 deletions
diff --git a/taskdefs/src/org/aspectj/tools/ant/taskdefs/Ajdoc.java b/taskdefs/src/org/aspectj/tools/ant/taskdefs/Ajdoc.java
index e3d9b55b1..44ee2b02f 100644
--- a/taskdefs/src/org/aspectj/tools/ant/taskdefs/Ajdoc.java
+++ b/taskdefs/src/org/aspectj/tools/ant/taskdefs/Ajdoc.java
@@ -8,715 +8,723 @@
*
* Contributors:
* Xerox/PARC initial implementation
+ * 2006, Arno Schmidmeier, (reactivated the source and removed deprecated calls)
* ******************************************************************/
package org.aspectj.tools.ant.taskdefs;
-import org.apache.tools.ant.*;
+import java.io.File;
+import java.util.ArrayList;
+import java.util.Collection;
+import java.util.Collections;
+import java.util.HashMap;
+import java.util.Iterator;
+import java.util.List;
+import java.util.Map;
+import java.util.StringTokenizer;
+import org.apache.tools.ant.BuildException;
+import org.apache.tools.ant.Location;
+import org.apache.tools.ant.Project;
+import org.apache.tools.ant.taskdefs.MatchingTask;
+import org.apache.tools.ant.types.Commandline;
+import org.apache.tools.ant.types.Path;
+import org.apache.tools.ant.types.Reference;
+import org.aspectj.tools.ajdoc.Main;
-public class Ajdoc extends Task { // XXX disabled pending ajdoc implementation
-
-}
+/**
+ * A task to run the ajdoc tool.
+ *
+ * @author Jeff Palm
+ */
+public class Ajdoc extends MatchingTask {
+ /** The name of ajdoc class we're using. */
+ public final static String AJDOC_CLASSNAME = "org.aspectj.tools.ajdoc.Main";
+
+ /** If true, ignore fork param and use FORCE_FORK_VALUE */
+ public final static boolean FORCE_FORK = false;
+
+ /** value used as fork when FORCE_FORK is true */
+ public final static boolean FORCE_FORK_VALUE = true;
+
+ protected Commandline cmd;
+ protected Commandline vmcmd;
+ private Path sourcepath;
+ private File destdir;
+ private Collection sourcefiles;
+ private Collection packagenames;
+ private File packageList;
+ private Path bootclasspath;
+ private Path extdirs;
+ private Path classpath;
+ private Path internalclasspath;
+ private List argfiles;
+ private Path docletpath;
+ private Collection links;
+ private Collection groups;
+ private Doclet doclet;
+ private boolean failonerror;
+ private boolean fork;
+
+ private boolean source14;
+
+ /** reset all to initial values - permit gc if Ajdoc is held */
+ public Ajdoc() {
+ reset();
+ }
+
+ protected void reset() {
+ cmd = new Commandline();
+ vmcmd = new Commandline();
+ sourcepath = null;
+ destdir = null ;
+ sourcefiles = null;
+ packagenames = null;
+ packageList = null;
+ bootclasspath = null;
+ extdirs = null;
+ classpath = null;
+ internalclasspath = null;
+ argfiles = null;
+ docletpath = null;
+ links = new ArrayList();
+ groups = new ArrayList();
+ doclet = null;
+ failonerror = false;
+ fork = false;
+ }
+
+ protected final boolean setif(boolean b, String flag) {
+ if (b) cmd.createArgument().setValue(flag);
+ return b;
+ }
+
+ protected final void setfile(String flag, String file) {
+ set(flag, getProject().resolveFile(file).getAbsolutePath());
+ }
+
+ protected final void set(String flag, String val) {
+ setif(true, flag, val);
+ }
+
+ protected final boolean setif(boolean b, String flag, String val) {
+ if (setif(b, flag)) cmd.createArgument().setValue(val);
+ return b;
+ }
+
+ public void setSource(String input) {
+ source14 = "1.4".equals(input);
+ }
+
+ public void setSourcepath(Path path) {
+ if (sourcepath == null) {
+ sourcepath = path;
+ } else {
+ sourcepath.append(path);
+ }
+ }
+
+ public Path createSourcepath() {
+ return sourcepath == null ?
+ (sourcepath = new Path(getProject())) :
+ sourcepath.createPath();
+ }
+
+ public void setSourcepathRef(Reference id) {
+ createSourcepath().setRefid(id);
+ }
+
+ public void setSrcdir(Path path) { setSourcepath(path); }
+
+ public Path createSrcdir() { return createSourcepath(); }
+
+ public void setSrcdirRef(Reference id) { setSourcepathRef(id); }
+
+ public void setDestdir(String destdir) {
+ this.destdir = getProject().resolveFile(destdir);
+ }
+
+ public void setSourcefiles(String list) {
+ (sourcefiles == null ?
+ sourcefiles = new ArrayList() :
+ sourcefiles).addAll(strings(list));
+ }
+
+ public void setPackagenames(String list) {
+ (packagenames == null ?
+ packagenames = new ArrayList() :
+ packagenames).addAll(strings(list, true));
+ }
+
+ public void setPackageList(String packageList) {
+ this.packageList = getProject().resolveFile(packageList);
+ }
+
+ public void setClasspath(Path path) {
+ if (classpath == null) {
+ classpath = path;
+ } else {
+ classpath.append(path);
+ }
+ }
+
+ public Path createClasspath() {
+ return (classpath == null ?
+ classpath = new Path(getProject()) :
+ classpath).createPath();
+ }
+
+ public void setClasspathref(Reference id) {
+ createClasspath().setRefid(id);
+ }
+
+ public void setBootclasspath(Path path) { // todo: unsupported
+ if (bootclasspath == null) {
+ bootclasspath = path;
+ } else {
+ bootclasspath.append(path);
+ }
+ }
+
+ public Path createBootclasspath() { // todo: unsupported
+ return (bootclasspath == null ?
+ bootclasspath = new Path(getProject()) :
+ bootclasspath).createPath();
+ }
+
+ public void setBootclasspathref(Reference bootclasspathref) { // todo: unsupported
+ createBootclasspath().setRefid(bootclasspathref);
+ }
+
+ public void setInternalclasspath(Path internalclasspath) {
+ if (this.internalclasspath == null) {
+ this.internalclasspath = internalclasspath;
+ } else {
+ this.internalclasspath.append(internalclasspath);
+ }
+ }
+
+ public Path createInternalclasspath() {
+ if (internalclasspath == null) {
+ internalclasspath = new Path(getProject());
+ }
+ return internalclasspath.createPath();
+ }
+
+
+ public void setInternalclasspathref(Reference internalclasspathref) {
+ createInternalclasspath().setRefid(internalclasspathref);
+ }
+
+ public void setExtdirs(Path path) {
+ if (extdirs == null) {
+ extdirs = path;
+ } else {
+ extdirs.append(path);
+ }
+ }
+
+ public List createArgfiles() {
+ return (argfiles == null ?
+ argfiles = new ArrayList() :
+ argfiles);
+ }
+
+ public void setArgfile(String argfile) {
+ createArgfiles().add(getProject().resolveFile(argfile));
+ }
+
+ public void setArgfiles(String argfiles) {
+ createArgfiles().addAll(files(argfiles));
+ }
+
+ public void setOverview(String overview) {
+ setfile("-overview", overview);
+ }
+
+ public void setPublic(boolean b) {
+ setif(b, "-public");
+ }
+
+ public void setPackage(boolean b) {
+ setif(b, "-package");
+ }
+
+ public void setProtected(boolean b) {
+ setif(b, "-protected");
+ }
+
+ public void setPrivate(boolean b) {
+ setif(b, "-private");
+ }
+
+ public void setOld(boolean old) {
+ setif(old, "-old");
+ }
+
+ public void setAuthor(boolean author) {
+ setif(author, "-author");
+ }
+
+ public void setSplitindex(boolean splitindex) {
+ setif(splitindex, "-splitindex");
+ }
+
+ public void setWindowtitle(String windowtitle) {
+ set("-windowtitle", windowtitle);
+ }
+
+ public void setDoctitle(String doctitle) {
+ set("-doctitle", doctitle);
+ }
+
+ public void setHeader(String header) {
+ set("-header", header);
+ }
+
+ public void setFooter(String footer) {
+ set("-footer", footer);
+ }
+
+ public void setBottom(String bottom) {
+ set("-bottom", bottom);
+ }
+ public void setVerbose(boolean b) {
+ setif(b, "-verbose");
+ }
-//
-//import org.aspectj.tools.ajdoc.Main;
-//import org.apache.tools.ant.*;
-//import org.apache.tools.ant.types.*;
-//import org.apache.tools.ant.taskdefs.*;
-//import java.io.*;
-//import java.util.*;
-//
-///**
-// * A task to run the ajdoc tool.
-// *
-// * @author Jeff Palm
-// */
-//public class Ajdoc extends MatchingTask {
-// /** The name of ajdoc class we're using. */
-// public final static String AJDOC_CLASSNAME = "org.aspectj.tools.ajdoc.Main";
-//
-// /** If true, ignore fork param and use FORCE_FORK_VALUE */
-// public final static boolean FORCE_FORK = false;
-//
-// /** value used as fork when FORCE_FORK is true */
-// public final static boolean FORCE_FORK_VALUE = true;
-//
-// protected Commandline cmd;
-// protected Commandline vmcmd;
-// private Path sourcepath;
-// private File destdir;
-// private Collection sourcefiles;
-// private Collection packagenames;
-// private File packageList;
-// private Path bootclasspath;
-// private Path extdirs;
-// private Path classpath;
-// private Path internalclasspath;
-// private List argfiles;
-// private Path docletpath;
-// private Collection links;
-// private Collection groups;
-// private Doclet doclet;
-// private boolean failonerror;
-// private boolean fork;
-//
-// private boolean source14;
-//
-// /** reset all to initial values - permit gc if Ajdoc is held */
-// public Ajdoc() {
-// reset();
-// }
-//
-// protected void reset() {
-// cmd = new Commandline();
-// vmcmd = new Commandline();
-// sourcepath = null;
-// destdir = null ;
-// sourcefiles = null;
-// packagenames = null;
-// packageList = null;
-// bootclasspath = null;
-// extdirs = null;
-// classpath = null;
-// internalclasspath = null;
-// argfiles = null;
-// docletpath = null;
-// links = new ArrayList();
-// groups = new ArrayList();
-// doclet = null;
-// failonerror = false;
-// fork = false;
-// }
-//
-// protected final boolean setif(boolean b, String flag) {
-// if (b) cmd.createArgument().setValue(flag);
-// return b;
-// }
-//
-// protected final void setfile(String flag, String file) {
-// set(flag, project.resolveFile(file).getAbsolutePath());
-// }
-//
-// protected final void set(String flag, String val) {
-// setif(true, flag, val);
-// }
-//
-// protected final boolean setif(boolean b, String flag, String val) {
-// if (setif(b, flag)) cmd.createArgument().setValue(val);
-// return b;
-// }
-//
-// public void setSource(String input) {
-// source14 = "1.4".equals(input);
-// }
-//
-// public void setSourcepath(Path path) {
-// if (sourcepath == null) {
-// sourcepath = path;
-// } else {
-// sourcepath.append(path);
-// }
-// }
-//
-// public Path createSourcepath() {
-// return sourcepath == null ?
-// (sourcepath = new Path(project)) :
-// sourcepath.createPath();
-// }
-//
-// public void setSourcepathRef(Reference id) {
-// createSourcepath().setRefid(id);
-// }
-//
-// public void setSrcdir(Path path) { setSourcepath(path); }
-//
-// public Path createSrcdir() { return createSourcepath(); }
-//
-// public void setSrcdirRef(Reference id) { setSourcepathRef(id); }
-//
-// public void setDestdir(String destdir) {
-// this.destdir = project.resolveFile(destdir);
-// }
-//
-// public void setSourcefiles(String list) {
-// (sourcefiles == null ?
-// sourcefiles = new ArrayList() :
-// sourcefiles).addAll(strings(list));
-// }
-//
-// public void setPackagenames(String list) {
-// (packagenames == null ?
-// packagenames = new ArrayList() :
-// packagenames).addAll(strings(list, true));
-// }
-//
-// public void setPackageList(String packageList) {
-// this.packageList = project.resolveFile(packageList);
-// }
-//
-// public void setClasspath(Path path) {
-// if (classpath == null) {
-// classpath = path;
-// } else {
-// classpath.append(path);
-// }
-// }
-//
-// public Path createClasspath() {
-// return (classpath == null ?
-// classpath = new Path(project) :
-// classpath).createPath();
-// }
-//
-// public void setClasspathref(Reference id) {
-// createClasspath().setRefid(id);
-// }
-//
-// public void setBootclasspath(Path path) { // todo: unsupported
-// if (bootclasspath == null) {
-// bootclasspath = path;
-// } else {
-// bootclasspath.append(path);
-// }
-// }
-//
-// public Path createBootclasspath() { // todo: unsupported
-// return (bootclasspath == null ?
-// bootclasspath = new Path(project) :
-// bootclasspath).createPath();
-// }
-//
-// public void setBootclasspathref(Reference bootclasspathref) { // todo: unsupported
-// createBootclasspath().setRefid(bootclasspathref);
-// }
-//
-// public void setInternalclasspath(Path internalclasspath) {
-// if (this.internalclasspath == null) {
-// this.internalclasspath = internalclasspath;
-// } else {
-// this.internalclasspath.append(internalclasspath);
-// }
-// }
-//
-// public Path createInternalclasspath() {
-// if (internalclasspath == null) {
-// internalclasspath = new Path(project);
-// }
-// return internalclasspath.createPath();
-// }
-//
-//
-// public void setInternalclasspathref(Reference internalclasspathref) {
-// createInternalclasspath().setRefid(internalclasspathref);
-// }
-//
-// public void setExtdirs(Path path) {
-// if (extdirs == null) {
-// extdirs = path;
-// } else {
-// extdirs.append(path);
-// }
-// }
-//
-// public List createArgfiles() {
-// return (argfiles == null ?
-// argfiles = new ArrayList() :
-// argfiles);
-// }
-//
-// public void setArgfile(String argfile) {
-// createArgfiles().add(project.resolveFile(argfile));
-// }
-//
-// public void setArgfiles(String argfiles) {
-// createArgfiles().addAll(files(argfiles));
-// }
-//
-// public void setOverview(String overview) {
-// setfile("-overview", overview);
-// }
-//
-// public void setPublic(boolean b) {
-// setif(b, "-public");
-// }
-//
-// public void setPackage(boolean b) {
-// setif(b, "-package");
-// }
-//
-// public void setProtected(boolean b) {
-// setif(b, "-protected");
-// }
-//
-// public void setPrivate(boolean b) {
-// setif(b, "-private");
-// }
-//
-// public void setOld(boolean old) {
-// setif(old, "-old");
-// }
-//
-// public void setAuthor(boolean author) {
-// setif(author, "-author");
-// }
-//
-// public void setSplitindex(boolean splitindex) {
-// setif(splitindex, "-splitindex");
-// }
-//
-// public void setWindowtitle(String windowtitle) {
-// set("-windowtitle", windowtitle);
-// }
-//
-// public void setDoctitle(String doctitle) {
-// set("-doctitle", doctitle);
-// }
-//
-// public void setHeader(String header) {
-// set("-header", header);
-// }
-//
-// public void setFooter(String footer) {
-// set("-footer", footer);
-// }
-//
-// public void setBottom(String bottom) {
-// set("-bottom", bottom);
-// }
-//
-// public void setVerbose(boolean b) {
-// setif(b, "-verbose");
-// }
-//
-// public void setVersion(boolean b) {
-// setif(b, "-version");
-// }
-//
-// public void setUse(boolean b) {
-// setif(b, "-use");
-// }
-//
-// public void setStandard(boolean b) {
-// setif(b, "-standard");
-// }
-//
-// public class Link {
-// protected String href;
-// protected boolean offline;
-// protected String packagelistLoc;
-// public Link() {}
-// public void setHref(String href) {
-// this.href = href;
-// }
-// public void setOffline(boolean offline) {
-// this.offline = offline;
-// }
-// public void setPackagelistLoc(String packagelistLoc) {
-// this.packagelistLoc = packagelistLoc;
-// }
-// }
-//
-// public void setLink(String href) {
-// createLink().setHref(href);
-// }
-//
-// public Link createLink() {
-// Link link = new Link();
-// links.add(link);
-// return link;
-// }
-//
-// public void setLinkoffline(String linkoffline) {
-// Link link = createLink();
-// int ispace = linkoffline.indexOf(" ");
-// if (ispace == -1) {
-// throw new BuildException("linkoffline usage: <url> <url2>!", location);
-// }
-// link.setHref(linkoffline.substring(0, ispace).trim());
-// link.setPackagelistLoc(linkoffline.substring(ispace+1).trim());
-// }
-//
-// public class Group {
-// private String title;
-// private List packages;
-// public Group() {}
-// public void setTitle(String title) {
-// this.title = title;
-// }
-// public final void setPackages(String packages) {
-// setPackagenames(packages);
-// }
-// public void setPackagenames(String packages) {
-// this.packages = strings(packages);
-// }
-// }
-//
-// public void setGroup(String str) {
-// for (StringTokenizer t = new StringTokenizer(str, ",", false);
-// t.hasMoreTokens();) {
-// String s = t.nextToken().trim();
-// int ispace = s.indexOf(' ');
-// if (ispace != -1) {
-// Group group = createGroup();
-// group.setTitle(s.substring(0, ispace));
-// group.setPackagenames(s.substring(ispace+1));
-// } else {
-// throw new BuildException
-// ("group usage: group=[<title> <pkglist>]*", location);
-// }
-// }
-// }
-//
-// public Group createGroup() {
-// Group group = new Group();
-// groups.add(group);
-// return group;
-// }
-//
-// public void setNodeprecated(boolean nodeprecated) {
-// setif(nodeprecated, "-nodeprecated");
-// }
-//
-// public void setNodeprecatedlist(boolean nodeprecatedlist) {
-// setif(nodeprecatedlist, "-nodeprecatedlist");
-// }
-//
-// public void setNotree(boolean notree) {
-// setif(notree, "-notree");
-// }
-//
-// public void setNoindex(boolean noindex) {
-// setif(noindex, "-noindex");
-// }
-//
-// public void setNohelp(boolean nohelp) {
-// setif(nohelp, "-nohelp");
-// }
-//
-// public void setNonavbar(boolean nonavbar) {
-// setif(nonavbar, "-nonavbar");
-// }
-//
-// public void setSerialwarn(boolean serialwarn) {
-// setif(serialwarn, "-serialwarn");
-// }
-//
-// public void setHelpfile(String helpfile) {
-// setfile("-helpfile", helpfile);
-// }
-//
-// public void setStylesheetfile(String stylesheetfile) {
-// setfile("-stylesheetfile", stylesheetfile);
-// }
-//
-// public void setCharset(String charset) { set("-charset", charset); }
-//
-// public void setDocencoding(String docencoding) {
-// set("-docencoding", docencoding);
-// }
-//
-// public void setDoclet(String doclet) {
-// createDoclet().setName(doclet);
-// }
-//
-// public static class Param {
-// protected String name;
-// protected String value;
-// public Param() {}
-// public void setName(String name) { this.name = name; }
-// public void setValue(String value) { this.value = value; }
-// }
-//
-// public class Doclet {
-// protected String name;
-// protected Path path;
-// protected List params = new ArrayList();
-// public Doclet() {}
-// public void setName(String name) {
-// this.name = name;
-// }
-// public void setPath(Path path) {
-// if (this.path == null) {
-// this.path = path;
-// } else {
-// this.path.append(path);
-// }
-// }
-// public Path createPath() {
-// return (path == null ?
-// path = new Path(project) :
-// path).createPath();
-// }
-// public Param createParam() {
-// Param param = new Param();
-// params.add(param);
-// return param;
-// }
-// }
-//
-// public Doclet createDoclet() {
-// if (doclet != null) {
-// throw new BuildException("Only one doclet is allowed!");
-// }
-// return doclet = new Doclet();
-// }
-//
-// public void setDocletpath(Path path) {
-// (docletpath == null ?
-// docletpath = path :
-// docletpath).append(path);
-// }
-//
-// public Path createDocletpath() {
-// return docletpath == null ?
-// (docletpath = new Path(project)) :
-// docletpath.createPath();
-// }
-//
-// public void setDocletpathRef(Reference id) {
-// createDocletpath().setRefid(id);
-// }
-//
-// public void setAdditionalparam(String additionalparam) {
-// cmd.createArgument().setLine(additionalparam);
-// }
-//
-// public void setFailonerror(boolean failonerror) {
-// this.failonerror = failonerror;
-// }
-//
-// public void setFork(boolean fork) {
-// this.fork = fork;
-// }
-//
-// public Commandline.Argument createJvmarg() {
-// return vmcmd.createArgument();
-// }
-//
-// public void setMaxmemory(String max) {
-// createJvmarg().setValue((Project.getJavaVersion().
-// startsWith("1.1") ?
-// "-mx" : "-Xmx") +max);
-// }
-//
-// public void execute() throws BuildException {
-// if (sourcepath == null && argfiles == null) {
-// throw new BuildException("one of sourcepath or argfiles must be set!",
-// location);
-// }
-// if (sourcepath != null) {
-// cmd.createArgument().setValue("-sourcepath");
-// cmd.createArgument().setPath(sourcepath);
-// }
-// if (destdir != null) {
-// cmd.createArgument().setValue("-d");
-// cmd.createArgument().setFile(destdir);
-// }
-// if (classpath != null) {
-// cmd.createArgument().setValue("-classpath");
-// cmd.createArgument().setPath(classpath);
-// }
-// if (bootclasspath != null) {
-// cmd.createArgument().setValue("-bootclasspath");
-// cmd.createArgument().setPath(bootclasspath);
-// }
-// if (extdirs != null) {
-// cmd.createArgument().setValue("-extdirs");
-// cmd.createArgument().setPath(extdirs);
-// }
-//
-// if (source14) {
-// cmd.createArgument().setValue("-source");
-// cmd.createArgument().setValue("1.4");
-// }
-//
-// for (Iterator i = links.iterator(); i.hasNext();) {
-// Link link = (Link)i.next();
-// if (link.href == null) {
-// throw new BuildException("Link href cannot be null!", location);
-// }
-// if (link.packagelistLoc != null) {
-// cmd.createArgument().setValue("-linkoffline");
-// cmd.createArgument().setValue(link.href);
-// cmd.createArgument().setValue(link.packagelistLoc);
-// } else {
-// cmd.createArgument().setValue("-link");
-// cmd.createArgument().setValue(link.href);
-// }
-// }
-// if (doclet != null) {
-// if (doclet.name == null) {
-// throw new BuildException("Doclet name cannot be null!", location);
-// }
-// cmd.createArgument().setValue("-doclet");
-// cmd.createArgument().setValue(doclet.name);
-// if (doclet.path != null) {
-// cmd.createArgument().setValue("-docletpath");
-// cmd.createArgument().setPath(doclet.path);
-// }
-// for (Iterator i = doclet.params.iterator(); i.hasNext();) {
-// Param param = (Param)i.next();
-// if (param.name == null) {
-// throw new BuildException("Doclet params cannot be null!",
-// location);
-// }
-// cmd.createArgument().setValue(param.name);
-// if (param.value == null) {
-// cmd.createArgument().setValue(param.value);
-// }
-// }
-// }
-// Map groupMap = new HashMap();
-// for (Iterator i = groups.iterator(); i.hasNext();) {
-// Group group = (Group)i.next();
-// if (group.title == null) {
-// throw new BuildException("Group names cannot be null!",
-// location);
-// }
-// if (group.packages == null) {
-// throw new BuildException("Group packages cannot be null!",
-// location);
-// }
-// List packages = (List)groupMap.get(group.title);
-// if (packages == null) {
-// packages = new ArrayList();
-// }
-// packages.addAll(group.packages);
-// groupMap.put(group.title, packages);
-// }
-// for (Iterator i = groupMap.keySet().iterator(); i.hasNext();) {
-// String title = (String)i.next();
-// List packages = (List)groupMap.get(title);
-// String pkgstr = "";
-// for (Iterator j = packages.iterator(); j.hasNext();) {
-// pkgstr += j.next();
-// if (j.hasNext()) pkgstr += ",";
-// }
-// cmd.createArgument().setValue("-group");
-// cmd.createArgument().setValue(title);
-// cmd.createArgument().setValue(pkgstr);
-// }
-// if (argfiles != null) {
-// for (Iterator i = argfiles.iterator(); i.hasNext();) {
-// String name = i.next()+"";
-// File argfile = project.resolveFile(name);
-// if (check(argfile, name, false, location)) {
-// cmd.createArgument().setValue("-argfile");
-// cmd.createArgument().setFile(argfile);
-// }
-// }
-// }
-// if (packageList != null) {
-// cmd.createArgument().setValue("@" + packageList);
-// }
-// if (null != packagenames) {
-// for (Iterator i = packagenames.iterator(); i.hasNext();) {
-// cmd.createArgument().setValue((String)i.next());
-// }
-// }
-// // support for include parameter as a MatchingTask
-// int numfiles = 0;
-// if (sourcepath != null) {
-// String[] dirs = sourcepath.list();
-// for (int i = 0; i < dirs.length; i++) {
-// File dir = project.resolveFile(dirs[i]);
-// check(dir, dirs[i], true, location);
-// String[] files = getDirectoryScanner(dir).getIncludedFiles();
-// for (int j = 0; j < files.length; j++) {
-// File file = new File(dir, files[j]);
-// if (file.getName().endsWith(".java")
-// || file.getName().endsWith(".aj")) {
-// cmd.createArgument().setFile(file);
-// numfiles++;
-// }
-// }
-// }
-// }
-// if (sourcefiles != null) {
-// for (Iterator i = sourcefiles.iterator(); i.hasNext();) {
-// // let ajdoc resolve sourcefiles relative to sourcepath,
-// cmd.createArgument().setValue((String)i.next());
-// }
-// }
-// // XXX PR682 weak way to report errors - need to refactor
-// int result = compile();
-// if (failonerror && (0 != result)) {
-// throw new BuildException("Ajdoc failed with code " + result);
-// }
-// reset();
-// }
-//
-// protected int compile() throws BuildException { // todo: doc that fork is ignored
-// try {
-// String[] args = cmd.getArguments();
-// if (fork) {
-// log("Warning: fork is ignored ", Project.MSG_WARN);
-// }
-// return Main.execute(args); // todo: direct to new Ajdoc().execute(..)?
-// } catch (Throwable t) {
-// throw new BuildException(t);
-// }
-// }
-//
-// protected interface Mapper {
-// public Object map(String str);
-// }
-//
-// protected final List list(String str, Mapper mapper) {
-// if (str == null) return Collections.EMPTY_LIST;
-// List list = new ArrayList();
-// for (StringTokenizer t = new StringTokenizer(str, ",", false);
-// t.hasMoreTokens();) {
-// list.add(mapper.map(t.nextToken().trim()));
-// }
-// return list;
-// }
-//
-// protected final List files(String str) {
-// return list(str, new Mapper() {
-// public Object map(String s) {
-// return project.resolveFile(s);
-// }
-// });
-// }
-//
-// protected final List strings(String str) {
-// return strings(str, false);
-// }
-//
-// protected final List strings(String str, final boolean filterSlashes) {
-// return list(str, new Mapper() {
-// public Object map(String s) {
-// return filterSlashes ? filterSlashes(s) : s;
-// }
-// });
-// }
-//
-// protected final String filterSlashes(String str) {
-// if (str == null) return null;
-// return str.
-// replace('/', '.').
-// replace('\\', '.').
-// replace(File.separatorChar, '.');
-// }
-//
-// protected final boolean check(File file, String name,
-// boolean isDir, Location loc) {
-// loc = loc != null ? loc : location;
-// if (file == null) {
-// throw new BuildException(name + " is null!", loc);
-// }
-// if (!file.exists()) {
-// throw new BuildException(file + "doesn't exist!", loc);
-// }
-// if (isDir ^ file.isDirectory()) {
-// throw new BuildException(file + " should" +
-// (!isDir ? "n't" : "") +
-// " be a directory!", loc);
-// }
-// return true;
-// }
-//}
+ public void setVersion(boolean b) {
+ setif(b, "-version");
+ }
+
+ public void setUse(boolean b) {
+ setif(b, "-use");
+ }
+
+ public void setStandard(boolean b) {
+ setif(b, "-standard");
+ }
+
+ public class Link {
+ protected String href;
+ protected boolean offline;
+ protected String packagelistLoc;
+ public Link() {}
+ public void setHref(String href) {
+ this.href = href;
+ }
+ public void setOffline(boolean offline) {
+ this.offline = offline;
+ }
+ public void setPackagelistLoc(String packagelistLoc) {
+ this.packagelistLoc = packagelistLoc;
+ }
+ }
+
+ public void setLink(String href) {
+ createLink().setHref(href);
+ }
+
+ public Link createLink() {
+ Link link = new Link();
+ links.add(link);
+ return link;
+ }
+
+ public void setLinkoffline(String linkoffline) {
+ Link link = createLink();
+ int ispace = linkoffline.indexOf(" ");
+ if (ispace == -1) {
+ throw new BuildException("linkoffline usage: <url> <url2>!", getLocation());
+ }
+ link.setHref(linkoffline.substring(0, ispace).trim());
+ link.setPackagelistLoc(linkoffline.substring(ispace+1).trim());
+ }
+
+ public class Group {
+ private String title;
+ private List packages;
+ public Group() {}
+ public void setTitle(String title) {
+ this.title = title;
+ }
+ public final void setPackages(String packages) {
+ setPackagenames(packages);
+ }
+ public void setPackagenames(String packages) {
+ this.packages = strings(packages);
+ }
+ }
+
+ public void setGroup(String str) {
+ for (StringTokenizer t = new StringTokenizer(str, ",", false);
+ t.hasMoreTokens();) {
+ String s = t.nextToken().trim();
+ int ispace = s.indexOf(' ');
+ if (ispace != -1) {
+ Group group = createGroup();
+ group.setTitle(s.substring(0, ispace));
+ group.setPackagenames(s.substring(ispace+1));
+ } else {
+ throw new BuildException
+ ("group usage: group=[<title> <pkglist>]*", getLocation());
+ }
+ }
+ }
+
+ public Group createGroup() {
+ Group group = new Group();
+ groups.add(group);
+ return group;
+ }
+
+ public void setNodeprecated(boolean nodeprecated) {
+ setif(nodeprecated, "-nodeprecated");
+ }
+
+ public void setNodeprecatedlist(boolean nodeprecatedlist) {
+ setif(nodeprecatedlist, "-nodeprecatedlist");
+ }
+
+ public void setNotree(boolean notree) {
+ setif(notree, "-notree");
+ }
+
+ public void setNoindex(boolean noindex) {
+ setif(noindex, "-noindex");
+ }
+
+ public void setNohelp(boolean nohelp) {
+ setif(nohelp, "-nohelp");
+ }
+
+ public void setNonavbar(boolean nonavbar) {
+ setif(nonavbar, "-nonavbar");
+ }
+
+ public void setSerialwarn(boolean serialwarn) {
+ setif(serialwarn, "-serialwarn");
+ }
+
+ public void setHelpfile(String helpfile) {
+ setfile("-helpfile", helpfile);
+ }
+
+ public void setStylesheetfile(String stylesheetfile) {
+ setfile("-stylesheetfile", stylesheetfile);
+ }
+
+ public void setCharset(String charset) { set("-charset", charset); }
+
+ public void setDocencoding(String docencoding) {
+ set("-docencoding", docencoding);
+ }
+
+ public void setDoclet(String doclet) {
+ createDoclet().setName(doclet);
+ }
+
+ public static class Param {
+ protected String name;
+ protected String value;
+ public Param() {}
+ public void setName(String name) { this.name = name; }
+ public void setValue(String value) { this.value = value; }
+ }
+
+ public class Doclet {
+ protected String name;
+ protected Path path;
+ protected List params = new ArrayList();
+ public Doclet() {}
+ public void setName(String name) {
+ this.name = name;
+ }
+ public void setPath(Path path) {
+ if (this.path == null) {
+ this.path = path;
+ } else {
+ this.path.append(path);
+ }
+ }
+ public Path createPath() {
+ return (path == null ?
+ path = new Path(getProject()) :
+ path).createPath();
+ }
+ public Param createParam() {
+ Param param = new Param();
+ params.add(param);
+ return param;
+ }
+ }
+
+ public Doclet createDoclet() {
+ if (doclet != null) {
+ throw new BuildException("Only one doclet is allowed!");
+ }
+ return doclet = new Doclet();
+ }
+
+ public void setDocletpath(Path path) {
+ (docletpath == null ?
+ docletpath = path :
+ docletpath).append(path);
+ }
+
+ public Path createDocletpath() {
+ return docletpath == null ?
+ (docletpath = new Path(getProject())) :
+ docletpath.createPath();
+ }
+
+ public void setDocletpathRef(Reference id) {
+ createDocletpath().setRefid(id);
+ }
+
+ public void setAdditionalparam(String additionalparam) {
+ cmd.createArgument().setLine(additionalparam);
+ }
+
+ public void setFailonerror(boolean failonerror) {
+ this.failonerror = failonerror;
+ }
+
+ public void setFork(boolean fork) {
+ this.fork = fork;
+ }
+
+ public Commandline.Argument createJvmarg() {
+ return vmcmd.createArgument();
+ }
+
+ public void setMaxmemory(String max) {
+ createJvmarg().setValue((Project.getJavaVersion().
+ startsWith("1.1") ?
+ "-mx" : "-Xmx") +max);
+ }
+
+ public void execute() throws BuildException {
+ if (sourcepath == null && argfiles == null) {
+ throw new BuildException("one of sourcepath or argfiles must be set!",
+ getLocation());
+ }
+ if (sourcepath != null) {
+ cmd.createArgument().setValue("-sourcepath");
+ cmd.createArgument().setPath(sourcepath);
+ }
+ if (destdir != null) {
+ cmd.createArgument().setValue("-d");
+ cmd.createArgument().setFile(destdir);
+ }
+ if (classpath != null) {
+ cmd.createArgument().setValue("-classpath");
+ cmd.createArgument().setPath(classpath);
+ }
+ if (bootclasspath != null) {
+ cmd.createArgument().setValue("-bootclasspath");
+ cmd.createArgument().setPath(bootclasspath);
+ }
+ if (extdirs != null) {
+ cmd.createArgument().setValue("-extdirs");
+ cmd.createArgument().setPath(extdirs);
+ }
+
+ if (source14) {
+ cmd.createArgument().setValue("-source");
+ cmd.createArgument().setValue("1.4");
+ }
+
+ for (Iterator i = links.iterator(); i.hasNext();) {
+ Link link = (Link)i.next();
+ if (link.href == null) {
+ throw new BuildException("Link href cannot be null!", getLocation());
+ }
+ if (link.packagelistLoc != null) {
+ cmd.createArgument().setValue("-linkoffline");
+ cmd.createArgument().setValue(link.href);
+ cmd.createArgument().setValue(link.packagelistLoc);
+ } else {
+ cmd.createArgument().setValue("-link");
+ cmd.createArgument().setValue(link.href);
+ }
+ }
+ if (doclet != null) {
+ if (doclet.name == null) {
+ throw new BuildException("Doclet name cannot be null!", getLocation());
+ }
+ cmd.createArgument().setValue("-doclet");
+ cmd.createArgument().setValue(doclet.name);
+ if (doclet.path != null) {
+ cmd.createArgument().setValue("-docletpath");
+ cmd.createArgument().setPath(doclet.path);
+ }
+ for (Iterator i = doclet.params.iterator(); i.hasNext();) {
+ Param param = (Param)i.next();
+ if (param.name == null) {
+ throw new BuildException("Doclet params cannot be null!",
+ getLocation());
+ }
+ cmd.createArgument().setValue(param.name);
+ if (param.value == null) {
+ cmd.createArgument().setValue(param.value);
+ }
+ }
+ }
+ Map groupMap = new HashMap();
+ for (Iterator i = groups.iterator(); i.hasNext();) {
+ Group group = (Group)i.next();
+ if (group.title == null) {
+ throw new BuildException("Group names cannot be null!",
+ getLocation());
+ }
+ if (group.packages == null) {
+ throw new BuildException("Group packages cannot be null!",
+ getLocation());
+ }
+ List packages = (List)groupMap.get(group.title);
+ if (packages == null) {
+ packages = new ArrayList();
+ }
+ packages.addAll(group.packages);
+ groupMap.put(group.title, packages);
+ }
+ for (Iterator i = groupMap.keySet().iterator(); i.hasNext();) {
+ String title = (String)i.next();
+ List packages = (List)groupMap.get(title);
+ String pkgstr = "";
+ for (Iterator j = packages.iterator(); j.hasNext();) {
+ pkgstr += j.next();
+ if (j.hasNext()) pkgstr += ",";
+ }
+ cmd.createArgument().setValue("-group");
+ cmd.createArgument().setValue(title);
+ cmd.createArgument().setValue(pkgstr);
+ }
+ if (argfiles != null) {
+ for (Iterator i = argfiles.iterator(); i.hasNext();) {
+ String name = i.next()+"";
+ File argfile = getProject().resolveFile(name);
+ if (check(argfile, name, false, getLocation())) {
+ cmd.createArgument().setValue("-argfile");
+ cmd.createArgument().setFile(argfile);
+ }
+ }
+ }
+ if (packageList != null) {
+ cmd.createArgument().setValue("@" + packageList);
+ }
+ if (null != packagenames) {
+ for (Iterator i = packagenames.iterator(); i.hasNext();) {
+ cmd.createArgument().setValue((String)i.next());
+ }
+ }
+ // support for include parameter as a MatchingTask
+ int numfiles = 0;
+ if (sourcepath != null) {
+ String[] dirs = sourcepath.list();
+ for (int i = 0; i < dirs.length; i++) {
+ File dir = getProject().resolveFile(dirs[i]);
+ check(dir, dirs[i], true, getLocation());
+ String[] files = getDirectoryScanner(dir).getIncludedFiles();
+ for (int j = 0; j < files.length; j++) {
+ File file = new File(dir, files[j]);
+ if (file.getName().endsWith(".java")
+ || file.getName().endsWith(".aj")) {
+ cmd.createArgument().setFile(file);
+ numfiles++;
+ }
+ }
+ }
+ }
+ if (sourcefiles != null) {
+ for (Iterator i = sourcefiles.iterator(); i.hasNext();) {
+ // let ajdoc resolve sourcefiles relative to sourcepath,
+ cmd.createArgument().setValue((String)i.next());
+ }
+ }
+ // XXX PR682 weak way to report errors - need to refactor
+ int result = compile();
+ if (failonerror && (0 != result)) {
+ throw new BuildException("Ajdoc failed with code " + result);
+ }
+ reset();
+ }
+
+ protected int compile() throws BuildException { // todo: doc that fork is ignored
+ try {
+ String[] args = cmd.getArguments();
+ if (fork) {
+ log("Warning: fork is ignored ", Project.MSG_WARN);
+ }
+ Main.main(args);
+ if (Main.hasAborted())
+ return 1;
+ else
+ return 0;
+ } catch (Throwable t) {
+ throw new BuildException(t);
+ }
+ }
+
+ protected interface Mapper {
+ public Object map(String str);
+ }
+
+ protected final List list(String str, Mapper mapper) {
+ if (str == null) return Collections.EMPTY_LIST;
+ List list = new ArrayList();
+ for (StringTokenizer t = new StringTokenizer(str, ",", false);
+ t.hasMoreTokens();) {
+ list.add(mapper.map(t.nextToken().trim()));
+ }
+ return list;
+ }
+
+ protected final List files(String str) {
+ return list(str, new Mapper() {
+ public Object map(String s) {
+ return getProject().resolveFile(s);
+ }
+ });
+ }
+
+ protected final List strings(String str) {
+ return strings(str, false);
+ }
+
+ protected final List strings(String str, final boolean filterSlashes) {
+ return list(str, new Mapper() {
+ public Object map(String s) {
+ return filterSlashes ? filterSlashes(s) : s;
+ }
+ });
+ }
+
+ protected final String filterSlashes(String str) {
+ if (str == null) return null;
+ return str.
+ replace('/', '.').
+ replace('\\', '.').
+ replace(File.separatorChar, '.');
+ }
+
+ protected final boolean check(File file, String name,
+ boolean isDir, Location loc) {
+ loc = loc != null ? loc : getLocation();
+ if (file == null) {
+ throw new BuildException(name + " is null!", loc);
+ }
+ if (!file.exists()) {
+ throw new BuildException(file + "doesn't exist!", loc);
+ }
+ if (isDir ^ file.isDirectory()) {
+ throw new BuildException(file + " should" +
+ (!isDir ? "n't" : "") +
+ " be a directory!", loc);
+ }
+ return true;
+ }
+}
diff --git a/taskdefs/src/org/aspectj/tools/ant/taskdefs/aspectjTaskdefs.properties b/taskdefs/src/org/aspectj/tools/ant/taskdefs/aspectjTaskdefs.properties
index 5f2239518..dfcfee696 100644
--- a/taskdefs/src/org/aspectj/tools/ant/taskdefs/aspectjTaskdefs.properties
+++ b/taskdefs/src/org/aspectj/tools/ant/taskdefs/aspectjTaskdefs.properties
@@ -1,2 +1,3 @@
ajc=org.aspectj.tools.ant.taskdefs.Ajc10
iajc=org.aspectj.tools.ant.taskdefs.AjcTask
+ajdoc=org.aspectj.tools.ant.taskdefs.Ajdoc
diff --git a/taskdefs/testsrc/org/aspectj/tools/ant/taskdefs/AjdocTest.java b/taskdefs/testsrc/org/aspectj/tools/ant/taskdefs/AjdocTest.java
index d73c8ee1a..4527c6c9f 100644
--- a/taskdefs/testsrc/org/aspectj/tools/ant/taskdefs/AjdocTest.java
+++ b/taskdefs/testsrc/org/aspectj/tools/ant/taskdefs/AjdocTest.java
@@ -14,6 +14,7 @@
package org.aspectj.tools.ant.taskdefs;
import org.apache.tools.ant.Project;
+import org.apache.tools.ant.types.Path;
import java.io.File;
@@ -34,21 +35,22 @@ public class AjdocTest extends TestCase {
Ajdoc task = new Ajdoc();
Project p = new Project();
task.setProject(p);
- // XXX restore when ajdoc is restored
-// task.setSource("1.4");
-// task.setSourcepath(new Path(p, "testdata"));
-// task.setIncludes("Ajdoc14Source.java");
-// task.setDestdir("bin/AjdocTest");
-// task.setClasspath(new Path(p, "../lib/test/aspectjrt.jar"));
+ task.setSource("1.4");
+ Path ppath = new Path(p,"../taskdefs/testdata");
+ task.setSourcepath(ppath);
+ task.setIncludes("Ajdoc14Source.java");
+ task.setDestdir("bin/AjdocTest");
+ task.setClasspath(new Path(p, "../lib/test/aspectjrt.jar"));
+ task.execute();
+ }
+
+ public void testHelp() {
+ Ajdoc task = new Ajdoc();
+ Project p = new Project();
+ task.setProject(p);
+ task.setSourcepath(new Path(p, "../taskdefs/testdata"));
+ task.setIncludes("none");
+ task.setDestdir("bin/AjdocTest");
task.execute();
}
-// public void testHelp() {
-// Ajdoc task = new Ajdoc();
-// Project p = new Project();
-// task.setProject(p);
-// task.setSourcepath(new Path(p, "testdata"));
-// task.setIncludes("none");
-// task.setDestdir("bin/AjdocTest");
-// task.execute();
-// }
}