Google Groups no longer supports new Usenet posts or subscriptions. Historical content remains viewable.
Dismiss

[Caml-list] compiling C library wrapper

10 views
Skip to first unread message

Aaron Bohannon

unread,
Nov 5, 2009, 5:32:26 PM11/5/09
to caml...@yquem.inria.fr
Hi,

I am quite confused by the whole process of compiling and installing
wrappers for C libraries. It seems like I can get things to work OK
without really knowing what I'm doing if everything is put and built
in a single directory. The hard part seems to be putting the right
files in the right places and getting the path arguments correct.
Then things stop working, and I have to really understand what's going
on, but the manual doesn't explain this part of the process in any
detail.

Let's say I have a library "/opt/local/lib/libfoo.a" for which I want
to build and use a (native-code) OCaml wrapper. Here are the steps as
I understand them:

1) Write the file "foo_stubs.c" and compile it to get "foo_stubs.o".

2) Build the library "libfoo_stubs.a" by running

ar rc libfoo_stubs.a foo_stubs.o

3) Copy "libfoo_stubs.a" to its permanent location, let's say,
"/usr/local/lib/ocaml/stubs/libfoo_stubs.a".

4) Write "foo.mli" and use it to build "foo.cmi"

5) Write "foo.ml" and use it to build "foo.cmxa" by running

ocamlopt -a -o foo.cmxa foo.ml
-ccopt -L/opt/local/lib -cclib -lfoo
-ccopt -L/usr/local/lib/ocaml/stubs -cclib -lfoo_stubs

6) Copy "foo.cmi" and "foo.cmxa" to their permanent location, let's
say "/usr/local/lib/ocaml/foo/"

7) Write my file "bar.ml" that needs to use the library, and compile
it by running

ocamlopt -I /usr/local/lib/ocaml/foo -o bar foo.cmxa bar.ml

However, this command ends up passing gcc the filename

/usr/local/lib/ocaml/foo/foo.a

which doesn't exist, so I get an error. Where did this filename come
from? Where did I go wrong?

- Aaron

_______________________________________________
Caml-list mailing list. Subscription management:
http://yquem.inria.fr/cgi-bin/mailman/listinfo/caml-list
Archives: http://caml.inria.fr
Beginner's list: http://groups.yahoo.com/group/ocaml_beginners
Bug reports: http://caml.inria.fr/bin/caml-bugs

David Allsopp

unread,
Nov 5, 2009, 6:10:46 PM11/5/09
to Aaron Bohannon, caml...@yquem.inria.fr
Aaron Bohannon wrote:
> I am quite confused by the whole process of compiling and installing
> wrappers for C libraries. It seems like I can get things to work OK
> without really knowing what I'm doing if everything is put and built
> in a single directory. The hard part seems to be putting the right
> files in the right places and getting the path arguments correct.
> Then things stop working, and I have to really understand what's going
> on, but the manual doesn't explain this part of the process in any
> detail.

Have a look at ocamlmklib in the manual - if it's available on your platform
then it nicely hides away a lot of this.

<snip - steps 1-4 are fine>


> 5) Write "foo.ml" and use it to build "foo.cmxa" by running
>
> ocamlopt -a -o foo.cmxa foo.ml
> -ccopt -L/opt/local/lib -cclib -lfoo
> -ccopt -L/usr/local/lib/ocaml/stubs -cclib -lfoo_stubs

This command will also build foo.cmx, foo.a and foo.o

> 6) Copy "foo.cmi" and "foo.cmxa" to their permanent location, let's
> say "/usr/local/lib/ocaml/foo/"

You should also copy foo.a to this directory which should fix the problem.
foo.cmxa contains information required by OCaml but the actual code is in
foo.a (as it's been natively compiled). Similarly, .cmx files contain
information which ocamlopt needs but the actual code is in .o (or .obj)
files. For native code, it's a code idea to copy the .cmx files too as it
allows ocamlopt to do some inlining (I think that's right...)

> 7) Write my file "bar.ml" that needs to use the library, and compile
> it by running
>
> ocamlopt -I /usr/local/lib/ocaml/foo -o bar foo.cmxa bar.ml

This should now work without error.


David

Aaron Bohannon

unread,
Nov 5, 2009, 6:38:19 PM11/5/09
to David Allsopp, caml...@yquem.inria.fr
Ah! Yes, that's exactly the part I didn't understand and everything
works fine now. Thank you!

I can't say I completely understand the byte-code case, but I don't
have an urgent need to.

ocamlmklib seems fine, but if it's just a matter of saving keystrokes,
"make" does a pretty good job of that (as long as I know what to tell
"make" to do).

- Aaron

Richard Jones

unread,
Nov 7, 2009, 7:26:17 AM11/7/09
to Aaron Bohannon, caml...@yquem.inria.fr
On Thu, Nov 05, 2009 at 06:38:05PM -0500, Aaron Bohannon wrote:
> Ah! Yes, that's exactly the part I didn't understand and everything
> works fine now. Thank you!
>
> I can't say I completely understand the byte-code case, but I don't
> have an urgent need to.
>
> ocamlmklib seems fine, but if it's just a matter of saving keystrokes,
> "make" does a pretty good job of that (as long as I know what to tell
> "make" to do).

For the install step, use 'ocamlfind install'.

Grab the latest source tarball for one of our projects,
eg. libvirt-ocaml, to see how we do it:

http://libvirt.org/sources/ocaml/
or: http://libguestfs.org/download/

Rich.

--
Richard Jones
Red Hat

Aaron Bohannon

unread,
Nov 7, 2009, 11:34:42 AM11/7/09
to Richard Jones, caml...@yquem.inria.fr
Thanks, I will look into that if I want to distribute wrapper code for
others to use. My current problems just involve using wrapper code
from other people with incomplete/broken Makefiles.

- Aaron

0 new messages