]> matita.cs.unibo.it Git - helm.git/blob - helm/interface/cicParser.ml
- the mathql interpreter is not helm-dependent any more
[helm.git] / helm / interface / cicParser.ml
1 (* Copyright (C) 2000, HELM Team.
2  * 
3  * This file is part of HELM, an Hypertextual, Electronic
4  * Library of Mathematics, developed at the Computer Science
5  * Department, University of Bologna, Italy.
6  * 
7  * HELM is free software; you can redistribute it and/or
8  * modify it under the terms of the GNU General Public License
9  * as published by the Free Software Foundation; either version 2
10  * of the License, or (at your option) any later version.
11  * 
12  * HELM is distributed in the hope that it will be useful,
13  * but WITHOUT ANY WARRANTY; without even the implied warranty of
14  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15  * GNU General Public License for more details.
16  *
17  * You should have received a copy of the GNU General Public License
18  * along with HELM; if not, write to the Free Software
19  * Foundation, Inc., 59 Temple Place - Suite 330, Boston,
20  * MA  02111-1307, USA.
21  * 
22  * For details, see the HELM World-Wide-Web page,
23  * http://cs.unibo.it/helm/.
24  *)
25
26 (******************************************************************************)
27 (*                                                                            *)
28 (*                               PROJECT HELM                                 *)
29 (*                                                                            *)
30 (*                Claudio Sacerdoti Coen <sacerdot@cs.unibo.it>               *)
31 (*                                 24/01/2000                                 *)
32 (*                                                                            *)
33 (* This is the main (top level) module of a parser for cic objects from xml   *)
34 (* files to the internal representation. It uses the modules cicParser2       *)
35 (* (objects level) and cicParser3 (terms level)                               *)
36 (*                                                                            *)
37 (******************************************************************************)
38
39 exception Warnings;;
40
41 class warner =
42   object 
43     method warn w =
44       print_endline ("WARNING: " ^ w) ;
45       (raise Warnings : unit)
46   end
47 ;;
48
49 exception EmptyUri;;
50
51 (* given an uri u it returns the list of tokens of the base uri of u *)
52 (* e.g.: token_of_uri "cic:/a/b/c/d.xml" returns ["a" ; "b" ; "c"]   *)
53 let tokens_of_uri uri =
54  let uri' = UriManager.string_of_uri uri in
55  let rec chop_list =
56   function
57      [] -> raise EmptyUri
58    | he::[fn] -> [he]
59    | he::tl -> he::(chop_list tl)
60  in
61   let trimmed_uri = Str.replace_first (Str.regexp "cic:") "" uri' in
62    let list_of_tokens = Str.split (Str.regexp "/") trimmed_uri in
63     chop_list list_of_tokens
64 ;;
65
66 (* given the filename of an xml file of a cic object it returns its internal *)
67 (* representation. process_annotations is true if the annotations do really  *)
68 (* matter                                                                    *)
69 let term_of_xml filename uri process_annotations =
70  let module Y = Pxp_yacc in
71   try 
72     let d =
73       (* sets the current base uri to resolve relative URIs *)
74       CicParser3.current_sp := tokens_of_uri uri ;
75       CicParser3.current_uri := uri ;
76       CicParser3.process_annotations := process_annotations ;
77       CicParser3.ids_to_targets :=
78        if process_annotations then Some (Hashtbl.create 500) else None ;
79       let config = {Y.default_config with Y.warner = new warner} in
80       Y.parse_document_entity config
81 (*PXP       (Y.ExtID (Pxp_types.System filename,
82          new Pxp_reader.resolve_as_file ~url_of_id ()))
83 *)     (PxpUriResolver.from_file filename)
84        CicParser3.domspec
85     in
86      let ids_to_targets = !CicParser3.ids_to_targets in
87       let res = (CicParser2.get_term d#root, ids_to_targets) in
88        CicParser3.ids_to_targets := None ; (* let's help the GC *)
89        res
90   with
91    e ->
92      print_endline ("Filename: " ^ filename ^ "\nException: ") ;
93      print_endline (Pxp_types.string_of_exn e) ;
94      raise e
95 ;;