mirror of
https://github.com/AppleCommander/AppleCommander.git
synced 2024-12-21 17:29:55 +00:00
Adding Ant Task as a subproject and adding into build. Closes #80.
This commit is contained in:
parent
fd066eea6d
commit
867d73e9b2
16
DEVELOPER.md
16
DEVELOPER.md
@ -2,7 +2,7 @@
|
||||
|
||||
AppleCommander has switched to using [Gradle](https://gradle.org/) for build and build dependencies.
|
||||
|
||||
There is still a bunch of ANT related build information around. They no longer apply and "should" get cleaned up over time.
|
||||
There is still a bunch of ANT related build information around in `ant-build`. This should get cleaned up over time.
|
||||
|
||||
## Structure
|
||||
|
||||
@ -29,6 +29,20 @@ BUILD SUCCESSFUL in 554ms
|
||||
19 actionable tasks: 19 up-to-date
|
||||
```
|
||||
|
||||
## Testing for Ant Task
|
||||
|
||||
The Apache Ant Task has been added as an independent "application" to the Gradle source structure. It resides in `app/ant-ac`. To test the Ant Task, there is an actual Ant build script available. Run this script from the AppleCommander project directory -- it should figure out paths from that starting position.
|
||||
|
||||
```
|
||||
$ ant -f app/ant-ac/src/test/resources/build-testacant.xml
|
||||
Buildfile: /.../AppleCommander/app/ant-ac/src/test/resources/build-testacant.xml
|
||||
|
||||
<snip>
|
||||
|
||||
BUILD SUCCESSFUL
|
||||
Total time: 0 seconds
|
||||
```
|
||||
|
||||
## Building
|
||||
|
||||
```
|
||||
|
@ -1,97 +0,0 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project name="ac-ant-test" default="all">
|
||||
|
||||
<property name="projdir" value=".."/>
|
||||
<target name="version" description="Get version from source.">
|
||||
<property name="main.path" value="${projdir}/src/com/webcodepro/applecommander/ui"/>
|
||||
<loadfile srcfile="${main.path}/AppleCommander.java" property="acVersion">
|
||||
<filterchain>
|
||||
<linecontainsregexp>
|
||||
<regexp pattern='^.*String VERSION = ".*";.*$'/>
|
||||
</linecontainsregexp>
|
||||
<tokenfilter>
|
||||
<replaceregex pattern='^.*String VERSION = "(.*)";.*$' replace='\1'/>
|
||||
</tokenfilter>
|
||||
<striplinebreaks/>
|
||||
</filterchain>
|
||||
</loadfile>
|
||||
<echo>Testing ant support from version ${acVersion}...</echo>
|
||||
|
||||
<!-- Set a number of properties based on that version number -->
|
||||
<taskdef name="appleCommander" classname="com.webcodepro.applecommander.ui.AntTask" classpath="${projdir}/work/dist/AppleCommander-${acVersion}-ac.jar"/>
|
||||
<property name="dos140image" value="${projdir}/work/dist/test-${acVersion}-dos140.do"/>
|
||||
<property name="pro140image" value="${projdir}/work/dist/test-${acVersion}-pro140.po"/>
|
||||
<property name="pro800image" value="${projdir}/work/dist/test-${acVersion}-pro800.po"/>
|
||||
<property name="pas140image" value="${projdir}/work/dist/test-${acVersion}-pas140.po"/>
|
||||
<property name="pas800image" value="${projdir}/work/dist/test-${acVersion}-pas800.po"/>
|
||||
|
||||
</target>
|
||||
|
||||
<target name="all" depends="version, clean, test" description="Tests some of the functions of the AppleCommander Ant task. Run 'clean' afterwards to clean up.">
|
||||
<!-- This target is here to orchestrate the staging of other tasks via the 'depends' clause. -->
|
||||
</target>
|
||||
|
||||
<target name="test" description="Run the bulk of the testing.">
|
||||
<!-- First, build images to play with -->
|
||||
<appleCommander command="dos140" imagename="${dos140image}" />
|
||||
<appleCommander command="pro800" imagename="${pro800image}" />
|
||||
<appleCommander command="pro140" imagename="${pro140image}" />
|
||||
<appleCommander command="pas800" imagename="${pas800image}" />
|
||||
<appleCommander command="pas140" imagename="${pas140image}" />
|
||||
<!-- Now, copy a file to the images -->
|
||||
<appleCommander command="p" input="manifest.mf" imagename="${dos140image}" filename="MANIFEST" type="T" />
|
||||
<appleCommander command="p" input="manifest.mf" imagename="${pas140image}" filename="MANIFEST" type="text" />
|
||||
<appleCommander command="p" input="manifest.mf" failonerror="false" imagename="${pas800image}" filename="MANIFEST" type="text" />
|
||||
<appleCommander command="p" input="manifest.mf" imagename="${pro140image}" filename="MANIFEST" type="txt" />
|
||||
<appleCommander command="p" input="${pas140image}" failonerror="false" imagename="${pro800image}" filename="BIG140IMG" type="bin" />
|
||||
<!-- Now, copy a file that should not fit on the images -->
|
||||
<echo message="Here we expect messages from [appleCommander] complaining about file space requirements not being met..."/>
|
||||
<appleCommander failonerror="false" command="p" input="${pro800image}" imagename="${dos140image}" filename="BLOWUP" type="T" />
|
||||
<appleCommander failonerror="false" command="p" input="${pro800image}" imagename="${pas140image}" filename="BLOWUP" type="text" />
|
||||
<appleCommander failonerror="false" command="p" input="${pro800image}" imagename="${pas800image}" filename="BLOWUP" type="text" />
|
||||
<appleCommander failonerror="false" command="p" input="${pro800image}" imagename="${pro140image}" filename="BLOWUP" type="txt" />
|
||||
<appleCommander failonerror="false" command="p" input="${pro800image}" imagename="${pro800image}" filename="BLOWUP" type="txt" />
|
||||
<!-- Now, ask for some directories -->
|
||||
<echo message="Here we are asking for a normal DOS directory."/>
|
||||
<appleCommander command="ls" imagename="${dos140image}" />
|
||||
<echo message="Here we are asking for a native Pascal directory."/>
|
||||
<appleCommander command="l" imagename="${pas800image}" />
|
||||
<echo message="Here we are asking for a detailed ProDOS directory."/>
|
||||
<appleCommander command="ll" imagename="${pro800image}" />
|
||||
<!-- Now, ask for some information on images -->
|
||||
<echo message="Here we are asking for general image information."/>
|
||||
<appleCommander command="i" imagename="${dos140image}" />
|
||||
<!-- Now, delete that file we created -->
|
||||
<appleCommander command="d" imagename="${dos140image}" filename="MANIFEST" />
|
||||
<appleCommander command="d" imagename="${pas140image}" filename="MANIFEST" />
|
||||
<echo message="Note: the 'No match' message is coming from the Pascal 140k image, which gets corrupted when it is blown up with the large file."/>
|
||||
<appleCommander command="d" imagename="${pas800image}" filename="MANIFEST" />
|
||||
<appleCommander command="d" imagename="${pro140image}" filename="MANIFEST" />
|
||||
<appleCommander command="d" imagename="${pro800image}" filename="BIG140IMG" />
|
||||
<!-- Now, the files should be gone -->
|
||||
<echo message="Now, the files that appeared before should be gone."/>
|
||||
<appleCommander command="ls" imagename="${dos140image}" />
|
||||
<appleCommander command="l" imagename="${pas800image}" />
|
||||
<appleCommander command="ll" imagename="${pro800image}" />
|
||||
<!-- Now, test some file exporting -->
|
||||
<echo message="Here are the contents of a file:"/>
|
||||
<appleCommander command="p" input="manifest.mf" imagename="${pro140image}" filename="TEST" type="txt" />
|
||||
<appleCommander command="e" imagename="${pro140image}" filename="TEST" />
|
||||
<echo message="Here are the contents of a file, native:"/>
|
||||
<appleCommander command="g" imagename="${pro140image}" filename="TEST" />
|
||||
<appleCommander command="x" imagename="${pro140image}" outputpath="${projdir}/work/dist" />
|
||||
<appleCommander command="p" input="${pro140image}" imagename="${pro800image}" filename="TEST.po" type="bin" />
|
||||
<appleCommander command="g" imagename="${pro800image}" filename="TEST.po" output="${projdir}/work/dist/TEST.po"/>
|
||||
<echo message="Files TEST.po and ${pro140image} should match." />
|
||||
<echo message="Files should be exported to the current working directory now." />
|
||||
</target>
|
||||
|
||||
<target name="clean" description="Get rid of testing artifacts.">
|
||||
<delete file="${dos140image}" />
|
||||
<delete file="${pas140image}" />
|
||||
<delete file="${pas800image}" />
|
||||
<delete file="${pro140image}" />
|
||||
<delete file="${pro800image}" />
|
||||
<delete file="TEST.txt" />
|
||||
</target>
|
||||
</project>
|
26
app/ant-ac/build.gradle
Normal file
26
app/ant-ac/build.gradle
Normal file
@ -0,0 +1,26 @@
|
||||
plugins {
|
||||
id 'java-library'
|
||||
}
|
||||
|
||||
sourceCompatibility = 11
|
||||
targetCompatibility = 11
|
||||
|
||||
repositories {
|
||||
mavenCentral()
|
||||
}
|
||||
|
||||
dependencies {
|
||||
implementation project(':app:cli-ac')
|
||||
implementation project(':lib:ac-api')
|
||||
compileOnly "org.apache.ant:ant:$antVersion"
|
||||
}
|
||||
|
||||
jar {
|
||||
archiveBaseName = 'AppleCommander'
|
||||
archiveAppendix = 'ant'
|
||||
|
||||
dependsOn configurations.runtimeClasspath
|
||||
from {
|
||||
configurations.runtimeClasspath.collect { it.isDirectory() ? it : zipTree(it) }
|
||||
}
|
||||
}
|
98
app/ant-ac/src/test/resources/build-testacant.xml
Normal file
98
app/ant-ac/src/test/resources/build-testacant.xml
Normal file
@ -0,0 +1,98 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
<project name="ac-ant-test" default="all">
|
||||
|
||||
<property name="projdir" value="../../../../.."/>
|
||||
<property name="appantdir" value="app/ant-ac/src/test/resources" />
|
||||
<property name="tmpdir" value="build/tmp" />
|
||||
<mkdir dir="${projdir}/${tmpdir}" />
|
||||
|
||||
<target name="version" description="Get version from source.">
|
||||
<echo>Testing ant support...</echo>
|
||||
|
||||
<path id="antJar">
|
||||
<fileset dir="${projdir}/app/ant-ac/build/libs" includes="AppleCommander-ant-*.jar" />
|
||||
</path>
|
||||
|
||||
<!-- Set a number of properties based on that version number -->
|
||||
<taskdef name="appleCommander" classname="com.webcodepro.applecommander.ui.AntTask" classpathref="antJar"/>
|
||||
<property name="dos140image" value="${tmpdir}/test-ant-dos140.do"/>
|
||||
<property name="pro140image" value="${tmpdir}/test-ant-pro140.po"/>
|
||||
<property name="pro800image" value="${tmpdir}/test-ant-pro800.po"/>
|
||||
<property name="pas140image" value="${tmpdir}/test-ant-pas140.po"/>
|
||||
<property name="pas800image" value="${tmpdir}/test-ant-pas800.po"/>
|
||||
</target>
|
||||
|
||||
<target name="all" depends="version, clean, test" description="Tests some of the functions of the AppleCommander Ant task. Run 'clean' afterwards to clean up.">
|
||||
<!-- This target is here to orchestrate the staging of other tasks via the 'depends' clause. -->
|
||||
</target>
|
||||
|
||||
<target name="test" description="Run the bulk of the testing.">
|
||||
<!-- First, build images to play with -->
|
||||
<appleCommander command="dos140" imagename="${dos140image}" />
|
||||
<appleCommander command="pro800" imagename="${pro800image}" />
|
||||
<appleCommander command="pro140" imagename="${pro140image}" />
|
||||
<appleCommander command="pas800" imagename="${pas800image}" />
|
||||
<appleCommander command="pas140" imagename="${pas140image}" />
|
||||
<!-- Now, copy a file to the images -->
|
||||
<appleCommander command="p" input="${appantdir}/manifest.mf"
|
||||
imagename="${dos140image}" filename="MANIFEST" type="T" />
|
||||
<appleCommander command="p" input="${appantdir}/manifest.mf"
|
||||
imagename="${pas140image}" filename="MANIFEST" type="text" />
|
||||
<appleCommander command="p" input="${appantdir}/manifest.mf" failonerror="false"
|
||||
imagename="${pas800image}" filename="MANIFEST" type="text" />
|
||||
<appleCommander command="p" input="${appantdir}/manifest.mf"
|
||||
imagename="${pro140image}" filename="MANIFEST" type="txt" />
|
||||
<appleCommander command="p" input="${pas140image}" failonerror="false"
|
||||
imagename="${pro800image}" filename="BIG140IMG" type="bin" />
|
||||
<!-- Now, copy a file that should not fit on the images -->
|
||||
<echo message="Here we expect messages from [appleCommander] complaining about file space requirements not being met..."/>
|
||||
<appleCommander failonerror="false" command="p" input="${pro800image}" imagename="${dos140image}" filename="BLOWUP" type="T" />
|
||||
<appleCommander failonerror="false" command="p" input="${pro800image}" imagename="${pas140image}" filename="BLOWUP" type="text" />
|
||||
<appleCommander failonerror="false" command="p" input="${pro800image}" imagename="${pas800image}" filename="BLOWUP" type="text" />
|
||||
<appleCommander failonerror="false" command="p" input="${pro800image}" imagename="${pro140image}" filename="BLOWUP" type="txt" />
|
||||
<appleCommander failonerror="false" command="p" input="${pro800image}" imagename="${pro800image}" filename="BLOWUP" type="txt" />
|
||||
<!-- Now, ask for some directories -->
|
||||
<echo message="Here we are asking for a normal DOS directory."/>
|
||||
<appleCommander command="ls" imagename="${dos140image}" />
|
||||
<echo message="Here we are asking for a native Pascal directory."/>
|
||||
<appleCommander command="l" imagename="${pas800image}" />
|
||||
<echo message="Here we are asking for a detailed ProDOS directory."/>
|
||||
<appleCommander command="ll" imagename="${pro800image}" />
|
||||
<!-- Now, ask for some information on images -->
|
||||
<echo message="Here we are asking for general image information."/>
|
||||
<appleCommander command="i" imagename="${dos140image}" />
|
||||
<!-- Now, delete that file we created -->
|
||||
<appleCommander command="d" imagename="${dos140image}" filename="MANIFEST" />
|
||||
<appleCommander command="d" imagename="${pas140image}" filename="MANIFEST" />
|
||||
<echo message="Note: the 'No match' message is coming from the Pascal 140k image, which gets corrupted when it is blown up with the large file."/>
|
||||
<appleCommander command="d" imagename="${pas800image}" filename="MANIFEST" />
|
||||
<appleCommander command="d" imagename="${pro140image}" filename="MANIFEST" />
|
||||
<appleCommander command="d" imagename="${pro800image}" filename="BIG140IMG" />
|
||||
<!-- Now, the files should be gone -->
|
||||
<echo message="Now, the files that appeared before should be gone."/>
|
||||
<appleCommander command="ls" imagename="${dos140image}" />
|
||||
<appleCommander command="l" imagename="${pas800image}" />
|
||||
<appleCommander command="ll" imagename="${pro800image}" />
|
||||
<!-- Now, test some file exporting -->
|
||||
<echo message="Here are the contents of a file:"/>
|
||||
<appleCommander command="p" input="${appantdir}/manifest.mf"
|
||||
imagename="${pro140image}" filename="TEST" type="txt" />
|
||||
<appleCommander command="e" imagename="${pro140image}" filename="TEST" />
|
||||
<echo message="Here are the contents of a file, native:"/>
|
||||
<appleCommander command="g" imagename="${pro140image}" filename="TEST" />
|
||||
<appleCommander command="x" imagename="${pro140image}" outputpath="${tmpdir}" />
|
||||
<appleCommander command="p" input="${pro140image}" imagename="${pro800image}" filename="TEST.po" type="bin" />
|
||||
<appleCommander command="g" imagename="${pro800image}" filename="TEST.po" output="${tmpdir}/TEST.po"/>
|
||||
<echo message="Files TEST.po and ${pro140image} should match." />
|
||||
<echo message="Files should be exported to the current working directory now." />
|
||||
</target>
|
||||
|
||||
<target name="clean" description="Get rid of testing artifacts.">
|
||||
<delete file="${dos140image}" />
|
||||
<delete file="${pas140image}" />
|
||||
<delete file="${pas800image}" />
|
||||
<delete file="${pro140image}" />
|
||||
<delete file="${pro800image}" />
|
||||
<delete file="TEST.txt" />
|
||||
</target>
|
||||
</project>
|
@ -4,6 +4,7 @@ include ':lib:ac-api'
|
||||
include ':lib:ac-swt-common'
|
||||
include ':app:cli-ac'
|
||||
include ':app:cli-acx'
|
||||
include ':app:ant-ac'
|
||||
include ':app:gui-swing'
|
||||
include ':app:gui-swt-macosx-aarch64'
|
||||
include ':app:gui-swt-macosx-x86_64'
|
||||
|
Loading…
Reference in New Issue
Block a user