2017-02-09 02:53:49 +08:00
|
|
|
@rem ------------------------------------------------------
|
2017-02-14 02:03:29 +08:00
|
|
|
@rem batch file to build tcc using mingw, msvc or tcc itself
|
2017-02-09 02:53:49 +08:00
|
|
|
@rem ------------------------------------------------------
|
2009-07-19 04:06:46 +08:00
|
|
|
|
2017-02-09 02:53:49 +08:00
|
|
|
@echo off
|
2017-02-14 17:45:35 +08:00
|
|
|
setlocal
|
various stuff
win32/Makefile ("for cygwin") removed
- On cygwin, the normal ./configure && make can be used with either
cygwin's "GCC for Win32 Toolchain"
./configure --cross-prefix=i686-w64-mingw32-
or with an existing tcc:
./configure --cc=<old-tccdir>/tcc.exe
tcctest.c:
- exclude test_high_clobbers() on _WIN64 (does not work)
tests2/95_bitfield.c:
- use 'signed char' for ARM (where default 'char' is unsigned)
tests:
- remove -I "expr" diff option to allow tests with
busybox-diff.
libtcc.c, tcc.c:
- removed -iwithprefix option. It is supposed to be
combined with -iprefix which we don't have either.
tccgen.c:
- fix assignments and return of 'void', as in
void f() {
void *p, *q;
*p = *q:
return *p;
}
This appears to be allowed but should do nothing.
tcc.h, libtcc.c, tccpp.c:
- Revert "Introduce VIP sysinclude paths which are always searched first"
This reverts commit 1d5e386b0a78393ac6b670c209a185849ec798a1.
The patch was giving tcc's system includes priority over -I which
is not how it should be.
tccelf.c:
- add DT_TEXTREL tag only if text relocations are actually
used (which is likely not the case on x86_64)
- prepare_dynamic_rel(): avoid relocation of unresolved
(weak) symbols
tccrun.c:
- for HAVE_SELINUX, use two mappings to the same (real) file.
(it was so once except the RX mapping wasn't used at all).
tccpe.c:
- fix relocation constant used for x86_64 (by Andrei E. Warentin)
- #ifndef _WIN32 do "chmod 755 ..." to get runnable exes on cygwin.
tccasm.c:
- keep forward asm labels static, otherwise they will endup
in dynsym eventually.
configure, Makefile:
- mingw32: respect ./configure options --bindir --docdir --libdir
- allow overriding tcc when building libtcc1.a and libtcc.def with
make XTCC=<tcc program to use>
- use $(wildcard ...) for install to allow installing just
a cross compiler for example
make cross-arm
make install
- use name <target>-libtcc1.a
build-tcc.bat:
- add options: -clean, -b bindir
2017-10-12 00:13:43 +08:00
|
|
|
if (%1)==(-clean) goto :cleanup
|
|
|
|
set CC=gcc
|
2017-02-09 02:53:49 +08:00
|
|
|
set /p VERSION= < ..\VERSION
|
2021-08-21 15:10:56 +08:00
|
|
|
git.exe --version 2>nul
|
|
|
|
if not %ERRORLEVEL%==0 goto :git_done
|
|
|
|
for /f %%b in ('git.exe rev-parse --abbrev-ref HEAD') do set GITHASH=%%b
|
|
|
|
for /f %%h in ('git.exe rev-parse --short HEAD') do set GITHASH=%GITHASH%:%%h
|
|
|
|
git.exe diff --quiet
|
|
|
|
if %ERRORLEVEL%==1 set GITHASH=%GITHASH%-mod
|
|
|
|
set DEF_GITHASH=-DTCC_GITHASH="""%GITHASH%"""
|
|
|
|
:git_done
|
2017-02-09 02:53:49 +08:00
|
|
|
set INST=
|
|
|
|
set DOC=no
|
various stuff
win32/Makefile ("for cygwin") removed
- On cygwin, the normal ./configure && make can be used with either
cygwin's "GCC for Win32 Toolchain"
./configure --cross-prefix=i686-w64-mingw32-
or with an existing tcc:
./configure --cc=<old-tccdir>/tcc.exe
tcctest.c:
- exclude test_high_clobbers() on _WIN64 (does not work)
tests2/95_bitfield.c:
- use 'signed char' for ARM (where default 'char' is unsigned)
tests:
- remove -I "expr" diff option to allow tests with
busybox-diff.
libtcc.c, tcc.c:
- removed -iwithprefix option. It is supposed to be
combined with -iprefix which we don't have either.
tccgen.c:
- fix assignments and return of 'void', as in
void f() {
void *p, *q;
*p = *q:
return *p;
}
This appears to be allowed but should do nothing.
tcc.h, libtcc.c, tccpp.c:
- Revert "Introduce VIP sysinclude paths which are always searched first"
This reverts commit 1d5e386b0a78393ac6b670c209a185849ec798a1.
The patch was giving tcc's system includes priority over -I which
is not how it should be.
tccelf.c:
- add DT_TEXTREL tag only if text relocations are actually
used (which is likely not the case on x86_64)
- prepare_dynamic_rel(): avoid relocation of unresolved
(weak) symbols
tccrun.c:
- for HAVE_SELINUX, use two mappings to the same (real) file.
(it was so once except the RX mapping wasn't used at all).
tccpe.c:
- fix relocation constant used for x86_64 (by Andrei E. Warentin)
- #ifndef _WIN32 do "chmod 755 ..." to get runnable exes on cygwin.
tccasm.c:
- keep forward asm labels static, otherwise they will endup
in dynsym eventually.
configure, Makefile:
- mingw32: respect ./configure options --bindir --docdir --libdir
- allow overriding tcc when building libtcc1.a and libtcc.def with
make XTCC=<tcc program to use>
- use $(wildcard ...) for install to allow installing just
a cross compiler for example
make cross-arm
make install
- use name <target>-libtcc1.a
build-tcc.bat:
- add options: -clean, -b bindir
2017-10-12 00:13:43 +08:00
|
|
|
set EXES_ONLY=no
|
2017-02-09 02:53:49 +08:00
|
|
|
goto :a0
|
various stuff
win32/Makefile ("for cygwin") removed
- On cygwin, the normal ./configure && make can be used with either
cygwin's "GCC for Win32 Toolchain"
./configure --cross-prefix=i686-w64-mingw32-
or with an existing tcc:
./configure --cc=<old-tccdir>/tcc.exe
tcctest.c:
- exclude test_high_clobbers() on _WIN64 (does not work)
tests2/95_bitfield.c:
- use 'signed char' for ARM (where default 'char' is unsigned)
tests:
- remove -I "expr" diff option to allow tests with
busybox-diff.
libtcc.c, tcc.c:
- removed -iwithprefix option. It is supposed to be
combined with -iprefix which we don't have either.
tccgen.c:
- fix assignments and return of 'void', as in
void f() {
void *p, *q;
*p = *q:
return *p;
}
This appears to be allowed but should do nothing.
tcc.h, libtcc.c, tccpp.c:
- Revert "Introduce VIP sysinclude paths which are always searched first"
This reverts commit 1d5e386b0a78393ac6b670c209a185849ec798a1.
The patch was giving tcc's system includes priority over -I which
is not how it should be.
tccelf.c:
- add DT_TEXTREL tag only if text relocations are actually
used (which is likely not the case on x86_64)
- prepare_dynamic_rel(): avoid relocation of unresolved
(weak) symbols
tccrun.c:
- for HAVE_SELINUX, use two mappings to the same (real) file.
(it was so once except the RX mapping wasn't used at all).
tccpe.c:
- fix relocation constant used for x86_64 (by Andrei E. Warentin)
- #ifndef _WIN32 do "chmod 755 ..." to get runnable exes on cygwin.
tccasm.c:
- keep forward asm labels static, otherwise they will endup
in dynsym eventually.
configure, Makefile:
- mingw32: respect ./configure options --bindir --docdir --libdir
- allow overriding tcc when building libtcc1.a and libtcc.def with
make XTCC=<tcc program to use>
- use $(wildcard ...) for install to allow installing just
a cross compiler for example
make cross-arm
make install
- use name <target>-libtcc1.a
build-tcc.bat:
- add options: -clean, -b bindir
2017-10-12 00:13:43 +08:00
|
|
|
:a2
|
|
|
|
shift
|
|
|
|
:a3
|
|
|
|
shift
|
|
|
|
:a0
|
|
|
|
if not (%1)==(-c) goto :a1
|
|
|
|
set CC=%~2
|
|
|
|
if (%2)==(cl) set CC=@call :cl
|
|
|
|
goto :a2
|
|
|
|
:a1
|
|
|
|
if (%1)==(-t) set T=%2&& goto :a2
|
|
|
|
if (%1)==(-v) set VERSION=%~2&& goto :a2
|
|
|
|
if (%1)==(-i) set INST=%2&& goto :a2
|
|
|
|
if (%1)==(-d) set DOC=yes&& goto :a3
|
|
|
|
if (%1)==(-x) set EXES_ONLY=yes&& goto :a3
|
|
|
|
if (%1)==() goto :p1
|
2017-02-09 02:53:49 +08:00
|
|
|
:usage
|
|
|
|
echo usage: build-tcc.bat [ options ... ]
|
|
|
|
echo options:
|
2017-02-14 02:03:29 +08:00
|
|
|
echo -c prog use prog (gcc/tcc/cl) to compile tcc
|
2017-02-09 02:53:49 +08:00
|
|
|
echo -c "prog options" use prog with options to compile tcc
|
|
|
|
echo -t 32/64 force 32/64 bit default target
|
|
|
|
echo -v "version" set tcc version
|
various stuff
win32/Makefile ("for cygwin") removed
- On cygwin, the normal ./configure && make can be used with either
cygwin's "GCC for Win32 Toolchain"
./configure --cross-prefix=i686-w64-mingw32-
or with an existing tcc:
./configure --cc=<old-tccdir>/tcc.exe
tcctest.c:
- exclude test_high_clobbers() on _WIN64 (does not work)
tests2/95_bitfield.c:
- use 'signed char' for ARM (where default 'char' is unsigned)
tests:
- remove -I "expr" diff option to allow tests with
busybox-diff.
libtcc.c, tcc.c:
- removed -iwithprefix option. It is supposed to be
combined with -iprefix which we don't have either.
tccgen.c:
- fix assignments and return of 'void', as in
void f() {
void *p, *q;
*p = *q:
return *p;
}
This appears to be allowed but should do nothing.
tcc.h, libtcc.c, tccpp.c:
- Revert "Introduce VIP sysinclude paths which are always searched first"
This reverts commit 1d5e386b0a78393ac6b670c209a185849ec798a1.
The patch was giving tcc's system includes priority over -I which
is not how it should be.
tccelf.c:
- add DT_TEXTREL tag only if text relocations are actually
used (which is likely not the case on x86_64)
- prepare_dynamic_rel(): avoid relocation of unresolved
(weak) symbols
tccrun.c:
- for HAVE_SELINUX, use two mappings to the same (real) file.
(it was so once except the RX mapping wasn't used at all).
tccpe.c:
- fix relocation constant used for x86_64 (by Andrei E. Warentin)
- #ifndef _WIN32 do "chmod 755 ..." to get runnable exes on cygwin.
tccasm.c:
- keep forward asm labels static, otherwise they will endup
in dynsym eventually.
configure, Makefile:
- mingw32: respect ./configure options --bindir --docdir --libdir
- allow overriding tcc when building libtcc1.a and libtcc.def with
make XTCC=<tcc program to use>
- use $(wildcard ...) for install to allow installing just
a cross compiler for example
make cross-arm
make install
- use name <target>-libtcc1.a
build-tcc.bat:
- add options: -clean, -b bindir
2017-10-12 00:13:43 +08:00
|
|
|
echo -i tccdir install tcc into tccdir
|
2017-02-09 02:53:49 +08:00
|
|
|
echo -d create tcc-doc.html too (needs makeinfo)
|
various stuff
win32/Makefile ("for cygwin") removed
- On cygwin, the normal ./configure && make can be used with either
cygwin's "GCC for Win32 Toolchain"
./configure --cross-prefix=i686-w64-mingw32-
or with an existing tcc:
./configure --cc=<old-tccdir>/tcc.exe
tcctest.c:
- exclude test_high_clobbers() on _WIN64 (does not work)
tests2/95_bitfield.c:
- use 'signed char' for ARM (where default 'char' is unsigned)
tests:
- remove -I "expr" diff option to allow tests with
busybox-diff.
libtcc.c, tcc.c:
- removed -iwithprefix option. It is supposed to be
combined with -iprefix which we don't have either.
tccgen.c:
- fix assignments and return of 'void', as in
void f() {
void *p, *q;
*p = *q:
return *p;
}
This appears to be allowed but should do nothing.
tcc.h, libtcc.c, tccpp.c:
- Revert "Introduce VIP sysinclude paths which are always searched first"
This reverts commit 1d5e386b0a78393ac6b670c209a185849ec798a1.
The patch was giving tcc's system includes priority over -I which
is not how it should be.
tccelf.c:
- add DT_TEXTREL tag only if text relocations are actually
used (which is likely not the case on x86_64)
- prepare_dynamic_rel(): avoid relocation of unresolved
(weak) symbols
tccrun.c:
- for HAVE_SELINUX, use two mappings to the same (real) file.
(it was so once except the RX mapping wasn't used at all).
tccpe.c:
- fix relocation constant used for x86_64 (by Andrei E. Warentin)
- #ifndef _WIN32 do "chmod 755 ..." to get runnable exes on cygwin.
tccasm.c:
- keep forward asm labels static, otherwise they will endup
in dynsym eventually.
configure, Makefile:
- mingw32: respect ./configure options --bindir --docdir --libdir
- allow overriding tcc when building libtcc1.a and libtcc.def with
make XTCC=<tcc program to use>
- use $(wildcard ...) for install to allow installing just
a cross compiler for example
make cross-arm
make install
- use name <target>-libtcc1.a
build-tcc.bat:
- add options: -clean, -b bindir
2017-10-12 00:13:43 +08:00
|
|
|
echo -x just create the executables
|
|
|
|
echo -clean delete all previously produced files and directories
|
2017-02-09 02:53:49 +08:00
|
|
|
exit /B 1
|
|
|
|
|
various stuff
win32/Makefile ("for cygwin") removed
- On cygwin, the normal ./configure && make can be used with either
cygwin's "GCC for Win32 Toolchain"
./configure --cross-prefix=i686-w64-mingw32-
or with an existing tcc:
./configure --cc=<old-tccdir>/tcc.exe
tcctest.c:
- exclude test_high_clobbers() on _WIN64 (does not work)
tests2/95_bitfield.c:
- use 'signed char' for ARM (where default 'char' is unsigned)
tests:
- remove -I "expr" diff option to allow tests with
busybox-diff.
libtcc.c, tcc.c:
- removed -iwithprefix option. It is supposed to be
combined with -iprefix which we don't have either.
tccgen.c:
- fix assignments and return of 'void', as in
void f() {
void *p, *q;
*p = *q:
return *p;
}
This appears to be allowed but should do nothing.
tcc.h, libtcc.c, tccpp.c:
- Revert "Introduce VIP sysinclude paths which are always searched first"
This reverts commit 1d5e386b0a78393ac6b670c209a185849ec798a1.
The patch was giving tcc's system includes priority over -I which
is not how it should be.
tccelf.c:
- add DT_TEXTREL tag only if text relocations are actually
used (which is likely not the case on x86_64)
- prepare_dynamic_rel(): avoid relocation of unresolved
(weak) symbols
tccrun.c:
- for HAVE_SELINUX, use two mappings to the same (real) file.
(it was so once except the RX mapping wasn't used at all).
tccpe.c:
- fix relocation constant used for x86_64 (by Andrei E. Warentin)
- #ifndef _WIN32 do "chmod 755 ..." to get runnable exes on cygwin.
tccasm.c:
- keep forward asm labels static, otherwise they will endup
in dynsym eventually.
configure, Makefile:
- mingw32: respect ./configure options --bindir --docdir --libdir
- allow overriding tcc when building libtcc1.a and libtcc.def with
make XTCC=<tcc program to use>
- use $(wildcard ...) for install to allow installing just
a cross compiler for example
make cross-arm
make install
- use name <target>-libtcc1.a
build-tcc.bat:
- add options: -clean, -b bindir
2017-10-12 00:13:43 +08:00
|
|
|
@rem ------------------------------------------------------
|
|
|
|
@rem sub-routines
|
|
|
|
|
|
|
|
:cleanup
|
|
|
|
set LOG=echo
|
|
|
|
%LOG% removing files:
|
|
|
|
for %%f in (*tcc.exe libtcc.dll lib\*.a) do call :del_file %%f
|
|
|
|
for %%f in (..\config.h ..\config.texi) do call :del_file %%f
|
|
|
|
for %%f in (include\*.h) do @if exist ..\%%f call :del_file %%f
|
|
|
|
for %%f in (include\tcclib.h examples\libtcc_test.c) do call :del_file %%f
|
2020-02-11 12:57:12 +08:00
|
|
|
for %%f in (lib\*.o *.o *.obj *.def *.pdb *.lib *.exp *.ilk) do call :del_file %%f
|
various stuff
win32/Makefile ("for cygwin") removed
- On cygwin, the normal ./configure && make can be used with either
cygwin's "GCC for Win32 Toolchain"
./configure --cross-prefix=i686-w64-mingw32-
or with an existing tcc:
./configure --cc=<old-tccdir>/tcc.exe
tcctest.c:
- exclude test_high_clobbers() on _WIN64 (does not work)
tests2/95_bitfield.c:
- use 'signed char' for ARM (where default 'char' is unsigned)
tests:
- remove -I "expr" diff option to allow tests with
busybox-diff.
libtcc.c, tcc.c:
- removed -iwithprefix option. It is supposed to be
combined with -iprefix which we don't have either.
tccgen.c:
- fix assignments and return of 'void', as in
void f() {
void *p, *q;
*p = *q:
return *p;
}
This appears to be allowed but should do nothing.
tcc.h, libtcc.c, tccpp.c:
- Revert "Introduce VIP sysinclude paths which are always searched first"
This reverts commit 1d5e386b0a78393ac6b670c209a185849ec798a1.
The patch was giving tcc's system includes priority over -I which
is not how it should be.
tccelf.c:
- add DT_TEXTREL tag only if text relocations are actually
used (which is likely not the case on x86_64)
- prepare_dynamic_rel(): avoid relocation of unresolved
(weak) symbols
tccrun.c:
- for HAVE_SELINUX, use two mappings to the same (real) file.
(it was so once except the RX mapping wasn't used at all).
tccpe.c:
- fix relocation constant used for x86_64 (by Andrei E. Warentin)
- #ifndef _WIN32 do "chmod 755 ..." to get runnable exes on cygwin.
tccasm.c:
- keep forward asm labels static, otherwise they will endup
in dynsym eventually.
configure, Makefile:
- mingw32: respect ./configure options --bindir --docdir --libdir
- allow overriding tcc when building libtcc1.a and libtcc.def with
make XTCC=<tcc program to use>
- use $(wildcard ...) for install to allow installing just
a cross compiler for example
make cross-arm
make install
- use name <target>-libtcc1.a
build-tcc.bat:
- add options: -clean, -b bindir
2017-10-12 00:13:43 +08:00
|
|
|
%LOG% removing directories:
|
|
|
|
for %%f in (doc libtcc) do call :del_dir %%f
|
|
|
|
%LOG% done.
|
|
|
|
exit /B 0
|
|
|
|
:del_file
|
|
|
|
if exist %1 del %1 && %LOG% %1
|
|
|
|
exit /B 0
|
|
|
|
:del_dir
|
|
|
|
if exist %1 rmdir /Q/S %1 && %LOG% %1
|
|
|
|
exit /B 0
|
|
|
|
|
2017-02-14 02:03:29 +08:00
|
|
|
:cl
|
|
|
|
@echo off
|
|
|
|
set CMD=cl
|
|
|
|
:c0
|
|
|
|
set ARG=%1
|
|
|
|
set ARG=%ARG:.dll=.lib%
|
|
|
|
if (%1)==(-shared) set ARG=-LD
|
|
|
|
if (%1)==(-o) shift && set ARG=-Fe%2
|
|
|
|
set CMD=%CMD% %ARG%
|
|
|
|
shift
|
|
|
|
if not (%1)==() goto :c0
|
|
|
|
echo on
|
2021-08-21 15:10:56 +08:00
|
|
|
%CMD% -O2 -W2 -Zi -MT -GS- -nologo %DEF_GITHASH% -link -opt:ref,icf
|
2017-02-14 02:03:29 +08:00
|
|
|
@exit /B %ERRORLEVEL%
|
|
|
|
|
various stuff
win32/Makefile ("for cygwin") removed
- On cygwin, the normal ./configure && make can be used with either
cygwin's "GCC for Win32 Toolchain"
./configure --cross-prefix=i686-w64-mingw32-
or with an existing tcc:
./configure --cc=<old-tccdir>/tcc.exe
tcctest.c:
- exclude test_high_clobbers() on _WIN64 (does not work)
tests2/95_bitfield.c:
- use 'signed char' for ARM (where default 'char' is unsigned)
tests:
- remove -I "expr" diff option to allow tests with
busybox-diff.
libtcc.c, tcc.c:
- removed -iwithprefix option. It is supposed to be
combined with -iprefix which we don't have either.
tccgen.c:
- fix assignments and return of 'void', as in
void f() {
void *p, *q;
*p = *q:
return *p;
}
This appears to be allowed but should do nothing.
tcc.h, libtcc.c, tccpp.c:
- Revert "Introduce VIP sysinclude paths which are always searched first"
This reverts commit 1d5e386b0a78393ac6b670c209a185849ec798a1.
The patch was giving tcc's system includes priority over -I which
is not how it should be.
tccelf.c:
- add DT_TEXTREL tag only if text relocations are actually
used (which is likely not the case on x86_64)
- prepare_dynamic_rel(): avoid relocation of unresolved
(weak) symbols
tccrun.c:
- for HAVE_SELINUX, use two mappings to the same (real) file.
(it was so once except the RX mapping wasn't used at all).
tccpe.c:
- fix relocation constant used for x86_64 (by Andrei E. Warentin)
- #ifndef _WIN32 do "chmod 755 ..." to get runnable exes on cygwin.
tccasm.c:
- keep forward asm labels static, otherwise they will endup
in dynsym eventually.
configure, Makefile:
- mingw32: respect ./configure options --bindir --docdir --libdir
- allow overriding tcc when building libtcc1.a and libtcc.def with
make XTCC=<tcc program to use>
- use $(wildcard ...) for install to allow installing just
a cross compiler for example
make cross-arm
make install
- use name <target>-libtcc1.a
build-tcc.bat:
- add options: -clean, -b bindir
2017-10-12 00:13:43 +08:00
|
|
|
@rem ------------------------------------------------------
|
|
|
|
@rem main program
|
2017-02-18 16:55:34 +08:00
|
|
|
|
various stuff
win32/Makefile ("for cygwin") removed
- On cygwin, the normal ./configure && make can be used with either
cygwin's "GCC for Win32 Toolchain"
./configure --cross-prefix=i686-w64-mingw32-
or with an existing tcc:
./configure --cc=<old-tccdir>/tcc.exe
tcctest.c:
- exclude test_high_clobbers() on _WIN64 (does not work)
tests2/95_bitfield.c:
- use 'signed char' for ARM (where default 'char' is unsigned)
tests:
- remove -I "expr" diff option to allow tests with
busybox-diff.
libtcc.c, tcc.c:
- removed -iwithprefix option. It is supposed to be
combined with -iprefix which we don't have either.
tccgen.c:
- fix assignments and return of 'void', as in
void f() {
void *p, *q;
*p = *q:
return *p;
}
This appears to be allowed but should do nothing.
tcc.h, libtcc.c, tccpp.c:
- Revert "Introduce VIP sysinclude paths which are always searched first"
This reverts commit 1d5e386b0a78393ac6b670c209a185849ec798a1.
The patch was giving tcc's system includes priority over -I which
is not how it should be.
tccelf.c:
- add DT_TEXTREL tag only if text relocations are actually
used (which is likely not the case on x86_64)
- prepare_dynamic_rel(): avoid relocation of unresolved
(weak) symbols
tccrun.c:
- for HAVE_SELINUX, use two mappings to the same (real) file.
(it was so once except the RX mapping wasn't used at all).
tccpe.c:
- fix relocation constant used for x86_64 (by Andrei E. Warentin)
- #ifndef _WIN32 do "chmod 755 ..." to get runnable exes on cygwin.
tccasm.c:
- keep forward asm labels static, otherwise they will endup
in dynsym eventually.
configure, Makefile:
- mingw32: respect ./configure options --bindir --docdir --libdir
- allow overriding tcc when building libtcc1.a and libtcc.def with
make XTCC=<tcc program to use>
- use $(wildcard ...) for install to allow installing just
a cross compiler for example
make cross-arm
make install
- use name <target>-libtcc1.a
build-tcc.bat:
- add options: -clean, -b bindir
2017-10-12 00:13:43 +08:00
|
|
|
:p1
|
2017-02-14 17:45:35 +08:00
|
|
|
if not %T%_==_ goto :p2
|
|
|
|
set T=32
|
|
|
|
if %PROCESSOR_ARCHITECTURE%_==AMD64_ set T=64
|
|
|
|
if %PROCESSOR_ARCHITEW6432%_==AMD64_ set T=64
|
|
|
|
:p2
|
2021-08-21 15:10:56 +08:00
|
|
|
if "%CC:~-3%"=="gcc" set CC=%CC% -O2 -s -static %DEF_GITHASH%
|
2017-02-09 02:53:49 +08:00
|
|
|
set D32=-DTCC_TARGET_PE -DTCC_TARGET_I386
|
|
|
|
set D64=-DTCC_TARGET_PE -DTCC_TARGET_X86_64
|
2017-02-23 15:41:57 +08:00
|
|
|
set P32=i386-win32
|
|
|
|
set P64=x86_64-win32
|
2017-02-09 02:53:49 +08:00
|
|
|
if %T%==64 goto :t64
|
|
|
|
set D=%D32%
|
|
|
|
set DX=%D64%
|
2017-02-23 15:41:57 +08:00
|
|
|
set PX=%P64%
|
2021-03-30 17:25:58 +08:00
|
|
|
set TX=64
|
various stuff
win32/Makefile ("for cygwin") removed
- On cygwin, the normal ./configure && make can be used with either
cygwin's "GCC for Win32 Toolchain"
./configure --cross-prefix=i686-w64-mingw32-
or with an existing tcc:
./configure --cc=<old-tccdir>/tcc.exe
tcctest.c:
- exclude test_high_clobbers() on _WIN64 (does not work)
tests2/95_bitfield.c:
- use 'signed char' for ARM (where default 'char' is unsigned)
tests:
- remove -I "expr" diff option to allow tests with
busybox-diff.
libtcc.c, tcc.c:
- removed -iwithprefix option. It is supposed to be
combined with -iprefix which we don't have either.
tccgen.c:
- fix assignments and return of 'void', as in
void f() {
void *p, *q;
*p = *q:
return *p;
}
This appears to be allowed but should do nothing.
tcc.h, libtcc.c, tccpp.c:
- Revert "Introduce VIP sysinclude paths which are always searched first"
This reverts commit 1d5e386b0a78393ac6b670c209a185849ec798a1.
The patch was giving tcc's system includes priority over -I which
is not how it should be.
tccelf.c:
- add DT_TEXTREL tag only if text relocations are actually
used (which is likely not the case on x86_64)
- prepare_dynamic_rel(): avoid relocation of unresolved
(weak) symbols
tccrun.c:
- for HAVE_SELINUX, use two mappings to the same (real) file.
(it was so once except the RX mapping wasn't used at all).
tccpe.c:
- fix relocation constant used for x86_64 (by Andrei E. Warentin)
- #ifndef _WIN32 do "chmod 755 ..." to get runnable exes on cygwin.
tccasm.c:
- keep forward asm labels static, otherwise they will endup
in dynsym eventually.
configure, Makefile:
- mingw32: respect ./configure options --bindir --docdir --libdir
- allow overriding tcc when building libtcc1.a and libtcc.def with
make XTCC=<tcc program to use>
- use $(wildcard ...) for install to allow installing just
a cross compiler for example
make cross-arm
make install
- use name <target>-libtcc1.a
build-tcc.bat:
- add options: -clean, -b bindir
2017-10-12 00:13:43 +08:00
|
|
|
goto :p3
|
2017-02-09 02:53:49 +08:00
|
|
|
:t64
|
|
|
|
set D=%D64%
|
|
|
|
set DX=%D32%
|
2017-02-23 15:41:57 +08:00
|
|
|
set PX=%P32%
|
2021-03-30 17:25:58 +08:00
|
|
|
set TX=32
|
various stuff
win32/Makefile ("for cygwin") removed
- On cygwin, the normal ./configure && make can be used with either
cygwin's "GCC for Win32 Toolchain"
./configure --cross-prefix=i686-w64-mingw32-
or with an existing tcc:
./configure --cc=<old-tccdir>/tcc.exe
tcctest.c:
- exclude test_high_clobbers() on _WIN64 (does not work)
tests2/95_bitfield.c:
- use 'signed char' for ARM (where default 'char' is unsigned)
tests:
- remove -I "expr" diff option to allow tests with
busybox-diff.
libtcc.c, tcc.c:
- removed -iwithprefix option. It is supposed to be
combined with -iprefix which we don't have either.
tccgen.c:
- fix assignments and return of 'void', as in
void f() {
void *p, *q;
*p = *q:
return *p;
}
This appears to be allowed but should do nothing.
tcc.h, libtcc.c, tccpp.c:
- Revert "Introduce VIP sysinclude paths which are always searched first"
This reverts commit 1d5e386b0a78393ac6b670c209a185849ec798a1.
The patch was giving tcc's system includes priority over -I which
is not how it should be.
tccelf.c:
- add DT_TEXTREL tag only if text relocations are actually
used (which is likely not the case on x86_64)
- prepare_dynamic_rel(): avoid relocation of unresolved
(weak) symbols
tccrun.c:
- for HAVE_SELINUX, use two mappings to the same (real) file.
(it was so once except the RX mapping wasn't used at all).
tccpe.c:
- fix relocation constant used for x86_64 (by Andrei E. Warentin)
- #ifndef _WIN32 do "chmod 755 ..." to get runnable exes on cygwin.
tccasm.c:
- keep forward asm labels static, otherwise they will endup
in dynsym eventually.
configure, Makefile:
- mingw32: respect ./configure options --bindir --docdir --libdir
- allow overriding tcc when building libtcc1.a and libtcc.def with
make XTCC=<tcc program to use>
- use $(wildcard ...) for install to allow installing just
a cross compiler for example
make cross-arm
make install
- use name <target>-libtcc1.a
build-tcc.bat:
- add options: -clean, -b bindir
2017-10-12 00:13:43 +08:00
|
|
|
goto :p3
|
2010-12-04 23:47:08 +08:00
|
|
|
|
various stuff
win32/Makefile ("for cygwin") removed
- On cygwin, the normal ./configure && make can be used with either
cygwin's "GCC for Win32 Toolchain"
./configure --cross-prefix=i686-w64-mingw32-
or with an existing tcc:
./configure --cc=<old-tccdir>/tcc.exe
tcctest.c:
- exclude test_high_clobbers() on _WIN64 (does not work)
tests2/95_bitfield.c:
- use 'signed char' for ARM (where default 'char' is unsigned)
tests:
- remove -I "expr" diff option to allow tests with
busybox-diff.
libtcc.c, tcc.c:
- removed -iwithprefix option. It is supposed to be
combined with -iprefix which we don't have either.
tccgen.c:
- fix assignments and return of 'void', as in
void f() {
void *p, *q;
*p = *q:
return *p;
}
This appears to be allowed but should do nothing.
tcc.h, libtcc.c, tccpp.c:
- Revert "Introduce VIP sysinclude paths which are always searched first"
This reverts commit 1d5e386b0a78393ac6b670c209a185849ec798a1.
The patch was giving tcc's system includes priority over -I which
is not how it should be.
tccelf.c:
- add DT_TEXTREL tag only if text relocations are actually
used (which is likely not the case on x86_64)
- prepare_dynamic_rel(): avoid relocation of unresolved
(weak) symbols
tccrun.c:
- for HAVE_SELINUX, use two mappings to the same (real) file.
(it was so once except the RX mapping wasn't used at all).
tccpe.c:
- fix relocation constant used for x86_64 (by Andrei E. Warentin)
- #ifndef _WIN32 do "chmod 755 ..." to get runnable exes on cygwin.
tccasm.c:
- keep forward asm labels static, otherwise they will endup
in dynsym eventually.
configure, Makefile:
- mingw32: respect ./configure options --bindir --docdir --libdir
- allow overriding tcc when building libtcc1.a and libtcc.def with
make XTCC=<tcc program to use>
- use $(wildcard ...) for install to allow installing just
a cross compiler for example
make cross-arm
make install
- use name <target>-libtcc1.a
build-tcc.bat:
- add options: -clean, -b bindir
2017-10-12 00:13:43 +08:00
|
|
|
:p3
|
2017-02-09 02:53:49 +08:00
|
|
|
@echo on
|
2009-07-19 04:06:46 +08:00
|
|
|
|
2017-02-09 02:53:49 +08:00
|
|
|
:config.h
|
|
|
|
echo>..\config.h #define TCC_VERSION "%VERSION%"
|
|
|
|
echo>> ..\config.h #ifdef TCC_TARGET_X86_64
|
2017-02-23 15:41:57 +08:00
|
|
|
echo>> ..\config.h #define TCC_LIBTCC1 "libtcc1-64.a"
|
2017-02-09 02:53:49 +08:00
|
|
|
echo>> ..\config.h #else
|
2017-02-23 15:41:57 +08:00
|
|
|
echo>> ..\config.h #define TCC_LIBTCC1 "libtcc1-32.a"
|
2017-02-09 02:53:49 +08:00
|
|
|
echo>> ..\config.h #endif
|
|
|
|
|
2017-02-18 16:55:34 +08:00
|
|
|
for %%f in (*tcc.exe *tcc.dll) do @del %%f
|
2017-02-09 02:53:49 +08:00
|
|
|
|
2021-03-30 17:25:58 +08:00
|
|
|
@if _%TCC_C%_==__ goto compiler_2parts
|
|
|
|
@rem if TCC_C was defined then build only tcc.exe
|
|
|
|
%CC% -o tcc.exe %TCC_C% %D%
|
|
|
|
@goto :compiler_done
|
|
|
|
|
|
|
|
:compiler_2parts
|
|
|
|
@if _%LIBTCC_C%_==__ set LIBTCC_C=..\libtcc.c
|
|
|
|
%CC% -o libtcc.dll -shared %LIBTCC_C% %D% -DLIBTCC_AS_DLL
|
2017-02-09 02:53:49 +08:00
|
|
|
@if errorlevel 1 goto :the_end
|
2017-09-25 00:57:48 +08:00
|
|
|
%CC% -o tcc.exe ..\tcc.c libtcc.dll %D% -DONE_SOURCE"=0"
|
2017-07-24 03:24:11 +08:00
|
|
|
%CC% -o %PX%-tcc.exe ..\tcc.c %DX%
|
2021-03-30 17:25:58 +08:00
|
|
|
:compiler_done
|
2020-10-24 03:38:53 +08:00
|
|
|
@if (%EXES_ONLY%)==(yes) goto :files_done
|
2009-07-19 04:06:46 +08:00
|
|
|
|
2017-02-09 02:53:49 +08:00
|
|
|
if not exist libtcc mkdir libtcc
|
|
|
|
if not exist doc mkdir doc
|
|
|
|
copy>nul ..\include\*.h include
|
|
|
|
copy>nul ..\tcclib.h include
|
|
|
|
copy>nul ..\libtcc.h libtcc
|
|
|
|
copy>nul ..\tests\libtcc_test.c examples
|
|
|
|
copy>nul tcc-win32.txt doc
|
2009-07-19 04:06:46 +08:00
|
|
|
|
2021-03-30 17:25:58 +08:00
|
|
|
if exist libtcc.dll .\tcc -impdef libtcc.dll -o libtcc\libtcc.def
|
2017-02-18 16:55:34 +08:00
|
|
|
@if errorlevel 1 goto :the_end
|
2009-12-20 05:22:43 +08:00
|
|
|
|
|
|
|
:libtcc1.a
|
2021-03-30 17:25:58 +08:00
|
|
|
call :makelib %T%
|
2017-02-09 02:53:49 +08:00
|
|
|
@if errorlevel 1 goto :the_end
|
2021-03-30 17:25:58 +08:00
|
|
|
@if exist %PX%-tcc.exe call :makelib %TX%
|
2017-02-09 02:53:49 +08:00
|
|
|
@if errorlevel 1 goto :the_end
|
2020-01-19 18:15:12 +08:00
|
|
|
.\tcc -m%T% -c ../lib/bcheck.c -o lib/bcheck.o -g
|
2020-01-18 05:58:39 +08:00
|
|
|
.\tcc -m%T% -c ../lib/bt-exe.c -o lib/bt-exe.o
|
|
|
|
.\tcc -m%T% -c ../lib/bt-log.c -o lib/bt-log.o
|
|
|
|
.\tcc -m%T% -c ../lib/bt-dll.c -o lib/bt-dll.o
|
2013-09-19 21:50:38 +08:00
|
|
|
|
2017-02-09 02:53:49 +08:00
|
|
|
:tcc-doc.html
|
|
|
|
@if not (%DOC%)==(yes) goto :doc-done
|
2016-10-02 03:06:33 +08:00
|
|
|
echo>..\config.texi @set VERSION %VERSION%
|
2017-02-09 02:53:49 +08:00
|
|
|
cmd /c makeinfo --html --no-split ../tcc-doc.texi -o doc/tcc-doc.html
|
|
|
|
:doc-done
|
|
|
|
|
2020-10-24 03:38:53 +08:00
|
|
|
:files_done
|
2017-02-18 16:55:34 +08:00
|
|
|
for %%f in (*.o *.def) do @del %%f
|
2017-02-09 02:53:49 +08:00
|
|
|
|
|
|
|
:copy-install
|
|
|
|
@if (%INST%)==() goto :the_end
|
|
|
|
if not exist %INST% mkdir %INST%
|
2021-03-30 17:25:58 +08:00
|
|
|
for %%f in (*tcc.exe *tcc.dll) do @copy>nul %%f %INST%\%%f
|
2017-02-23 15:41:57 +08:00
|
|
|
@if not exist %INST%\lib mkdir %INST%\lib
|
2020-01-18 05:58:39 +08:00
|
|
|
for %%f in (lib\*.a lib\*.o lib\*.def) do @copy>nul %%f %INST%\%%f
|
2017-02-23 15:41:57 +08:00
|
|
|
for %%f in (include examples libtcc doc) do @xcopy>nul /s/i/q/y %%f %INST%\%%f
|
2017-02-09 02:53:49 +08:00
|
|
|
|
|
|
|
:the_end
|
|
|
|
exit /B %ERRORLEVEL%
|
2021-03-30 17:25:58 +08:00
|
|
|
|
|
|
|
:makelib
|
|
|
|
.\tcc -m%1 -c ../lib/libtcc1.c
|
|
|
|
.\tcc -m%1 -c lib/crt1.c
|
|
|
|
.\tcc -m%1 -c lib/crt1w.c
|
|
|
|
.\tcc -m%1 -c lib/wincrt1.c
|
|
|
|
.\tcc -m%1 -c lib/wincrt1w.c
|
|
|
|
.\tcc -m%1 -c lib/dllcrt1.c
|
|
|
|
.\tcc -m%1 -c lib/dllmain.c
|
|
|
|
.\tcc -m%1 -c lib/chkstk.S
|
|
|
|
.\tcc -m%1 -c ../lib/alloca.S
|
|
|
|
.\tcc -m%1 -c ../lib/alloca-bt.S
|
|
|
|
.\tcc -m%1 -c ../lib/stdatomic.c
|
|
|
|
.\tcc -m%1 -ar lib/libtcc1-%1.a libtcc1.o crt1.o crt1w.o wincrt1.o wincrt1w.o dllcrt1.o dllmain.o chkstk.o alloca.o alloca-bt.o stdatomic.o
|
|
|
|
exit /B %ERRORLEVEL%
|