From 6d62efb57a22555a95e84866917f40012edb530a Mon Sep 17 00:00:00 2001 From: Connor Lane Smith Date: Thu, 16 Jun 2011 01:53:33 +0100 Subject: [PATCH] make sbase-box --- Makefile | 19 ++++++++++++++++++- 1 file changed, 18 insertions(+), 1 deletion(-) diff --git a/Makefile b/Makefile index d730c49..2029f1a 100644 --- a/Makefile +++ b/Makefile @@ -89,6 +89,23 @@ dist: clean @gzip sbase-$(VERSION).tar @rm -rf sbase-$(VERSION) +sbase-box: $(SRC) + @echo creating box binary + @mkdir -p build + @cp -r $(HDR) util build + @for f in $(SRC); do sed "s/^main.*/`basename $$f .c`_main(int argc, char *argv[])/" < $$f > build/$$f; done + @echo '#include ' > build/$@.c + @echo '#include ' >> build/$@.c + @echo '#include ' >> build/$@.c + @echo '#include "util.h"' >> build/$@.c + @for f in $(SRC); do echo "int `basename $$f .c`_main(int, char **);" >> build/sbase-box.c; done + @echo 'int main(int argc, char *argv[]) { char *s = basename(argv[0]); if(0);' >> build/sbase-box.c + @for f in $(SRC); do echo "else if(!strcmp(s, \"`basename $$f .c`\")) `basename $$f .c`_main(argc, argv);" >> build/sbase-box.c; done + @printf 'else eprintf("%%s: unknown program\\n", s); return EXIT_SUCCESS; }' >> build/sbase-box.c + @echo LD $@ + @$(LD) -o $@ build/*.c build/util/*.c $(CFLAGS) $(LDFLAGS) + @rm -r build + clean: @echo cleaning - @rm -f $(BIN) $(OBJ) $(LIB) util.a + @rm -f $(BIN) $(OBJ) $(LIB) util.a sbase-box