Sophie

Sophie

distrib > Mageia > 5 > i586 > media > core-release > by-pkgid > b4812c02dfe2aef57518a39a375ad6e8 > files > 52

ocaml-argot-1.1-6.mga5.i586.rpm

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN"
            "http://www.w3.org/TR/REC-html40/loose.dtd">
<HTML>
<HEAD>
<TITLE>Argot 1.1 
Reference Manual
</TITLE>

<META http-equiv="Content-Type" content="text/html; charset=US-ASCII">
<META name="GENERATOR" content="hevea 1.10">
<STYLE type="text/css">
.li-itemize{margin:1ex 0ex;}
.li-enumerate{margin:1ex 0ex;}
.dd-description{margin:0ex 0ex 1ex 4ex;}
.dt-description{margin:0ex;}
.toc{list-style:none;}
.thefootnotes{text-align:left;margin:0ex;}
.dt-thefootnotes{margin:0em;}
.dd-thefootnotes{margin:0em 0em 0em 2em;}
.footnoterule{margin:1em auto 1em 0px;width:50%;}
.caption{padding-left:2ex; padding-right:2ex; margin-left:auto; margin-right:auto}
.title{margin:2ex auto;text-align:center}
.center{text-align:center;margin-left:auto;margin-right:auto;}
.flushleft{text-align:left;margin-left:0ex;margin-right:auto;}
.flushright{text-align:right;margin-left:auto;margin-right:0ex;}
DIV TABLE{margin-left:inherit;margin-right:inherit;}
PRE{text-align:left;margin-left:0ex;margin-right:auto;}
BLOCKQUOTE{margin-left:4ex;margin-right:4ex;text-align:left;}
TD P{margin:0px;}
.boxed{border:1px solid black}
.textboxed{border:1px solid black}
.vbar{border:none;width:2px;background-color:black;}
.hbar{border:none;height:2px;width:100%;background-color:black;}
.hfill{border:none;height:1px;width:200%;background-color:black;}
.vdisplay{border-collapse:separate;border-spacing:2px;width:auto; empty-cells:show; border:2px solid red;}
.vdcell{white-space:nowrap;padding:0px;width:auto; border:2px solid green;}
.display{border-collapse:separate;border-spacing:2px;width:auto; border:none;}
.dcell{white-space:nowrap;padding:0px;width:auto; border:none;}
.dcenter{margin:0ex auto;}
.vdcenter{border:solid #FF8000 2px; margin:0ex auto;}
.minipage{text-align:left; margin-left:0em; margin-right:auto;}
.marginpar{border:solid thin black; width:20%; text-align:left;}
.marginparleft{float:left; margin-left:0ex; margin-right:1ex;}
.marginparright{float:right; margin-left:1ex; margin-right:0ex;}
.theorem{text-align:left;margin:1ex auto 1ex 0ex;}
.part{margin:2ex auto;text-align:center}
.figure{border-top: thin solid black; border-bottom: thin solid black;}
.caption{border-bottom: thin solid black;}
BODY{background:white;}
.title{padding:1ex;background:white;}
.titlemain{padding:1ex;background:white;}
.titlerest{padding:1ex;background:white;}
.part{padding:1ex;background:#7F7F7F;}
.section{padding:.5ex;background:#7F7F7F;}
.subsection{padding:0.3ex;background:#B2B2B2;}
.subsubsection{padding:0.5ex;background:#E5E5E5;}
.chapter{padding:0.5ex;background:#7F7F7F;}
.fmarginpar{border:solid thin #B2B2B2; width:20%; text-align:left;}
.ffootnoterule{border:none;margin:1em auto 1em 0px;width:50%;background:#7F7F7F;}
.ftoc1{list-style:none;margin:0ex 1ex;padding:0ex 1ex;border-left:1ex solid #7F7F7F;}
.ftoc2{list-style:none;margin:1ex 1ex;padding:0ex 1ex;border-left:1ex solid #7F7F7F;}
.ftoc3{list-style:none;margin:0ex 1ex;padding:0ex 1ex;border-left:1ex solid #7F7F7F;}
.ftoc4{list-style:none;margin:0ex 1ex;padding:0ex 1ex;border-left:1ex solid #B2B2B2;}
.ftoc5{list-style:none;margin:0ex 1ex;padding:0ex 1ex;border-left:1ex solid #E5E5E5;}
.ftoc6{list-style:none;margin:0ex 1ex;padding:0ex 1ex;border-left:1ex solid #CCFFCC;}
/* Argot icons -- from the "Silk icon set 1.3" by Mark James, available at http://www.famfamfam.com/lab/icons/silk/ */
.argot_attention { border: 0px; width: 24px; height: 24px; background-image:url(); background-repeat:no-repeat; }
.argot_bug { border: 0px; width: 24px; height: 24px; background-image:url(); background-repeat:no-repeat; }
.argot_error { border: 0px; width: 24px; height: 24px; background-image:url(); background-repeat:no-repeat; }
.argot_info { border: 0px; width: 24px; height: 24px; background-image:url(); background-repeat:no-repeat; }
.argot_new { border: 0px; width: 24px; height: 24px; background-image:url(); background-repeat:no-repeat; }
.argot_note { border: 0px; width: 24px; height: 24px; background-image:url(); background-repeat:no-repeat; }
.argot_remark { border: 0px; width: 24px; height: 24px; background-image:url(); background-repeat:no-repeat; }
.argot_search { border: 0px; width: 24px; height: 24px; background-image:url(); background-repeat:no-repeat; }
.argot_stateful { border: 0px; width: 24px; height: 24px; background-image:url(); background-repeat:no-repeat; }
.argot_threadsafe { border: 0px; width: 24px; height: 24px; background-image:url(); background-repeat:no-repeat; }
.argot_threadunsafe { border: 0px; width: 24px; height: 24px; background-image:url(); background-repeat:no-repeat; }
.argot_todo { border: 0px; width: 24px; height: 24px; background-image:url(); background-repeat:no-repeat; }
.argot_todoc { border: 0px; width: 24px; height: 24px; background-image:url(); background-repeat:no-repeat; }
.argot_tofix { border: 0px; width: 24px; height: 24px; background-image:url(); background-repeat:no-repeat; }
.argot_warning { border: 0px; width: 24px; height: 24px; background-image:url(); background-repeat:no-repeat; }
</STYLE>
</HEAD>
<BODY >
<!--HEVEA command line is: hevea -fix -O -exec /usr/local/lib/hevea/xxdate.exe book.hva -o argot.html article.hva fancysection.hva argot.tex -->
<!--CUT DEF chapter 1 --><TABLE CLASS="title"><TR><TD><H1 CLASS="titlemain">Argot 1.1<BR>
Reference Manual</H1><H3 CLASS="titlerest">Copyright &#XA9; 2010-2012 Xavier Clerc &#X2013; <A HREF="mailto:argot@x9c.fr">argot@x9c.fr</A><BR>
Released under the <SPAN STYLE="font-variant:small-caps">gpl</SPAN> v3</H3><H3 CLASS="titlerest">August&#XA0;5, 2012</H3></TD></TR>
</TABLE><!--TOC chapter Contents-->
<H1 CLASS="chapter"><!--SEC ANCHOR -->Contents</H1><!--SEC END --><UL CLASS="ftoc1"><LI CLASS="li-toc">
<A HREF="#htoc1">Chapter&#XA0;1&#XA0;&#XA0;Overview</A>
<UL CLASS="ftoc2"><LI CLASS="li-toc">
<A HREF="#htoc2">1.1&#XA0;&#XA0;Purpose</A>
</LI><LI CLASS="li-toc"><A HREF="#htoc3">1.2&#XA0;&#XA0;License</A>
</LI><LI CLASS="li-toc"><A HREF="#htoc4">1.3&#XA0;&#XA0;Contributions</A>
</LI></UL>
</LI><LI CLASS="li-toc"><A HREF="#htoc5">Chapter&#XA0;2&#XA0;&#XA0;Building Argot</A>
<UL CLASS="ftoc2"><LI CLASS="li-toc">
<A HREF="#htoc6">2.1&#XA0;&#XA0;Step 0: dependencies</A>
</LI><LI CLASS="li-toc"><A HREF="#htoc7">2.2&#XA0;&#XA0;Step 1: configuration</A>
</LI><LI CLASS="li-toc"><A HREF="#htoc8">2.3&#XA0;&#XA0;Step 2: compilation</A>
</LI><LI CLASS="li-toc"><A HREF="#htoc9">2.4&#XA0;&#XA0;Step 3: installation</A>
</LI></UL>
</LI><LI CLASS="li-toc"><A HREF="#htoc10">Chapter&#XA0;3&#XA0;&#XA0;Running Argot</A>
<UL CLASS="ftoc2"><LI CLASS="li-toc">
<A HREF="#htoc11">3.1&#XA0;&#XA0;Through direct call to <TT>ocamldoc</TT></A>
</LI><LI CLASS="li-toc"><A HREF="#htoc12">3.2&#XA0;&#XA0;Through <TT>ocamlbuild</TT></A>
</LI></UL>
</LI><LI CLASS="li-toc"><A HREF="#htoc13">Chapter&#XA0;4&#XA0;&#XA0;Argot formatting</A>
<UL CLASS="ftoc2"><LI CLASS="li-toc">
<A HREF="#htoc14">4.1&#XA0;&#XA0;Text formatting</A>
</LI><LI CLASS="li-toc"><A HREF="#htoc15">4.2&#XA0;&#XA0;Tables</A>
</LI><LI CLASS="li-toc"><A HREF="#htoc16">4.3&#XA0;&#XA0;Token substitution</A>
</LI><LI CLASS="li-toc"><A HREF="#htoc17">4.4&#XA0;&#XA0;Images</A>
</LI><LI CLASS="li-toc"><A HREF="#htoc18">4.5&#XA0;&#XA0;Folding</A>
</LI></UL>
</LI><LI CLASS="li-toc"><A HREF="#htoc19">Chapter&#XA0;5&#XA0;&#XA0;Argot tags</A>
</LI><LI CLASS="li-toc"><A HREF="#htoc20">Chapter&#XA0;6&#XA0;&#XA0;Search</A>
</LI></UL><!--TOC chapter Overview-->
<H1 CLASS="chapter"><!--SEC ANCHOR --><A NAME="htoc1">Chapter&#XA0;1</A>&#XA0;&#XA0;Overview</H1><!--SEC END --><!--TOC section Purpose-->
<H2 CLASS="section"><!--SEC ANCHOR --><A NAME="htoc2">1.1</A>&#XA0;&#XA0;Purpose</H2><!--SEC END --><P>
The OCaml<SUP><A NAME="text1" HREF="#note1">1</A></SUP>distribution contains a tool named <TT>ocamldoc</TT> whose duty is to produce <SPAN STYLE="font-variant:small-caps">api</SPAN> documentation by extracting information from source comments. Argot is an enhanced <SPAN STYLE="font-variant:small-caps">html</SPAN> generator for <TT>ocamldoc</TT> providing additional text formatting, additional tags, and support for symbol search. The name &#X201C;Argot&#X201D; stems from the following acronym: <I>Argot is a Raised Generator for the Ocamldoc Tool</I>.</P><!--TOC section License-->
<H2 CLASS="section"><!--SEC ANCHOR --><A NAME="htoc3">1.2</A>&#XA0;&#XA0;License</H2><!--SEC END --><P>
Argot is distributed under the terms of the <SPAN STYLE="font-variant:small-caps">gpl</SPAN> version 3. This licensing scheme should not cause any problem, as documentation generation will not contaminate code. Moreover, generated documentation files can be used without any restriction.</P><!--TOC section Contributions-->
<H2 CLASS="section"><!--SEC ANCHOR --><A NAME="htoc4">1.3</A>&#XA0;&#XA0;Contributions</H2><!--SEC END --><P>
In order to improve the project, I am primarily looking for testers and bug reporters. Pointing errors in documentation and indicating where it should be enhanced is also very helpful.<BR>
Bugs and feature requests can be made at <TT><A HREF="http://bugs.x9c.fr">http://bugs.x9c.fr</A></TT>.<BR>
Other requetes can be sent to <A HREF="mailto:argot@x9c.fr">argot@x9c.fr</A>.

</P><!--BEGIN NOTES chapter-->
<HR CLASS="ffootnoterule"><DL CLASS="thefootnotes"><DT CLASS="dt-thefootnotes">
<A NAME="note1" HREF="#text1">1</A></DT><DD CLASS="dd-thefootnotes">The official OCaml website can be reached at <TT><A HREF="http://caml.inria.fr">http://caml.inria.fr</A></TT> and contains the full development suite (compilers, tools, virtual machine, <I>etc.</I>) as well as links to third-party contributions.
</DD></DL>
<!--END NOTES-->
<!--TOC chapter Building Argot-->
<H1 CLASS="chapter"><!--SEC ANCHOR --><A NAME="htoc5">Chapter&#XA0;2</A>&#XA0;&#XA0;Building Argot</H1><!--SEC END --><!--TOC section Step 0: dependencies-->
<H2 CLASS="section"><!--SEC ANCHOR --><A NAME="htoc6">2.1</A>&#XA0;&#XA0;Step 0: dependencies</H2><!--SEC END --><P>
Before starting to build Argot, one first have to check that dependencies are already installed. The following elements are needed in order to build Argot:
</P><UL CLASS="itemize"><LI CLASS="li-itemize">
OCaml, version 4.00.0;
</LI><LI CLASS="li-itemize"><TT>make</TT>, in its GNU Make 3.81 flavor;
</LI><LI CLASS="li-itemize">a classical Unix shell, such as <TT>bash</TT>;
</LI><LI CLASS="li-itemize"><B>optionally:</B> Findlib<SUP><A NAME="text2" HREF="#note2">1</A></SUP>, version 1.3.3.
</LI></UL><!--TOC section Step 1: configuration-->
<H2 CLASS="section"><!--SEC ANCHOR --><A NAME="htoc7">2.2</A>&#XA0;&#XA0;Step 1: configuration</H2><!--SEC END --><P>
The configuration of Argot is done by executing <TT>sh configure</TT>. One can specify elements if they are not correctly inferred by the <TT>configure</TT> script; the following switches are available:
</P><UL CLASS="itemize"><LI CLASS="li-itemize">
<TT>-ocaml-prefix</TT> to specify the prefix path to the OCaml installation (usually <TT>/usr/local</TT>);
</LI><LI CLASS="li-itemize"><TT>-ocamlfind</TT> to specify the path to the <TT>ocamlfind</TT> executable;
</LI><LI CLASS="li-itemize"><TT>-no-native-dynlink</TT> to disable the build of the native version of the generator, even if native dynamic linking is available.
</LI></UL><!--TOC section Step 2: compilation-->
<H2 CLASS="section"><!--SEC ANCHOR --><A NAME="htoc8">2.3</A>&#XA0;&#XA0;Step 2: compilation</H2><!--SEC END --><P>
The actual build of Argot is launched by executing <TT>make all</TT>. When build is finished, it is possible to run some simple tests by running <TT>make tests</TT>.</P><!--TOC section Step 3: installation-->
<H2 CLASS="section"><!--SEC ANCHOR --><A NAME="htoc9">2.4</A>&#XA0;&#XA0;Step 3: installation</H2><!--SEC END --><P>
Argot is installed by executing <TT>make install</TT>. According to local settings, it may be necessary to acquire privileged accesses, running for example <TT>sudo</TT> <TT>make</TT> <TT>install</TT>. The actual installation directory depends on the use of <TT>ocamlfind</TT>: if present the files are placed inside the Findlib hierarchy, otherwise they are placed in the directory printed by the <TT>ocamldoc -customdir</TT> command (<I>i.&#XA0;e.</I> <TT>$PREFIX/lib/ocaml/ocamldoc/custom</TT>).

</P><!--BEGIN NOTES chapter-->
<HR CLASS="ffootnoterule"><DL CLASS="thefootnotes"><DT CLASS="dt-thefootnotes">
<A NAME="note2" HREF="#text2">1</A></DT><DD CLASS="dd-thefootnotes">Findlib, a library manager for OCaml, is available at <TT><A HREF="http://projects.camlcity.org/projects/findlib.html">http://projects.camlcity.org/projects/findlib.html</A></TT>.
</DD></DL>
<!--END NOTES-->
<!--TOC chapter Running Argot-->
<H1 CLASS="chapter"><!--SEC ANCHOR --><A NAME="htoc10">Chapter&#XA0;3</A>&#XA0;&#XA0;Running Argot</H1><!--SEC END --><!--TOC section Through direct call to <TT>ocamldoc</TT>-->
<H2 CLASS="section"><!--SEC ANCHOR --><A NAME="htoc11">3.1</A>&#XA0;&#XA0;Through direct call to <TT>ocamldoc</TT></H2><!--SEC END --><!--TOC subsection Without Findlib-->
<H3 CLASS="subsection"><!--SEC ANCHOR -->Without Findlib</H3><!--SEC END --><P>
Once built and installed, using Argot is as simple as switching from:
</P><DIV CLASS="center">
<TT>ocamldoc -html -d <I>destination-path files</I></TT><BR>
 or<BR>
 <TT>ocamldoc.opt -html -d <I>destination-path files</I></TT>
</DIV><P>
to:
</P><DIV CLASS="center">
<TT>ocamldoc -g argot.cmo -d <I>destination-path files</I></TT><BR>
 or<BR>
 <TT>ocamldoc.opt -g argot.cmxs -d <I>destination-path files</I></TT>
</DIV><!--TOC subsection With Findlib-->
<H3 CLASS="subsection"><!--SEC ANCHOR -->With Findlib</H3><!--SEC END --><P>
Argot execution is akin to the previous section, except that the use of findlib implies to pass the installation directory to the <TT>ocamldoc</TT> tool, thus leading to:
</P><DIV CLASS="center">
<TT>ocamldoc -i <I>argot-path</I> -g argot.cmo -d <I>destination-path files</I></TT><BR>
 or<BR>
 <TT>ocamldoc.opt -i <I>argot-path</I> -g argot.cmxs -d <I>destination-path files</I></TT>
</DIV><P>
where <I><TT>argot-path</TT></I> is <TT>&#X2018;ocamlfind query argot&#X2018;</TT>.</P><!--TOC section Through <TT>ocamlbuild</TT>-->
<H2 CLASS="section"><!--SEC ANCHOR --><A NAME="htoc12">3.2</A>&#XA0;&#XA0;Through <TT>ocamlbuild</TT></H2><!--SEC END --><P>
Generating documentation through <TT>ocamlbuild</TT> implies to first create a <TT><I>modules</I>.odocl</TT> file containing the list of modules (one per line) to generate documentation for. Then, documentation can be generated by executing <TT>ocamlbuild</TT> <TT><I>modules</I>.docdir/index.html</TT>. In order to make use of Argot, the following line should be added to the <TT>_tags</TT> file:
</P><DIV CLASS="center">
<TT>"<I>modules</I>.docdir/index.html": argot</TT>
</DIV><P>
which marks the index file with the <TT>argot</TT> tag.<BR>

It is thus necessary to handle the aforementioned tag by defining an <TT>ocamlbuild</TT> plugin. This implies to create a <TT>myocamlbuild.ml</TT> file with the contents presented by code sample&#XA0;<A HREF="#ocamlbuild-plugin">3.1</A>.<BR>

The main code of the plugin calls the <TT>define_argot</TT> to replace the default <SPAN STYLE="font-variant:small-caps">html</SPAN> generator with Argot. The <TT>define_argot</TT> function takes four parameters:
</P><UL CLASS="itemize"><LI CLASS="li-itemize">
an optional <TT>search</TT> parameter (defaulting to <TT>true</TT>), indicating whether search information should be generated;
</LI><LI CLASS="li-itemize">an optional <TT>frame</TT> parameter (defaulting to <TT>true</TT>), indicating whether search criteria should be presented in a frame;
</LI><LI CLASS="li-itemize">an optional <TT>fulltext</TT> parameter (defaulting to <TT>true</TT>), indicating whether full-text search information should be generated;
</LI><LI CLASS="li-itemize">a mandatory parameter of type <TT>(string * string) list</TT>, giving the definitions used by the <TT>TOKEN</TT> formatter.
</LI></UL><P>
All these parameters correspond to command-line switches whose meaning are detailed in chapter&#XA0;<A HREF="#ch:formatting">4</A> and&#XA0;<A HREF="#ch:search">6</A>.</P><BLOCKQUOTE CLASS="figure">
<DIV CLASS="caption"><TABLE CELLSPACING=6 CELLPADDING=0><TR><TD VALIGN=top ALIGN=left>Code sample 3.1: <A NAME="ocamlbuild-plugin"></A>Example of <TT>ocamlbuild</TT> plugin.</TD></TR>
</TABLE></DIV>
<PRE CLASS="verbatim">
open Ocamlbuild_plugin
open Ocamlbuild_pack

let define_argot ?(search=true) ?(frame=true) ?(fulltext=true) defs =
  let rec is_native spec = (* heuristics *)
    match spec with
    | S (hd :: _) -&gt; is_native hd
    | A x | P x | Px x | Sh x -&gt; Filename.check_suffix x ".opt"
    | V "OCAMLDOC" -&gt;
        (try ignore (Command.search_in_path "ocamldoc.opt"); true with _ -&gt; false)
    | Quote x -&gt; is_native x
    | _ -&gt; true in
  let gen =
    if is_native !Options.ocamldoc then
      [A"-g"; A"argot.cmxs"]
    else
      [A"-g"; A"argot.cmo"] in
  let switches =
    if search then
      [A"-search"]
      @ (if frame then [A"-search-frame"] else [])
      @ (if fulltext then [A"-full-text"] else [])
    else
      [] in
  let defs =
    List.map
      (fun (k, v) -&gt; [(A"-define"); (A k); (A v)])
      defs in
  let defs = List.flatten defs in
  flag ["argot"] (S (gen @ switches @ defs));
  let myocamldoc tags =
    Ocaml_tools.ocamldoc_l_dir (tags -- "extension:html") in
  rule "ocamldoc: argot"
    ~prod:"%.docdir/index.html"
    ~dep:"%.odocl"
    ~stamp:"%.docdir/html.stamp"
    ~insert:`top
    (Ocaml_tools.document_ocaml_project ~ocamldoc:myocamldoc
       "%.odocl"
       "%.docdir/index.html"
       "%.docdir")

let () =
  dispatch begin function
    | After_rules -&gt;
        define_argot ["a", "b"]
    | _ -&gt; ()
  end
</PRE></BLOCKQUOTE><!--TOC chapter Argot formatting-->
<H1 CLASS="chapter"><!--SEC ANCHOR --><A NAME="htoc13">Chapter&#XA0;4</A>&#XA0;&#XA0;Argot formatting</H1><!--SEC END --><P>
<A NAME="ch:formatting"></A></P><!--TOC section Text formatting-->
<H2 CLASS="section"><!--SEC ANCHOR --><A NAME="htoc14">4.1</A>&#XA0;&#XA0;Text formatting</H2><!--SEC END --><P>
In addition to the already available <TT>{b ...}</TT> (for bold), <TT>{i ...}</TT> (for italic), and <TT>{e ...}</TT> (for emphasized), Argot provides the following text formatting modifiers:
</P><UL CLASS="itemize"><LI CLASS="li-itemize">
<TT>{s ...}</TT> for stroke;
</LI><LI CLASS="li-itemize"><TT>{u ...}</TT> for underline;
</LI><LI CLASS="li-itemize"><TT>{h ...}</TT> for highlight.
</LI></UL><!--TOC section Tables-->
<H2 CLASS="section"><!--SEC ANCHOR --><A NAME="htoc15">4.2</A>&#XA0;&#XA0;Tables</H2><!--SEC END --><P>
In order to define tables, the following elements can be used:
</P><UL CLASS="itemize"><LI CLASS="li-itemize">
<TT>{table ...}</TT> to actually define a table;
</LI><LI CLASS="li-itemize"><TT>{caption ...}</TT> to define its associated caption;
</LI><LI CLASS="li-itemize"><TT>{row ...}</TT> to add a row to the table;
</LI><LI CLASS="li-itemize"><TT>{header ...}</TT> to add an header cell to the row;
</LI><LI CLASS="li-itemize"><TT>{data ...}</TT> to add a data cell to the row;
</LI><LI CLASS="li-itemize"><TT>{span <I>n</I> ...}</TT> (where <I>n</I> should be a positive integer) to add a data cell spanning <I>n</I> columns to the row.
</LI></UL><P>
Code sample&#XA0;<A HREF="#table-example">4.1</A> give an example of a complete table definition.</P><BLOCKQUOTE CLASS="figure">
<DIV CLASS="caption"><TABLE CELLSPACING=6 CELLPADDING=0><TR><TD VALIGN=top ALIGN=left>Code sample 4.1: <A NAME="table-example"></A>Example of a table.</TD></TR>
</TABLE></DIV>
<PRE CLASS="verbatim">
{table {caption the caption}
       {row {header key} {header value}}
       {row {data key1}  {data {i data1}}}
       {row {data key2}  {data {i data2}}}
       {row {span 2 summary}}}
</PRE></BLOCKQUOTE><!--TOC section Token substitution-->
<H2 CLASS="section"><!--SEC ANCHOR --><A NAME="htoc16">4.3</A>&#XA0;&#XA0;Token substitution</H2><!--SEC END --><P>
Token substitution allows one to use the value of either an environment variable or a command-line switch into an <SPAN STYLE="font-variant:small-caps">html</SPAN> page. This may for example be useful to insert the current date, or to specify the path of an element at documentation generation time:
</P><PRE CLASS="verbatim">  {token DATE}
  file {token FILE_PATH}/file.ext
</PRE><P>The value of a token is first searched in <TT>-define <I>id value</I></TT> switches passed to the <TT>ocamldoc</TT> tool, and then searched among the environment variables.<BR>

Instead of passing multiple <TT>-define</TT> switches, it is also possible to load a bunch of definitions from a file through the <TT>-definitions <I>file</I></TT> switch. Each line should have the following form: <TT><I>id</I>=<I>value</I></TT>, where the <TT>#</TT> character introduces comments (ending with the end of the line). Lines that do not conform to the given format are ignored.<BR>

Finally, it is possible to refer to other variables when defining a new one (as long as this does not create a circular definition). As an example, the file represented by code sample&#XA0;<A HREF="#definition-file">4.2</A> could be passed to the <TT>-definitions</TT> switch.</P><BLOCKQUOTE CLASS="figure">
<DIV CLASS="caption"><TABLE CELLSPACING=6 CELLPADDING=0><TR><TD VALIGN=top ALIGN=left>Code sample 4.2: <A NAME="definition-file"></A>Example of definition file.</TD></TR>
</TABLE></DIV>
<PRE CLASS="verbatim">
BASE=/path/to # prefix
NAME=file
FILE=$(BASE)/$(NAME).txt
</PRE></BLOCKQUOTE><!--TOC section Images-->
<H2 CLASS="section"><!--SEC ANCHOR --><A NAME="htoc17">4.4</A>&#XA0;&#XA0;Images</H2><!--SEC END --><P>
It is possible to include images into the generated pages through <TT>{image <I>path</I>}</TT>. The image data will be directly embedded into the page using base64 format, in such a way that no external link remains in the generated <SPAN STYLE="font-variant:small-caps">html</SPAN>. There is thus no need to package the image along with the <SPAN STYLE="font-variant:small-caps">html</SPAN> pages.<BR>

To avoid to use the full path to the image, it is possible to use the aforementioned token substitution inside the <TT>image</TT> formatter:
</P><PRE CLASS="verbatim">  {image {token IMAGE_PATH}/img.png}
</PRE><P>Then, one has to specify the value for <TT>IMAGE_PATH</TT> on the command-line through the <TT>-define</TT> switch seen above:
</P><PRE CLASS="verbatim">  ocamldoc -define IMAGE_PATH /path/to/images ...
</PRE><!--TOC section Folding-->
<H2 CLASS="section"><!--SEC ANCHOR --><A NAME="htoc18">4.5</A>&#XA0;&#XA0;Folding</H2><!--SEC END --><P>
When some explanation, albeit useful, is long and/or may appear as a digression, it is possible to <I>fold</I> it. It means that the texte inside a <CODE>{fold</CODE> <I>digression</I><CODE>}</CODE> will appear as an ellipsis (<I>i.e.&#XA0;</I><TT>...</TT>) and will be <I>unfolded</I> (that is revealed) when the ellipsis will be clicked. At the opposite, clicking on the ellipsis while the <I>foldable</I> text is visible will make it disappear. Any formatting instruction can be used in the digression.

</P><!--TOC chapter Argot tags-->
<H1 CLASS="chapter"><!--SEC ANCHOR --><A NAME="htoc19">Chapter&#XA0;5</A>&#XA0;&#XA0;Argot tags</H1><!--SEC END --><P>Argot also defines a bunch of new tags that can be used to enhance documentation. Some of these tags come with image icons; these have been designed by Mark James, released under the Creative Commons Attribution 2.5 License, and are available at <TT><A HREF="http://www.famfamfam.com/lab/icons/silk/">http://www.famfamfam.com/lab/icons/silk/</A></TT>.<BR>

The additional tags are:
</P><UL CLASS="itemize"><LI CLASS="li-itemize">
<TT>@obvious</TT>, a bare placeholder;
</LI><LI CLASS="li-itemize"><TT>@typevar</TT>, to document type variables in the same way <TT>@param</TT> is used for parameters;
</LI><LI CLASS="li-itemize"><TT>@copyright</TT> and <TT>@license</TT> to be used along with the <TT>@author</TT> parameter;
</LI><LI CLASS="li-itemize"><TT>@alias</TT>, <TT>@synonym</TT>, and <TT>@equivalent</TT>, to define synonyms or equivalences;<BR>
 </LI><LI CLASS="li-itemize"><TT>@todo</TT>, or <TT>@unimplemented</TT>, to mark an implementation-in-progress;
</LI><LI CLASS="li-itemize"><TT>@todoc</TT>, or <TT>@docme</TT>, to mark a documentation-in-progress;
</LI><LI CLASS="li-itemize"><TT>@tofix</TT>, or <TT>@fixme</TT>, to mark a fix-in-progress;<BR>
 </LI><LI CLASS="li-itemize"><TT>@stateful</TT>, to mark that a given function relies on a state;
</LI><LI CLASS="li-itemize"><TT>@threadsafe</TT>, to mark that a given function can be used in a multithread context;
</LI><LI CLASS="li-itemize"><TT>@threadunsafe</TT>, to mark that a given function cannot be used in a multithread context;<BR>
 </LI><LI CLASS="li-itemize"><TT>@attention</TT>, to introduce text by the <IMG SRC="" class="argot_attention" alt="new" title="new"
align="middle"> icon;
</LI><LI CLASS="li-itemize"><TT>@bug</TT>, to introduce text by the <IMG SRC="" class="argot_bug" alt="new" title="new"
align="middle"> icon;
</LI><LI CLASS="li-itemize"><TT>@error</TT>, to introduce text by the <IMG SRC="" class="argot_error" alt="new" title="new"
align="middle"> icon;
</LI><LI CLASS="li-itemize"><TT>@info</TT>, to introduce text by the <IMG SRC="" class="argot_info" alt="new" title="new"
align="middle"> icon;
</LI><LI CLASS="li-itemize"><TT>@new</TT>, to introduce text by the <IMG SRC="" class="argot_new" alt="new" title="new"
align="middle"> icon;
</LI><LI CLASS="li-itemize"><TT>@note</TT>, to introduce text by the <IMG SRC="" class="argot_note" alt="new" title="new"
align="middle"> icon;
</LI><LI CLASS="li-itemize"><TT>@remark</TT>, to introduce text by the <IMG SRC="" class="argot_remark" alt="new" title="new"
align="middle"> icon;
</LI><LI CLASS="li-itemize"><TT>@warning</TT>, to introduce text by the <IMG SRC="" class="argot_warning" alt="new" title="new"
align="middle"> icon.
</LI></UL><!--TOC paragraph -->
<H5 CLASS="paragraph"><!--SEC ANCHOR --></H5><!--SEC END --><P>
The <TT>@license</TT> tag will only print its argument if it does not recognize the license, but will create a link to the actual webpage of the license otherwise. The list of predefined licenses is the following (the recognition being case insensitive):
</P><UL CLASS="itemize"><LI CLASS="li-itemize">
<TT>gpl</TT>, <TT>gpl1</TT>, and <TT>gplv1</TT> will point to <TT><A HREF="http://www.gnu.org/licenses/old-licenses/gpl-1.0.html">http://www.gnu.org/licenses/old-licenses/gpl-1.0.html</A></TT>
</LI><LI CLASS="li-itemize"><TT>gpl2</TT>, and <TT>gplv2</TT> will point to <TT><A HREF="http://www.gnu.org/licenses/old-licenses/gpl-2.0.html">http://www.gnu.org/licenses/old-licenses/gpl-2.0.html</A></TT>
</LI><LI CLASS="li-itemize"><TT>gpl3</TT>, and <TT>gplv3</TT> will point to <TT><A HREF="http://www.gnu.org/licenses/gpl.html">http://www.gnu.org/licenses/gpl.html</A></TT>
</LI><LI CLASS="li-itemize"><TT>lgpl</TT>, and <TT>lgplv2</TT> will point to <TT><A HREF="http://www.gnu.org/licenses/old-licenses/lgpl-2.0.html">http://www.gnu.org/licenses/old-licenses/lgpl-2.0.html</A></TT>
</LI><LI CLASS="li-itemize"><TT>lgpl21</TT>, <TT>lgpl2.1</TT>, <TT>lgpl2_1</TT>, <TT>lgplv21</TT>, <TT>lgplv2.1</TT>, and <TT>lgplv2_1</TT> will point to <TT><A HREF="http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html">http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html</A></TT>
</LI><LI CLASS="li-itemize"><TT>lgpl3</TT>, and <TT>lgplv3</TT> will point to <TT><A HREF="http://www.gnu.org/licenses/lgpl.html">http://www.gnu.org/licenses/lgpl.html</A></TT>
</LI><LI CLASS="li-itemize"><TT>agpl</TT> will point to <TT><A HREF="http://www.gnu.org/licenses/agpl.html">http://www.gnu.org/licenses/agpl.html</A></TT>
</LI><LI CLASS="li-itemize"><TT>bsd</TT> will point to <TT><A HREF="http://www.freebsd.org/copyright/license.html">http://www.freebsd.org/copyright/license.html</A></TT>
</LI><LI CLASS="li-itemize"><TT>mit</TT> will point to <TT><A HREF="http://www.opensource.org/licenses/mit-license.php">http://www.opensource.org/licenses/mit-license.php</A></TT>
</LI><LI CLASS="li-itemize"><TT>apache</TT> will point to <TT><A HREF="http://www.apache.org/licenses/">http://www.apache.org/licenses/</A></TT>
</LI><LI CLASS="li-itemize"><TT>qpl</TT> will point to <TT><A HREF="http://doc.trolltech.com/3.0/license.html">http://doc.trolltech.com/3.0/license.html</A></TT>
</LI><LI CLASS="li-itemize"><TT>cecill</TT>, and <TT>cecill-a</TT> will point to <TT><A HREF="http://www.cecill.info/licences/Licence_CeCILL_V2-en.html">http://www.cecill.info/licences/Licence_CeCILL_V2-en.html</A></TT>
</LI><LI CLASS="li-itemize"><TT>cecill-b</TT> will point to <TT><A HREF="http://www.cecill.info/licences/Licence_CeCILL-B_V1-en.html">http://www.cecill.info/licences/Licence_CeCILL-B_V1-en.html</A></TT>
</LI><LI CLASS="li-itemize"><TT>cecill-c</TT> will point to <TT><A HREF="http://www.cecill.info/licences/Licence_CeCILL-C_V1-en.html">http://www.cecill.info/licences/Licence_CeCILL-C_V1-en.html</A></TT>
</LI></UL><!--TOC chapter Search-->
<H1 CLASS="chapter"><!--SEC ANCHOR --><A NAME="htoc20">Chapter&#XA0;6</A>&#XA0;&#XA0;Search</H1><!--SEC END --><P>
<A NAME="ch:search"></A>
Argot is able to embed search facilities<SUP><A NAME="text3" HREF="#note3">1</A></SUP> into the generated pages when passed the <TT>-search</TT> command-line switch. The default behaviour is to open a search window by clicking on the magnifying glass (<I>i.e.&#XA0;</I> <IMG SRC="" class="argot_search" alt="new" title="new"
align="middle">) that appears on the <TT>index.html</TT> page as well as on each module page. However, it is possible to have the search pane in a frame by passing the <TT>-search-frame</TT> command-line switch; <TT>argot_index.html</TT> is then the main file.<BR>

The search panel is composed of two parts: the upper part allowing to select search criteria, and the lower part displaying results. Clicking on a search result will make the main window point to the clicked element.<BR>

Five search modes are provided:
</P><UL CLASS="itemize"><LI CLASS="li-itemize">
search by exact name&#XA0;;
</LI><LI CLASS="li-itemize">search by regular expression over names&#XA0;;
</LI><LI CLASS="li-itemize">search by type;
</LI><LI CLASS="li-itemize">search by type using manifests;
</LI><LI CLASS="li-itemize">full-text search.
</LI></UL><!--TOC paragraph Search by name-->
<H5 CLASS="paragraph"><!--SEC ANCHOR -->Search by name</H5><!--SEC END --><P> can be made on simple names as well as on fully qualified names. Moreover, all names can be used&#XA0;: values, types, modules, constructors, <I>etc</I>.</P><!--TOC paragraph Search by regular expression-->
<H5 CLASS="paragraph"><!--SEC ANCHOR -->Search by regular expression</H5><!--SEC END --><P> is akin to search by name except that all names matching the passed regular expression are returned. The regular expression should be written using the JavaScript syntax<SUP><A NAME="text4" HREF="#note4">2</A></SUP>. As an example, it is possible to retrieve all the elements starting with <TT>fold</TT> by using the following regular expression: <TT>fold.*</TT>.</P><!--TOC paragraph Search by type-->
<H5 CLASS="paragraph"><!--SEC ANCHOR -->Search by type</H5><!--SEC END --><P> allows to search for a value by giving its type<SUP><A NAME="text5" HREF="#note5">3</A></SUP>. It is based on the ideas put forward by Roberto Di Cosmo (in particular the <TT>ocamlsearch</TT> tool for CamlLight). This means that the search does not retrieve values with <I>exactly</I> the same type, but with values whose types are <I>isomorphic</I><SUP><A NAME="text6" HREF="#note6">4</A></SUP>. Practically this means that for example:
</P><UL CLASS="itemize"><LI CLASS="li-itemize">
<TT>int -&gt; float -&gt; int</TT>, <TT>float -&gt; int -&gt; int</TT>, and <TT>float * int -&gt; int</TT> are isomorphic (because the differences are only in the way and order parameters are passed);
</LI><LI CLASS="li-itemize"><TT>string</TT> and <TT>unit -&gt; string</TT> are isomorphic (because one always has a <TT>unit</TT> value at hand);
</LI><LI CLASS="li-itemize"><TT>&#X2019;from list -&gt; (&#X2019;from -&gt; &#X2019;to) -&gt; &#X2019;to list</TT> and <TT>(&#X2019;a -&gt; &#X2019;b) -&gt; &#X2019;a list -&gt; &#X2019;b list</TT> are isomorphic (because type variables can be renamed, and parameters reordered).
</LI></UL><P>
<I>note 1:</I> labels are just ignored during search<BR>
<I>note 2:</I> a signature containing optional arguments is considered as the set of all signatures that can be generated by including/discarding the optional arugments</P><!--TOC paragraph Search by type using manifests-->
<H5 CLASS="paragraph"><!--SEC ANCHOR -->Search by type using manifests</H5><!--SEC END --><P> is similar to bare search by type, except that types are replaced by their manifests if provided. More, in this context, record types are mapped to tuples by droping the field names. Practically, this means that searching for type <TT>float * float -&gt; float</TT> will return (among others) <TT>Complex.norm</TT> whose type is <TT>Complex.t -&gt; float</TT>. Indeed, as <TT>Complex.t</TT> has manifest <TT>{ re : float; im : float; }</TT>, it is clearly isomorphic to <TT>float * float</TT>.</P><!--TOC paragraph Full-text search-->
<H5 CLASS="paragraph"><!--SEC ANCHOR -->Full-text search</H5><!--SEC END --><P> is the ability to search words appearing in the documentation. Words should be separated by spaces, and the result set will present the elements whose documentation contains all the words.

</P><!--BEGIN NOTES chapter-->
<HR CLASS="ffootnoterule"><DL CLASS="thefootnotes"><DT CLASS="dt-thefootnotes">
<A NAME="note3" HREF="#text3">1</A></DT><DD CLASS="dd-thefootnotes">Search features need JavaScript to be available and enabled in the browser used to consult the documentation.
</DD><DT CLASS="dt-thefootnotes"><A NAME="note4" HREF="#text4">2</A></DT><DD CLASS="dd-thefootnotes">See <TT><A HREF="http://www.w3schools.com/jsref/jsref_obj_regexp.asp">http://www.w3schools.com/jsref/jsref_obj_regexp.asp</A></TT> for reference.
</DD><DT CLASS="dt-thefootnotes"><A NAME="note5" HREF="#text5">3</A></DT><DD CLASS="dd-thefootnotes">As of version 1.1, type-based search is still experimental and does not support the following features: objects, polymorphic variants, and modules.
</DD><DT CLASS="dt-thefootnotes"><A NAME="note6" HREF="#text6">4</A></DT><DD CLASS="dd-thefootnotes">See <TT><A HREF="http://www.dicosmo.org/ResearchThemes/ISOS/ISOShomepage.html">http://www.dicosmo.org/ResearchThemes/ISOS/ISOShomepage.html</A></TT> for more information.
</DD></DL>
<!--END NOTES-->
<!--CUT END -->
<!--HTMLFOOT-->
<!--ENDHTML-->
<!--FOOTER-->
<HR SIZE=2><BLOCKQUOTE CLASS="quote"><EM>This document was translated from L<sup>A</sup>T<sub>E</sub>X by
<A HREF="http://hevea.inria.fr/index.html">H<FONT SIZE=2><sup>E</sup></FONT>V<FONT SIZE=2><sup>E</sup></FONT>A</A>.</EM></BLOCKQUOTE></BODY>
</HTML>