ANT不完全總結(jié)_第1頁
ANT不完全總結(jié)_第2頁
ANT不完全總結(jié)_第3頁
ANT不完全總結(jié)_第4頁
ANT不完全總結(jié)_第5頁
已閱讀5頁,還剩11頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)

文檔簡介

1、ANT不完全總結(jié)ANT不完全總結(jié) 好久沒有用Ant了,最近讓MyEclipse、JBuilder2008逼的重回Ant上了。手生了,寫了一個腳本后,重新總結(jié)下。參考了官方的文檔和網(wǎng)上一些資料。 一、ANT的介紹Ant的全名是"Another Neat Tool",是由James Duncan Davidson在Make工具無法滿足他的需求下所撰寫出來的構(gòu)建(build)工具。 Ant用Java編寫,服務(wù)于Java。 二、ANT的安裝配置1、獲取ANT 2、安裝ANTset ANT_HOME=c:antset JAVA_HOM

2、E=c:jdk-.05set PATH=%PATH%;%ANT_HOME%bin 三、使用ANTAnt的build腳本是一個XML文件,稱為Buildfile,每個Buildfile包含一個project和若干個target元素,每個target又可以包含若干個task元素,每個task元素可以有一個id屬性。當(dāng)然id屬性必須在整個文檔中是唯一的。結(jié)構(gòu)如下: <project/>   <target/>      <task/>   

3、60;  <task/>   </target>   <target>      <task/>   </target></project>  1、project有三個屬性,這些屬性都不是必須的。比如:<project name="testwebant" basedir="." default="all">屬性說明

4、如下:name:指定項目的名字。basedir:指定項目根路徑,用于計算所有其他路徑的基路徑。該屬性可以被basedir property覆蓋。當(dāng)覆蓋時,該屬性被忽略。如果屬性和basedir property都沒有設(shè)定,就使用buildfile文件的父目錄。default:指定當(dāng)沒有指定執(zhí)行目標(biāo)時,所要執(zhí)行的目標(biāo)。 2、target 一個target可以依賴于其他的target。例如,你可能會有一個target用于編譯程序,一個target用于生成可執(zhí)行文件。你在生成可執(zhí)行文件之前必須先編譯通過,所以生成可執(zhí)行文件的target依賴于編譯target。Ant會處理這種依賴

5、關(guān)系。 Ant會依照depends屬性中target出現(xiàn)的順序(從左到右)依次執(zhí)行每個target。然而,要記住的是只要某個target依賴于一個target,后者就會被先執(zhí)行。<target name="A"/><target name="B" depends="A"/><target name="C" depends="B"/><target name="D" depends="C,B,A"/>

6、假定我們要執(zhí)行target D。從它的依賴屬性來看,你可能認為先執(zhí)行C,然后B,最后A被執(zhí)行。錯了,C依賴于B,B依賴于A,所以先執(zhí)行A,然后B,然后C,最后D被執(zhí)行。 一個target只能被執(zhí)行一次,即時有多個target依賴于它。 如果(或如果不)某些屬性被設(shè)定,才執(zhí)行某個target。這樣,允許根據(jù)系統(tǒng)的狀態(tài)(java version, OS, 命令行屬性定義等等)來更好地控制build的過程。要想讓一個target這樣做,你就應(yīng)該在target元素中,加入if(或unless)屬性,帶上target因該有所判斷的屬性。例如:<target name="

7、;build-module-A" if="module-A-present"/><target name="build-own-fake-module-A" unless="module-A-present"/>如果沒有if或unless屬性,target總會被執(zhí)行。 可選的description屬性可用來提供關(guān)于target的一行描述,這些描述可由-projecthelp命令行選項輸出。 target有下面的屬性,僅僅name屬性是必須的。:name: target的名字。depend

8、s: 用逗號分隔的target的名字列表,也就是依賴表。if 執(zhí)行target所需要設(shè)定的屬性名。unless 執(zhí)行target需要清除設(shè)定的屬性名。description 關(guān)于target功能的簡短描述。 3、tasktask不是一個Buildfile的元素,是一個泛稱。 一個task是一段可執(zhí)行的代碼。 一個task可以有多個屬性(如果你愿意的話,可以將其稱之為變量)。屬性只可能包含對property的引用。這些引用會在task執(zhí)行前被解析。 下面是Task的一般構(gòu)造形式:<name attribute1="value1"

9、attribute2="value2" . />這里name是task的名字,attributeN是屬性名,valueN是屬性值。 有一套內(nèi)置的(built-in)task,以及一些可選task,但你也可以編寫自己的task。 所有的task都有一個task名字屬性。Ant用屬性值來產(chǎn)生日志信息。 可以給task賦一個id屬性:<taskname id="taskID" . />這里taskname是task的名字,而taskID是這個task的唯一標(biāo)識符。通過這個標(biāo)識符,你可以在腳本中引用相應(yīng)的task。

10、例如,在腳本中你可以這樣:<script . >task1.setFoo("bar");</script>設(shè)定某個task實例的foo屬性。在另一個task中(用java編寫),你可以利用下面的語句存取相應(yīng)的實例。project.getReference("task1"). 注意1:如果task1還沒有運行,就不會被生效(例如:不設(shè)定屬性),如果你在隨后配置它,你所作的一切都會被覆蓋。 注意2:未來的Ant版本可能不會兼容這里所提的屬性,因為很有可能根本沒有task實例,只有proxies。 4、Pr

11、operties一個project可以有很多的properties??梢栽赽uildfile中用property task來設(shè)定,或在Ant之外設(shè)定。如果是在外部設(shè)定的,則可以通過下面的方式來引入properties配置文件。<property file="perties"/> 一個property有一個名字和一個值。property可用于task的屬性值。這是通過將屬性名放在"$"和""之間并放在屬性值的位置來實現(xiàn)的。例如如果有一個property builddir的值是"

12、build",這個property就可用于屬性值:$builddir/classes。這個值就可被解析為build/classes。  Ant內(nèi)置屬性 如果你使用了<property> task 定義了所有的系統(tǒng)屬性,Ant允許你使用這些屬性。例如,$對應(yīng)操作系統(tǒng)的名字。 要想得到系統(tǒng)屬性的列表可參考the Javadoc of System.getProperties。 除了Java的系統(tǒng)屬性,Ant還定義了一些自己的內(nèi)置屬性:basedir project基目錄的絕對路徑 (與<project>

13、;的basedir屬性一樣)。ant.file buildfile的絕對路徑。ant.version Ant的版本。   例子<project name="MyProject" default="dist" basedir=".">       <!- set global properties for this build ->    <property name="src&

14、quot; value="."/>    <property name="build" value="build"/>    <property name="dist" value="dist"/>     <target name="init">        &l

15、t;!- Create the time stamp ->        <tstamp/>        <!- Create the build directory structure used by compile ->        <mkdir dir="$build"/>    <

16、;/target>     <target name="compile" depends="init">        <!- Compile the java code from $src into $build ->        <javac srcdir="$src" destdir="$build&qu

17、ot;/>    </target>     <target name="dist" depends="compile">        <!- Create the distribution directory ->        <mkdir dir="$dist/lib"/&

18、gt;        <!- Put everything in $build into the MyProject-$DSTAMP.jar file ->        <jar jarfile="$dist/lib/MyProject-$DSTAMP.jar" basedir="$build"/>    </target>  &

19、#160;  <target name="clean">        <!- Delete the $build and $dist directory trees ->        <delete dir="$build"/>        <delete dir="$dist&q

20、uot;/>    </target> </project> 4、PATH和CLASSPATH 你可以用":"和""作為分隔符,指定類似PATH和CLASSPATH的引用。Ant會把分隔符轉(zhuǎn)換為當(dāng)前系統(tǒng)所用的分隔符。 當(dāng)需要指定類似路徑的值時,可以使用嵌套元素。一般的形式是<classpath>   <pathelement path="$classpath"/>   &l

21、t;pathelement location="lib/helper.jar"/></classpath>location屬性指定了相對于project基目錄的一個文件和目錄,而path屬性接受逗號或分號分隔的一個位置列表。path屬性一般用作預(yù)定義的路徑其他情況下,應(yīng)該用多個location屬性。 為簡潔起見,classpath標(biāo)簽支持自己的path和location屬性。所以:<classpath>   <pathelement path="$classpath"/></c

22、lasspath>可以被簡寫作:<classpath path="$classpath"/>也可通過<fileset>元素指定路徑。構(gòu)成一個fileset的多個文件加入path-like structure的順序是未定的。<classpath>   <pathelement path="$classpath"/>   <fileset dir="lib">      <inc

23、lude name="*/*.jar"/>   </fileset>   <pathelement location="classes"/></classpath>上面的例子構(gòu)造了一個路徑值包括:$classpath的路徑,跟著lib目錄下的所有jar文件,接著是classes目錄。 如果你想在多個task中使用相同的path-like structure,你可以用<path>元素定義他們(與target同級),然后通過id屬性引用參考Referenc

24、s例子。 path-like structure可能包括對另一個path-like structurede的引用(通過嵌套<path>元素):<path id="base.path">   <pathelement path="$classpath"/>   <fileset dir="lib">      <include name="*/*.jar"/>

25、   </fileset>   <pathelement location="classes"/></path><path id="tests.path">   <path refid="base.path"/>   <pathelement location="testclasses"/></path> 前面所提的關(guān)于<classpat

26、h>的簡潔寫法對于<path>也是有效的,如:<path id="tests.path">   <path refid="base.path"/>   <pathelement location="testclasses"/></path>可寫成:<path id="base.path" path="$classpath"/> 5、命令行變量 有些task可接

27、受參數(shù),并將其傳遞給另一個進程。為了能在變量中包含空格字符,可使用嵌套的arg元素。Attribute Description Requiredvalue 一個命令行變量;可包含空格字符。 只能用一個line 空格分隔的命令行變量列表。file 作為命令行變量的文件名;會被文件的絕對名替代。path 一個作為單個命令行變量的path-like的字符串;或作為分隔符,Ant會將其轉(zhuǎn)變?yōu)樘囟ㄆ脚_的分隔符。 例子<arg value="-l -a"/>是一個含有空格的單個的命令行變量。<arg line="-l -a"/>是兩

28、個空格分隔的命令行變量。<arg path="/dir;/dir2:dir3"/>是一個命令行變量,其值在DOS系統(tǒng)上為dir;dir2;dir3;在Unix系統(tǒng)上為/dir:/dir2:/dir3 。   6、ID引用 buildfile元素的id屬性可用來引用這些元素。如果你需要一遍遍的復(fù)制相同的XML代碼塊,這一屬性就很有用如多次使用<classpath>結(jié)構(gòu)。 下面的例子:<project . >    <target . > &

29、#160;         <rmic .>                 <classpath>                   

30、0;   <pathelement location="lib/"/>                       <pathelement path="$additional.path"/>        

31、0;        </classpath>           </rmic>    </target>    <target . >        <javac .>      

32、;      <classpath>                <pathelement location="lib/"/>                <pathelement path=&q

33、uot;$additional.path"/>            </classpath>        </javac>    </target></project>可以寫成如下形式:<project . >        <pat

34、helement location="lib/"/>        <pathelement path="$additional.path"/>    </path>    <target . >        <rmic .>      

35、60; </rmic>    </target>    <target . >        <javac .>        </javac>    </target></project>所有使用PatternSets, FileSets 或 path-like structures

36、嵌套元素的task也接受這種類型的引用。  四、Ant內(nèi)置的常用任務(wù) Ant中內(nèi)置的任務(wù)很多很多,要想記住每個任務(wù)幾乎異想天開,對于開發(fā)者來說,我們僅僅需要知道一些常見的任務(wù)使用即可。對于不常用的任務(wù),可以在使用的時候直接到里去查看使用手冊。 Ant中的任務(wù)可以為3類。核心任務(wù)。核心任務(wù)是Ant自帶的任務(wù)。可選任務(wù)??蛇x任務(wù)實來自第三方的任務(wù),因此需要一個附加的JAR文件。用戶自定義的任務(wù)。用戶自定義的任務(wù)實用戶自己開發(fā)的任務(wù)。  下面是Ant中常用的一些任務(wù)用法的簡單總結(jié): 1、<mkdir>創(chuàng)建一個目錄,如果

37、他的父目錄不存在,也會被同時創(chuàng)建。它有一個屬性dir用來指定所創(chuàng)建的目錄名,其代碼如下:<mkdir dir="build/classes"/>如果build不存在,也會被同時創(chuàng)建。  2、<delete>刪除文件或者目錄, 如:屬性如下:file表示要刪除的文件。dir表示要刪除的目錄。includeEmptyDirs 表示指定是否要刪除空目錄,默認值是刪除。failonerror 表示指定當(dāng)碰到錯誤是否停止,默認值是自動停止。verbose 表示指定是否列出所刪除的文件,默認值為不列出。 (1). 刪除一個文件<

38、;delete file="/lib/ant.jar"/>(2). 刪除指定目錄及其子目錄<delete dir="lib"/>(3). 刪除指定的一組文件<delete>    <fileset dir="." includes="*/*.bak"/></delete>(4). 刪除指定目錄及其子目錄,包括他自己<delete includeEmptyDirs="true">  

39、  <fileset dir="build"/></delete> 3、<jar>該標(biāo)簽用來生成一個jar文件,其屬性如下。destfile 表示jar文件名。basedir  表示被歸檔的文件夾。includes 表示被歸檔的文件模式。exchudes 表示被排除的文件模式。例如:<jar destfile="helloworld.jar" basedir="build/classes">   <manifest> 

40、;  <attribute name="Main-class" value="HelloWorld"/>   </manifest></jar> 4、<javac>該標(biāo)簽用于編譯一個或一組java文件,其屬性如下。srcdir 表示源文件的目錄。destdir 表示class文件的輸出目錄。include 表示被編譯的文件的模式。excludes 表示被排除的文件的模式。classpath 表示所使用的類路徑。debug 表示包含的調(diào)試信息。optimize 表示是否

41、使用優(yōu)化。verbose 表示提供詳細的輸出信息。fileonerror 表示當(dāng)碰到錯誤就自動停止。 5、<java>該標(biāo)簽用來執(zhí)行編譯生成的.class文件,其屬性如下。classname 表示將執(zhí)行的類名。jar 表示包含該類的JAR文件名。classpath 所表示用到的類路徑。fork 表示在一個新的虛擬機中運行該類。failonerror 表示當(dāng)出現(xiàn)錯誤時自動停止。output 表示輸出文件。append 表示追加或者覆蓋默認文件。例如:<java classname="HelloWorld">   <c

42、lasspath>   <pathelement path="build/classes"/>   </classpath></java>  6、<copy>該標(biāo)簽用于文件或文件集的拷貝,其屬性如下。file 表示源文件。tofile 表示目標(biāo)文件。todir 表示目標(biāo)目錄。overwrite 表示指定是否覆蓋目標(biāo)文件,默認值是不覆蓋。includeEmptyDirs 表示制定是否拷貝空目錄,默認值為拷貝。failonerror 表示指定如目標(biāo)沒有發(fā)現(xiàn)是否自動停

43、止,默認值是停止。verbose 表示制定是否顯示詳細信息,默認值不顯示。 (1). 拷貝單個的文件:<copy file="myfile.txt" tofile="mycopy.txt"/>(2). 拷貝單個的文件到指定目錄下<copy file="myfile.txt" todir="./some/other/dir"/>(3). 拷貝一個目錄到另外一個目錄下<copy todir="./new/dir">    &

44、lt;fileset dir="src_dir"/></copy>(4). 拷貝一批文件到指定目錄下<copy todir="./dest/dir">    <fileset dir="src_dir">      <exclude name="*/*.java"/>    </fileset></copy> <copy todir="./dest/dir">    <fileset dir="src_dir" excludes="*/*.java"/></copy>(5). 拷貝一批文件到指定目錄下,將文件

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論