From: Richard Jones <rich@annexia.org>
To: caml-list@inria.fr
Subject: camlp4 question: Mixing a printer and Ast.fold
Date: Fri, 21 Mar 2008 15:06:40 +0000 [thread overview]
Message-ID: <20080321150639.GA29482@annexia.org> (raw)
I'm trying to translate Sylvain Le Gall's gettext module to use camlp4
from ocaml 3.10.0. The module is a printer which folds over the AST
looking for certain types of function call by name. A simplified
version is shown below.
This program is supposed to look for all instances of a function named
f applied to a string.
I cannot for the life of me work out how to get this to compile. I've
tried about a dozen different variations of the module names, 'open',
'include' etc. and got a dozen different errors.
----------------------------------------------------------------------
module Id = struct
let name = "pr_gettext"
let version = "$Id$"
end
module Make (Syntax : Camlp4.Sig.Syntax)
: Camlp4.Sig.Printer(Syntax.Ast).S =
struct
module Loc = Syntax.Loc
module Ast = Syntax.Ast
class visitor = object
inherit Ast.fold as super
val t = []
method t = t
method expr = function
| <:expr@loc< f $str:singular$ >> ->
let t = str :: t in
{< t = t >}
| e -> super#expr e
end
let print_interf ?input_file ?output_file _ = ()
let print_implem ?input_file ?output_file ast =
let visitor = (new visitor)#str_item in
let t = (visitor ast)#t in
List.iter prerr_endline t
end
(* Register the new printer. *)
module M = Camlp4.Register.Printer(Id)(Make)
----------------------------------------------------------------------
ocamlc -I +camlp4 -I /usr/lib64/ocaml/camlp4/Camlp4Parsers -pp camlp4of.opt camlp4lib.cma test.ml -o test.cmo
File "test.ml", line 19, characters 19-19:
Unbound constructor Ast.ExApp
Please let me know how to compile this before I go mad...
Rich.
--
Richard Jones
Red Hat
next reply other threads:[~2008-03-21 15:06 UTC|newest]
Thread overview: 12+ messages / expand[flat|nested] mbox.gz Atom feed top
2008-03-21 15:06 Richard Jones [this message]
2008-03-21 15:36 ` [Caml-list] " Jeremy Yallop
2008-03-21 15:51 ` Richard Jones
2008-03-21 15:46 ` Nicolas Pouillard
2008-03-21 15:58 ` Richard Jones
2008-03-26 9:29 ` Sylvain Le Gall
2008-03-21 16:44 ` [Caml-list] " Richard Jones
2008-03-21 16:50 ` Nicolas Pouillard
2008-03-21 16:56 ` Richard Jones
2008-03-21 17:03 ` Nicolas Pouillard
2008-03-21 17:21 ` Richard Jones
2008-03-21 20:19 ` Richard Jones
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=20080321150639.GA29482@annexia.org \
--to=rich@annexia.org \
--cc=caml-list@inria.fr \
/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