2012-08-06 11:59:37 +08:00
: :This script is used to finish a android automated compiler.
: :You should make sure have finished the environment setting.
: :Here are the environment variables you should set.
: :%ANT_HOME% %ANDROID_HOME% %JAVA_HOME% %CYGWIN% %GITBIN% %ANDROID_NDK%
: : Don't change it until you know what you do.
if not exist " %CYGWIN% " echo Couldn't find Cygwin at " %CYGWIN% " and you should set like this " C:\cygwin " & pause & exit 1
if not exist " %GITBIN% " echo Couldn't find Gitbin at " %GITBIN% " and you should set like this " F:\Git\bin " & pause & exit 2
if not exist " %ANDROID_HOME% " echo Couldn't find ANDROID_HOME at " %ANDROID_HOME% " and you should set like this " D:\Windows7\android-sdk-windows " & pause & exit 3
if not exist " %ANDROID_NDK% " echo Couldn't find Cygwin at " %ANDROID_NDK% " and you should set like this " D:\Windows7\android-ndk-r8 " & pause & exit 4
if not exist " %JAVA_HOME% " echo Couldn't find Cygwin at " %JAVA_HOME% " and you should set like this " C:\Program Files\Java\jdk1.7.0_05 " & pause & exit 5
set _PROJECTNAME = TestCpp
cd ..\..\..\..
: project
: :Copy build Configuration files to target directory
copy %cd% \tools\JenkinsScript\ant.properties %cd% \samples\%_PROJECTNAME% \proj.android
copy %cd% \tools\JenkinsScript\build.xml %cd% \samples\%_PROJECTNAME% \proj.android
copy %cd% \tools\JenkinsScript\Windows\android\rootconfig.sh %cd% \samples\%_PROJECTNAME% \proj.android
: :Modify the configuration files
cd samples\%_PROJECTNAME% \proj.android
rootconfig.sh %_PROJECTNAME%
cd ..
set _PROJECTLOCATION = %cd%
: :A command line that make the current user get the ownrship of project.
: :cacls proj.android\*.* /T /E /C /P %_USERNAME%:F
: :Use cygwin compile the source code.
cygpath " %_PROJECTLOCATION% \proj.android\build_native.sh " | call %CYGWIN% \Cygwin.bat
: :cacls proj.android\*.* /T /E /C /P %_USERNAME%:F
: :echo "%_PROJECTION%/proj.android/build_native.sh"|call %CYGWIN%\Cygwin.bat
: :cacls proj.android\*.* /T /E /C /P %_USERNAME%:F
call android update project -p proj.android
cd proj.android
: :Make sure the original android build target is android-8
for /f " delims= " %% a in ( 'findstr /i "target=android-" ant.properties' ) do set xx = %% a
echo %xx%
for /f " delims= " %% a in ( ant.properties) do (
if " %% a " == " %xx% " ( echo /target=android-8) else echo /%% a
)>>"anttmp.properties"
move anttmp.properties ant.properties
: :Android ant build(debug,API level:8).
call ant debug
2012-08-22 11:08:18 +08:00
set result8 = %ERRORLEVEL%
if " %_PROJECTNAME% " NEQ " TestCpp " goto API_10
if %result8% NEQ 0 goto API_10
cd bin
2012-08-24 10:23:00 +08:00
ren TestCpp-debug.apk TestCpp-debug-8.apk
2012-08-22 11:08:18 +08:00
cd ..
2012-08-06 11:59:37 +08:00
2012-08-22 11:08:18 +08:00
: API_10
2012-08-06 11:59:37 +08:00
: :Change API level.(API level:10)
for /f " delims= " %% a in ( ant.properties) do (
if " %% a " == " target=android-8 " ( echo /target=android-10) else echo /%% a
)>>"anttmp.properties"
move anttmp.properties ant.properties
: :Android ant build(debug,API level:10).
call ant debug
set result10 = %ERRORLEVEL%
2012-08-22 11:08:18 +08:00
if " %_PROJECTNAME% " NEQ " TestCpp " goto API_11
if %result10% NEQ 0 goto API_11
cd bin
2012-08-24 10:23:00 +08:00
ren TestCpp-debug.apk TestCpp-debug-10.apk
2012-08-22 11:08:18 +08:00
cd ..
2012-08-06 11:59:37 +08:00
2012-08-22 11:08:18 +08:00
: API_11
2012-08-06 11:59:37 +08:00
: :Change API level.(API level:11)
for /f " delims= " %% a in ( ant.properties) do (
if " %% a " == " target=android-10 " ( echo /target=android-11) else echo /%% a
)>>"anttmp.properties"
move anttmp.properties ant.properties
: :Android ant build(debug,API level:11).
call ant debug
set result11 = %ERRORlEVEL%
2012-08-22 11:08:18 +08:00
if " %_PROJECTNAME% " NEQ " TestCpp " goto API_12
if %result11% NEQ 0 goto API_12
cd bin
2012-08-24 10:23:00 +08:00
ren TestCpp-debug.apk TestCpp-debug-11.apk
2012-08-22 11:08:18 +08:00
cd ..
2012-08-06 11:59:37 +08:00
2012-08-22 11:08:18 +08:00
: API_12
2012-08-06 11:59:37 +08:00
: :Change API level.(API level:12)
for /f " delims= " %% a in ( ant.properties) do (
if " %% a " == " target=android-11 " ( echo /target=android-12) else echo /%% a
)>>"anttmp.properties"
move anttmp.properties ant.properties
: :Android ant build(debug,API level:12).
call ant debug
set result12 = %ERRORLEVEL%
2012-08-22 11:08:18 +08:00
if " %_PROJECTNAME% " NEQ " TestCpp " goto API_13
if %result12% NEQ 0 goto API_13
cd bin
2012-08-24 10:23:00 +08:00
ren TestCpp-debug.apk TestCpp-debug-12.apk
2012-08-22 11:08:18 +08:00
cd ..
2012-08-06 11:59:37 +08:00
2012-08-22 11:08:18 +08:00
: API_13
2012-08-06 11:59:37 +08:00
: :Change API level.(API level:13)
for /f " delims= " %% a in ( ant.properties) do (
if " %% a " == " target=android-12 " ( echo /target=android-13) else echo /%% a
)>>"anttmp.properties"
move anttmp.properties ant.properties
: :Android ant build(debug,API level:13).
call ant debug
set result13 = %ERRORLEVEL%
2012-08-22 11:08:18 +08:00
if " %_PROJECTNAME% " NEQ " TestCpp " goto NEXTPROJ
if %result13% NEQ 0 goto NEXTPROJ
cd bin
2012-08-24 10:23:00 +08:00
ren TestCpp-debug.apk TestCpp-debug-13.apk
2012-08-22 11:08:18 +08:00
cd ..
2012-08-06 11:59:37 +08:00
2012-08-22 11:08:18 +08:00
: NEXTPROJ
2012-08-06 11:59:37 +08:00
: :After all test versions completed,changed current API level to the original.(API level:8)
for /f " delims= " %% a in ( ant.properties) do (
if " %% a " == " target=android-13 " ( echo /target=android-8) else echo /%% a
)>>"anttmp.properties"
move anttmp.properties ant.properties
: :Calculate the errorlevel and change build target.
cd ..\..\..
2012-08-22 11:08:18 +08:00
if " %_PROJECTNAME% " == " TestCpp " set /a testresult1 = ( result8 + result10 + result11 + result12 + result13 ) && set _PROJECTNAME = HelloCpp&& goto project
if " %_PROJECTNAME% " == " HelloCpp " set /a testresult2 = ( result8 + result10 + result11 + result12 + result13 ) && set _PROJECTNAME = HelloLua&& goto project
if " %_PROJECTNAME% " == " HelloLua " set /a testresult3 = ( result8 + result10 + result11 + result12 + result13 )
2012-08-06 11:59:37 +08:00
set /a testresult = ( testresult1 + testresult2 + testresult3 )
2012-08-22 11:08:18 +08:00
if %testresult% NEQ 0 goto error
2012-08-06 11:59:37 +08:00
goto success
: error
echo Error.
2012-08-22 11:08:18 +08:00
: :git checkout -f
: :git clean -df -x
2012-08-06 11:59:37 +08:00
exit 1
: success
echo Success.
2012-08-22 11:08:18 +08:00
: :git checkout -f
: :git clean -df -x
2012-08-06 11:59:37 +08:00
exit 0
: :End.