X-Git-Url: http://wien.tomnetworks.com/gitweb/?a=blobdiff_plain;f=libgc%2FMakefile.am;h=0700ae8b5b4a1737daef9920d11d5ae9740f5cdb;hb=58fdac7b8a191881c721c1e04592fc4a8b4b6ab1;hp=4ce5dc7b693efae31e09c341bc631978b8af4a13;hpb=b585d00928892398dfbfc315ed78b8032fa14708;p=mono.git diff --git a/libgc/Makefile.am b/libgc/Makefile.am index 4ce5dc7b693..0700ae8b5b4 100644 --- a/libgc/Makefile.am +++ b/libgc/Makefile.am @@ -41,19 +41,18 @@ asm_libgc_sources = endif libmonogc_la_SOURCES = allchblk.c alloc.c blacklst.c checksums.c dbg_mlc.c \ -dyn_load.c finalize.c gc_dlopen.c gcj_mlc.c headers.c aix_irix_threads.c \ +dyn_load.c finalize.c gc_dlopen.c gcj_mlc.c headers.c \ malloc.c mallocx.c mark.c mark_rts.c misc.c new_hblk.c \ obj_map.c os_dep.c pcr_interface.c ptr_chck.c real_malloc.c reclaim.c \ solaris_pthreads.c solaris_threads.c specific.c stubborn.c typd_mlc.c \ backgraph.c win32_threads.c \ pthread_support.c pthread_stop_world.c darwin_stop_world.c \ -$(asm_libgc_sources) +mach_dep.c $(asm_libgc_sources) - -# Include THREADLIBS here to ensure that the correct versions of +# Include THREADDLLIBS here to ensure that the correct versions of # linuxthread semaphore functions get linked: -libmonogc_la_LIBADD = @addobjs@ $(THREADLIBS) $(UNWINDLIBS) -libmonogc_la_DEPENDENCIES = @addobjs@ +libmonogc_la_LIBADD = $(THREADDLLIBS) $(UNWINDLIBS) +libmonogc_la_DEPENDENCIES = libmonogc_la_LDFLAGS = -version-info 1:2:0 EXTRA_libmonogc_la_SOURCES = alpha_mach_dep.S \ @@ -69,20 +68,52 @@ EXTRA_DIST += alpha_mach_dep.S mips_sgi_mach_dep.s sparc_mach_dep.S AM_CFLAGS = @GC_CFLAGS@ +if CPLUSPLUS +extra_checks = test_cpp +else +extra_checks = +endif + +#check_PROGRAMS = gctest $(extra_checks) + +#test.o: $(srcdir)/tests/test.c +# $(COMPILE) -c $(srcdir)/tests/test.c +# Using $< in the above seems to fail with the HP/UX on Itanium make. +#test_cpp.o: $(srcdir)/tests/test_cpp.cc +# $(CXXCOMPILE) -c $(srcdir)/tests/test_cpp.cc + +## FIXME: this is probably the reason why some files from BUILT_SOURCES +## are included in the distribution +# gctest_OBJECTS = test.o +#gctest_SOURCES = tests/test.c +#gctest_LDADD = ./libgc.la $(THREADDLLIBS) $(UNWINDLIBS) $(EXTRA_TEST_LIBS) +#test_cpp_SOURCES = tests/test_cpp.cc +#test_cpp_LDADD = ./libgc.la ./libgccpp.la $(THREADDLLIBS) $(UNWINDLIBS) $(EXTRA_TEST_LIBS) + +#TESTS = gctest $(extra_checks) + ## FIXME: relies on internal code generated by automake. -all_objs = @addobjs@ $(libgc_la_OBJECTS) +all_objs = $(libgc_la_OBJECTS) $(all_objs) : include/private/gcconfig.h include/private/gc_priv.h \ include/private/gc_hdrs.h include/gc.h include/gc_gcj.h include/gc_mark.h ## FIXME: we shouldn't have to do this, but automake forces us to. +if COMPILER_XLC + ## XLC neither requires nor tolerates the unnecessary assembler goop + ASM_CPP_OPTIONS = +else + ## We use -Wp,-P to strip #line directives. Irix `as' chokes on + ## these. + ASM_CPP_OPTIONS = -Wp,-P -x assembler-with-cpp +endif .s.lo: ## We use -Wp,-P to strip #line directives. Irix `as' chokes on ## these. - $(LTCOMPILE) -Wp,-P -x assembler-with-cpp -c $< + $(LTCOMPILE) $(ASM_CPP_OPTIONS) -c $< ## We have our own definition of LTCOMPILE because we want to use our ## CFLAGS, not those passed in from the top level make. -LTCOMPILE = $(LIBTOOL) --mode=compile $(CC) $(DEFS) $(INCLUDES) \ +LTCOMPILE = $(LIBTOOL) --mode=compile --tag=CC $(CC) $(DEFS) $(INCLUDES) \ -I$(top_srcdir)/include $(AM_CPPFLAGS) $(CPPFLAGS) \ $(AM_CFLAGS) $(MY_CFLAGS) $(GC_CFLAGS) LINK = $(LIBTOOL) --mode=link $(CC) $(AM_CFLAGS) $(MY_CFLAGS) $(LDFLAGS) -o $@ @@ -144,7 +175,7 @@ CONFIG_STATUS_DEPENDENCIES = $(srcdir)/configure.host # :FIXME: why do we distribute this one??? # -EXTRA_DIST += libtool.m4 configure.host +EXTRA_DIST += configure.host # # :GOTCHA: GNU make rule for making .s out of .S is flawed,