mirror of
https://github.com/mirror/tinycc.git
synced 2025-01-03 04:30:08 +08:00
install-clean-tuning
* Don't use /usr/local/lib/tcc/libtcc1.a for i386 and x86_64 A $(tccdir)/i386 directory was used to install a libtcc1.a but only when cross compiling. And no x86_64 directory. * Build/install i386-tcc/x86_64-tcc and not a tcc * Build/install i386-win-tcc/x86_64-win-tcc and not a i386-win-mingw32-tcc/... * DEFINES = -DTCC_TARGET_I386... also for i386-tcc and i386-win-tcc * Make a symlink tcc to the i386-tcc/x86_64-tcc for a "make test" * Build a $(ARCH) directory with a symlink to the libtcc1.a for a "make test" * Remove a /usr/local/lib/tcc directory on uninstall * Remove a /usr/local/share/doc/tcc directory on uninstall * Remove a $(ARCH) directory on "make clean" * Remove a *-tcc files on "make clean"
This commit is contained in:
parent
54fc439e9e
commit
76af948623
42
Makefile
42
Makefile
@ -101,6 +101,15 @@ $(ARM_FPA_LD_CROSS)_LINK = arm-fpa-ld-tcc$(EXESUF)
|
|||||||
$(ARM_VFP_CROSS)_LINK = arm-vfp-tcc$(EXESUF)
|
$(ARM_VFP_CROSS)_LINK = arm-vfp-tcc$(EXESUF)
|
||||||
$(ARM_EABI_CROSS)_LINK = arm-eabi-tcc$(EXESUF)
|
$(ARM_EABI_CROSS)_LINK = arm-eabi-tcc$(EXESUF)
|
||||||
|
|
||||||
|
ifeq ($(ARCH),i386)
|
||||||
|
PROGS:=$($(I386_CROSS)_LINK)
|
||||||
|
$($(I386_CROSS)_LINK)_TCC = yes
|
||||||
|
endif
|
||||||
|
ifeq ($(ARCH),x86-64)
|
||||||
|
PROGS:=$($(X64_CROSS)_LINK)
|
||||||
|
$($(X64_CROSS)_LINK)_TCC = yes
|
||||||
|
endif
|
||||||
|
|
||||||
CORE_FILES = tcc.c libtcc.c tccpp.c tccgen.c tccelf.c tccasm.c tccrun.c
|
CORE_FILES = tcc.c libtcc.c tccpp.c tccgen.c tccelf.c tccasm.c tccrun.c
|
||||||
CORE_FILES += tcc.h config.h libtcc.h tcctok.h
|
CORE_FILES += tcc.h config.h libtcc.h tcctok.h
|
||||||
I386_FILES = $(CORE_FILES) i386-gen.c i386-asm.c i386-asm.h i386-tok.h
|
I386_FILES = $(CORE_FILES) i386-gen.c i386-asm.c i386-asm.h i386-tok.h
|
||||||
@ -126,12 +135,12 @@ LIBTCC1_CROSS=lib/x86_64-win/libtcc1.a
|
|||||||
LIBTCC1=libtcc1.a
|
LIBTCC1=libtcc1.a
|
||||||
else ifeq ($(ARCH),i386)
|
else ifeq ($(ARCH),i386)
|
||||||
NATIVE_FILES=$(I386_FILES)
|
NATIVE_FILES=$(I386_FILES)
|
||||||
PROGS_CROSS=$(X64_CROSS) $(WIN32_CROSS) $(WIN64_CROSS) $(ARM_CROSS) $(ARM64_CROSS) $(C67_CROSS) $(WINCE_CROSS)
|
PROGS_CROSS=$($(X64_CROSS)_LINK) $($(WIN32_CROSS)_LINK) $($(WIN64_CROSS)_LINK) $(ARM_CROSS) $(ARM64_CROSS) $(C67_CROSS) $(WINCE_CROSS)
|
||||||
LIBTCC1_CROSS=lib/i386-win/libtcc1.a lib/x86_64-win/libtcc1.a
|
LIBTCC1_CROSS=lib/i386-win/libtcc1.a lib/x86_64-win/libtcc1.a
|
||||||
LIBTCC1=libtcc1.a
|
LIBTCC1=libtcc1.a
|
||||||
else ifeq ($(ARCH),x86-64)
|
else ifeq ($(ARCH),x86-64)
|
||||||
NATIVE_FILES=$(X86_64_FILES)
|
NATIVE_FILES=$(X86_64_FILES)
|
||||||
PROGS_CROSS=$(I386_CROSS) $(WIN32_CROSS) $(WIN64_CROSS) $(ARM_CROSS) $(ARM64_CROSS) $(C67_CROSS) $(WINCE_CROSS)
|
PROGS_CROSS=$($(I386_CROSS)_LINK) $($(WIN32_CROSS)_LINK) $($(WIN64_CROSS)_LINK) $(ARM_CROSS) $(ARM64_CROSS) $(C67_CROSS) $(WINCE_CROSS)
|
||||||
LIBTCC1_CROSS=lib/i386-win/libtcc1.a lib/x86_64-win/libtcc1.a lib/i386/libtcc1.a
|
LIBTCC1_CROSS=lib/i386-win/libtcc1.a lib/x86_64-win/libtcc1.a lib/i386/libtcc1.a
|
||||||
LIBTCC1=libtcc1.a
|
LIBTCC1=libtcc1.a
|
||||||
else ifeq ($(ARCH),arm)
|
else ifeq ($(ARCH),arm)
|
||||||
@ -169,18 +178,18 @@ tcc$(EXESUF): tcc.o $(LIBTCC)
|
|||||||
%-tcc$(EXESUF): tcc.c
|
%-tcc$(EXESUF): tcc.c
|
||||||
$(CC) -o $@ $< -DONE_SOURCE $(DEFINES) $(CPPFLAGS) $(CFLAGS) $(LIBS) $(LDFLAGS)
|
$(CC) -o $@ $< -DONE_SOURCE $(DEFINES) $(CPPFLAGS) $(CFLAGS) $(LIBS) $(LDFLAGS)
|
||||||
$(if $($@_LINK),ln -sf $@ $($@_LINK))
|
$(if $($@_LINK),ln -sf $@ $($@_LINK))
|
||||||
|
$(if $($@_TCC),ln -sf $@ tcc)
|
||||||
|
|
||||||
# profiling version
|
# profiling version
|
||||||
tcc_p$(EXESUF): $(NATIVE_FILES)
|
tcc_p$(EXESUF): $(NATIVE_FILES)
|
||||||
$(CC) -o $@ $< -DONE_SOURCE $(NATIVE_DEFINES) $(CPPFLAGS_P) $(CFLAGS_P) $(LIBS_P) $(LDFLAGS_P)
|
$(CC) -o $@ $< -DONE_SOURCE $(NATIVE_DEFINES) $(CPPFLAGS_P) $(CFLAGS_P) $(LIBS_P) $(LDFLAGS_P)
|
||||||
|
|
||||||
$(I386_CROSS): DEFINES = -DTCC_TARGET_I386 \
|
$(I386_CROSS) $($(I386_CROSS)_LINK): DEFINES = -DTCC_TARGET_I386
|
||||||
-DCONFIG_TCCDIR="\"$(tccdir)/i386\""
|
$(X64_CROSS) $($(X64_CROSS)_LINK): DEFINES = -DTCC_TARGET_X86_64
|
||||||
$(X64_CROSS): DEFINES = -DTCC_TARGET_X86_64
|
$(WIN32_CROSS) $($(WIN32_CROSS)_LINK): DEFINES = -DTCC_TARGET_I386 -DTCC_TARGET_PE \
|
||||||
$(WIN32_CROSS): DEFINES = -DTCC_TARGET_I386 -DTCC_TARGET_PE \
|
|
||||||
-DCONFIG_TCCDIR="\"$(tccdir)/win32\"" \
|
-DCONFIG_TCCDIR="\"$(tccdir)/win32\"" \
|
||||||
-DCONFIG_TCC_LIBPATHS="\"{B}/lib/32;{B}/lib\""
|
-DCONFIG_TCC_LIBPATHS="\"{B}/lib/32;{B}/lib\""
|
||||||
$(WIN64_CROSS): DEFINES = -DTCC_TARGET_X86_64 -DTCC_TARGET_PE \
|
$(WIN64_CROSS) $($(WIN64_CROSS)_LINK): DEFINES = -DTCC_TARGET_X86_64 -DTCC_TARGET_PE \
|
||||||
-DCONFIG_TCCDIR="\"$(tccdir)/win32\"" \
|
-DCONFIG_TCCDIR="\"$(tccdir)/win32\"" \
|
||||||
-DCONFIG_TCC_LIBPATHS="\"{B}/lib/64;{B}/lib\""
|
-DCONFIG_TCC_LIBPATHS="\"{B}/lib/64;{B}/lib\""
|
||||||
$(WINCE_CROSS): DEFINES = -DTCC_TARGET_PE
|
$(WINCE_CROSS): DEFINES = -DTCC_TARGET_PE
|
||||||
@ -237,6 +246,8 @@ tiny_libmaker$(EXESUF): win32/tools/tiny_libmaker.c
|
|||||||
# TinyCC runtime libraries
|
# TinyCC runtime libraries
|
||||||
libtcc1.a : FORCE
|
libtcc1.a : FORCE
|
||||||
$(MAKE) -C lib native
|
$(MAKE) -C lib native
|
||||||
|
if test ! -d $(ARCH); then mkdir $(ARCH); fi
|
||||||
|
if test ! -L $(ARCH)/$@; then ln -s ../$@ $(ARCH)/$@; fi
|
||||||
lib/%/libtcc1.a : FORCE $(PROGS_CROSS)
|
lib/%/libtcc1.a : FORCE $(PROGS_CROSS)
|
||||||
$(MAKE) -C lib cross TARGET=$*
|
$(MAKE) -C lib cross TARGET=$*
|
||||||
|
|
||||||
@ -269,7 +280,8 @@ endif
|
|||||||
mkdir -p "$(tccdir)"
|
mkdir -p "$(tccdir)"
|
||||||
mkdir -p "$(tccdir)/include"
|
mkdir -p "$(tccdir)/include"
|
||||||
ifneq ($(LIBTCC1),)
|
ifneq ($(LIBTCC1),)
|
||||||
$(INSTALL) -m644 $(LIBTCC1) "$(tccdir)"
|
mkdir -p "$(tccdir)/$(ARCH)"
|
||||||
|
$(INSTALL) -m644 $(LIBTCC1) "$(tccdir)/$(ARCH)"
|
||||||
endif
|
endif
|
||||||
$(INSTALL) -m644 $(addprefix $(top_srcdir)/include/,$(TCC_INCLUDES)) $(top_srcdir)/tcclib.h "$(tccdir)/include"
|
$(INSTALL) -m644 $(addprefix $(top_srcdir)/include/,$(TCC_INCLUDES)) $(top_srcdir)/tcclib.h "$(tccdir)/include"
|
||||||
mkdir -p "$(libdir)"
|
mkdir -p "$(libdir)"
|
||||||
@ -301,15 +313,11 @@ uninstall:
|
|||||||
rm -fv $(foreach P,$(PROGS),"$(bindir)/$P")
|
rm -fv $(foreach P,$(PROGS),"$(bindir)/$P")
|
||||||
rm -fv $(foreach P,$(LIBTCC1),"$(tccdir)/$P")
|
rm -fv $(foreach P,$(LIBTCC1),"$(tccdir)/$P")
|
||||||
rm -fv $(foreach P,$(TCC_INCLUDES),"$(tccdir)/include/$P")
|
rm -fv $(foreach P,$(TCC_INCLUDES),"$(tccdir)/include/$P")
|
||||||
rm -fv "$(tccdir)/include/tcclib.h"
|
rm -fv "$(mandir)/man1/tcc.1" "$(infodir)/tcc-doc.info"
|
||||||
rm -fv "$(docdir)/tcc-doc.html" "$(mandir)/man1/tcc.1" "$(infodir)/tcc-doc.info"
|
|
||||||
rm -fv "$(libdir)/$(LIBTCC)" "$(includedir)/libtcc.h"
|
rm -fv "$(libdir)/$(LIBTCC)" "$(includedir)/libtcc.h"
|
||||||
rm -fv "$(libdir)/libtcc.so*"
|
rm -fv "$(libdir)/libtcc.so*"
|
||||||
rm -rf "$(tccdir)/win32"
|
rm -rv "$(tccdir)"
|
||||||
-rmdir $(tccdir)/include
|
rm -rv "$(docdir)"
|
||||||
ifneq ($(ARCH),i386)
|
|
||||||
rm -rf "$(tccdir)/i386"
|
|
||||||
endif
|
|
||||||
else
|
else
|
||||||
# on windows
|
# on windows
|
||||||
install: $(PROGS) $(TCCLIBS) $(TCCDOCS)
|
install: $(PROGS) $(TCCLIBS) $(TCCDOCS)
|
||||||
@ -357,7 +365,9 @@ export LIBTCC1
|
|||||||
|
|
||||||
clean:
|
clean:
|
||||||
rm -vf $(PROGS) tcc_p$(EXESUF) tcc.pod *~ *.o *.a *.so* *.out *.log \
|
rm -vf $(PROGS) tcc_p$(EXESUF) tcc.pod *~ *.o *.a *.so* *.out *.log \
|
||||||
*.exe a.out tags TAGS libtcc_test$(EXESUF)
|
*.exe a.out tags TAGS libtcc_test$(EXESUF) tcc
|
||||||
|
-rm -r $(ARCH)
|
||||||
|
-rm *-tcc
|
||||||
$(MAKE) -C tests $@
|
$(MAKE) -C tests $@
|
||||||
ifneq ($(LIBTCC1),)
|
ifneq ($(LIBTCC1),)
|
||||||
$(MAKE) -C lib $@
|
$(MAKE) -C lib $@
|
||||||
|
Loading…
Reference in New Issue
Block a user