X-Git-Url: http://wien.tomnetworks.com/gitweb/?a=blobdiff_plain;f=libgc%2FMakefile.am;h=735cc3bdaf8a9096974994326828aa520a329577;hb=200d321ef407a158e923316dc402bab55497a540;hp=bdb299aa49aabd1873a69c08e326279ce93b5ef3;hpb=234225d112c4b018b8d1796f4c06a15812137500;p=mono.git diff --git a/libgc/Makefile.am b/libgc/Makefile.am index bdb299aa49a..735cc3bdaf8 100644 --- a/libgc/Makefile.am +++ b/libgc/Makefile.am @@ -22,6 +22,8 @@ AUTOMAKE_OPTIONS = foreign SUBDIRS = include doc +INCLUDES = -I$(top_builddir)/.. -I$(top_srcdir)/.. + # # libtool is not capable of creating shared/static versions of a convenience # library, so we have to do it ourselves @@ -39,7 +41,7 @@ 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 \ @@ -47,10 +49,9 @@ backgraph.c win32_threads.c \ pthread_support.c pthread_stop_world.c darwin_stop_world.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_LIBADD = @addobjs@ $(THREADDLLIBS) $(UNWINDLIBS) libmonogc_la_DEPENDENCIES = @addobjs@ libmonogc_la_LDFLAGS = -version-info 1:2:0 @@ -67,16 +68,48 @@ 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) : 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. @@ -142,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,