caml-list - the Caml user's mailing list
 help / color / mirror / Atom feed
* camlp4 question
@ 2005-09-08  8:02 Christophe Raffalli
  2005-09-08  8:16 ` Christophe Raffalli
  2005-09-08 17:41 ` [Caml-list] " Martin Jambon
  0 siblings, 2 replies; 9+ messages in thread
From: Christophe Raffalli @ 2005-09-08  8:02 UTC (permalink / raw)
  To: caml-list


I am writing a tool to facilitate the use of callback of camlfunction 
from C. I have a first prototype running for lablGlut, but I want to 
make it nicer using camlp4 (this extension should produce automatically 
the C wrapper for each callback, the user will only have to compile the 
produced C file).

The pb is that I need to retrieve information given in one module from 
another. The minimum I need to do is to search for the path given to 
ocamlc (the -I options) from camlp4 code, but I would prefer a better 
way, and I do not know how to retrive this PATH anyway.

Here is an example to illustrate what I need (the type 'a callback is a 
type to a C wrapper for a function of type 'a) :

-- file glut.ml, part of the lablGlut library --

...

let visibility_state_of_int = function
     0 ->  NOT_VISIBLE
   | 1 -> VISIBLE
   | _ -> raise (BadEnum "visibility_state")

REGISTER_CONVERSION visibility_state_of_int

external visibilityFunc :
   cb:(state:visibility_state_t->unit) callback->unit
    = "ml_glutVisibilityFunc"

...

-- file test.ml an example using lablGlut --

open Glut

...

let state_changed ~state =
   match value with
     NOT_VISIBLE -> printf "window not visible."; print_newline()
   | VISIBLE -> printf "window not visible."; print_newline()

MAKE_WRAPPER state_changed state_changed_cb
(* here I need to search for the convertion for the type 
visibility_state_of_int which was defined in glut.ml to make the
C wrapper state_changed_cb : (visibility_state_of_int -> unit) callback *)

let _ = Glut.visibilityFunc state_changed_cb

...

Can someone help ?


^ permalink raw reply	[flat|nested] 9+ messages in thread
* camlp4 question
@ 2005-11-30  9:29 Christophe Raffalli
  2005-12-01  9:13 ` [Caml-list] " Hendrik Tews
  0 siblings, 1 reply; 9+ messages in thread
From: Christophe Raffalli @ 2005-11-30  9:29 UTC (permalink / raw)
  To: caml-list

[-- Attachment #1: Type: text/plain, Size: 383 bytes --]


I would like to produce an abbreviated command for

camlp4 mylexer.cmo mypa_o.cmo pa_extend.cmo q_MLast.cmo pr_dump.cmo\
  pa_bindlib.cmo

I tried to mimic the compilation of camlp4o:

ocamlc -I +camlp4 odyl.cma camlp4.cma mylexer.cmo mypa_o.cmo\
 pa_bindlib.cmo pr_dump.cmo odyl.cmo -o camlp4bo

But when I try to use ocamlp4bo, it produces no output ...

What am I doing wrong ?


[-- Attachment #2: OpenPGP digital signature --]
[-- Type: application/pgp-signature, Size: 894 bytes --]

^ permalink raw reply	[flat|nested] 9+ messages in thread
* Camlp4 question
@ 2005-10-28 19:44 Matt Gushee
  2005-11-01 14:04 ` [Caml-list] " Hendrik Tews
  0 siblings, 1 reply; 9+ messages in thread
From: Matt Gushee @ 2005-10-28 19:44 UTC (permalink / raw)
  To: caml-list

I had occasion today to look through the pa_r.ml, and noticed the
following (line 329 in OCaml 3.08.4):

  | "object"; cspo = OPT class_self_patt; cf = class_structure; "end" ->
      (* <:expr< object $opt:cspo$ $list:cf$ end >> *)
      MLast.ExObj loc cspo cf ]

So a quotation expander was created for objects as ordinary expressions,
but evidently there was something wrong with it. Anyone know what the
problem was?

--
Matt Gushee
Englewood, CO, USA


^ permalink raw reply	[flat|nested] 9+ messages in thread
* [Caml-list] camlp4 question...
@ 2004-10-05  3:45 Pietro Abate
  2004-10-05  5:38 ` Dmitry Lomov
  0 siblings, 1 reply; 9+ messages in thread
From: Pietro Abate @ 2004-10-05  3:45 UTC (permalink / raw)
  To: ocaml ml

Hi all,

I'd like to write a small extension to transform 

let f <a;b;c> = ...

in 

let f new_id =
	match new_id with
	|[a;b;c] -> ...
	|_ -> failwith "wrong arguments"

I've tried with something like:
        expr: LEVEL "simple"
        [[
            "let"; OPT "rec"; "<"; l = LIST1 LIDENT; ">"; $list:pel$ "in" e = expr ->
                <:expr< let .... = function [] -> failwith "ffff" | $list:l$ -> $e$ >>
        ]];

but I'm stuck... In particular, how can I parse $list:pel$ ?
pel = LIST patt ?

thanks,
p

-- 
++ "All great truths begin as blasphemies." -George Bernard Shaw
++ Please avoid sending me Word or PowerPoint attachments.
   See http://www.fsf.org/philosophy/no-word-attachments.html

-------------------
To unsubscribe, mail caml-list-request@inria.fr Archives: http://caml.inria.fr
Bug reports: http://caml.inria.fr/bin/caml-bugs FAQ: http://caml.inria.fr/FAQ/
Beginner's list: http://groups.yahoo.com/group/ocaml_beginners


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

end of thread, other threads:[~2005-12-01  9:13 UTC | newest]

Thread overview: 9+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2005-09-08  8:02 camlp4 question Christophe Raffalli
2005-09-08  8:16 ` Christophe Raffalli
2005-09-08 17:36   ` [Caml-list] " Martin Jambon
2005-09-08 17:44     ` Christophe Raffalli
2005-09-08 17:41 ` [Caml-list] " Martin Jambon
  -- strict thread matches above, loose matches on Subject: below --
2005-11-30  9:29 Christophe Raffalli
2005-12-01  9:13 ` [Caml-list] " Hendrik Tews
2005-10-28 19:44 Camlp4 question Matt Gushee
2005-11-01 14:04 ` [Caml-list] " Hendrik Tews
2004-10-05  3:45 [Caml-list] camlp4 question Pietro Abate
2004-10-05  5:38 ` Dmitry Lomov

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).