You can not select more than 25 topics Topics must start with a chinese character,a letter or number, can include dashes ('-') and can be up to 35 characters long.

WHATSNEW 71 kB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915
  1. Changes from Ant 1.5.2 to current CVS version
  2. =============================================
  3. Changes that could break older environments:
  4. --------------------------------------------
  5. * Targets cannot have the empty string as their name any longer.
  6. * ant.jar's manifest does no longer include a Class-Path entry, so it
  7. is no longer possible to run Ant via "java -jar ant.jar" without
  8. manually altering the CLASSPATH. Instead of that a file
  9. ant-bootstrap.jar is included in the etc directory of the binary
  10. distribution, copy this to the lib directory and use
  11. "java -jar ant-bootstrap.jar" instead if you want to run Ant without
  12. the wrapper script (not recommended).
  13. * The <script> task now requires Apache BSF instead of the older IBM
  14. version. See <http://jakarta.apache.org/bsf/>
  15. * <xmlproperty> will no longer fail if the file to be loaded doesn't exist.
  16. * ZipScanner#getIncludedFiles will now return the names of the ZipEntries
  17. that have been matched instead of the name of the archive.
  18. * XML namespaces are now enabled in the XML parser, meaning XML namespace
  19. declarations no longer cause errors.
  20. * The <zip> task and friends have been heavily modified, almost every
  21. method signature of the Zip class has changed. If you have subclassed
  22. Zip (or one of its subclasses), your class will most likely not
  23. compile against the current code base. If it still compiles, it will
  24. probably not work as in Ant 1.5.1.
  25. Fixed bugs:
  26. -----------
  27. * <translate> was not ignoring comment lines.
  28. * Expand tasks did not behave as expected with PatternSets.
  29. * <property environment=... /> now works on OS/400.
  30. * <manifest> wouldn't update an existing manifest if only an attribute
  31. of an existing section changed.
  32. * ant.bat now supports the ANT_ARGS and JAVACMD environment variables
  33. again (like Ant 1.5 did).
  34. * The "plain" <junit> <formatter> could throw a NullPointerException
  35. if an error occured in setUp.
  36. * <cab> could hang listcab on large <fileset>s.
  37. * <junit> will now produce output when a test times out as well.
  38. * The starteam stcheckout, stcheckin tasks now correctly compute status of files
  39. against whatever local tree they are run against and, optionally, will not
  40. process a file if it is current. Previously you had to process everything
  41. unless you ran against the default folder which wasn't the normal use-case for
  42. ant-starteam. The stlist task now similarly displays that status correctly
  43. making it a more generally useful tool.
  44. * <replace> would count some internal character replacements when
  45. reporting the number of replaced tokens.
  46. * <concat> would cause an exception if a <filelist> pointed to files
  47. that do not exist.
  48. * <javadoc> will now pass -source to custom doclets as well.
  49. * <cvstagdiff> would throw a NullPointException if there had been no
  50. differences.
  51. * <cvschangelog> could miss today's changes.
  52. * entity includes would cause exceptions if path names included spaces.
  53. * <concat> could append newline characters between concatenated files.
  54. * <xmlvalidate> ignored the specified encoding of the files to
  55. validate.
  56. * the errorsbeginat attribute of the <http> condition didn't work.
  57. * Ant will try to force loading of certain packages like com.sun.*
  58. from the system classloader. The packages are determined by the
  59. version of the JVM running Ant.
  60. * Ant didn't find the runtime libraries on IBM's JDK 1.4 for Linux.
  61. * addConfiguredXXX would not work for TaskAdapter wrapped tasks
  62. * random component of temporary files is now always a positive integer.
  63. * Fix <ilasm> outputfile testing so that the output file does not need
  64. to exist beforehand.
  65. * Ant could incorrectly try to use the 1.4 regexp implementation even
  66. if it isn't available if you run the JVM with -Xverify:none.
  67. * Ant would die with an exception if you used nested <reference>
  68. elements in Ant and the refid attribute didn't point to an existing
  69. project reference.
  70. * The <get> task can now be compiled (and Ant thus bootstrapped) using
  71. Kaffee.
  72. * build.sysclasspath will now be honored by more tasks.
  73. * <jar update="true"> would remove the original manifest.
  74. * Ant will now exit with a return code of 1 if it encounters problems
  75. with the command line arguments.
  76. * ClassLoader creation changes to use a factory method in Project. A new
  77. class AntClassLoader2 implemented for 1.2+ specific features including
  78. Package information and addition of classes specified in the Class-Path
  79. element of a Jar's manifest.
  80. * It is now possible in <exec> to resolve the executable to a project basedir or
  81. execution dir relative executable. The resolveExecutable must be used to
  82. pick up such executables.
  83. * splash screen wouldn't disppear when build was finished.
  84. * <exec> output and error streams can now be redirected independently to either
  85. a property or a file (or both)
  86. Other changes:
  87. --------------
  88. * The filesetmanifest attribute of <jar> has been reenabled.
  89. * The start and end tokens for <translate> may now be longer than a
  90. single character.
  91. * <setproxy> lets you set the username and password for proxies that want authentication
  92. * <loadproperties> has a new encoding attribute.
  93. * <echoproperties> can now create XML output.
  94. * <echoproperties> has a new srcfile attribute that can make it read
  95. properties files and output them instead of Ant's properties.
  96. * <filterset> will now resolve filters recursively.
  97. * <input> has a new attribute that allows you to specify a default value.
  98. * All tasks can be used outside of <target>s
  99. * Added <image> task (requires JAI).
  100. * New condition <isreference>
  101. * <ftp> now has a preservelastmodified attribute to preserve the
  102. timestamp of a downloaded file.
  103. * new rmdir action for <ftp> that removes directories from a fileset.
  104. * The SOS and VSS tasks will no longer unconditionally prepend a $ to
  105. vsspath or projectpath.
  106. * OS/400 now gets detected by the os condition.
  107. * <arg> has a new attribute pathref that can be used to reference
  108. previously defined paths.
  109. * <xmlproperty> has been improved, you can now expand ${properties},
  110. define ids or paths and use Ant's location magic for filename resolutions
  111. in the XML file.
  112. * <xmlcatalog> will now support external catalogs according to the
  113. OASIS "Open Catalog" standard - if resolver.jar (newer than version
  114. 1.0) from Apache's xml-commons is in your CLASSPATH.
  115. * Starteam tasks now have support for revision labels and build labels.
  116. Checkouts now have the option of using repository timestamps, instead
  117. of current.
  118. * new task <symlink> that creates and maintains symbolic links.
  119. * new tasks <chown> and <chgrp> which are wrappers of the Unix commands.
  120. * new task <attrib> to change file attributes on Windows systems.
  121. * MailLogger now sets the Date header correctly.
  122. * Shipped XML parser is now Xerces 2.3.0
  123. * <style> has a new attribute reloadstylesheet to work around a
  124. bug in widespread Xalan versions.
  125. * <tarfileset> has a new dirmode attribute to specify the permissions
  126. for directories.
  127. * <zip> can now store Unix permissions in a way that can be
  128. reconstructed by Info-Zip's unzip command.
  129. * <fixcrlf>'s eol attribute now also understand "mac", "unix" and "dos".
  130. * <classfileset> now picks up dependencies of the form MyClass.class. This
  131. works for the code generated by the Sun java compiler. It may not work for
  132. all compilers.
  133. * <tar>'s up-to-date check didn't work for nested <(tar)fileset>s.
  134. * a new attribute "globalopts" can be added to all Perforce tasks.
  135. You can put in it all the strings described by p4 help usage. Refer to
  136. the docs for more information.
  137. * <replaceregexp> now has an optional encoding attribute to support
  138. replacing in files that are in a different encoding than the
  139. platform's default.
  140. Changes from Ant 1.5.1Beta1 to 1.5.1
  141. ====================================
  142. Fixed bugs:
  143. -----------
  144. * <tstamp>'s prefix attribute failed to apply to nested <format> elements.
  145. * <junitreport> created an empty junit-noframes.html if no format had
  146. been specified.
  147. * <basename> would remove more than it should if the file name
  148. contained more than one dot.
  149. * <filterset>s nested into <filterset>s didn't work.
  150. Other changes:
  151. --------------
  152. * Shipped XML parser is now Xerces 2.2.0
  153. * Filesets now support a 'file' attribute, allowing a single-file
  154. fileset to be constructed without having to specify its parent
  155. directory separately.
  156. * <junit> will now return the result of a call to getName instead of
  157. "unknown" for Test implementations that don't extend TestCase but have
  158. a public String getName() method.
  159. Changes from Ant 1.5 to 1.5.1Beta1
  160. ==================================
  161. Fixed bugs:
  162. -----------
  163. * Date/time in CvsChangeLog was in local timezone and 12 hour format leading
  164. to a problem when sorting by time. It is now UTC (GMT) and in 24-hour
  165. format as per cvs 'specifications'.
  166. * CvsTagDiff now supports ampersand modules or modules that have a different
  167. root directory than their name.
  168. * EjbJar threw NPEs for the Websphere element. The property 'websphere.home'
  169. was not documented.
  170. * Mail example in the documentation was not correct.
  171. * Checksum was broken in the following scenario:
  172. (using verifyproperty OR in a condition) AND using filesets
  173. with multiple files.
  174. * The ExpandProperties filter threw NPEs when defined using
  175. the <filterreader> format.
  176. * The sh wrapper script didn't work under Cygwin if ANT_HOME wasn't
  177. set with a Unix style filename.
  178. * The sh wrapper script could fail if you started Ant from a directory
  179. with whitespace in its name.
  180. * ant -diagnostics was not working properly when the task dependency
  181. was missing and was just printing the missing dependency.
  182. * If a task got redefined via <taskdef>, it lost its child elements.
  183. * <property>'s classpathref attribute was broken.
  184. * <arg line="''" /> would result in no command line argument, will now
  185. be a single empty argument. Use <arg value="''"/> if you need the
  186. quotes literally.
  187. * <replaceregexp> could append a newline character at the end of the
  188. file.
  189. Other changes:
  190. --------------
  191. * Appendix E of Java Development with Ant (Loughran/Hatcher) was
  192. contributed to the docs.
  193. * <available> will only print deprecration warnings if it is actually
  194. used to change the value of a property.
  195. Changes from Ant 1.5beta3 to Ant 1.5
  196. ====================================
  197. Changes that could break older environments:
  198. --------------------------------------------
  199. * The filesetmanifest attribute added to <jar> after the 1.4.1
  200. release has been removed for now. This change may affect only
  201. the 1.5Beta/1.6Alpha users. An attempt will be made to add this
  202. feature back into Ant 1.6.
  203. Fixed bugs:
  204. -----------
  205. * <zip> and friends would always update existing archive if you set
  206. the update attribute to true.
  207. * To support backward compatibility with older versions, <pathconvert>
  208. will once again set the property, even if the result is the empty
  209. string, unless the new 'setonempty' attribute is set to false|no|off
  210. (default is "true").
  211. * The manifest task would crash XmlLogger
  212. Other changes:
  213. --------------
  214. * added **/.svn and **/.svn/** to the default excludes
  215. Changes from Ant 1.5beta2 to Ant 1.5beta3
  216. =========================================
  217. Changes that could break older environments:
  218. --------------------------------------------
  219. * Project.getBuildListeners now returns a clone of the listener
  220. list. Changes to the returned list will not affect the listeners
  221. currently attached to the Project. It also means that it is safe to
  222. iterate over the returned list if listeners are added or removed
  223. during the traversal.
  224. * <pvcs> default filenameformat has been different from Ant 1.4.1.
  225. Now it is different from 1.5beta1 and 1.5beta2.
  226. * Some messages that are printed during startup will not be
  227. written to the logfile specified via -logfile as they might destroy
  228. the format of the file for special BuildLoggers (like XmlLogger).
  229. * <pathconvert> won't set the property if the result is the empty string.
  230. Fixed bugs:
  231. -----------
  232. * <available> could fail to find files or directories that happen to
  233. start with the name of the project's basedir but are not children of
  234. the basedir.
  235. * Nested <property>'s inside <ant> can now be overriden by subsequent
  236. <ant> and <antcall> tasks.
  237. * <xslt>'s outputtype attribute wouldn't do anything.
  238. * <linecontains> filterreader could swallow lines.
  239. * <sequential> used to configure the tasks (set their attributes)
  240. before the first task has been executed. This means that properties
  241. that have been set by nested task seemed to be unset for the other
  242. tasks in the same <sequential> element.
  243. * <javac>'s sourcepath setting has been ignored by some compiler
  244. implementations.
  245. * <javadoc>'s packagelist attribute didn't work.
  246. * the plain mailer would always use port 25 in <mail>.
  247. * Ant's default logger could swallow empty lines.
  248. * ejbjar's iPlanet nested element now can process multiple descriptors.
  249. * IPlanetEjbc was looking in the wrong place for four iiop files.
  250. * <javac> would pass the -source switch to JDK 1.3's javac, even
  251. though it doesn't support it.
  252. Other changes:
  253. --------------
  254. * <checksum> now uses a buffer (of configurable size).
  255. * The "Trying to override task definition" warning has been degraded
  256. to verbose level if the two task definitions only differ in the class
  257. loader instance that has loaded the definition.
  258. * Add a jvmargs to the ejbjar's weblogic element to allow additional
  259. arguments to be provided to the VM runnign ejbc. Document the
  260. jvmdebuglevel attribute which can be used to avoid warnings about
  261. interface classess being found on the classpath. Document the new
  262. <sysproperty> element which allows JVM properties to be defined.
  263. Added an outputdir attribute to allow the destination to be a
  264. directory into which the exploded jar is written.
  265. * ejbjar now supports Borland Enterprise Server 5 and Jonas 2.5
  266. Changes from Ant 1.5beta1 to Ant 1.5beta2
  267. =========================================
  268. Changes that could break older environments:
  269. --------------------------------------------
  270. * Properties will now be expanded in mail message bodies. This means
  271. that one $ sign will be stripped if your mail message contains the text
  272. $$.
  273. * org.apache.tools.ant.taskdefs.Expand no longer extends MatchingTask.
  274. * Available#setFile now again uses a File argument as it did in 1.4,
  275. this may break environments that have been adapted to the String
  276. argument version present in 1.5beta1.
  277. Fixed bugs:
  278. -----------
  279. * When <move> attempts a rename, it deletes the destination file, if it
  280. exists, before renaming the source file. However, <move> was not
  281. checking if the destination file was actually a directory before
  282. trying to delete it.
  283. * Make CVS Tasks to work under Cygwin.
  284. * Fix LineContains to handle huge files elegantly without causing
  285. Stack Overflows.
  286. * if you ask for the "classic" compiler on Java1.4, you get upgraded to
  287. "modern" because there is no classic compiler any more.
  288. * the <http> condition was viewing 404 'not found' exceptions as success. Now
  289. it defaults to viewing any response >=400 as an error, and has an errorsBeginAt
  290. attribute you can use if you want a higher or lower value.
  291. * <get> throws a build exception on an http authorization error, unless you
  292. have set ignoreerrors to true.
  293. * <wsdltodotnet> was spelt in Wintel case: <WsdlToDotnet>. It is now lower
  294. case, though the old spelling is retained for anyone who used it.
  295. * Merging of Manifests in jar now works as documented.
  296. * paths that have been separated by colons would be incorrectly parsed
  297. on NetWare.
  298. * runant.pl now supports NetWare.
  299. * <tempfile> and <setproxy> tasks were in beta1, but not defined by
  300. default; They now are. <tempfile> fills a property with the name of a
  301. temporary file; <setproxy> lets you set the JVM's http, ftp and socks proxy
  302. settings.
  303. * <available classname="foo" ignoresystemclasses="true"> failed for
  304. JDK 1.1 and 1.2, even if the class could be found on the
  305. user-specified classpath.
  306. * <property environment=... /> now works on z/OS.
  307. * forked <javac> failed for the wrong reason on JDK 1.1 - Ant would
  308. use a temporary file to hold the names of the files to compile under
  309. some conditons, but 1.1 doesn't support this feature. Ant will no
  310. longer try this, but you may run into problems with the length of the
  311. command line now.
  312. * the refid attribute for <property>s nested into <ant> or <param>s
  313. nested into <antcall> didn't work.
  314. * <replaceregexp> didn't work for nested <fileset>s.
  315. * <javadoc> dropped sourcepath entries if no "interesting" .java
  316. source files could be found below them. This has been backwards
  317. incompatible and caused problems with custom doclets like xdoclet.
  318. * Using the doclet, docletpath or docletpathref attributes of
  319. <javadoc> may have caused NullPointerExceptions.
  320. * nested <filesets> of <javadoc> would include too much.
  321. * <dependset> will no longer choke on <targetfileset>s that point to
  322. non-existing directories.
  323. * <patch> didn't work at all.
  324. * <replace> and <replaceregexp> now fail if the file they are working
  325. on is locked.
  326. * <javadoc> would pick up the wrong executable in the combination JDK
  327. 1.2 and AIX.
  328. Other changes:
  329. --------------
  330. * z/OS now gets detected by the os condition.
  331. * <fileset> and <dirset> now have an optional followsymlink attribute
  332. that can prevent Ant from following symbolic links on some platforms.
  333. * BeanShell is now supported in the <script> task.
  334. * <ejbjar> under Weblogic attempts to use the ejbc20 compiler for 2.0 beans
  335. based on the deployment descriptor's DTD reference. Under weblogic 7.00 Beta
  336. this ejbc class has been deprecated. To avoid the deprecation warning use
  337. ejbcclass="weblogic.ejbc".
  338. * <ejbjar> will add a manifest to the generated jar based on the naming
  339. convention in use. This overrides the manifest specified in the
  340. <ejbjar> attribute
  341. Changes from Ant 1.4.1 to 1.5beta1
  342. ==================================
  343. Changes that could break older environments:
  344. --------------------------------------------
  345. * Important: Single $ signs are no longer silently stripped!
  346. =======
  347. * Project.getBuildListeners now returns a clone of the listener
  348. list. Changes to the returned list will not affect the listeners
  349. currently attached to the Project. It also means that it is safe to
  350. iterate over the returned list if listeners are added or removed
  351. during the traversal.
  352. * <pvcs> default filenameformat has been different from Ant 1.4.1.
  353. Now it is different from 1.5beta1 and 1.5beta2.
  354. * Some messages that are printed during startup will not be
  355. written to the logfile specified via -logfile as they might destroy
  356. the format of the file for special BuildLoggers (like XmlLogger).
  357. Fixed bugs:
  358. -----------
  359. * <available> could fail to find files or directories that happen to
  360. start with the name of the project's basedir but are not children of
  361. the basedir.
  362. * Nested <property>'s inside <ant> can now be overriden by subsequent
  363. <ant> and <antcall> tasks.
  364. * <xslt>'s outputtype attribute wouldn't do anything.
  365. * <linecontains> filterreader could swallow lines.
  366. * <sequential> used to configure the tasks (set their attributes)
  367. before the first task has been executed. This means that properties
  368. that have been set by nested task seemed to be unset for the other
  369. tasks in the same <sequential> element.
  370. * <javac>'s sourcepath setting has been ignored by some compiler
  371. implementations.
  372. * <javadoc>'s packagelist attribute didn't work.
  373. * the plain mailer would always use port 25 in <mail>.
  374. * Ant's default logger could swallow empty lines.
  375. * ejbjar's iPlanet nested element now can process multiple descriptors.
  376. * IPlanetEjbc was looking in the wrong place for four iiop files.
  377. * <javac> would pass the -source switch to JDK 1.3's javac, even
  378. though it doesn't support it.
  379. Other changes:
  380. --------------
  381. * <checksum> now uses a buffer (of configurable size).
  382. * The "Trying to override task definition" warning has been degraded
  383. to verbose level if the two task definitions only differ in the class
  384. loader instance that has loaded the definition.
  385. * Add a jvmargs to the ejbjar's weblogic element to allow additional
  386. arguments to be provided to the VM runnign ejbc. Document the
  387. jvmdebuglevel attribute which can be used to avoid warnings about
  388. interface classess being found on the classpath. Document the new
  389. <sysproperty> element which allows JVM properties to be defined.
  390. Added an outputdir attribute to allow the destination to be a
  391. directory into which the exploded jar is written.
  392. * ejbjar now supports Borland Enterprise Server 5 and Jonas 2.5
  393. Changes from Ant 1.5beta1 to Ant 1.5beta2
  394. =========================================
  395. Changes that could break older environments:
  396. --------------------------------------------
  397. * Properties will now be expanded in mail message bodies. This means
  398. that one $ sign will be stripped if your mail message contains the text
  399. $$.
  400. * org.apache.tools.ant.taskdefs.Expand no longer extends MatchingTask.
  401. * Available#setFile now again uses a File argument as it did in 1.4,
  402. this may break environments that have been adapted to the String
  403. argument version present in 1.5beta1.
  404. Fixed bugs:
  405. -----------
  406. * When <move> attempts a rename, it deletes the destination file, if it
  407. exists, before renaming the source file. However, <move> was not
  408. checking if the destination file was actually a directory before
  409. trying to delete it.
  410. * Make CVS Tasks to work under Cygwin.
  411. * Fix LineContains to handle huge files elegantly without causing
  412. Stack Overflows.
  413. * if you ask for the "classic" compiler on Java1.4, you get upgraded to
  414. "modern" because there is no classic compiler any more.
  415. * the <http> condition was viewing 404 'not found' exceptions as success. Now
  416. it defaults to viewing any response >=400 as an error, and has an errorsBeginAt
  417. attribute you can use if you want a higher or lower value.
  418. * <get> throws a build exception on an http authorization error, unless you
  419. have set ignoreerrors to true.
  420. * <wsdltodotnet> was spelt in Wintel case: <WsdlToDotnet>. It is now lower
  421. case, though the old spelling is retained for anyone who used it.
  422. * Merging of Manifests in jar now works as documented.
  423. * paths that have been separated by colons would be incorrectly parsed
  424. on NetWare.
  425. * runant.pl now supports NetWare.
  426. * <tempfile> and <setproxy> tasks were in beta1, but not defined by
  427. default; They now are. <tempfile> fills a property with the name of a
  428. temporary file; <setproxy> lets you set the JVM's http, ftp and socks proxy
  429. settings.
  430. * <available classname="foo" ignoresystemclasses="true"> failed for
  431. JDK 1.1 and 1.2, even if the class could be found on the
  432. user-specified classpath.
  433. * <property environment=... /> now works on z/OS.
  434. * forked <javac> failed for the wrong reason on JDK 1.1 - Ant would
  435. use a temporary file to hold the names of the files to compile under
  436. some conditons, but 1.1 doesn't support this feature. Ant will no
  437. longer try this, but you may run into problems with the length of the
  438. command line now.
  439. * the refid attribute for <property>s nested into <ant> or <param>s
  440. nested into <antcall> didn't work.
  441. * <replaceregexp> didn't work for nested <fileset>s.
  442. * <javadoc> dropped sourcepath entries if no "interesting" .java
  443. source files could be found below them. This has been backwards
  444. incompatible and caused problems with custom doclets like xdoclet.
  445. * Using the doclet, docletpath or docletpathref attributes of
  446. <javadoc> may have caused NullPointerExceptions.
  447. * nested <filesets> of <javadoc> would include too much.
  448. * <dependset> will no longer choke on <targetfileset>s that point to
  449. non-existing directories.
  450. * <patch> didn't work at all.
  451. * <replace> and <replaceregexp> now fail if the file they are working
  452. on is locked.
  453. * <javadoc> would pick up the wrong executable in the combination JDK
  454. 1.2 and AIX.
  455. Other changes:
  456. --------------
  457. * z/OS now gets detected by the os condition.
  458. * <fileset> and <dirset> now have an optional followsymlink attribute
  459. that can prevent Ant from following symbolic links on some platforms.
  460. * BeanShell is now supported in the <script> task.
  461. * <ejbjar> under Weblogic attempts to use the ejbc20 compiler for 2.0 beans
  462. based on the deployment descriptor's DTD reference. Under weblogic 7.00 Beta
  463. this ejbc class has been deprecated. To avoid the deprecation warning use
  464. ejbcclass="weblogic.ejbc".
  465. * <ejbjar> will add a manifest to the generated jar based on the naming
  466. convention in use. This overrides the manifest specified in the
  467. <ejbjar> attribute
  468. Changes from Ant 1.4.1 to 1.5beta1
  469. ==================================
  470. Changes that could break older environments:
  471. --------------------------------------------
  472. * Important: Single $ signs are no longer silently stripped!
  473. * The filesetmanifest attribute added to <jar> after the 1.4.1
  474. release has been removed for now. This change may affect only
  475. the 1.5Beta/1.6Alpha users. An attempt will be made to add this
  476. feature back into Ant 1.6.
  477. Fixed bugs:
  478. -----------
  479. * <zip> and friends would always update existing archive if you set
  480. the update attribute to true.
  481. * To support backward compatibility with older versions, <pathconvert>
  482. will once again set the property, even if the result is the empty
  483. string, unless the new 'setonempty' attribute is set to false|no|off
  484. (default is "true").
  485. * The manifest task would crash XmlLogger
  486. Other changes:
  487. --------------
  488. * added **/.svn and **/.svn/** to the default excludes
  489. Changes from Ant 1.5beta2 to Ant 1.5beta3
  490. =========================================
  491. Changes that could break older environments:
  492. --------------------------------------------
  493. * Project.getBuildListeners now returns a clone of the listener
  494. list. Changes to the returned list will not affect the listeners
  495. currently attached to the Project. It also means that it is safe to
  496. iterate over the returned list if listeners are added or removed
  497. during the traversal.
  498. * <pvcs> default filenameformat has been different from Ant 1.4.1.
  499. Now it is different from 1.5beta1 and 1.5beta2.
  500. * Some messages that are printed during startup will not be
  501. written to the logfile specified via -logfile as they might destroy
  502. the format of the file for special BuildLoggers (like XmlLogger).
  503. * <pathconvert> won't set the property if the result is the empty string.
  504. Fixed bugs:
  505. -----------
  506. * <available> could fail to find files or directories that happen to
  507. start with the name of the project's basedir but are not children of
  508. the basedir.
  509. * Nested <property>'s inside <ant> can now be overriden by subsequent
  510. <ant> and <antcall> tasks.
  511. * <xslt>'s outputtype attribute wouldn't do anything.
  512. * <linecontains> filterreader could swallow lines.
  513. * <sequential> used to configure the tasks (set their attributes)
  514. before the first task has been executed. This means that properties
  515. that have been set by nested task seemed to be unset for the other
  516. tasks in the same <sequential> element.
  517. * <javac>'s sourcepath setting has been ignored by some compiler
  518. implementations.
  519. * <javadoc>'s packagelist attribute didn't work.
  520. * the plain mailer would always use port 25 in <mail>.
  521. * Ant's default logger could swallow empty lines.
  522. * ejbjar's iPlanet nested element now can process multiple descriptors.
  523. * IPlanetEjbc was looking in the wrong place for four iiop files.
  524. * <javac> would pass the -source switch to JDK 1.3's javac, even
  525. though it doesn't support it.
  526. Other changes:
  527. --------------
  528. * <checksum> now uses a buffer (of configurable size).
  529. * The "Trying to override task definition" warning has been degraded
  530. to verbose level if the two task definitions only differ in the class
  531. loader instance that has loaded the definition.
  532. * Add a jvmargs to the ejbjar's weblogic element to allow additional
  533. arguments to be provided to the VM runnign ejbc. Document the
  534. jvmdebuglevel attribute which can be used to avoid warnings about
  535. interface classess being found on the classpath. Document the new
  536. <sysproperty> element which allows JVM properties to be defined.
  537. Added an outputdir attribute to allow the destination to be a
  538. directory into which the exploded jar is written.
  539. * ejbjar now supports Borland Enterprise Server 5 and Jonas 2.5
  540. Changes from Ant 1.5beta1 to Ant 1.5beta2
  541. =========================================
  542. Changes that could break older environments:
  543. --------------------------------------------
  544. * Properties will now be expanded in mail message bodies. This means
  545. that one $ sign will be stripped if your mail message contains the text
  546. $$.
  547. * org.apache.tools.ant.taskdefs.Expand no longer extends MatchingTask.
  548. * Available#setFile now again uses a File argument as it did in 1.4,
  549. this may break environments that have been adapted to the String
  550. argument version present in 1.5beta1.
  551. Fixed bugs:
  552. -----------
  553. * When <move> attempts a rename, it deletes the destination file, if it
  554. exists, before renaming the source file. However, <move> was not
  555. checking if the destination file was actually a directory before
  556. trying to delete it.
  557. * Make CVS Tasks to work under Cygwin.
  558. * Fix LineContains to handle huge files elegantly without causing
  559. Stack Overflows.
  560. * if you ask for the "classic" compiler on Java1.4, you get upgraded to
  561. "modern" because there is no classic compiler any more.
  562. * the <http> condition was viewing 404 'not found' exceptions as success. Now
  563. it defaults to viewing any response >=400 as an error, and has an errorsBeginAt
  564. attribute you can use if you want a higher or lower value.
  565. * <get> throws a build exception on an http authorization error, unless you
  566. have set ignoreerrors to true.
  567. * <wsdltodotnet> was spelt in Wintel case: <WsdlToDotnet>. It is now lower
  568. case, though the old spelling is retained for anyone who used it.
  569. * Merging of Manifests in jar now works as documented.
  570. * paths that have been separated by colons would be incorrectly parsed
  571. on NetWare.
  572. * runant.pl now supports NetWare.
  573. * <tempfile> and <setproxy> tasks were in beta1, but not defined by
  574. default; They now are. <tempfile> fills a property with the name of a
  575. temporary file; <setproxy> lets you set the JVM's http, ftp and socks proxy
  576. settings.
  577. * <available classname="foo" ignoresystemclasses="true"> failed for
  578. JDK 1.1 and 1.2, even if the class could be found on the
  579. user-specified classpath.
  580. * <property environment=... /> now works on z/OS.
  581. * forked <javac> failed for the wrong reason on JDK 1.1 - Ant would
  582. use a temporary file to hold the names of the files to compile under
  583. some conditons, but 1.1 doesn't support this feature. Ant will no
  584. longer try this, but you may run into problems with the length of the
  585. command line now.
  586. * the refid attribute for <property>s nested into <ant> or <param>s
  587. nested into <antcall> didn't work.
  588. * <replaceregexp> didn't work for nested <fileset>s.
  589. * <javadoc> dropped sourcepath entries if no "interesting" .java
  590. source files could be found below them. This has been backwards
  591. incompatible and caused problems with custom doclets like xdoclet.
  592. * Using the doclet, docletpath or docletpathref attributes of
  593. <javadoc> may have caused NullPointerExceptions.
  594. * nested <filesets> of <javadoc> would include too much.
  595. * <dependset> will no longer choke on <targetfileset>s that point to
  596. non-existing directories.
  597. * <patch> didn't work at all.
  598. * <replace> and <replaceregexp> now fail if the file they are working
  599. on is locked.
  600. * <javadoc> would pick up the wrong executable in the combination JDK
  601. 1.2 and AIX.
  602. Other changes:
  603. --------------
  604. * z/OS now gets detected by the os condition.
  605. * <fileset> and <dirset> now have an optional followsymlink attribute
  606. that can prevent Ant from following symbolic links on some platforms.
  607. * BeanShell is now supported in the <script> task.
  608. * <ejbjar> under Weblogic attempts to use the ejbc20 compiler for 2.0 beans
  609. based on the deployment descriptor's DTD reference. Under weblogic 7.00 Beta
  610. this ejbc class has been deprecated. To avoid the deprecation warning use
  611. ejbcclass="weblogic.ejbc".
  612. * <ejbjar> will add a manifest to the generated jar based on the naming
  613. convention in use. This overrides the manifest specified in the
  614. <ejbjar> attribute
  615. Changes from Ant 1.4.1 to 1.5beta1
  616. ==================================
  617. Changes that could break older environments:
  618. --------------------------------------------
  619. * Important: Single $ signs are no longer silently stripped!
  620. Before you panic that we have broken all your build files, we have kept
  621. the old "$$" -> "$" behaviour. So only build files which accidentally had
  622. a $ sign in a string that was being silently stripped may break.
  623. We added this fix to stop newbie confusion; if you want to write a
  624. build file which works on ant versions 1.4.1 or earlier, stay with
  625. the double $$ sign rule.
  626. * Shipped XML parser is now Xerces 2.0.1 along with the XML Parser APIs.
  627. XML Parser APIs is a separate jar that contains the necessary
  628. JAXP/DOM/SAX classes.
  629. * <telnet> was fixed to expand properties inside nested <read> and
  630. <write> elements; before this only happened when you assigned the text
  631. to the string attribute. If you had $ signs in the string, they may
  632. need escaping.
  633. * the RegexpMatcher interface has been extended to support case
  634. insensitive matches and other options - custom implementations of
  635. this interface won't work any longer. We recommend to use the new
  636. Regexp interface that also supports substitution instead of the
  637. RegexpMatcher interface in the future.
  638. * <gzip> will throw an exception if your src attribute points to a directory.
  639. * Unjar, Unzip and Unwar will throw an exception if the Src attribute
  640. represents a directory. Support for nested filesets is provided
  641. instead.
  642. * It is no longer possible to overwrite a property using tasks like
  643. <condition>, <exec>, <pathconvert>, or <tstamp>. In some exceptional
  644. cases it will generate a warning if you attempt to overwrite an
  645. existing property.
  646. * Taskwriters please note: Whenever tasks had any overloaded set* methods,
  647. Ant's introspection mechanism would select the last overloaded method
  648. provided to it by the Java Runtime. A modification has now been made such
  649. that when the Java Runtime provides a method with a String as its argument,
  650. a check is made to see if there is another overloaded method that takes in
  651. some other type of argument. If there is one such method, then the method
  652. that takes in String as an argument is not selected by the Introspector.
  653. * The pattern definition **/._* has been included into the Default
  654. Excludes list.
  655. * <propertyfile>'s <entry> element was modified to remove "never" as a value
  656. as its behavior was undocumented and flakey.
  657. * The -projecthelp flag now only prints out targets that include the
  658. 'description' attribute, unless the -verbose or -debug flag is included
  659. on the Ant command line.
  660. * Ant's testcases now require JUnit 3.7 or above, as they now use the new
  661. assertTrue method instead of assert.
  662. * If the 'output' attribute of <ant> is set to a simple filename or a
  663. relative path, the file is created relative to ${basedir}, not ${user.dir}.
  664. * The default value for build.compiler is now javac1.x with x
  665. depending on the JDK that is running Ant instead of classic/modern.
  666. Fixed bugs:
  667. -----------
  668. * A bug existed that prevented generated log files from being deleted as
  669. part of the build process itself. This has now been fixed.
  670. * Fixed bug where <move> ignored <filterset>s.
  671. * Ant works properly with the combination of Java1.4/WindowsXP.
  672. * Fixed bug where <java> used to sometimes invoke class constructors twice.
  673. * Fixed bug with 4NT shell support.
  674. * Fixed bug where ant would not perform ftp without remotedir being
  675. specified even though this was not mandatory.
  676. * Fixed bug where ant would not copy system properties into new Project
  677. in ant/antcall tasks when inheritall="false" is set.
  678. * <propertyfile> would not close the original property file.
  679. * <ant> will no longer override a subbuild's basedir with inheritall="true".
  680. * Fixed problem with the built-in <junit> formatters which assumed
  681. that only one test could be running at the same time - this is not
  682. necessarily true, see junit.extensions.ActiveTestSuite.
  683. * <jar>'s whenEmpty attribute is useless as JARs are never empty, they
  684. contain at least a manifest file, therefore it will now print a
  685. warning and do nothing.
  686. * <typedef> hasn't been all that useful as it couldn't be used outside
  687. of targets (it can now) and nested "unknown" elements have always
  688. been considered to be tasks (changed as well).
  689. * <fixcrlf> would fail for files that contained lines longer than 8kB.
  690. * Some junit formatters incorrectly assumed that all testcases would
  691. inherit from junit.framework.TestCase.
  692. * <fixcrlf> dropped the first characters from Mac files.
  693. Other changes:
  694. --------------
  695. * Selector Elements now provide a way to create filesets based on
  696. sophisticated selection criteria.
  697. * Gzip and Bzip2 files can now be constructed in the fly when using
  698. the tar task without having to create the intermediate tar file on
  699. disk. The Untar task can also untar GZip and BZip2 files on the fly
  700. without creating the intermediate tar file.
  701. * New optional type, <classfileset> added.
  702. * <ejbjar> now allows control over which additional classes and interfaces
  703. are added to the generated EJB jars. A new attribute "dependency" can be
  704. defined which controls what classes are added. The addition of classes now uses
  705. the Jakarta-BCEL library rather than reflection, meaning bean classes are
  706. no longer loaded into Ant's JVM. The default dependency analyzer is known as
  707. the ancestor analyzer. It provides the same behaviour as the 1.4.1 version of
  708. <ejbjar>. If the BCEL library is not present, a warning will be issued stating
  709. the ancestor analyzer is not available. In this case <ejbjar> will continue
  710. to function but will not add super classes to the jar.
  711. * <available> has a new attribute named ignoreSystemClasses.
  712. * New task <cvschangelog/> generates an XML report of changes that occur
  713. on CVS repository.
  714. * New filter readers: ClassConstants, ExpandProperties, HeadFilter,
  715. LineContains, LineContainsRegExp, PrefixLines, ReplaceTokens,
  716. StripJavaComments, StripLineBreaks, StripLineComments, TabsToSpaces,
  717. TailFilter.
  718. * <copy>, <loadfile>, <loadproperties>, <move> support FilterChains
  719. of FilterReaders.
  720. * New task <loadproperties> to load contents of file as Ant properties,
  721. with nested <filterchain> elements.
  722. * New task <loadfile> to load a whole file into a property.
  723. * New task <echoproperties> to list your current properties to the screen
  724. or a file.
  725. * New tasks <bzip2> and <bunzip2> to pack and unpack files using the
  726. BZip2 alogrithm.
  727. * New tasks <replaceregexp>, <checksum>, <translate>, <waitfor>,
  728. <manifest>, <vsscp>, <vssadd>, <vsscreate>, <splash>, <basename>, <dirname>,
  729. <concat>, <sourceoffsite>, <jarlib-available>, <jarlib-display>,
  730. <jarlib-manifest>, <jarlib-resolve>.
  731. * A new combined <mail> task, which replaces the old <mail> and
  732. <mimemail> tasks, has been added. The <mimemail> task, and
  733. old SendEmail and MimeMail classes have been deprecated.
  734. * Mail task allows specification of port number.
  735. * Users can control what <zip> and <jar> must do when duplicate files
  736. are found. A new element <zipgroupfileset> allows for multiple zip
  737. files to be merged into the archive. In addition, <jar> also has
  738. another new attribute: filesetmanifest. The existing manifest
  739. attribute of <jar> now also accepts the name of a jar added through
  740. a fileset.
  741. * gzip now checks that the zipfile is older than the source file
  742. before rebuilding the zipfile.
  743. * TarFileset takes in three new attributes - fullpath, prefix
  744. and preserveLeadingSlashes.
  745. * <move> attempts to rename the directory, if everything inside it is
  746. included, before performing file-by-file moves. This attempt will
  747. be done only if filtering is off and if mappers are not used. This
  748. is a performance improvement and there is no change otherwise in
  749. the funtionality of this task.
  750. * Exec task has extra attribute "resultproperty" to get the return code
  751. into a property.
  752. * Exec task prints a message when a timed-out process is killed.
  753. * Added optional attributes - name, arch and version to the <os> task.
  754. * Unjar, Untar, Unwar and Unzip now support patternsets to
  755. select files from an archive for extraction. Filesets may be
  756. used to select archived files for unarchival.
  757. * Javac task allows debug levels to be specified. Debug levels
  758. will have an effect only when the modern compiler or the
  759. classic compiler (version 1.2 and higher) is used and debugging
  760. is enabled.
  761. * Added support for specifying CVS_RSH in the <cvs/> task
  762. * The attributes zipfile, jarfile, warfile and earfile (from the Zip,
  763. Jar, War and Ear tasks) have been deprecated and superseded by a
  764. new attribute "destfile".
  765. * Added new conditions <isset>, <checksum>, <http>, <socket>, <contains>,
  766. <filesmatch>.
  767. * <taskdef> and <typedef> will now emit a warning if a task/type of
  768. the given name already exists.
  769. * A new revision of VAJ tasks: The most important new feature
  770. is the ability to execute VAJ tasks from the command line by
  771. exploiting the Remote Tool Access feature of VAJ.
  772. * Improved support for Novell NetWare.
  773. * Added an optional encoding attribute to <fixcrlf>.
  774. * <apply> has a new attribute relative that allows users to pass the
  775. filenames as relative instead of absolute paths on the command line.
  776. * References can now be copied into the child build by <ant> and
  777. <antcall> using nested <reference> elements or the new inheritRefs
  778. attribute.
  779. * <fail> now supports builds to fail based on conditions via if and
  780. unless attributes.
  781. * Ant now comes with two new BuildLogger implementations - one that
  782. can send emails containing a log of the build process (MailLogger),
  783. and one that colorizes the output based on message levels, using
  784. ANSI color code escape sequences (AnsiColorLogger).
  785. * A "package" mapper type has been added to allow package directory
  786. names replaced with the dotted form.
  787. * You can now specify environment variables in the <java> and <junit> tasks
  788. if the fork attribute has been set to true.
  789. * -propertyfile command-line option has been added to load an entire
  790. property file just as -D properties are declared (as user properties).
  791. -D properties take precedence over -propertyfile specified ones.
  792. * You can now set an ANT_ARGS environment variable to hold arguments you
  793. always want passed to the 'ant' command -- for example, if you always
  794. want to use a different logger or the -find flag.
  795. * <tstamp> now supports a new "prefix" attribute to prefix properties set.
  796. * You can now specify the -sourcepath for <javac> explicitly.
  797. * <javac> now supports a new "listfiles" attribute to list the source
  798. files it's handing off to the compiler.
  799. * The compiler implementation for <javac> can now be chosen on a task by
  800. task basis. The new "compiler" attribute of <javac> can be used to override
  801. the value of the build.compiler property, if set.
  802. * <javac> has a new nested element, <compilerarg>, which allows you
  803. to specify additional args for the specific compiler you're using.
  804. * <javac>'s "source" attribute is now enabled for jikes as well.
  805. * <propertyfile>'s <entry> now has a 'unit' attribute to specify the
  806. increment/decrement unit on date operations.
  807. * <property> now supports a 'prefix' attribute when loading from a file
  808. or resource.
  809. * In Ant 1.4, a feature has been added to the <junit> task that would
  810. add ant.jar, optional.jar and junit.jar implicitly to the classpath -
  811. this feature can now be disabled by setting the new includeantruntime
  812. attribute to false.
  813. * <style> behaves differently from any other directory-based task, as it
  814. processes all files that it finds in included directories in
  815. addition to the files matched by your patterns. There is now a new
  816. attribute, 'scanincludeddirectories', to suppress this behavior.
  817. * <javadoc> now supports a <tag> nested element to provide the -tag option
  818. to the standard Java 1.4 doclet. The element is ignored when not running
  819. on Java 1.4.
  820. * <ftp> can now chmod files on a remote server that supports
  821. "site chmod", as well as set the umask before transferring files, if
  822. the server supports "site umask".
  823. * New <serverdeploy> "optional" task.
  824. * <patternset> now supports nested patternsets.
  825. * Perforce tasks now support a "failonerror" attribute (defaults to "true").
  826. * Open Source application server JOnAS support:
  827. EJB hot deploy and deploy with <serverdeploy> and <ejbjar>
  828. * Added new DirSet (<dirset>) datatype.
  829. * <path> now supports nested <dirset> and <filelist> elements.
  830. * <pathconvert> now supports nested <dirset> and <filelist> elements.
  831. * <pathconvert>'s "dirsep" and "pathsep" attributes now accept
  832. multi-character values.
  833. * <copy> task now has a 'failonerror' attribute to allow keep-going
  834. behaviour when the file to be copied is not found (defaults to "true").
  835. * <uptodate> now has a 'srcfile' attribute to allow specifying a
  836. full-path filename.
  837. * <exec>, <sql> and <java> now support append attributes to allow
  838. appending the output to an existing file.
  839. * <java> now supports a timeout attribute analog to <exec> - it is
  840. highly recommended to only use it together with fork="true".
  841. * <javadoc> now supports a source attribute to enable javadoc to
  842. handle assertions present in JDK 1.4 source code.
  843. * <replace> supports a new replacefilterfile attribute that
  844. automatically turns all properties of a given file into
  845. replacefilters.
  846. * An alias of <xslt> has been added to refer to the <style> task.
  847. * The compiler implementation for <rmic> can now be chosen on a task by
  848. task basis. The new "compiler" attribute of <rmic> can be used to override
  849. the value of the build.rmic property, if set.
  850. * <rmic> has a new nested element, <compilerarg>, which allows you
  851. to specify additional args for the specific compiler you're using.
  852. * org.apache.tools.ant.XmlLogger now is a BuildLogger, rather than just
  853. a BuildListener. It can operate in either mode successfully.
  854. * <junit> has a new attribute "showoutput". If set to true, output
  855. generated by tests will be sent to Ant's logging system as well as
  856. to the formatters (instead of sending it to the formatters
  857. exclusively).
  858. * Ant has now a pluggable way to prompt users for input, which is used
  859. by the new <input> task. IDE integrators can provide an
  860. implementation of the InputHandler interface to decouple Ant's input
  861. from the console. An implementation that gets its input from a file
  862. for unattended builds is part of Ant's distribution.
  863. For more details see docs/manual/inputhandler.html.
  864. * <patch> has a new attribute that selects the directory in which to
  865. run the command.
  866. * <javadoc> now supports two new nested elements, <fileset> and <packageset>.
  867. Changes from Ant 1.4 to Ant 1.4.1
  868. ===========================================
  869. Fixed bugs:
  870. -----------
  871. * <ant>'s antfile attribute will now also be considered an absolute path on
  872. Windows systems, if it starts with a \ and no drive specifier.
  873. * The fullpath attribute of <zipfileset> has been ignored if you used
  874. the src attribute at the same time.
  875. * The manifest file is now always placed as the second entry (after /META-INF)
  876. in generated jars. This allows the manifest to be read by JarInputStreams
  877. * Fixed bug in depend task which would fail with a NullPointerException if no
  878. dependency cache was specified.
  879. * sql task now handles REM statements correctly so that lines starying with rem
  880. but which are not comments are actually processed.
  881. * XMLLogger now uses the task's name rather than the classname
  882. * <mapper>s will now work as expected if the to pattern expands to an
  883. absolute pathname.
  884. * <javac> didn't ignore memory settings in non-fork mode
  885. * <cab> didn't split the options attribute into several command line
  886. arguments correctly.
  887. Other changes:
  888. --------------
  889. * New source attribute for <javac> to enable assertion in JDK 1.4
  890. * XmlLogger and <antstructure> now add an encoding declaration to the
  891. XML files they generate.
  892. * <fileset> has a new attribute "casesensitive" to make it match
  893. filenames in a case insensitive way (if you set it to false) - by
  894. default filesets remain case sensitive.
  895. Changes from Ant 1.3 to Ant 1.4
  896. ===========================================
  897. Changes that could break older environments:
  898. --------------------------------------------
  899. * JUnitReport now uses the xalan redirect extension for multi-output.
  900. With Xalan 1.2.2 it forces the use of bsf.jar in the classpath.
  901. (Available in the xalan distribution). It is recommended to switch
  902. to Xalan 2.x that do not need it.
  903. * Zip.setWhenempty() has changed its signature.
  904. * <rmic> is now implemented using a factory. This makes extending
  905. rmic to use a new compiler a lot easier but may break custom
  906. versions of this task that rely on the old implementation.
  907. * several Zip methods have changed their signature as we now use a Zip
  908. package of our own that handles Unix permissions for directories.
  909. Furthermore <zip> will now use the platform's default character
  910. encoding for filenames - this is consistent with the command line
  911. ZIP tools, but causes problems if you try to open them from within
  912. Java and your filenames contain non US-ASCII characters. Use the new
  913. encoding attribute of the task and set it to UTF8 to get the old
  914. behavior.
  915. * The <pvcs> task has been moved to a package of its own.
  916. * JUnitResultFormater has two additional methods that must be
  917. implemented by custom formatters.
  918. * Ant will no longer use the canonical version of a path internally -
  919. this may yield different results on filesystems that support
  920. symbolic links.
  921. * The output generated by the xml formatter for <junit> has changed
  922. again, it doesn't format the numeric value in the time attribute anymore.
  923. * Pattern matching rules have changes slightly, the pattern foo*
  924. doesn't match files contained in a directory named foo - use foo/*
  925. instead.
  926. * <fixcrlf> will not remove trailing whitespace at the end of lines anymore.
  927. * The Classloader usage has been changed for the taskdef, property, available
  928. and sql tasks so that it delegates to the parent classloader. This may cause
  929. ClassNotFoundExceptions to be thrown if a system class attempts to load a
  930. class in the taskdef's classpath (typically factory objects).
  931. * Ant now allows multithreading of tasks and the containment of tasks within
  932. other tasks. This can break customer listeners which do not expect messages
  933. from a task before the previous task has finished.
  934. * Ant now installs its own ouput stream into System.out to route output to the
  935. task currently executing on the current thread. This also means that all
  936. output is now routed as Ant message events. Customer listeners and loggers
  937. should not call System.out at any time. This has always been true but such
  938. usage now will cause problems due to possible recursion.
  939. * Invalid manifest files will now cause build failures in the <jar> task.
  940. * Ant Introspection now looks for methods with method names starting with
  941. addConfigured. When called these methods are passed an argument after it has
  942. been configured from the build file. Custom tasks supporting nested elements
  943. starting with the name configured will no longer function.
  944. * The environment variable JAVACMD that can be used to specify the
  945. java executable to Ant's wrapper scripts must not contain additional
  946. command line parameters any longer - please use the environment
  947. variable ANT_OPTS for such parameters now.
  948. * Ant's wrapper scripts now quote the CLASSPATH environment variable, thus
  949. supporting classpaths which refer to directories containing spaces. This means
  950. that the CLASSPATH environment variable cannot have quotes. Any quotes should
  951. be removed. This will not affect the operation of the CLASSPATH environment
  952. variable in other contexts.
  953. * A delete task like
  954. <delete includeEmptyFilesets="true">
  955. <fileset dir="somedir" />
  956. </delete>
  957. will now remove "somedir" as well, unless there are still files left
  958. in it (matched by the default excludes).
  959. * The copy task will now fail if the file to be copied is not found.
  960. * Ant properties defined in properties files now behave the same way as
  961. properties defined in the build file. In particular the $ character needs
  962. to be escaped in property values by doubling it to $$. So, to define a
  963. property with the value $hello, you need to define it in a properties file
  964. as
  965. test.prop=$$hello
  966. This was not the case in Ant 1.3
  967. Other changes:
  968. --------------
  969. * New tasks: ear, p4counter, record, cvspass, vsscheckin, vsscheckout,
  970. typedef, sleep, mimemail, set of tasks for Continuus/Synergy, dependset,
  971. condition, maudit, mmetrics, jpcoverage, jpcovreport, jpcovmerge
  972. * Ant now uses JAXP 1.1
  973. * rmic now supports Kaffe's and Weblogic's version of rmic.
  974. * new magic property build.rmic to chose the rmic implementation
  975. * <tar> will now add empty directories as well
  976. * you can now specify a description for <p4change>
  977. * <touch> can now work on <fileset>s
  978. * <uptodate> now supports a value attribute
  979. * <fail> supports nested text
  980. * <fixcrlf> won't override files that are already in the correct
  981. format.
  982. * <sql> now supports REM comments as well as // and --
  983. * <jar> now has a nested <metainf> element following the same idea as
  984. <war>'s <webinf>.
  985. * <pvcs> can now handle multiple projects.
  986. * <available> now has a "type" attribute you can use in conjunction
  987. with the "file" attribute to specify whether the "file" you're
  988. looking for is a file or a directory.
  989. * New <junit> formatter named "brief"
  990. * <ejbjar> changes
  991. * Add support for Borland Application Server to the <ejbjar> task using
  992. a <borland> nested element.
  993. * Add support for iPlanet Application Server to the <ejbjar> task. Also
  994. includes some iPlanet utility tasks
  995. * Add support for JBoss Application Server to the <ejbjar> task.
  996. * Add a naming attribute to control the naming scheme that
  997. ejbjar uses to name the generated EJB jars.
  998. * Weblogic element now sets the compiler class for EJB 2.0 beans
  999. * <dtd> elements can be specified at the <ejbjar> level for building generic
  1000. beans
  1001. * <dtd> elements can now be URLs
  1002. * Allow the manifest to be specified for the generated jars
  1003. * The weblogic element now supprts an attribte noEJBC to skip the processing
  1004. of the jar by ejbc. The ejbc step will then occur at deployment
  1005. * weblogic will tell ejbc to use Jikes compiler if build.compiler is set to
  1006. jikes. It can be restored to the default, javac, operation if desired.
  1007. * Allow the <sql> Delimiter to be set in the so that Oracle stored procs may be
  1008. entered
  1009. * <execon> and <apply> can now optionally skip empty filesets.
  1010. * <javadoc> has a new useexternalfile attribute that makes it use a
  1011. temporary file for sourcefile and package names - helps to defeat
  1012. command line length limitations.
  1013. * Data types like <path> can now be defined inside of <target>s
  1014. * you can now specify a classpath for <style> - the XSLZ processor
  1015. will be loaded from this path
  1016. * added a force attribute to <style> to support dependencies that the
  1017. task cannot determine itself (dependency on parameters, not file
  1018. modification times for example)
  1019. * added vmlauncher attribute to exec tasks. This defaults to true. If
  1020. it is set to false, the VM's ability to launch commands in bypassed
  1021. and the OS shell, either directly or through the auxillary antRun
  1022. scripts is used.
  1023. * regexp mapper now supports the java.util.regex package of JDK 1.4.
  1024. * New filesonly attribute for <zip> and friends to suppress directory
  1025. entries.
  1026. * New update attribute for <zip> and friends - update an existing
  1027. archive instead of creating a new one.
  1028. * <apply> and <execon> have been merged into a single task.
  1029. * added vssver.scc to the default excludes
  1030. * <available> has a new filepath attribute/nested element that allows
  1031. you top search for a file in a given path.
  1032. * <junit> can now optionally set a property on test failure.
  1033. * <taskdef> can now define several tasks at once, reading the
  1034. name/classname pairs from a property file or resource.
  1035. * <unzip/unjar/unwar> and <untar> now have an overwrite attribute that
  1036. defaults to true. If set to false, files that are newer than the
  1037. files in the archive will not be replaced.
  1038. * <patternset> and <fileset> now support nested <in/excludesfile>
  1039. elements - using these you can have more than one in/excludes file
  1040. per <patternset>.
  1041. * Three new supported compilers for javac: kjc for kopi, gcj for the
  1042. gcc frontend and sj for Symantec's compiler.
  1043. In addition extJavac or the new fork attribute can be
  1044. used to run the JDK's javac in a JVM separate from Ant.
  1045. * <fixrlf> can now with CR only line-ends and can use an arbitraty
  1046. between 2 and 80.
  1047. * The .NET tasks have been adapted to the beta2 release of the framework.
  1048. * <move> will now try to rename() files before copying them byte by
  1049. byte - only if filtering is of, of course.
  1050. * <ant> and <antcall> tasks now support a new attribute inheritAll. When set to
  1051. false, only user properties are passed through to the target Ant instance.
  1052. This includes properties set on the command line and properties explicitly
  1053. passed
  1054. * <javadoc> now skips off line links if the package list cannot be found.
  1055. * <wlrun> now allows the security policy file to exist outside the weblogic
  1056. directory.
  1057. * <java> task will set the Thread contextClassLoader under JDKs 1.2+ to the
  1058. classloader for the class being executed.
  1059. * Introduce the concept of a TaskContainer - a task or element which can contain
  1060. Ant Tasks.
  1061. * Add new tasks implementing the TaskContainer interface <parallel> and
  1062. <sequential> which allow parallel execution of tasks to be specified.
  1063. * <depend> task will now take into account dependencies on jar files and class
  1064. files from a given classpath.
  1065. * <jar> manifest entries may now be specified in the build file either
  1066. completely or to be merged with a manifest file.
  1067. * <tstamp> task custom formats now support locales.
  1068. * Added a listner which will forward events to Log4J. The log4j configuration
  1069. file should be in the directory from which Ant is run or passed as a system
  1070. property using a JVM argument.
  1071. * Introduced the concept of <filtersets> to allow for more control in which
  1072. filters get applied in a <copy> or <move> operation.
  1073. * Added nowarn attribute to javac and deprecated the Jikes-magic property
  1074. build.compiler.warnings.
  1075. * The <depend> task cache format has changed and all dependency information is
  1076. now stored in a single file.
  1077. Fixed bugs:
  1078. -----------
  1079. * Testcases have been made independent of current working directory.
  1080. * Input ZIP-Files will be closed when using a <zipfileset>.
  1081. * p4 tasks now don't fail if user, port or client have been omitted
  1082. (and this is acceptable for the context of the command).
  1083. * <javah>'s outputfile attribute will be resolved as relative to the
  1084. projects basedir.
  1085. * <antstructure> should create a valid DTD for propertyfile.operation.entry
  1086. and omit tasks it fails to load.
  1087. * won't try to pass a -bootclasspath flag to javac 1.1 anymore
  1088. * <style>'s style attribute no handles absolute paths correctly.
  1089. * <delete includeemptydirs="true"> now deletes more than just the leaf
  1090. directories.
  1091. * You can now specify a <fileset> for a directory that doesn't exist at
  1092. declaration time but will created before the fileset gets used for the
  1093. first time.
  1094. * If the quiet attribute has been set, <delete> will handle <fileset>s
  1095. with non-existing directories gracefully.
  1096. * Output written by testcases will now be captured by the <junit> task
  1097. and passed to the formatters.
  1098. * Quote the -group parameter to Javadoc as per the specification
  1099. * Initialise classes when loaded through the AntClassLoader - that is, run
  1100. static initializers
  1101. * Implement getResource() and getResources() in AntClassLoader
  1102. * Create the <ejbjar> weblogic command line as a set of arguments rather than
  1103. as a single line. Avoids problems with paths which contain spaces.
  1104. * <ejbjar> now fails when the weblogic ejbc compiler reports an error.
  1105. * Make the AntClassLoader load resources in the same order as it currently
  1106. loads classes.
  1107. * Handle classpaths with spaces
  1108. * Make sure XSLT processors close their output files in <style>.
  1109. * perform proper uptodate check in <rmic> when compiling for IIOP.
  1110. * <jjtree>'s uptodate test works even if outputdirectory is not the
  1111. parent dir of target
  1112. * <copy> will remove target file (if it exists) before writing to it -
  1113. this avoids problems with links on filesystems that support them.
  1114. * <ftp> now properly recurses remote directories.
  1115. * <ftp> closes remote connection when it's done.
  1116. * <junit> tries to include all necessary classes for the task itself
  1117. to the classpath when running in fork mode - doesn't work for JDK 1.1
  1118. * <apply> and <execon> do now execute the command only once, if you
  1119. specify the parallel attribute - instead of once per fileset.
  1120. * directory based tasks and fileset could miss some included files in
  1121. directories that have been excluded
  1122. * <fixcrlf> failed for large files.
  1123. * <move> removed files you tried to move to themselves.
  1124. * <sql> task will not trty to print the result set unless the query succeeded.
  1125. * Ant classloader will now ignore paths which are invalid relative to the
  1126. project base
  1127. * <ejbjar> weblogic elements check for jar file changes has been fixed.
  1128. Previously some changes would not be included.
  1129. * properties loaded from properties files are now resolved internally. This
  1130. removes the spurious warnings about usage of properties which have not been
  1131. set.
  1132. * <jar> task and friends now process the JAR manifest to ensure it is valid.
  1133. * The task finished event now includes any exception thrown by the task.
  1134. * <java> task now supports a jvmVersion attribute so that if another JVM is
  1135. being used, Ant can determine which options to use for features such as the
  1136. VM memory limits
  1137. Changes from Ant 1.2 to Ant 1.3
  1138. ===========================================
  1139. Changes that could break older environments:
  1140. --------------------------------------------
  1141. * Ant doesn't search for the buildfile anymore, unless you use the new
  1142. -find argument.
  1143. * <perforce> has been replaced by a number of new tasks.
  1144. * <javac> is now implemented using a factory. This makes extending
  1145. javac to use a new compiler a lot easier but may break custom
  1146. versions of this task that rely on the old implementation.
  1147. * The output generated by the xml formatter for <junit> has changed a
  1148. little, it doesn't append " sec" in the time attribute anymore.
  1149. Other changes:
  1150. --------------
  1151. * A GUI Frontend: Antidote. This is currently in development. At this
  1152. time, this is not part of the Ant release, although the source is
  1153. included if you are interested.
  1154. * New tasks: stylebook, propertyfile, depend, antlr, telnet, csc,
  1155. ilasm, apply, javah, several clearcase tasks, junitreport, sound
  1156. * Added output attribute to <java>.
  1157. * Added nested zipfileset element to <zip>
  1158. * Changed <sql> so that printing is at the task level rather than
  1159. the statement level.
  1160. * javadoc task will pass -d flag to any doclet if the destDir attribute is
  1161. given. If the doclet does not accept the -d flag then omit the destdir
  1162. attribute.
  1163. * <cab> can work on non-Windows platforms with the help of libcabinet.
  1164. See http://trill.cis.fordham.edu/~barbacha/cabinet_library/.
  1165. * <ftp> now supports passive mode.
  1166. * New <mapper> data type that can be used to get influence on the
  1167. target files for some tasks like <copy> or enable new types of tasks
  1168. like <apply>.
  1169. * <execon> provides more control over the command line now, the names
  1170. of the source files are no longer required to be at the end of the
  1171. command.
  1172. * Style tasks will now support TraX compliant XSL processors if one is present
  1173. in your classpath.
  1174. * Added a failonerror to the javac task. If set to false, the build will
  1175. continue even if there are compilation errors.
  1176. * Added nested format elements to the tstamp task allowing additional time
  1177. formats to be defined for arbitrary properties.
  1178. * Added classpath attribute and nested classpath element to <property>
  1179. to make the resource attribute more powerful.
  1180. * ${} property expansion will now be performed on the patterns read
  1181. from files specified as includesfile or excludesfile attributes.
  1182. * The <tar> and <untar> tasks now support GNU format for handling paths
  1183. which are greater than 100 characters in length. In addition the <tar>
  1184. task now supports nested filesets through which the file permissions
  1185. may be controlled.
  1186. * wlrun, wlstop and ejbjar now support Weblogic 6.0
  1187. * The MPasre task has been updated to work with MParse 2.0
  1188. * The documentation has been significantly updated.
  1189. Fixed bugs:
  1190. -----------
  1191. * <signjar> doesn't use deprectated methods anymore.
  1192. * javadoc's failonerror attribute works again
  1193. * javadoc's additionalparam attribute will now be split into separate
  1194. parameters (on spaces) to allow for more than one parameter.
  1195. * Changed <sql> task so that printing result sets works on Oracle
  1196. * Changes to ddcreator and ejbc helper to respect the descriptor hierarchy
  1197. keppgenerated in ejbc can now be turned off
  1198. * ejbjar now correctly ignores <ejb-ref> elements in the deployment descriptor.
  1199. CMP files are included by parsing the weblogic deployment descriptor rather
  1200. than relying on the naming convention used in ant 1.2
  1201. * ejbjar includes super classes and super interfaces into the generated ejb
  1202. jar files. The <support> nested element allows support classes to be
  1203. included in the EJB jar. The toplink element should now correctly locate
  1204. the toplink descriptor.
  1205. * <vssget> now correctly deals with spaces in arguments
  1206. * <jar> fails early if a given manifest file doesn't exist
  1207. * <rmic> doesn't search for the _Skel file anymore when stubversion is
  1208. set to 1.2.
  1209. * <rmic> uses the the same classpath to verify a class can be rmic'd
  1210. as it passes to the compiler.
  1211. * org.apache.tools.mail.MailMessage (and therefore <mail>) can now
  1212. handle SMTP servers sending multi line responses.
  1213. * nested <classpath> elements of <taskdef> now work for <taskdef>s not
  1214. nested into <target> as well.
  1215. * <property> and <available> will search for the resource "foo" instead
  1216. of "/org/apache/tools/ant/taskdefs/foo" when given a relative resource
  1217. name foo.
  1218. * Handle build files in directories whose name contained a "#" character
  1219. * <junit> can now log to files whose name contains a comma as well.
  1220. * The AntClassLoader now refers to the loader which loaded it, any
  1221. requests it does not handle itself. Previously these went to the
  1222. primordial loader.
  1223. Changes from Ant 1.1 to Ant 1.2
  1224. ===============================
  1225. Changes that could break older environments:
  1226. --------------------------------------------
  1227. * Semantics of <property> has changed again in the hope to be more
  1228. intuitive. ${} expansion now happens at runtime and <property> tags
  1229. living inside of targets only take effect if they are visited at
  1230. runtime.
  1231. As a side effect of this change, task's attributes get set at runtime
  1232. not at parser time as well, which might change the results of
  1233. <script>s or other custom tasks that reference other tasks by their id
  1234. attribute.
  1235. * copying of support files in <javac> has been removed - as well as
  1236. the filtering attribute.
  1237. * the <expand> and <keysubst> tasks have been removed.
  1238. * the ignore and items attributes of directory based tasks have been removed.
  1239. * the command line switches _not_ starting with - have been removed.
  1240. * Path and EnumeratedAttribute have been moved from
  1241. org.apache.tools.ant to org.apache.tools.ant.types.
  1242. * the class attributes of <available>, <java>, <rmic> and <taskdef>
  1243. have been removed.
  1244. * the src attribute of <chmod> has been removed.
  1245. * <patch> and <javadoc> have lost some of their attributes.
  1246. * <java> and <cvs> have lost some undocumented attributes.
  1247. * the Unix antRun script would search for command.sh in the directory
  1248. it changed to and invoke this instead of command if present. This
  1249. behavior has been dropped.
  1250. * <ejbjar> task syntax has been changed significantly
  1251. * <exec> is no longer implemented by org.apache.tool.ant.taskdefs.Exec.
  1252. Custom tasks that rely on Project.createTask("exec") to return an
  1253. instance of this class are going to fail.
  1254. * nested <include> and <exclude> elements expect the value of their
  1255. name attribute to be a single pattern, they don't accept multiple
  1256. patterns anymore. Split them into multiple elements of the same type.
  1257. * <delete dir="somedir" /> will now delete the directory itself as
  1258. well as all included files. If you just want to clean out the
  1259. directory and keep the empty one, use a nested fileset.
  1260. Other changes:
  1261. --------------
  1262. * New tasks: antstructure, cab, execon, fail, ftp, genkey, jlink,
  1263. junit, sql, javacc, jjtree, starteam, war, unwar, uptodate,
  1264. native2ascii, copy, move, mparse.
  1265. * copydir, copyfile, deltree and rename are now deprecated. They
  1266. should be replaced with the new copy, delete and move tasks.
  1267. * <java> uses a ClassLoader of its own in no-fork mode if a classpath is
  1268. specified.
  1269. * <style> will create the necessary target directories and reprocess
  1270. all files if the stylesheet changes.
  1271. * New data types fileset and patternset - expected to get a broader use.
  1272. They, as well as PATH like structures, can now be defined on a global
  1273. level and later be referenced by their id attribute.
  1274. * You can specify environment variables to <exec>.
  1275. * <get> can check whether a remote file is actually newer than a local
  1276. copy before it starts a download (HTTP only).
  1277. * Added a -logger option to allow the class which performs logging to be
  1278. specified on the command line.
  1279. * Added a -emacs option to tell the logger to leave out taskname adornments
  1280. on log output.
  1281. * <chmod> works on all files in parallel and supports multiple filesets.
  1282. * <replace> can now use tokens and/or values that cross line boundaries.
  1283. * build.compiler supports now jvc as well.
  1284. * project specific help can now be obtained with the -projecthelp option.
  1285. * Added a -debug option to make -verbose less verbose (and more useful)
  1286. * Ant will now search for a file named build.xml in the parent directory
  1287. and above (towards the root of the filesystem) if you didn't specify
  1288. -buildfile and there is no build.xml in the current directory.
  1289. * <echo> can now write to a file and accepts nested text.
  1290. Fixed bugs:
  1291. -----------
  1292. * <chmod> didn't work when used as a directory based task.
  1293. * Path, Available, Property didn't resolve relative filenames with
  1294. respect to the Project's basedir.
  1295. * Project didn't interpret the basedir attribute correctly in all
  1296. cases.
  1297. * Nested <src> in <javac> caused NullPointerException.
  1298. * Corrupt Zip- and Jar-files ar now deleted if the task fails.
  1299. * many more fixes we've forgotten to document here ...
  1300. * The packagelistloc attribute of <javadoc>'s <link> child will be
  1301. resolved as a file (i.e. it is either absolute or relative to
  1302. basedir).