From 14469e9fb6db827ce9b1308d11fff1026e50a75f Mon Sep 17 00:00:00 2001 From: Mistivia Date: Sun, 14 Dec 2025 04:42:37 +0800 Subject: use dynamic library --- Makefile | 31 +++++++++++++++++-------------- exts/vector.c | 1 - 2 files changed, 17 insertions(+), 15 deletions(-) diff --git a/Makefile b/Makefile index 6d78219..466de18 100644 --- a/Makefile +++ b/Makefile @@ -3,13 +3,16 @@ cc = gcc includes = -DWITHREADLINE -fPIC -ldflags = -lm -lreadline -lalgds +ldflags = -L./ -lm -lreadline -lalgds ifeq ($(mode), debug) cflags = $(includes) -g else cflags = $(includes) -O2 endif +curdir = ./ +installdir = /usr/local/lib/ + src = $(shell find ./ -maxdepth 1 -name '*.c' -not -name 'main.c') obj = $(src:.c=.o) @@ -19,11 +22,13 @@ extobj = $(extsrc:.c=.so) tests=$(shell ls tests/*.c) tests_bin=$(tests:.c=.bin) -all: bamboo-lisp $(extobj) $(tests_bin) +all: bamboo-lisp exts $(tests_bin) + +exts: $(extobj) -install: bamboo-lisp libbamboo-lisp.a +install: bamboo-lisp libbamboo-lisp.so sudo cp bamboo-lisp /usr/local/bin/bamboo-lisp - sudo cp libbamboo-lisp.a /usr/local/lib/ + sudo cp libbamboo-lisp.so $(installdir) sudo mkdir -p /usr/local/include/bamboo_lisp sudo cp *.h /usr/local/include/bamboo_lisp/ sudo mkdir -p /usr/local/share/bamboo-lisp/exts/ @@ -32,14 +37,14 @@ install: bamboo-lisp libbamboo-lisp.a prelude.c: prelude.lisp cat prelude.lisp | python scripts/genprelude.py > prelude.c -bamboo-lisp: $(obj) main.o - gcc $(cflags) -o $@ $^ $(ldflags) +bamboo-lisp: libbamboo-lisp.so main.o + gcc $(cflags) -o $@ $^ $(ldflags) -lbamboo-lisp -Wl,-rpath,$(curdir) -Wl,-rpath,$(installdir) -libbamboo-lisp.a: $(obj) - ar cr $@ $^ +libbamboo-lisp.so: $(obj) + gcc -shared -o $@ $^ $(ldflags) -$(extobj):%.so:%.c libbamboo-lisp.a - gcc -shared $(cflags) -I./ -o $@ $^ $(ldflags) +$(extobj):%.so:%.c libbamboo-lisp.so + gcc -shared $(cflags) -I./ -o $@ $^ $(ldflags) -lbamboo-lisp -Wl,-rpath,$(curdir) -Wl,-rpath,$(installdir) test: bamboo-lisp $(tests_bin) exts @echo @@ -54,10 +59,8 @@ main.o:main.c $(obj):%.o:%.c $(cc) -c $(cflags) $< -MD -MF $@.d -o $@ -$(obj):%.o:$(libs) - -$(tests_bin):%.bin:%.c $(obj) $(libs) - $(cc) $(cflags) -I./ -Ilibs/ $< $(obj) $(libs) -MD -MF $@.d -o $@ $(ldflags) +$(tests_bin):%.bin:%.c libbamboo-lisp.so + $(cc) $(cflags) -I./ $< -MD -MF $@.d -o $@ $(ldflags) -lbamboo-lisp -Wl,-rpath,$(curdir) -Wl,-rpath,$(installdir) clean: -rm $(shell find tests/ -name '*.bin') diff --git a/exts/vector.c b/exts/vector.c index d6d07dc..a67a504 100644 --- a/exts/vector.c +++ b/exts/vector.c @@ -112,7 +112,6 @@ static void vector_gcmark(Interp *interp, SExpPtrVector *gcstack, void *vself) { } } - int bamboo_lisp_ext_init(Interp *interp) { bamboo_lisp_array_meta.type = VECTOR_TYPEID; bamboo_lisp_array_meta.free = &vector_free; -- cgit v1.0