From: John Whitington <john@coherentgraphics.co.uk>
To: Gerd Stolpmann <info@gerd-stolpmann.de>
Cc: caml users <caml-list@inria.fr>
Subject: Re: [Caml-list] Building a mixed C / OCaml static library to be used from C
Date: Tue, 27 Aug 2013 14:12:35 +0100 [thread overview]
Message-ID: <521CA5C3.5030007@coherentgraphics.co.uk> (raw)
In-Reply-To: <1377210265.18270.4.camel@e130>
Hi,
Gerd Stolpmann wrote:
> Am Donnerstag, den 22.08.2013, 18:34 +0100 schrieb John Whitington:
>> Hi,
>>
>> I have the following recipe to build a static library of C functions
>> from a mixed ocaml / c codebase. The idea is that the final linking step
>> to build target 'test' won't require any special flags:
>>
>>
>> CAMLBASE = /Users/john/.opam/4.00.1/lib/
>>
>> mklib: cpdflib.mli cpdflib.ml cpdflibwrapper.c
>> ocamlfind ocamlc -package cpdf cpdflib.mli;
>> ocamlfind ocamlopt -package cpdf -c cpdflib.ml;
>> ocamlfind ocamlc cpdflibwrapper.c;
>> ocamlfind ocamlopt -I $(CAMLBASE)cpdf -I $(CAMLBASE)camlpdf \
>> -output-obj -o cpdflib.o \
>> unix.cmxa bigarray.cmxa camlpdf.cmxa cpdf.cmxa cpdflib.cmx;
>> ar -x $(CAMLBASE)camlpdf/libcamlpdf_stubs.a;
>> ar -x $(CAMLBASE)ocaml/libasmrun.a;
>> ar cr cpdflib.a *.o
>>
>> test: cpdflib.a cpdflibtest.c
>> cc cpdflibtest.c cpdflib.a -o test\
>> -L $(CAMLBASE)ocaml -lbigarray -lunix
>>
>> clean:
>> rm __.SYMDEF\ SORTED *.o *.cmx *.cmi *.a test
>>
>>
>> (Here, cpdflib.ml, cpdflib.mli and cpdflibwrapper.c form the C interface
>> to the OCaml functions. cpdflibtest.c calls caml_startup and then any
>> caml functions it likes).
>>
>> This works. However, I'm having trouble getting rid of "-L
>> $(CAMLBASE)ocaml -lbigarray -lunix" -- i'd like the person linking with
>> my cpdflib.a not to need any dependencies at all.
>>
>> When I add two more lines
>>
>> ar -x $(CAMLBASE)ocaml/bigarray.a;
>> ar -x $(CAMLBASE)ocaml/unix.a;
>
> These are the wrong two libs. bigarray.a and unix.a are already
> contained in cpdflib.a. What you need are libbigarray.a and libunix.a.
Ah. A schoolboy error. Thanks!
However, it looks like this might not be possible anyway. In this thread...
http://caml.inria.fr/pub/ml-archives/caml-list/2007/11/c0ce27aa2dd792643615b6b705750657.en.html
...Alain Frisch comments on the method above, saying:
> Ok, that's a hack to merge one library, plus more object files into a
> library. I know it is mentioned in the OCaml manual. Personally, I would
> not recommend to do that (you'll be stuck if you need to include e.g.
> libunix.a).
So, unless I can find a way to get partial linking with ld -r to work,
the best I have for now is:
CAMLBASE = /Users/john/.opam/4.00.1/lib/
mklib: cpdflib.mli cpdflib.ml cpdflibwrapper.c
ocamlfind ocamlc -package cpdf cpdflib.mli;
ocamlfind ocamlopt -package cpdf -c cpdflib.ml;
ocamlfind ocamlc cpdflibwrapper.c;
ocamlfind ocamlopt -I $(CAMLBASE)cpdf -I $(CAMLBASE)camlpdf \
-output-obj -o cpdflib.o \
unix.cmxa bigarray.cmxa camlpdf.cmxa cpdf.cmxa cpdflib.cmx;
cp $(CAMLBASE)ocaml/libasmrun.a libcpdf.a;
ar -x $(CAMLBASE)camlpdf/libcamlpdf_stubs.a;
ar r libcpdf.a *.o
test: libcpdf.a cpdflibtest.c
cc cpdflibtest.c -o test -L. -lcpdf -lbigarray -lunix
clean:
rm __.SYMDEF\ SORTED *.o *.cmx *.cmi *.a test
The end-user of the library still needs three -l options, but I need
only ship the three .a files (libcpdf, libbigarray, libunix), which I
suppose is not much harder on the end user than shipping one.
Obviously, I hope most people will be building from source, but I do
need to ship binary libraries too.
Thanks,
--
John Whitington
Director, Coherent Graphics Ltd
http://www.coherentpdf.com/
prev parent reply other threads:[~2013-08-27 13:12 UTC|newest]
Thread overview: 3+ messages / expand[flat|nested] mbox.gz Atom feed top
2013-08-22 17:34 John Whitington
2013-08-22 22:24 ` Gerd Stolpmann
2013-08-27 13:12 ` John Whitington [this message]
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=521CA5C3.5030007@coherentgraphics.co.uk \
--to=john@coherentgraphics.co.uk \
--cc=caml-list@inria.fr \
--cc=info@gerd-stolpmann.de \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox