mirror of
https://github.com/xomboverlord/ldc.git
synced 2026-04-18 01:39:03 +02:00
Basic support for runtime in shared library.
Needs to be built with runtime/build-sharedlibs.sh and activated manually by providing -defaultlib=llvmdc-runtime-shared -defaultlib=tango-cc-tango-shared -defaultlib=tango-gc-basic-shared on llvmdc call at the moment. To support D shared libraries in non-D code, we need to remove the main() from libllvmdc-runtime-shared.
This commit is contained in:
@@ -13,7 +13,8 @@
|
||||
LIB_TARGET_FULL=libtango-cc-tango.a
|
||||
LIB_TARGET_BC_ONLY=libtango-cc-tango-bc-only.a
|
||||
LIB_TARGET_C_ONLY=libtango-cc-tango-c-only.a
|
||||
LIB_MASK=libtango-cc-tango*.a
|
||||
LIB_TARGET_SHARED=libtango-cc-tango-shared.so
|
||||
LIB_MASK=libtango-cc-tango*.*
|
||||
|
||||
CP=cp -f
|
||||
RM=rm -f
|
||||
@@ -70,10 +71,11 @@ DOC_DEST=../../../doc/tango
|
||||
$(DC) -c -o- $(DOCFLAGS) -Df$*.html $<
|
||||
# $(DC) -c -o- $(DOCFLAGS) -Df$*.html tango.ddoc $<
|
||||
|
||||
targets : lib doc
|
||||
all : lib doc
|
||||
targets : lib sharedlib doc
|
||||
all : lib sharedlib doc
|
||||
tango : lib
|
||||
lib : tango.lib tango.bclib tango.clib
|
||||
sharedlib : tango.sharedlib
|
||||
doc : tango.doc
|
||||
|
||||
######################################################
|
||||
@@ -115,6 +117,7 @@ ALL_DOCS=
|
||||
tango.bclib : $(LIB_TARGET_BC_ONLY)
|
||||
tango.lib : $(LIB_TARGET_FULL)
|
||||
tango.clib : $(LIB_TARGET_C_ONLY)
|
||||
tango.sharedlib : $(LIB_TARGET_SHARED)
|
||||
|
||||
$(LIB_TARGET_BC_ONLY) : $(ALL_OBJS)
|
||||
$(RM) $@
|
||||
@@ -134,6 +137,14 @@ $(LIB_TARGET_C_ONLY) : $(OBJ_STDC)
|
||||
$(CLC) $@ $(OBJ_STDC)
|
||||
|
||||
|
||||
$(LIB_TARGET_SHARED) : $(ALL_OBJS) $(OBJ_STDC)
|
||||
$(RM) $@ $@.bc $@.s $@.o
|
||||
$(LLINK) -o=$@.bc $(ALL_OBJS)
|
||||
$(LCC) -relocation-model=pic -o=$@.s $@.bc
|
||||
$(CC) -c -o $@.o $@.s
|
||||
$(CC) -shared -o $@ $@.o $(OBJ_STDC)
|
||||
|
||||
|
||||
tango.doc : $(ALL_DOCS)
|
||||
echo Documentation generated.
|
||||
|
||||
|
||||
@@ -12,7 +12,8 @@
|
||||
|
||||
LIB_TARGET_BC=libtango-gc-basic-bc.a
|
||||
LIB_TARGET_NATIVE=libtango-gc-basic.a
|
||||
LIB_MASK=libtango-gc-basic*.a
|
||||
LIB_TARGET_SHARED=libtango-gc-basic-shared.so
|
||||
LIB_MASK=libtango-gc-basic*.*
|
||||
|
||||
CP=cp -f
|
||||
RM=rm -f
|
||||
@@ -63,9 +64,10 @@ LIB_DEST=..
|
||||
$(DC) -c -o- $(DOCFLAGS) -Df$*.html $<
|
||||
# $(DC) -c -o- $(DOCFLAGS) -Df$*.html dmd.ddoc $<
|
||||
|
||||
targets : lib doc
|
||||
all : lib doc
|
||||
targets : lib sharedlib doc
|
||||
all : lib sharedlib doc
|
||||
lib : basic.lib basic.nlib
|
||||
sharedlib : basic.sharedlib
|
||||
doc : basic.doc
|
||||
|
||||
######################################################
|
||||
@@ -85,6 +87,7 @@ ALL_DOCS=
|
||||
|
||||
basic.lib : $(LIB_TARGET_BC)
|
||||
basic.nlib : $(LIB_TARGET_NATIVE)
|
||||
basic.sharedlib : $(LIB_TARGET_SHARED)
|
||||
|
||||
$(LIB_TARGET_BC) : $(ALL_OBJS)
|
||||
$(RM) $@
|
||||
@@ -98,6 +101,13 @@ $(LIB_TARGET_NATIVE) : $(ALL_OBJS)
|
||||
$(CC) -c -o $@.o $@.s
|
||||
$(CLC) $@ $@.o
|
||||
|
||||
|
||||
$(LIB_TARGET_SHARED) : $(ALL_OBJS)
|
||||
$(RM) $@ $@.bc $@.s $@.o
|
||||
$(LLINK) -o=$@.bc $(ALL_OBJS)
|
||||
$(LCC) -relocation-model=pic -o=$@.s $@.bc
|
||||
$(CC) -shared -o $@ $@.s
|
||||
|
||||
basic.doc : $(ALL_DOCS)
|
||||
echo No documentation available.
|
||||
|
||||
|
||||
@@ -37,8 +37,8 @@ ADD_CFLAGS=
|
||||
#ADD_DFLAGS=
|
||||
ADD_DFLAGS=-I`pwd`/common/
|
||||
|
||||
targets : lib doc
|
||||
all : lib doc
|
||||
targets : lib sharedlib doc
|
||||
all : lib sharedlib doc
|
||||
|
||||
######################################################
|
||||
|
||||
@@ -56,6 +56,12 @@ lib : $(ALL_OBJS)
|
||||
make -C $(DIR_GC) -fllvmdc.mak lib DC=$(DC) ADD_DFLAGS="$(ADD_DFLAGS)" ADD_CFLAGS="$(ADD_CFLAGS)"
|
||||
# could link the three parts into one here, but why should we
|
||||
|
||||
sharedlib : $(ALL_OBJS)
|
||||
make -C $(DIR_CC) -fllvmdc.mak sharedlib DC=$(DC) ADD_DFLAGS="$(ADD_DFLAGS)" ADD_CFLAGS="$(ADD_CFLAGS)"
|
||||
make -C $(DIR_RT) -fllvmdc.mak sharedlib
|
||||
make -C $(DIR_GC) -fllvmdc.mak sharedlib DC=$(DC) ADD_DFLAGS="$(ADD_DFLAGS)" ADD_CFLAGS="$(ADD_CFLAGS)"
|
||||
# could link the three parts into one here, but why should we
|
||||
|
||||
doc : $(ALL_DOCS)
|
||||
make -C $(DIR_CC) -fllvmdc.mak doc
|
||||
make -C $(DIR_RT) -fllvmdc.mak doc
|
||||
|
||||
Reference in New Issue
Block a user