]> matita.cs.unibo.it Git - helm.git/commitdiff
aded hmysql/
authorEnrico Tassi <enrico.tassi@inria.fr>
Wed, 5 Oct 2005 08:41:07 +0000 (08:41 +0000)
committerEnrico Tassi <enrico.tassi@inria.fr>
Wed, 5 Oct 2005 08:41:07 +0000 (08:41 +0000)
helm/ocaml/METAS/meta.helm-extlib.src
helm/ocaml/METAS/meta.helm-hmysql.src [new file with mode: 0644]
helm/ocaml/METAS/meta.helm-metadata.src
helm/ocaml/hmysql/.depend [new file with mode: 0644]
helm/ocaml/hmysql/Makefile [new file with mode: 0644]
helm/ocaml/hmysql/hMysql.ml [new file with mode: 0644]
helm/ocaml/hmysql/hMysql.mli [new file with mode: 0644]

index 66a04fe828639219fa3f39c4819b6628beb4ee67..0bc6287deb3f4568d76277d3ba0d5d0cfedc286f 100644 (file)
@@ -1,4 +1,4 @@
-requires="unix mysql"
+requires="unix"
 version="0.0.1"
 archive(byte)="extlib.cma"
 archive(native)="extlib.cmxa"
diff --git a/helm/ocaml/METAS/meta.helm-hmysql.src b/helm/ocaml/METAS/meta.helm-hmysql.src
new file mode 100644 (file)
index 0000000..144141e
--- /dev/null
@@ -0,0 +1,4 @@
+requires="helm-registry mysql helm-extlib"
+version="0.0.1"
+archive(byte)="hmysql.cma"
+archive(native)="hmysql.cmxa"
index 9929f1552779dd883606d01932930a2ca0ea89c7..a5b138301dbe67a5f35b9acf477cc1ab7cb7d4e1 100644 (file)
@@ -1,4 +1,4 @@
-requires="mysql helm-cic_proof_checking"
+requires="helm-hmysql helm-cic_proof_checking"
 version="0.0.1"
 archive(byte)="metadata.cma"
 archive(native)="metadata.cmxa"
diff --git a/helm/ocaml/hmysql/.depend b/helm/ocaml/hmysql/.depend
new file mode 100644 (file)
index 0000000..e67a066
--- /dev/null
@@ -0,0 +1,2 @@
+hMysql.cmo: hMysql.cmi 
+hMysql.cmx: hMysql.cmi 
diff --git a/helm/ocaml/hmysql/Makefile b/helm/ocaml/hmysql/Makefile
new file mode 100644 (file)
index 0000000..f8ae017
--- /dev/null
@@ -0,0 +1,12 @@
+PACKAGE = hmysql
+REQUIRES = mysql helm-registry helm-extlib 
+PREDICATES =
+
+INTERFACE_FILES = \
+        hMysql.mli 
+IMPLEMENTATION_FILES = \
+       $(INTERFACE_FILES:%.mli=%.ml)
+EXTRA_OBJECTS_TO_INSTALL =
+EXTRA_OBJECTS_TO_CLEAN =
+
+include ../Makefile.common
diff --git a/helm/ocaml/hmysql/hMysql.ml b/helm/ocaml/hmysql/hMysql.ml
new file mode 100644 (file)
index 0000000..c7bfb32
--- /dev/null
@@ -0,0 +1,78 @@
+(* Copyright (C) 2005, HELM Team.
+ * 
+ * This file is part of HELM, an Hypertextual, Electronic
+ * Library of Mathematics, developed at the Computer Science
+ * Department, University of Bologna, Italy.
+ * 
+ * HELM is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU General Public License
+ * as published by the Free Software Foundation; either version 2
+ * of the License, or (at your option) any later version.
+ * 
+ * HELM is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with HELM; if not, write to the Free Software
+ * Foundation, Inc., 59 Temple Place - Suite 330, Boston,
+ * MA  02111-1307, USA.
+ * 
+ * For details, see the HELM World-Wide-Web page,
+ * http://cs.unibo.it/helm/.
+ *)
+
+type dbd = Mysql.dbd option 
+type result = Mysql.result option
+type error_code = Mysql.error_code
+
+let profiler = HExtlib.profile "mysql"
+
+let use_real_db () = 
+  not (Helm_registry.get_opt_default Helm_registry.bool
+    ~default:false "db.nodb")
+
+let quick_connect ?host ?database ?port ?password ?user () =
+ profiler.HExtlib.profile 
+   (fun () -> 
+     if use_real_db () then  
+       (Some (Mysql.quick_connect ?host ?database ?port ?password ?user ())) 
+     else
+       None)
+   ()
+
+let disconnect = function 
+  | None -> ()
+  | Some dbd -> profiler.HExtlib.profile Mysql.disconnect dbd
+
+let escape s =
+ profiler.HExtlib.profile Mysql.escape s
+
+let exec dbd s =
+  match dbd with
+  | None -> None 
+  | Some dbd -> Some (profiler.HExtlib.profile (Mysql.exec dbd) s)
+
+let map res ~f =
+  match res with 
+  | None ->  []
+  | Some res -> 
+      let map f = Mysql.map res ~f in
+      profiler.HExtlib.profile map f
+
+let iter res ~f =
+  match res with 
+  | None ->  ()
+  | Some res -> 
+      let iter f = Mysql.iter res ~f in
+      profiler.HExtlib.profile iter f
+
+let errno = function 
+  | None -> Mysql.Connection_error
+  | Some dbd -> profiler.HExtlib.profile Mysql.errno dbd
+
+let status = function 
+  | None -> Mysql.StatusError Mysql.Connection_error 
+  | Some dbd -> profiler.HExtlib.profile Mysql.status dbd
+
diff --git a/helm/ocaml/hmysql/hMysql.mli b/helm/ocaml/hmysql/hMysql.mli
new file mode 100644 (file)
index 0000000..a5b9059
--- /dev/null
@@ -0,0 +1,56 @@
+(* Copyright (C) 2005, HELM Team.
+ * 
+ * This file is part of HELM, an Hypertextual, Electronic
+ * Library of Mathematics, developed at the Computer Science
+ * Department, University of Bologna, Italy.
+ * 
+ * HELM is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU General Public License
+ * as published by the Free Software Foundation; either version 2
+ * of the License, or (at your option) any later version.
+ * 
+ * HELM is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with HELM; if not, write to the Free Software
+ * Foundation, Inc., 59 Temple Place - Suite 330, Boston,
+ * MA  02111-1307, USA.
+ * 
+ * For details, see the HELM World-Wide-Web page,
+ * http://cs.unibo.it/helm/.
+ *)
+
+(**
+ * {2 Proxy module around MySQL conection}
+ *
+ * The behaviour of this module is influenced by the Helm_registry boolean value
+ * of the "db.nodb" key. When set to "false" the module works as expected. When
+ * set to "true" all functions perform dummy action: connect and disconnect do
+ * nothing; exec, iter, and map work like the empty set of results has been
+ * returned; errno and status return Mysql.Connection_error
+ *)
+
+type dbd
+type result
+
+(* the exceptions raised are from the Mysql module *)
+
+val quick_connect :
+  ?host:string ->
+  ?database:string ->
+  ?port:int -> ?password:string -> ?user:string -> unit -> dbd
+
+val disconnect : dbd -> unit
+
+val exec: dbd -> string -> result
+val map : result -> f:(string option array -> 'a) -> 'a list
+val iter : result -> f:(string option array -> unit) -> unit
+
+val errno : dbd -> Mysql.error_code
+val status : dbd -> Mysql.status
+
+val escape: string -> string
+