up |
See the file INSTALL for instructions how to build and install findlib.
For a number of platforms, O'Caml can load bytecode-compiled libraries dynamically. For these platforms, findlib is very simple to use as explained in the following. For other platforms, see the paragraph below about "custom toploops".
After the toploop has been started, it is possible to load the special findlib support:[1]
$ ocaml Objective Caml version 3.07 # #use "topfind";; Findlib has been successfully loaded. Additional directives: #require "package";; to load a package #list;; to list the available packages #camlp4o;; to load camlp4 (standard syntax) #camlp4r;; to load camlp4 (revised syntax) #predicates "p,q,...";; to set these predicates Topfind.reset();; to force that packages will be reloaded #thread;; to enable threads - : unit = ()You can now list the available packages:
# #list;; bigarray (version: [distributed with Ocaml]) camlp4 (version: Camlp4 version 3.03 ALPHA) dbm (version: [distributed with Ocaml]) dynlink (version: [distributed with Ocaml]) findlib (version: 0.6) graphics (version: [distributed with Ocaml]) labltk (version: [distributed with Ocaml]) netstring (version: 0.10) num (version: [distributed with Ocaml]) stdlib (version: [distributed with Ocaml]) str (version: [distributed with Ocaml]) threads (version: [distributed with Ocaml]) unix (version: [distributed with Ocaml]) xstrp4 (version: 1.1)and load packages by simply typing:
# #require "netstring";; Loading /opt/ocaml/lib/unix.cma Loading /opt/ocaml/lib/str.cma Loading /opt/ocaml/site-lib/netstring/netstring.cma Loading /opt/ocaml/site-lib/netstring/netstring_top.cmoFindlib takes care to load packages that are required by loaded packages first. For example, "netstring" uses "unix" and "str" internally, but you do not need to load them because findlib does it for you. In this example you can also see that findlib loads netstring_top.cmo containing printers for the toploop.
You can also enable the Camlp4 parsers by simply typing
# #camlp4o;; Loading /opt/ocaml-3.03a/lib/camlp4/camlp4o.cma Camlp4 Parsing version 3.03 ALPHAfor the standard syntax or
# #camlp4r;; Loading /opt/ocaml-3.03a/lib/camlp4/camlp4r.cma Camlp4 Parsing version 3.03 ALPHAfor the revised syntax. (But you cannot switch between the syntaxes.)
For some platforms, O'Caml does not implement loading external libraries (e.g. Cygwin). One has to create a so-called custom toploop that statically links with these libraries. Example:
$ ocamlfind ocamlmktop -o mytop -package findlib,unix -linkpkg $ ./mytop Objective Caml version 3.07 # #use "topfind";; Findlib has been successfully loaded. Additional directives: #require "package";; to load a package #list;; to list the available packages #camlp4o;; to load camlp4 (standard syntax) #camlp4r;; to load camlp4 (revised syntax) #predicates "p,q,...";; to set these predicates Topfind.reset();; to force that packages will be reloaded #thread;; to enable threads - : unit = ()Now "#require" works for all libraries referring to the special "unix" functions.
The #require directive can also be used in scripts. Example:
#use "topfind";; #require "netstring";; open Cgi;; ...This makes it possible to write scripts that do not contain #directory directives that are specific for certain installations.
For Unix environments, you can start scripts directly if you apply the following trick:
#! /bin/sh # (* exec ocaml "$0" "$@" *) use "topfind";; #require "netstring";; open Cgi;; ...This works wherever O'Caml is installed.
Assumed you want to compile a program that uses the Netstring package. Do it the following way:
$ ocamlfind ocamlc -package netstring -c myprogram.mlThis way you do not need to add "-I" options to locate Netstring.
If you want to create an executable, do not forget to add the -linkpkg switch:
$ ocamlfind ocamlc -o myprogram -package netstring -linkpkg myprogram.cmoThis switch causes that the mentioned packages are added to the resulting executable.
If you want to include several packages, you can either add several "-package" options, or you can enumerate the packages separated by commas: -package netstring,labltk.
If you add a -syntax option, the compiler will be told to parse the source file using camlp4:
$ ocamlfind ocamlc -package netstring -syntax camlp4o -c myprogram.mlUse -syntax camlp4o for the standard syntax or -syntax camlp4r for the revised syntax.
Additionally, you can mention packages that add new syntax features. The package xstrp4 is an example of this:
$ ocamlfind ocamlc -package xstrp4,netstring -syntax camlp4o -c myprogram.mlNow you can use the $ notation that is implemented by xstrp4 in the source file myprogram.ml.
Note that you can also invoke ocamldep from ocamlfind:
$ ocamlfind ocamldep -package xstrp4 -syntax camlp4o *.ml *.mli >.dependThis enables the syntax extensions, too.
Since findlib-0.7, it is also possible to start ocamlbrowser from ocamlfind. For example,
$ ocamlfind browser -package xstrp4adds the correct path specification such that the modules contained in the package xstrp4 are also displayed. With
$ ocamlfind browser -allall package are added to the path spec.
There is a wizard that makes it very easy to write Makefiles. Call the wizard by
$ ocamlfind findlib/make_wizard(the wizard requires that the labltk library is available). A new window pops up, and by very few clicks you can describe your own library. Finally, a Makefile is written.
Findlib is neither a patch of O'Caml nor uses it internal features of the O'Caml programming environment. It is only a convention to install software components in filesystem hierarchies, a library interpreting this convention, and some frontend applications making the library useable for you.
One important consequence is that you can only refer to those software components that have previously been installed in a way findlib understands. This convention is beyond the scope of this QUICKSTART guide, see the reference manual for details. You can always check whether findlib accepts a component as "findlib package" by the command
$ ocamlfind list(this is the same as the #list directive in the toploop). If the package occurs in the list, it is found, otherwise not.
up |