-module MQICallbacks =
- struct
- let log s = print_string s; flush stdout
- end
+module U = MQueryUtil
+module X = MQueryMisc
+module I = MQueryInterpreter
+module C = MQIConn
let _ =
- let module U = MQueryUtil in
- let module X = MQueryMisc in
- let module I = MQueryInterpreter.Make(MQICallbacks) in
let t = X.start_time () in
let ich = Lexing.from_channel stdin in
- let flags = if Array.length Sys.argv >= 2 then Sys.argv.(1) else "" in
+ let flags = if Array.length Sys.argv >= 2 then Sys.argv.(1) else "" in
+ let log s = print_string s; flush stdout in
+ let handle = C.init (C.flags_of_string flags) log in
+ if not (C.connected handle) then begin
+ print_endline "mqitop: no connection"; flush stdout
+ end;
let rec aux () =
let t = X.start_time () in
- let r = I.execute flags (U.query_of_text ich) in
+ let r = I.execute handle (U.query_of_text ich) in
U.text_of_result print_string r "\n";
Printf.printf "mqitop: query: %s,%i\n" (X.stop_time t) (List.length r);
flush stdout; aux()
in
- if not (I.init flags) then begin
- print_endline "mqitop: no connection"; flush stdout
- end;
begin try aux() with End_of_file -> () end;
- I.close flags;
+ C.close handle;
Printf.printf "mqitop: done: %s\n" (X.stop_time t)