X-Git-Url: http://repo.macrolet.net/gitweb/?a=blobdiff_plain;f=contrib%2Fasdf-module.mk;h=8087ab9c71069bffdf637c4177d44672cdfaab78;hb=fb8533122551bbb7aea669f40bc91c1211809b58;hp=9bfb44c37354bbf8c7dffe48684cfe250c95e7d7;hpb=d4b738d6c0b354de817fa490b50814e40872b3d0;p=sbcl.git diff --git a/contrib/asdf-module.mk b/contrib/asdf-module.mk index 9bfb44c..8087ab9 100644 --- a/contrib/asdf-module.mk +++ b/contrib/asdf-module.mk @@ -1,11 +1,27 @@ CC=gcc -export CC SBCL + +# We need to extend flags to the C compiler and the linker +# here. sb-posix, sb-grovel, and sb-bsd-sockets depends upon these +# being set on x86_64. Setting these in their Makefiles is not +# adequate since, while we're building contrib, they can be compiled +# directly via ASDF from a non-C-aware module which has these tricky +# ones as dependencies. + +UNAME:=$(shell uname -m) +ifeq (x86_64,$(UNAME)) + export EXTRA_LDFLAGS=-m32 -shared + export EXTRA_CFLAGS+=-m32 +endif + +export CC SBCL EXTRA_CFLAGS EXTRA_LDFLAGS all: $(EXTRA_ALL_TARGETS) $(MAKE) -C ../asdf $(SBCL) --eval '(load "../asdf/asdf")' \ --eval "(setf asdf::*central-registry* '((MERGE-PATHNAMES \"systems/\" (TRUENAME (SB-EXT:POSIX-GETENV \"SBCL_HOME\")))))" \ + --eval "(push :sb-building-contrib *features*)" \ --eval "(asdf:operate 'asdf:load-op :$(SYSTEM))" \ + --eval "(progn (when (probe-file \"$(SYSTEM).fasl\") (error \"fasl file exists\")) (with-open-file (s \"$(SYSTEM).lisp\" :direction :output :if-exists :error) (print (quote (require :asdf)) s) (print (quote (require :$(SYSTEM))) s)) (compile-file \"$(SYSTEM).lisp\") (delete-file \"$(SYSTEM).lisp\"))" \ --eval "(quit)" test: all @@ -15,5 +31,5 @@ test: all install: $(EXTRA_INSTALL_TARGETS) - tar cf - . | ( cd $(INSTALL_DIR) && tar xpvf - ) - ( cd $(SBCL_HOME)/systems && ln -fs ../$(SYSTEM)/$(SYSTEM).asd . ) + tar cf - . | ( cd $(BUILD_ROOT)$(INSTALL_DIR) && tar xpvf - ) + ( cd $(BUILD_ROOT)$(SBCL_HOME)/systems && ln -fs ../$(SYSTEM)/$(SYSTEM).asd . )