Also add more accurate dependencies on headers so "make" works right when headers change
*~
_darcs
+*.gch
*.obj
*.o
*.s
vm/vm.o \
vm/words.o
+ MASTER_HEADERS = $(PLAF_MASTER_HEADERS) \
+ vm/layouts.hpp \
+ vm/platform.hpp \
+ vm/primitives.hpp \
+ vm/segments.hpp \
+ vm/gc_info.hpp \
+ vm/contexts.hpp \
+ vm/run.hpp \
+ vm/objects.hpp \
+ vm/counting_profiler.hpp \
+ vm/sampling_profiler.hpp \
+ vm/errors.hpp \
+ vm/bignumint.hpp \
+ vm/bignum.hpp \
+ vm/booleans.hpp \
+ vm/instruction_operands.hpp \
+ vm/code_blocks.hpp \
+ vm/bump_allocator.hpp \
+ vm/bitwise_hacks.hpp \
+ vm/mark_bits.hpp \
+ vm/free_list.hpp \
+ vm/fixup.hpp \
+ vm/tuples.hpp \
+ vm/free_list_allocator.hpp \
+ vm/write_barrier.hpp \
+ vm/object_start_map.hpp \
+ vm/nursery_space.hpp \
+ vm/aging_space.hpp \
+ vm/tenured_space.hpp \
+ vm/data_heap.hpp \
+ vm/code_heap.hpp \
+ vm/gc.hpp \
+ vm/debug.hpp \
+ vm/strings.hpp \
+ vm/words.hpp \
+ vm/float_bits.hpp \
+ vm/io.hpp \
+ vm/image.hpp \
+ vm/alien.hpp \
+ vm/callbacks.hpp \
+ vm/dispatch.hpp \
+ vm/entry_points.hpp \
+ vm/safepoints.hpp \
+ vm/vm.hpp \
+ vm/allot.hpp \
+ vm/tagged.hpp \
+ vm/data_roots.hpp \
+ vm/code_roots.hpp \
+ vm/generic_arrays.hpp \
+ vm/callstack.hpp \
+ vm/slot_visitor.hpp \
+ vm/collector.hpp \
+ vm/copying_collector.hpp \
+ vm/nursery_collector.hpp \
+ vm/aging_collector.hpp \
+ vm/to_tenured_collector.hpp \
+ vm/code_block_visitor.hpp \
+ vm/compaction.hpp \
+ vm/full_collector.hpp \
+ vm/arrays.hpp \
+ vm/math.hpp \
+ vm/byte_arrays.hpp \
+ vm/jit.hpp \
+ vm/quotations.hpp \
+ vm/inline_cache.hpp \
+ vm/mvm.hpp \
+ vm/factor.hpp \
+ vm/utilities.hpp
+
EXE_OBJS = $(PLAF_EXE_OBJS)
FFI_TEST_LIBRARY = libfactor-ffi-test$(SHARED_DLL_EXTENSION)
vm/ffi_test.o: vm/ffi_test.c
$(TOOLCHAIN_PREFIX)$(CC) -c $(CFLAGS) $(FFI_TEST_CFLAGS) -o $@ $<
-.cpp.o:
+vm/master.hpp.gch: vm/master.hpp $(MASTER_HEADERS)
+ $(TOOLCHAIN_PREFIX)$(CPP) -c -x c++-header $(CFLAGS) -o $@ $<
+
+%.o: %.cpp vm/master.hpp.gch
$(TOOLCHAIN_PREFIX)$(CPP) -c $(CFLAGS) -o $@ $<
-.S.o:
+%.o: %.S
$(TOOLCHAIN_PREFIX)$(CC) -c $(CFLAGS) -o $@ $<
-.mm.o:
+%.o: %.mm vm/master.hpp.gch
$(TOOLCHAIN_PREFIX)$(CPP) -c $(CFLAGS) -o $@ $<
.SUFFIXES: .mm
endif
clean:
+ rm -f vm/*.gch
rm -f vm/*.o
rm -f factor.dll
rm -f factor.lib
-
+PLAF_MASTER_HEADERS += \
+ cpu-arm.hpp
include vm/Config.unix
PLAF_DLL_OBJS += vm/os-genunix.o vm/os-linux.o vm/mvm-unix.o
+PLAF_MASTER_HEADERS += vm/os-genunix.hpp vm/os-linux.hpp
LIBS = -ldl -lm -lrt -lpthread $(X11_UI_LIBS) -Wl,--export-dynamic
SITE_CFLAGS += -Wl,--no-as-needed
include vm/Config.linux
include vm/Config.arm
PLAF_DLL_OBJS += vm/os-linux-arm.o
+PLAF_MASTER_HEADERS += vm/os-linux-arm.hpp
CFLAGS += -fPIC
PLAF_DLL_OBJS += vm/os-macosx.o vm/mach_signal.o vm/mvm-unix.o
+PLAF_MASTER_HEADERS += vm/os-macosx.hpp vm/mach_signal.hpp
DLL_EXTENSION = .dylib
SHARED_DLL_EXTENSION = .dylib
PLAF_DLL_OBJS = vm/os-unix.o
PLAF_EXE_OBJS += vm/main-unix.o
+PLAF_MASTER_HEADERS += vm/os-unix.hpp
ifdef NO_UI
X11_UI_LIBS =
PLAF_DLL_OBJS += vm/os-windows.o vm/mvm-windows.o
PLAF_EXE_OBJS += vm/resources.o vm/main-windows.o
+PLAF_MASTER_HEADERS += vm/os-windows.hpp vm/mvm-windows.hpp
EXE_SUFFIX=
EXE_EXTENSION=.exe
PLAF_DLL_OBJS += vm/os-windows-x86.32.o
+PLAF_MASTER_HEADERS += vm/os-windows.32.hpp
DLL_PATH=http://factorcode.org/dlls
WINDRES=windres
include vm/Config.windows
PLAF_DLL_OBJS += vm/os-windows-x86.64.o
+PLAF_MASTER_HEADERS += vm/os-windows.64.hpp
DLL_PATH=http://factorcode.org/dlls/64
CC=$(WIN64_PATH)-gcc.exe
WINDRES=$(WIN64_PATH)-windres.exe
PLAF_DLL_OBJS += vm/cpu-x86.o
+PLAF_MASTER_HEADERS += vm/cpu-x86.hpp
PLAF_DLL_OBJS += vm/cpu-x86.o
+PLAF_MASTER_HEADERS += vm/cpu-x86.hpp
PLAF_DLL_OBJS += vm/cpu-x86.o
+PLAF_MASTER_HEADERS += vm/cpu-x86.hpp