caml-list - the Caml user's mailing list
 help / color / mirror / Atom feed
* ocamlbuild and installed modules and libraries
@ 2008-11-16 18:22 Daniel Bünzli
  2008-11-16 20:37 ` [Caml-list] " Nicolas Pouillard
  0 siblings, 1 reply; 5+ messages in thread
From: Daniel Bünzli @ 2008-11-16 18:22 UTC (permalink / raw)
  To: OCaml Mailing List

Hello,

Is it possible to specify a single installed module (instead of a lib)  
for link time ? That is is there something like -lib but for module so  
that I can type :

ocamlbuild -I +xmlm -mod xmlm test.native

where test.ml uses the xmlm module

And what about having special tags use_lib_$LIB and use_mod_$MOD that  
automatically create rules to use libraries $LIB.cm(x)a and module  
$MOD.cm(o|x) so that just the appropriate -I to find the files has to  
be specified. In most cases having to use a plugin just for that seems  
overkill. Or is there another way ?

Best,

Daniel


^ permalink raw reply	[flat|nested] 5+ messages in thread

* Re: [Caml-list] ocamlbuild and installed modules and libraries
  2008-11-16 18:22 ocamlbuild and installed modules and libraries Daniel Bünzli
@ 2008-11-16 20:37 ` Nicolas Pouillard
  2008-11-17  9:20   ` Daniel Bünzli
  0 siblings, 1 reply; 5+ messages in thread
From: Nicolas Pouillard @ 2008-11-16 20:37 UTC (permalink / raw)
  To: daniel.buenzli; +Cc: caml-list

Excerpts from daniel.buenzli's message of Sun Nov 16 19:22:02 +0100 2008:
> Hello,
> 
> Is it possible to specify a single installed module (instead of a lib)  
> for link time ? That is is there something like -lib but for module so  
> that I can type :
> 
> ocamlbuild -I +xmlm -mod xmlm test.native
> 
> where test.ml uses the xmlm module

This would make sense, but I would prefer not to push things in this
direction. Options like -lib,-cflag,-lflag... are intended to be used
only in a quick hack usage, indeed they are global and tags are much
more powerful.

> And what about having special tags use_lib_$LIB and use_mod_$MOD that  
> automatically create rules to use libraries $LIB.cm(x)a and module  
> $MOD.cm(o|x) so that just the appropriate -I to find the files has to  
> be specified. In most cases having to use a plugin just for that seems  
> overkill. Or is there another way ?

I'm a bit uncomfortable with this kind of dynamic or special tags.

However the simplest solution to your problem is probably one of those:

  1/ ocamlbuild -cflags -I,+xmlm,xmlm.cmx test.native

  2/ ln -s <sources-of-xmlm> xmlm
     ocamlbuild -I xmlm test.native

  3/ ln -s $(ocamlc -where)/xmlm .
     ocamlbuild -tag_line '"xmlm": not_hygienic' -I xmlm test.native

Hope that helps,

-- 
Nicolas Pouillard aka Ertai


^ permalink raw reply	[flat|nested] 5+ messages in thread

* Re: [Caml-list] ocamlbuild and installed modules and libraries
  2008-11-16 20:37 ` [Caml-list] " Nicolas Pouillard
@ 2008-11-17  9:20   ` Daniel Bünzli
  2008-11-17  9:54     ` Romain Bardou
  0 siblings, 1 reply; 5+ messages in thread
From: Daniel Bünzli @ 2008-11-17  9:20 UTC (permalink / raw)
  To: Nicolas Pouillard; +Cc: caml-list


Le 16 nov. 08 à 21:37, Nicolas Pouillard a écrit :

> I'm a bit uncomfortable with this kind of dynamic or special tags.
>
> However the simplest solution to your problem is probably one of  
> those:
>
>  1/ ocamlbuild -cflags -I,+xmlm,xmlm.cmx test.native

You meant,

> ocamlbuild -cflags -I,+xmlm -lflags -I,+xmlm,xmlm.cmx test.native


I still think using ocamlbuild with installed libraries/modules is a  
little bit problematic. If we have to do it that way [1] we are hard- 
coding the location of the library in the plugin which doesn't feel  
right.

For me there should be (1) a way of defining the dependency on a  
module/library (hopefully without needing a plugin) and (2) a way of  
defining its location (-I). These two aspects should be decoupled.  
This makes it easier to drive the installation process in build  
scripts by using environment variables, i.e. I just need
to specify the location of the module/library I depend on via a  
suitable -I $DEPDIR to compile the sources.

Best,

Daniel

[1] http://brion.inria.fr/gallium/index.php/Using_an_external_library


^ permalink raw reply	[flat|nested] 5+ messages in thread

* Re: [Caml-list] ocamlbuild and installed modules and libraries
  2008-11-17  9:20   ` Daniel Bünzli
@ 2008-11-17  9:54     ` Romain Bardou
  2008-11-17 10:07       ` Daniel Bünzli
  0 siblings, 1 reply; 5+ messages in thread
From: Romain Bardou @ 2008-11-17  9:54 UTC (permalink / raw)
  To: Daniel Bünzli; +Cc: Nicolas Pouillard, caml-list

Daniel Bünzli a écrit :
> 
> Le 16 nov. 08 à 21:37, Nicolas Pouillard a écrit :
> 
>> I'm a bit uncomfortable with this kind of dynamic or special tags.
>>
>> However the simplest solution to your problem is probably one of those:
>>
>>  1/ ocamlbuild -cflags -I,+xmlm,xmlm.cmx test.native
> 
> You meant,
> 
>> ocamlbuild -cflags -I,+xmlm -lflags -I,+xmlm,xmlm.cmx test.native
> 
> 
> I still think using ocamlbuild with installed libraries/modules is a 
> little bit problematic. If we have to do it that way [1] we are 
> hard-coding the location of the library in the plugin which doesn't feel 
> right.
> 
> For me there should be (1) a way of defining the dependency on a 
> module/library (hopefully without needing a plugin) and (2) a way of 
> defining its location (-I). These two aspects should be decoupled. This 
> makes it easier to drive the installation process in build scripts by 
> using environment variables, i.e. I just need
> to specify the location of the module/library I depend on via a suitable 
> -I $DEPDIR to compile the sources.

Isn't it almost as simple to write, in a script:
   ocamlbuild -cflags -I,$DEPDIR -lflags -I,$DEPDIR
instead of:
   ocamlbuild -I $DEPDIR
Remember that $DEPDIR must be absolute, or relative to the _build directory.

Then you can use ocamlbuild with the -lib option as usual, in a 
"decoupled" way. For instance, if bla/bla.cma is in your current directory:

$ ocamlbuild -classic-display -lib bla -cflags -I,../bla -lflags 
-I,../bla test.byte
ocamldep.opt -modules test.ml > test.ml.depends
ocamlc.opt -c -I ../bla -o test.cmo test.ml
ocamlc.opt -I ../bla bla.cma test.cmo -o test.byte

And for modules, instead of -lib bla, you write -lflags bla.cmo or 
-lflags bla.cmx. You can have several -lflags if you want. Unfortunately 
you have to specify the extension, so it is true that a -mod option 
would actually add something.

I admit, though, that it is not really easy to understand how to include 
a library. One solution would be to have findlib in ocamlbuild, but even 
then, there would be problems if you want a Makefile which is supposed 
to work also when findlib is not installed.

I think there is a recent debate about the -I option of Ocamlbuild...

-- 
Romain Bardou


^ permalink raw reply	[flat|nested] 5+ messages in thread

* Re: [Caml-list] ocamlbuild and installed modules and libraries
  2008-11-17  9:54     ` Romain Bardou
@ 2008-11-17 10:07       ` Daniel Bünzli
  0 siblings, 0 replies; 5+ messages in thread
From: Daniel Bünzli @ 2008-11-17 10:07 UTC (permalink / raw)
  To: caml-list List


Le 17 nov. 08 à 10:54, Romain Bardou a écrit :

> Isn't it almost as simple to write, in a script:
>  ocamlbuild -cflags -I,$DEPDIR -lflags -I,$DEPDIR
> instead of:
>  ocamlbuild -I $DEPDIR
> Remember that $DEPDIR must be absolute, or relative to the _build  
> directory.

Yes, I can live with that.

> And for modules, instead of -lib bla, you write -lflags bla.cmo or - 
> lflags bla.cmx. You can have several -lflags if you want.  
> Unfortunately you have to specify the extension, so it is true that  
> a -mod option would actually add something.

That is the point, from my perspective the problem is solved for  
libraries but not for single modules.

Daniel


^ permalink raw reply	[flat|nested] 5+ messages in thread

end of thread, other threads:[~2008-11-17 10:08 UTC | newest]

Thread overview: 5+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2008-11-16 18:22 ocamlbuild and installed modules and libraries Daniel Bünzli
2008-11-16 20:37 ` [Caml-list] " Nicolas Pouillard
2008-11-17  9:20   ` Daniel Bünzli
2008-11-17  9:54     ` Romain Bardou
2008-11-17 10:07       ` Daniel Bünzli

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).