X-Git-Url: http://matita.cs.unibo.it/gitweb/?a=blobdiff_plain;f=components%2Fmetadata%2FmetadataDeps.ml;h=d34bd1c83eb9241bea1549a2f8527d583c27abd1;hb=83c41ad650a2736acf27ccae820923157283c6db;hp=3309843509c65c22af46a3e018c3615f5f96a57c;hpb=68d46ac40a575f3fce5958fb2776b38739703951;p=helm.git diff --git a/components/metadata/metadataDeps.ml b/components/metadata/metadataDeps.ml index 330984350..d34bd1c83 100644 --- a/components/metadata/metadataDeps.ml +++ b/components/metadata/metadataDeps.ml @@ -64,14 +64,17 @@ let direct_deps ~dbd uri = prerr_endline "invalid (direct) refObj metadata row"; assert false in - let do_query tbl = - let res = HMysql.exec dbd (SqlStatements.direct_deps tbl uri) in + let do_query (dbtype, tbl) = + let res = + HSql.exec dbtype dbd (SqlStatements.direct_deps tbl uri dbtype dbd) + in let deps = - HMysql.map res (fun row -> unbox_row (obj_metadata_of_row row)) in + HSql.map res (fun row -> unbox_row (obj_metadata_of_row row)) in deps in - do_query (MetadataTypes.obj_tbl ()) - @ do_query MetadataTypes.library_obj_tbl + do_query (HSql.User, MetadataTypes.obj_tbl ()) + @ do_query (HSql.Library, MetadataTypes.library_obj_tbl) + @ do_query (HSql.Legacy, MetadataTypes.library_obj_tbl) let inverse_deps ~dbd uri = let inv_obj_metadata_of_row = @@ -82,14 +85,17 @@ let inverse_deps ~dbd uri = prerr_endline "invalid (inverse) refObj metadata row"; assert false in - let do_query tbl = - let res = HMysql.exec dbd (SqlStatements.inverse_deps tbl uri) in + let do_query (dbtype, tbl) = + let res = + HSql.exec dbtype dbd (SqlStatements.inverse_deps tbl uri dbtype dbd) + in let deps = - HMysql.map res (fun row -> unbox_row (inv_obj_metadata_of_row row)) in + HSql.map res (fun row -> unbox_row (inv_obj_metadata_of_row row)) in deps in - do_query (MetadataTypes.obj_tbl ()) - @ do_query MetadataTypes.library_obj_tbl + do_query (HSql.User, MetadataTypes.obj_tbl ()) + @ do_query (HSql.Library, MetadataTypes.library_obj_tbl) + @ do_query (HSql.Legacy, MetadataTypes.library_obj_tbl) let topological_sort ~dbd uris = let module OrderedUri = @@ -103,21 +109,28 @@ let topological_sort ~dbd uris = let sorted_uris_of_baseuri ~dbd baseuri = let sql_pat = - Pcre.replace ~rex:(Pcre.regexp "_") ~templ:"\\_" baseuri ^ "%" + Pcre.replace ~pat:"([^\\\\])_" ~templ:"$1\\_" baseuri ^ "%" in - let query = + let query dbtype tbl = Printf.sprintf - ("SELECT source FROM %s WHERE source LIKE \"%s\" UNION "^^ - "SELECT source FROM %s WHERE source LIKE \"%s\"") - (MetadataTypes.name_tbl ()) sql_pat - MetadataTypes.library_name_tbl sql_pat + ("SELECT source FROM %s WHERE source LIKE \"%s\" " + ^^ HSql.escape_string_for_like dbtype dbd) + tbl sql_pat in - let result = HMysql.exec dbd query in let map cols = match cols.(0) with | Some s -> UriManager.uri_of_string s | _ -> assert false in - let uris = HMysql.map result map in + let uris = + List.fold_left + (fun acc (dbtype, table) -> + let result = HSql.exec dbtype dbd (query dbtype table) in + HSql.map result map @ acc) + [] + [HSql.User, MetadataTypes.name_tbl (); + HSql.Library, MetadataTypes.library_name_tbl; + HSql.Legacy, MetadataTypes.library_name_tbl] + in let sorted_uris = topological_sort ~dbd uris in let filter_map uri = let s =