Wiki source code of WOProject-Ant

Version 100.2 by Larry Mills-Gahl on 2023/11/13 11:56

Show last authors
1 WOProject Ant Tasks is a suite of extensions for ant to build WOApplications, WOFrameworks and native launchers for the standalone Java application.
2
3 == Introduction ==
4
5 Ant build files are broken into what are called '[[targets>>url:http://ant.apache.org/manual/using.html#targets||shape="rect"]]', similar to a [[Makefile>>url:http://en.wikipedia.org/wiki/Makefile||shape="rect"]]. These targets are a group of, what are called, '[[tasks>>url:http://ant.apache.org/manual/tasksoverview.html||shape="rect"]]'. Tasks are used for getting work done; they make something happend directly, e.g. [[move files>>url:http://ant.apache.org/manual/CoreTasks/move.html||shape="rect"]] on the filesystem, [[compile java>>url:http://ant.apache.org/manual/CoreTasks/javac.html||shape="rect"]] source files into classes, [[transfer files>>url:http://ant.apache.org/manual/OptionalTasks/scp.html||shape="rect"]] from one server to another over ssh, etc.
6
7 While Ant is distributed with around fifty built-in tasks, any number of customized tasks can easily be added by developers outside of the core Ant team.
8
9 WOProject is such a project. WOProject adds a half dozen tasks to Ant. These tasks allow WebObject developers the freedom to use Ant in their build process, instead of the using Apple's XCode suite. A few of these tasks are: [[doc:WOL.WOCompile]], [[doc:WOL.WOApplication]], [[doc:WOL.WOFramework]]. By using the -lib command line option to refer to woproject.jar, these tasks can be used directly in the typical Ant {{code language="none"}}build.xml{{/code}} file in building your WebObjects projects outside of the Eclipse/WOLips environment. It is not recommended to drop woproject.jar into your ant lib directory since woproject is under continuous development and different versions can trigger problems such as errors when build WOnder from source.
10
11 See the link above to the old site for in-depth documentation on each of these new tasks.
12
13 Reasons for using Ant to build WebObjects frameworks and applications:
14
15 * Ant is highly configurable and flexible, with constant additions from the open source community, and is considered a defacto standard by the Java community
16
17 * Builds of projects with a very large number of files without dependency failures
18
19 * Allows easy automation of daily builds for teams of developers, i.e. nightly builds for smoke testing, etc.
20
21 == Download and Install ==
22
23 You can download the ant tasks --from the [[sourceforge>>url:http://sourceforge.net/projects/woproject/||shape="rect"]] page-- from the automated [[Hudson build>>url:http://webobjects.mdimension.com/hudson/job/WOLipsStable/lastSuccessfulBuild/artifact/||shape="rect"]] page for WOProject. If you have installed the wolips material for using WebObjects with Eclipse then you can also find the ant tasks there. The path for this will look something like {{code language="none"}}.../eclipse/plugins/org.objectstyle.wolips.woproject.ant_2.0.0.3458/lib/woproject.jar{{/code}}. To use the ant plugins outside of Eclipse, either by extracting the jar file from the Eclipse distribution or by downloading it separately, you will need to install them into your computers' ant lib directory. On MacOS-X this would be{{code language="none"}} /Developer/Java/Ant/lib/woproject.jar{{/code}} (on Leopard w/ XCode 3.0, this would be {{code language="none"}}/usr/share/ant/lib/woproject.jar{{/code}}. You can also put this jar in {{code language="none"}}USER_HOME/.ant/lib/woproject.jar{{/code}}. A quick way to see where all of these lib directories are and what is loaded is to type '{{code language="none"}}ant -diagnostics{{/code}}').
24
25 == Ant Tasks ==
26
27 //(for tasks not documented here see// //[[//the old site//>>url:http://objectstyle.org/woproject-old/ant/||shape="rect"]]).//
28
29 * Java Launchers
30 ** [[doc:WOL.JApplication]]: A task for assembling native launchers for any Java applications for a number of OS platforms.
31
32 * Core WebObjects Tasks
33 ** [[doc:WOL.WOCompile]]: A Javac task extension that allows including WOFrameworks in CLASSPATH.
34 ** [[doc:WOL.WOApplication]]: A task for assembling WebObjects applications.
35 ** [[doc:WOL.WOFramework]]: A task for assembling WebObjects frameworks.
36 ** [[doc:WOL.WOGen]]: A task for generating custom Java EO classes from EOModel.
37 ** [[doc:WOL.EOModel]]: A task for configuring custom connection dictionary for EOModels.
38
39 * WebObjects Tools Integration Tasks:
40 ** [[PBIndex>>doc:WOL.PBIndex]]: Maintains PB.project file for integration with WOBuilder on Windows.
41 ** [[PBXIndex>>doc:WOL.PBXIndex]]: Maintains PBX.pbproj file for integration with WOBuilder and EOModeler on older Mac OS X.
42 ** [[XcodeIndex>>doc:WOL.XcodeIndex]]: Maintains XCode project files for integration with WOBuilder on the latest Mac OS X.
43
44 * [[doc:WOL.Embedding WOFrameworks]]
45 * [[doc:WOL.Servlet Builds]]
46
47 == FAQ ==
48
49 === I am making an EO adaptor framework and so need to manipulate the {{code language="none"}}Info.plist{{/code}} ===
50
51 Edit the {{code language="none"}}build.properties{{/code}} file and modify the {{code language="none"}}customInfoPListContent{{/code}} which will be appended near the end of the {{code language="none"}}Info.plist{{/code}} file that is constructed when the framework is build.