diff configure.bat @ 0:3e629dc19168

initial from svn dyncall-1745
author Daniel Adler
date Thu, 19 Mar 2015 22:24:28 +0100
parents
children f5e9f7f8a932
line wrap: on
line diff
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/configure.bat	Thu Mar 19 22:24:28 2015 +0100
@@ -0,0 +1,157 @@
+@ECHO OFF
+REM ///////////////////////////////////////////////////////////////////////////
+REM
+REM Copyright (c) 2007-2009 Daniel Adler <dadler@uni-goettingen.de>, 
+REM                         Tassilo Philipp <tphilipp@potion-studios.com>
+REM
+REM Permission to use, copy, modify, and distribute this software for any
+REM purpose with or without fee is hereby granted, provided that the above
+REM copyright notice and this permission notice appear in all copies.
+REM
+REM THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
+REM WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
+REM MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
+REM ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
+REM WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
+REM ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
+REM OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
+REM
+REM ///////////////////////////////////////////////////////////////////////////
+
+
+SETLOCAL
+
+REM Set default values.
+SET PACKAGE=dyncall
+SET CONFIG_HOST=windows
+SET CONFIG_OS=windows
+SET CONFIG_TOOL=msvc
+SET CONFIG_ASM=ml
+SET CONFIG_CONFIG=release
+IF [%PROCESSOR_ARCHITECTURE%] == [AMD64] (
+	SET CONFIG_ARCH=x64
+) ELSE IF [%PROCESSOR_ARCHITEW6432%] == [AMD64] (
+	SET CONFIG_ARCH=x64
+) ELSE (
+	SET CONFIG_ARCH=x86
+)
+
+REM Scan arguments.
+:MAIN_LOOP
+
+
+REM Help.
+IF [%1]==[] (
+	GOTO DONE
+) ELSE IF [%1]==[/?] (
+	ECHO.
+	ECHO.dyncall configuration shell-script
+	ECHO.Usage:
+	ECHO.  configure.bat [ options ]
+	ECHO.
+	ECHO.Options:
+	ECHO.  /?                print this page
+	ECHO.
+	ECHO.  /prefix PATH      set installation prefix ^(GNU make only^)
+	ECHO.  /prefix-bd PATH   set build directory prefix ^(GNU make only^)
+	ECHO.                    ^(only for use with gmake^)
+	ECHO.
+	ECHO.  /target-x86       build for x86 architecture ^(default^)
+	ECHO.  /target-x64       build for x64 architecture
+	ECHO.  /target-psp       build for PlayStation Portable ^(homebrew SDK^)
+	ECHO.  /target-nds-arm   build for Nintendo DS ^(devkitPro, ARM mode^)
+	ECHO.  /target-nds-thumb build for Nintendo DS ^(devkitPro, THUMB mode^)
+	ECHO.
+	ECHO.  /tool-msvc        use Microsoft Visual C++ compiler ^(default^)
+	ECHO.  /tool-gcc         use GNU Compiler Collection
+	ECHO.
+	ECHO.  /asm-ml           use Microsoft Macro Assembler ^(default^)
+	ECHO.  /asm-as           use the GNU Assembler
+	ECHO.  /asm-nasm         use NASM Assembler
+	ECHO.
+	ECHO.  /config-release   build release version ^(default^)
+	ECHO.  /config-debug     build debug version
+	GOTO:EOF
+) ELSE IF [%1]==[/prefix] (
+	SET CONFIG_PREFIX=%2
+	SHIFT
+) ELSE IF [%1]==[/prefix-bd] (
+	SET CONFIG_BUILDPREFIX=%2
+	SHIFT
+) ELSE IF [%1]==[/target-x86] (
+	SET CONFIG_ARCH=x86
+) ELSE IF [%1]==[/target-x64] (
+	SET CONFIG_ARCH=x64
+) ELSE IF [%1]==[/target-psp] (
+	SET CONFIG_ARCH=mips32
+	SET CONFIG_OS=psp
+) ELSE IF [%1]==[/target-nds-arm] (
+	SET CONFIG_ARCH=arm32_arm
+	SET CONFIG_OS=nds
+) ELSE IF [%1]==[/target-nds-thumb] (
+	SET CONFIG_ARCH=arm32_thumb
+	SET CONFIG_OS=nds
+) ELSE IF [%1]==[/tool-gcc] (
+	SET CONFIG_TOOL=gcc
+	SET CONFIG_ASM=as
+) ELSE IF [%1]==[/tool-msvc] (
+	SET CONFIG_TOOL=msvc
+	SET CONFIG_ASM=ml
+) ELSE IF [%1]==[/asm-as] (
+	SET CONFIG_ASM=as
+) ELSE IF [%1]==[/asm-nasm] (
+	SET CONFIG_ASM=nasm
+) ELSE IF [%1]==[/asm-ml] (
+	SET CONFIG_ASM=ml
+) ELSE IF [%1]==[/config-release] (
+	SET CONFIG_CONFIG=release
+) ELSE IF [%1]==[/config-debug] (
+	SET CONFIG_CONFIG=debug
+) ELSE (
+	ECHO Unknown parameter '%1'.
+	GOTO DONE
+)
+
+SHIFT
+GOTO MAIN_LOOP
+:DONE
+
+IF [%CONFIG_PREFIX%]==[] (
+	SET CONFIG_PREFIX=%CD%\install_%CONFIG_OS%_%CONFIG_ARCH%_%CONFIG_TOOL%_%CONFIG_CONFIG%
+)
+IF [%CONFIG_BUILDPREFIX%]==[] (
+	SET CONFIG_BUILDPREFIX=%CD%\build_out\%CONFIG_OS%_%CONFIG_ARCH%_%CONFIG_TOOL%_%CONFIG_CONFIG%
+)
+
+ECHO # auto-generated by configure.bat >ConfigVars
+ECHO CONFIG_PACKAGE=%PACKAGE%#>>ConfigVars
+ECHO CONFIG_HOST=%CONFIG_HOST%#>>ConfigVars
+ECHO CONFIG_OS=%CONFIG_OS%#>>ConfigVars
+ECHO CONFIG_ARCH=%CONFIG_ARCH%#>>ConfigVars
+ECHO CONFIG_TOOL=%CONFIG_TOOL%#>>ConfigVars
+ECHO CONFIG_ASM=%CONFIG_ASM%#>>ConfigVars
+ECHO CONFIG_CONFIG=%CONFIG_CONFIG%#>>ConfigVars
+ECHO CONFIG_PREFIX=%CONFIG_PREFIX%#>>ConfigVars
+ECHO CONFIG_BUILDPREFIX=%CONFIG_BUILDPREFIX%#>>ConfigVars
+
+ECHO Writing following configuration to ConfigVars:
+ECHO.
+ECHO Host OS:             %CONFIG_HOST%
+ECHO Target OS:           %CONFIG_OS%
+ECHO Target Architecture: %CONFIG_ARCH%
+ECHO Compiler:            %CONFIG_TOOL%
+ECHO Assembler:           %CONFIG_ASM%
+ECHO Build configuration: %CONFIG_CONFIG%
+ECHO Install prefix:      %CONFIG_PREFIX%
+ECHO Build prefix:        %CONFIG_BUILDPREFIX%
+
+
+REM We have to transform some pathes for the nds/devkitPro build.
+IF [%CONFIG_OS%]==[nds] (
+	REM Check if DEVKITPRO is set.
+	IF [%DEVKITPRO%]==[] (
+		ECHO ERROR: Environment variable DEVKITPRO must be set to absolute devkitPro path.
+	) ELSE (
+		buildsys\scripts\conf-nds.bat
+	)
+)