.gitignore: Add lib/arm64.
[tinycc.git] / Makefile
blobcf3010c643b4ceada8c71cff9ef0e0ceb429acb3
2 # Tiny C Compiler Makefile
5 TOP ?= .
6 include $(TOP)/config.mak
7 VPATH = $(top_srcdir)
9 CPPFLAGS += -I$(TOP) # for config.h
11 ifneq (-$(findstring gcc,$(CC))-,-gcc-)
12 ifeq (-$(findstring clang,$(CC))-,-clang-)
13 # make clang accept gnuisms in libtcc1.c
14 CFLAGS+=-fheinous-gnu-extensions
15 endif
16 endif
18 CPPFLAGS_P=$(CPPFLAGS) -DCONFIG_TCC_STATIC
19 CFLAGS_P=$(CFLAGS) -pg -static
20 LIBS_P=
21 LDFLAGS_P=$(LDFLAGS)
23 ifdef CONFIG_WIN64
24 CONFIG_WIN32=yes
25 endif
27 ifndef CONFIG_WIN32
28 LIBS=-lm
29 ifndef CONFIG_NOLDL
30 LIBS+=-ldl
31 endif
32 endif
34 # make libtcc as static or dynamic library?
35 ifdef DISABLE_STATIC
36 ifndef CONFIG_WIN32
37 LIBTCC=libtcc.so.1.0
38 else
39 LIBTCC=libtcc.dll
40 LIBTCC_DLL=yes
41 LIBTCC_EXTRA=libtcc.def libtcc.a
42 endif
43 LINK_LIBTCC=-Wl,-rpath,"$(libdir)"
44 ifdef DISABLE_RPATH
45 LINK_LIBTCC=
46 endif
47 else
48 LIBTCC=libtcc.a
49 LINK_LIBTCC=
50 endif
52 CONFIG_$(ARCH) = yes
53 NATIVE_DEFINES_$(CONFIG_i386) += -DTCC_TARGET_I386
54 NATIVE_DEFINES_$(CONFIG_x86-64) += -DTCC_TARGET_X86_64
55 NATIVE_DEFINES_$(CONFIG_WIN32) += -DTCC_TARGET_PE
56 NATIVE_DEFINES_$(CONFIG_uClibc) += -DTCC_UCLIBC
57 NATIVE_DEFINES_$(CONFIG_arm) += -DTCC_TARGET_ARM
58 NATIVE_DEFINES_$(CONFIG_arm_eabihf) += -DTCC_ARM_EABI -DTCC_ARM_HARDFLOAT
59 NATIVE_DEFINES_$(CONFIG_arm_eabi) += -DTCC_ARM_EABI
60 NATIVE_DEFINES_$(CONFIG_arm_vfp) += -DTCC_ARM_VFP
61 NATIVE_DEFINES_$(CONFIG_arm64) += -DTCC_TARGET_ARM64
62 NATIVE_DEFINES += $(NATIVE_DEFINES_yes)
64 ifeq ($(TOP),.)
66 PROGS=tcc$(EXESUF)
67 I386_CROSS = i386-linux-gnu-tcc$(EXESUF)
68 WIN32_CROSS = i386-win-mingw32-tcc$(EXESUF)
69 WIN64_CROSS = x86_64-win-mingw32-tcc$(EXESUF)
70 WINCE_CROSS = arm-win-mingw32ce-tcc$(EXESUF)
71 X64_CROSS = x86_64-linux-gnu-tcc$(EXESUF)
72 ARM_FPA_CROSS = arm-linux-fpa-tcc$(EXESUF)
73 ARM_FPA_LD_CROSS = arm-linux-fpa-ld-tcc$(EXESUF)
74 ARM_VFP_CROSS = arm-linux-gnu-tcc$(EXESUF)
75 ARM_EABI_CROSS = arm-linux-gnueabi-tcc$(EXESUF)
76 ARM_EABIHF_CROSS = arm-linux-gnueabihf-tcc$(EXESUF)
77 ARM_CROSS = $(ARM_FPA_CROSS) $(ARM_FPA_LD_CROSS) $(ARM_VFP_CROSS) $(ARM_EABI_CROSS)
78 ARM64_CROSS = arm64-tcc$(EXESUF)
79 C67_CROSS = c67-tcc$(EXESUF)
81 # Legacy symlinks for cross compilers
82 $(I386_CROSS)_LINK = i386-tcc$(EXESUF)
83 $(WIN32_CROSS)_LINK = i386-win-tcc$(EXESUF)
84 $(WIN64_CROSS)_LINK = x86_64-win-tcc$(EXESUF)
85 $(WINCE_CROSS)_LINK = arm-win-tcc$(EXESUF)
86 $(X64_CROSS)_LINK = x86_64-tcc$(EXESUF)
87 $(ARM_FPA_CROSS)_LINK = arm-fpa-tcc$(EXESUF)
88 $(ARM_FPA_LD_CROSS)_LINK = arm-fpa-ld-tcc$(EXESUF)
89 $(ARM_VFP_CROSS)_LINK = arm-vfp-tcc$(EXESUF)
90 $(ARM_EABI_CROSS)_LINK = arm-eabi-tcc$(EXESUF)
92 ifeq ($(HOST_OS),Windows)
93 ifeq ($(ARCH),i386)
94 PROGS:=$($(WIN32_CROSS)_LINK)
95 $($(WIN32_CROSS)_LINK)_TCC = yes
96 endif
97 ifeq ($(ARCH),x86-64)
98 PROGS:=$($(WIN64_CROSS)_LINK)
99 $($(WIN64_CROSS)_LINK)_TCC = yes
100 endif
101 endif
103 ifeq ($(HOST_OS),Linux)
104 ifeq ($(ARCH),i386)
105 PROGS:=$($(I386_CROSS)_LINK)
106 $($(I386_CROSS)_LINK)_TCC = yes
107 endif
108 ifeq ($(ARCH),x86-64)
109 PROGS:=$($(X64_CROSS)_LINK)
110 $($(X64_CROSS)_LINK)_TCC = yes
111 endif
112 endif
114 CORE_FILES = tcc.c libtcc.c tccpp.c tccgen.c tccelf.c tccasm.c tccrun.c
115 CORE_FILES += tcc.h config.h libtcc.h tcctok.h
116 I386_FILES = $(CORE_FILES) i386-gen.c i386-asm.c i386-asm.h i386-tok.h
117 WIN32_FILES = $(CORE_FILES) i386-gen.c i386-asm.c i386-asm.h i386-tok.h tccpe.c
118 WIN64_FILES = $(CORE_FILES) x86_64-gen.c i386-asm.c x86_64-asm.h tccpe.c
119 WINCE_FILES = $(CORE_FILES) arm-gen.c tccpe.c
120 X86_64_FILES = $(CORE_FILES) x86_64-gen.c i386-asm.c x86_64-asm.h
121 ARM_FILES = $(CORE_FILES) arm-gen.c
122 ARM64_FILES = $(CORE_FILES) arm64-gen.c
123 C67_FILES = $(CORE_FILES) c67-gen.c tcccoff.c
125 ifdef CONFIG_WIN64
126 PROGS+=tiny_impdef$(EXESUF) tiny_libmaker$(EXESUF)
127 NATIVE_FILES=$(WIN64_FILES)
128 PROGS_CROSS=$(WIN32_CROSS) $(I386_CROSS) $(X64_CROSS) $(ARM_CROSS) $(ARM64_CROSS) $(C67_CROSS) $(WINCE_CROSS)
129 LIBTCC1_CROSS=lib/i386-win/libtcc1.a
130 LIBTCC1=libtcc1.a
131 else ifdef CONFIG_WIN32
132 PROGS+=tiny_impdef$(EXESUF) tiny_libmaker$(EXESUF)
133 NATIVE_FILES=$(WIN32_FILES)
134 PROGS_CROSS=$(WIN64_CROSS) $(I386_CROSS) $(X64_CROSS) $(ARM_CROSS) $(ARM64_CROSS) $(C67_CROSS) $(WINCE_CROSS)
135 LIBTCC1_CROSS=lib/x86_64-win/libtcc1.a
136 LIBTCC1=libtcc1.a
137 else ifeq ($(ARCH),i386)
138 NATIVE_FILES=$(I386_FILES)
139 PROGS_CROSS=$($(X64_CROSS)_LINK) $($(WIN32_CROSS)_LINK) $($(WIN64_CROSS)_LINK) $(ARM_CROSS) $(ARM64_CROSS) $(C67_CROSS) $(WINCE_CROSS)
140 LIBTCC1_CROSS=lib/i386-win/libtcc1.a lib/x86_64-win/libtcc1.a
141 LIBTCC1=libtcc1.a
142 else ifeq ($(ARCH),x86-64)
143 NATIVE_FILES=$(X86_64_FILES)
144 PROGS_CROSS=$($(I386_CROSS)_LINK) $($(WIN32_CROSS)_LINK) $($(WIN64_CROSS)_LINK) $(ARM_CROSS) $(ARM64_CROSS) $(C67_CROSS) $(WINCE_CROSS)
145 LIBTCC1_CROSS=lib/i386-win/libtcc1.a lib/x86_64-win/libtcc1.a lib/i386/libtcc1.a
146 LIBTCC1=libtcc1.a
147 else ifeq ($(ARCH),arm)
148 NATIVE_FILES=$(ARM_FILES)
149 PROGS_CROSS=$(I386_CROSS) $(X64_CROSS) $(WIN32_CROSS) $(WIN64_CROSS) $(ARM64_CROSS) $(C67_CROSS) $(WINCE_CROSS)
150 LIBTCC1=libtcc1.a
151 LIBTCC1_CROSS=lib/i386-win/libtcc1.a lib/x86_64-win/libtcc1.a lib/i386/libtcc1.a
152 else ifeq ($(ARCH),arm64)
153 NATIVE_FILES=$(ARM64_FILES)
154 PROGS_CROSS=$(I386_CROSS) $(X64_CROSS) $(WIN32_CROSS) $(WIN64_CROSS) $(ARM_CROSS) $(C67_CROSS) $(WINCE_CROSS)
155 LIBTCC1=libtcc1.a
156 LIBTCC1_CROSS=lib/i386-win/libtcc1.a lib/x86_64-win/libtcc1.a lib/i386/libtcc1.a
157 endif
158 PROGS_CROSS_LINK=$(foreach PROG_CROSS,$(PROGS_CROSS),$($(PROG_CROSS)_LINK))
160 ifeq ($(TARGETOS),Darwin)
161 PROGS+=tiny_libmaker$(EXESUF)
162 endif
164 TCCLIBS = $(LIBTCC1) $(LIBTCC) $(LIBTCC_EXTRA)
165 TCCDOCS = tcc.1 tcc-doc.html tcc-doc.info
167 ifdef CONFIG_CROSS
168 PROGS+=$(PROGS_CROSS)
169 TCCLIBS+=$(LIBTCC1_CROSS)
170 endif
172 all: $(PROGS) $(TCCLIBS) $(TCCDOCS)
174 # Host Tiny C Compiler
175 tcc$(EXESUF): tcc.o $(LIBTCC)
176 $(CC) -o $@ $^ $(LIBS) $(CPPFLAGS) $(CFLAGS) $(LDFLAGS) $(LINK_LIBTCC)
178 # Cross Tiny C Compilers
179 %-tcc$(EXESUF): tcc.c
180 $(CC) -o $@ $< -DONE_SOURCE $(DEFINES) $(CPPFLAGS) $(CFLAGS) $(LIBS) $(LDFLAGS)
181 $(if $($@_LINK),ln -sf $@ $($@_LINK))
182 $(if $($@_TCC),ln -sf $@ tcc$(EXESUF))
184 # profiling version
185 tcc_p$(EXESUF): $(NATIVE_FILES)
186 $(CC) -o $@ $< -DONE_SOURCE $(NATIVE_DEFINES) $(CPPFLAGS_P) $(CFLAGS_P) $(LIBS_P) $(LDFLAGS_P)
188 $(I386_CROSS) $($(I386_CROSS)_LINK): DEFINES = -DTCC_TARGET_I386
189 $(X64_CROSS) $($(X64_CROSS)_LINK): DEFINES = -DTCC_TARGET_X86_64
190 $(WIN32_CROSS) $($(WIN32_CROSS)_LINK): DEFINES = -DTCC_TARGET_I386 -DTCC_TARGET_PE \
191 -DCONFIG_TCCDIR="\"$(tccdir)/win32\"" \
192 -DCONFIG_TCC_LIBPATHS="\"{B}/lib/32;{B}/lib\""
193 $(WIN64_CROSS) $($(WIN64_CROSS)_LINK): DEFINES = -DTCC_TARGET_X86_64 -DTCC_TARGET_PE \
194 -DCONFIG_TCCDIR="\"$(tccdir)/win32\"" \
195 -DCONFIG_TCC_LIBPATHS="\"{B}/lib/64;{B}/lib\""
196 $(WINCE_CROSS): DEFINES = -DTCC_TARGET_PE
197 $(C67_CROSS): DEFINES = -DTCC_TARGET_C67
198 $(ARM_FPA_CROSS): DEFINES = -DTCC_TARGET_ARM
199 $(ARM_FPA_LD_CROSS)$(EXESUF): DEFINES = -DTCC_TARGET_ARM -DLDOUBLE_SIZE=12
200 $(ARM_VFP_CROSS): DEFINES = -DTCC_TARGET_ARM -DTCC_ARM_VFP
201 $(ARM_EABI_CROSS): DEFINES = -DTCC_TARGET_ARM -DTCC_ARM_EABI -DTCC_ARM_VFP
202 $(ARM64_CROSS): DEFINES = -DTCC_TARGET_ARM64
204 $(I386_CROSS) $($(I386_CROSS)_LINK): $(I386_FILES)
205 $(X64_CROSS) $($(X64_CROSS)_LINK): $(X86_64_FILES)
206 $(WIN32_CROSS) $($(WIN32_CROSS)_LINK): $(WIN32_FILES)
207 $(WIN64_CROSS) $($(WIN64_CROSS)_LINK): $(WIN64_FILES)
208 $(WINCE_CROSS) $($(WINCE_CROSS)_LINK): $(WINCE_FILES)
209 $(C67_CROSS) $($(C67_CROSS)_LINK): $(C67_FILES)
210 $(ARM_FPA_CROSS) $(ARM_FPA_LD_CROSS) $(ARM_VFP_CROSS) $(ARM_EABI_CROSS): $(ARM_FILES)
211 $($(ARM_FPA_CROSS)_LINK) $($(ARM_FPA_LD_CROSS)_LINK) $($(ARM_VFP_CROSS)_LINK) $($(ARM_EABI_CROSS)_LINK): $(ARM_FILES)
212 $(ARM64_CROSS): $(ARM64_FILES)
214 # libtcc generation and test
215 ifndef ONE_SOURCE
216 LIBTCC_OBJ = $(filter-out tcc.o,$(patsubst %.c,%.o,$(filter %.c,$(NATIVE_FILES))))
217 LIBTCC_INC = $(filter %.h,$(CORE_FILES)) $(filter-out $(CORE_FILES),$(NATIVE_FILES))
218 else
219 LIBTCC_OBJ = libtcc.o
220 LIBTCC_INC = $(NATIVE_FILES)
221 libtcc.o : NATIVE_DEFINES += -DONE_SOURCE
222 endif
224 $(LIBTCC_OBJ) tcc.o : %.o : %.c $(LIBTCC_INC)
225 $(CC) -o $@ -c $< $(NATIVE_DEFINES) $(CPPFLAGS) $(CFLAGS)
227 ifndef LIBTCC_DLL
228 libtcc.a: $(LIBTCC_OBJ)
229 $(AR) rcs $@ $^
230 endif
232 libtcc.so.1.0: $(LIBTCC_OBJ)
233 $(CC) -shared -Wl,-soname,$@ -o $@ $^ $(LDFLAGS)
235 libtcc.so.1.0: CFLAGS+=-fPIC
237 ifdef LIBTCC_DLL
238 libtcc.dll libtcc.def libtcc.a: $(LIBTCC_OBJ)
239 $(CC) -shared $^ -o $@ $(LDFLAGS) -Wl,--output-def,libtcc.def,--out-implib,libtcc.a
240 endif
242 # windows utilities
243 tiny_impdef$(EXESUF): win32/tools/tiny_impdef.c
244 $(CC) -o $@ $< $(CPPFLAGS) $(CFLAGS) $(LDFLAGS)
245 tiny_libmaker$(EXESUF): win32/tools/tiny_libmaker.c
246 $(CC) -o $@ $< $(CPPFLAGS) $(CFLAGS) $(LDFLAGS)
248 # TinyCC runtime libraries
249 libtcc1.a : FORCE
250 $(MAKE) -C lib native
251 if test ! -d $(ARCH); then mkdir $(ARCH); fi
252 if test ! -L $(ARCH)/$@; then ln -sf ../$@ $(ARCH)/$@; fi
253 lib/%/libtcc1.a : FORCE $(PROGS_CROSS)
254 $(MAKE) -C lib cross TARGET=$*
256 FORCE:
258 # install
259 TCC_INCLUDES = stdarg.h stddef.h stdbool.h float.h varargs.h
260 INSTALL=install
261 ifdef STRIP_BINARIES
262 INSTALLBIN=$(INSTALL) -s
263 else
264 INSTALLBIN=$(INSTALL)
265 endif
267 install-strip: install
268 strip $(foreach PROG,$(PROGS),"$(bindir)"/$(PROG))
270 ifndef CONFIG_WIN32
271 install: $(PROGS) $(TCCLIBS) $(TCCDOCS)
272 mkdir -p "$(bindir)"
273 $(INSTALLBIN) -m755 $(PROGS) "$(bindir)"
274 cp -P tcc$(EXESUF) "$(bindir)"
275 mkdir -p "$(mandir)/man1"
276 -$(INSTALL) -m644 tcc.1 "$(mandir)/man1"
277 mkdir -p "$(infodir)"
278 -$(INSTALL) -m644 tcc-doc.info "$(infodir)"
279 mkdir -p "$(tccdir)"
280 mkdir -p "$(tccdir)/include"
281 ifneq ($(LIBTCC1),)
282 mkdir -p "$(tccdir)/$(ARCH)"
283 $(INSTALL) -m644 $(LIBTCC1) "$(tccdir)/$(ARCH)"
284 endif
285 $(INSTALL) -m644 $(addprefix $(top_srcdir)/include/,$(TCC_INCLUDES)) $(top_srcdir)/tcclib.h "$(tccdir)/include"
286 mkdir -p "$(libdir)"
287 $(INSTALL) -m644 $(LIBTCC) "$(libdir)"
288 ifdef DISABLE_STATIC
289 ln -sf "$(ln_libdir)/libtcc.so.1.0" "$(libdir)/libtcc.so.1"
290 ln -sf "$(ln_libdir)/libtcc.so.1.0" "$(libdir)/libtcc.so"
291 endif
292 mkdir -p "$(includedir)"
293 $(INSTALL) -m644 $(top_srcdir)/libtcc.h "$(includedir)"
294 mkdir -p "$(docdir)"
295 -$(INSTALL) -m644 tcc-doc.html "$(docdir)"
296 ifdef CONFIG_CROSS
297 mkdir -p "$(tccdir)/win32/lib/32"
298 mkdir -p "$(tccdir)/win32/lib/64"
299 ifneq ($(ARCH),i386)
300 mkdir -p "$(tccdir)/i386"
301 $(INSTALL) -m644 lib/i386/libtcc1.a "$(tccdir)/i386"
302 cp -r "$(tccdir)/include" "$(tccdir)/i386"
303 endif
304 $(INSTALL) -m644 $(top_srcdir)/win32/lib/*.def "$(tccdir)/win32/lib"
305 $(INSTALL) -m644 lib/i386-win/libtcc1.a "$(tccdir)/win32/lib/32"
306 $(INSTALL) -m644 lib/x86_64-win/libtcc1.a "$(tccdir)/win32/lib/64"
307 cp -r $(top_srcdir)/win32/include/. "$(tccdir)/win32/include"
308 cp -r "$(tccdir)/include" "$(tccdir)/win32"
309 endif
311 uninstall:
312 rm -fv $(foreach P,$(PROGS),"$(bindir)/$P")
313 rm -fv "$(bindir)/tcc$(EXESUF)"
314 rm -fv $(foreach P,$(LIBTCC1),"$(tccdir)/$P")
315 rm -fv $(foreach P,$(TCC_INCLUDES),"$(tccdir)/include/$P")
316 rm -fv "$(mandir)/man1/tcc.1" "$(infodir)/tcc-doc.info"
317 rm -fv "$(libdir)/$(LIBTCC)" "$(includedir)/libtcc.h"
318 rm -fv "$(libdir)/libtcc.so*"
319 rm -rv "$(tccdir)"
320 rm -rv "$(docdir)"
321 else
322 # on windows
323 install: $(PROGS) $(TCCLIBS) $(TCCDOCS)
324 mkdir -p "$(tccdir)"
325 mkdir -p "$(tccdir)/lib"
326 mkdir -p "$(tccdir)/include"
327 mkdir -p "$(tccdir)/examples"
328 mkdir -p "$(tccdir)/doc"
329 mkdir -p "$(tccdir)/libtcc"
330 $(INSTALLBIN) -m755 $(PROGS) "$(tccdir)"
331 $(INSTALL) -m644 $(LIBTCC1) $(top_srcdir)/win32/lib/*.def "$(tccdir)/lib"
332 cp -r $(top_srcdir)/win32/include/. "$(tccdir)/include"
333 cp -r $(top_srcdir)/win32/examples/. "$(tccdir)/examples"
334 $(INSTALL) -m644 $(addprefix $(top_srcdir)/include/,$(TCC_INCLUDES)) $(top_srcdir)/tcclib.h "$(tccdir)/include"
335 $(INSTALL) -m644 tcc-doc.html $(top_srcdir)/win32/tcc-win32.txt "$(tccdir)/doc"
336 $(INSTALL) -m644 $(top_srcdir)/libtcc.h $(LIBTCC_EXTRA) "$(tccdir)/libtcc"
337 $(INSTALL) -m644 $(LIBTCC) $(tccdir)
338 ifdef CONFIG_CROSS
339 mkdir -p "$(tccdir)/lib/32"
340 mkdir -p "$(tccdir)/lib/64"
341 -$(INSTALL) -m644 lib/i386-win/libtcc1.a "$(tccdir)/lib/32"
342 -$(INSTALL) -m644 lib/x86_64-win/libtcc1.a "$(tccdir)/lib/64"
343 endif
345 uninstall:
346 rm -rfv "$(tccdir)/*"
347 endif
349 # documentation and man page
350 tcc-doc.html: tcc-doc.texi
351 -makeinfo --no-split --html --number-sections -o $@ $<
353 tcc.1: tcc-doc.texi
354 -$(top_srcdir)/texi2pod.pl $< tcc.pod
355 -pod2man --section=1 --center="Tiny C Compiler" --release=`cat $(top_srcdir)/VERSION` tcc.pod > $@
357 tcc-doc.info: tcc-doc.texi
358 -makeinfo $<
360 # in tests subdir
361 export LIBTCC1
363 %est:
364 $(MAKE) -C tests $@ 'PROGS_CROSS=$(PROGS_CROSS)'
366 clean:
367 rm -vf $(PROGS) tcc_p$(EXESUF) tcc.pod *~ *.o *.a *.so* *.out *.log \
368 *.exe a.out tags TAGS libtcc_test$(EXESUF) tcc$(EXESUF)
369 -rm -r $(ARCH)
370 -rm *-tcc$(EXESUF)
371 $(MAKE) -C tests $@
372 ifneq ($(LIBTCC1),)
373 $(MAKE) -C lib $@
374 endif
376 distclean: clean
377 rm -vf config.h config.mak config.texi tcc.1 tcc-doc.info tcc-doc.html
379 config.mak:
380 @echo "Please run ./configure."
381 @exit 1
383 tags:
384 ctags $(top_srcdir)/*.[ch] $(top_srcdir)/include/*.h $(top_srcdir)/lib/*.[chS]
386 TAGS:
387 ctags -e $(top_srcdir)/*.[ch] $(top_srcdir)/include/*.h $(top_srcdir)/lib/*.[chS]
389 # create release tarball from *current* git branch (including tcc-doc.html
390 # and converting two files to CRLF)
391 TCC-VERSION := tcc-$(shell cat $(top_srcdir)/VERSION)
392 tar: tcc-doc.html
393 mkdir $(TCC-VERSION)
394 ( cd $(TCC-VERSION) && git --git-dir ../.git checkout -f )
395 cp tcc-doc.html $(TCC-VERSION)
396 for f in tcc-win32.txt build-tcc.bat ; do \
397 cat win32/$$f | sed 's,\(.*\),\1\r,g' > $(TCC-VERSION)/win32/$$f ; \
398 done
399 tar cjf $(TCC-VERSION).tar.bz2 $(TCC-VERSION)
400 rm -rf $(TCC-VERSION)
401 git reset
403 .PHONY: all clean tar tags TAGS distclean install uninstall FORCE
405 endif # ifeq ($(TOP),.)