|
Packit |
bd2e5d |
(***********************************************************************)
|
|
Packit |
bd2e5d |
(* *)
|
|
Packit |
bd2e5d |
(* MLTk, Tcl/Tk interface of OCaml *)
|
|
Packit |
bd2e5d |
(* *)
|
|
Packit |
bd2e5d |
(* Francois Rouaix, Francois Pessaux, Jun Furuse and Pierre Weis *)
|
|
Packit |
bd2e5d |
(* projet Cristal, INRIA Rocquencourt *)
|
|
Packit |
bd2e5d |
(* Jacques Garrigue, Kyoto University RIMS *)
|
|
Packit |
bd2e5d |
(* *)
|
|
Packit |
bd2e5d |
(* Copyright 2002 Institut National de Recherche en Informatique et *)
|
|
Packit |
bd2e5d |
(* en Automatique and Kyoto University. All rights reserved. *)
|
|
Packit |
bd2e5d |
(* This file is distributed under the terms of the GNU Library *)
|
|
Packit |
bd2e5d |
(* General Public License, with the special exception on linking *)
|
|
Packit |
bd2e5d |
(* described in file LICENSE found in the OCaml source tree. *)
|
|
Packit |
bd2e5d |
(* *)
|
|
Packit |
bd2e5d |
(***********************************************************************)
|
|
Packit |
bd2e5d |
(* Some notion of RPC *)
|
|
Packit |
bd2e5d |
open Camltk
|
|
Packit |
bd2e5d |
open Protocol
|
|
Packit |
bd2e5d |
|
|
Packit |
bd2e5d |
(* A RPC is just a callback with a particular name, plus a Tcl procedure *)
|
|
Packit |
bd2e5d |
let register name f =
|
|
Packit |
bd2e5d |
let id = new_function_id() in
|
|
Packit |
bd2e5d |
Hashtbl.add callback_naming_table id f;
|
|
Packit |
bd2e5d |
(* For rpc_info *)
|
|
Packit |
bd2e5d |
Textvariable.set (Textvariable.coerce ("camltkrpc("^name^")"))
|
|
Packit |
bd2e5d |
(string_of_cbid id);
|
|
Packit |
bd2e5d |
tkCommand [| TkToken "proc"; TkToken name; TkToken "args";
|
|
Packit |
bd2e5d |
TkToken ("camlcb "^(string_of_cbid id)^" $args") |]
|
|
Packit |
bd2e5d |
|
|
Packit |
bd2e5d |
(* RPC *)
|
|
Packit |
bd2e5d |
let invoke interp f args =
|
|
Packit |
bd2e5d |
tkEval [|
|
|
Packit |
bd2e5d |
TkToken "send";
|
|
Packit |
bd2e5d |
TkToken interp;
|
|
Packit |
bd2e5d |
TkToken f;
|
|
Packit |
bd2e5d |
TkTokenList (List.map (fun s -> TkToken s) args)
|
|
Packit |
bd2e5d |
|]
|
|
Packit |
bd2e5d |
|
|
Packit |
bd2e5d |
let async_invoke interp f args =
|
|
Packit |
bd2e5d |
tkCommand [|
|
|
Packit |
bd2e5d |
TkToken "send";
|
|
Packit |
bd2e5d |
TkToken "-async";
|
|
Packit |
bd2e5d |
TkToken interp;
|
|
Packit |
bd2e5d |
TkToken f;
|
|
Packit |
bd2e5d |
TkTokenList (List.map (fun s -> TkToken s) args)
|
|
Packit |
bd2e5d |
|]
|
|
Packit |
bd2e5d |
|
|
Packit |
bd2e5d |
let rpc_info interp =
|
|
Packit |
bd2e5d |
tkEval [|
|
|
Packit |
bd2e5d |
TkToken "send";
|
|
Packit |
bd2e5d |
TkToken interp;
|
|
Packit |
bd2e5d |
TkToken "array";
|
|
Packit |
bd2e5d |
TkToken "names";
|
|
Packit |
bd2e5d |
TkToken "camltkrpc"
|
|
Packit |
bd2e5d |
|]
|