]> matita.cs.unibo.it Git - helm.git/blob - helm/ocaml/cic/cicParser.ml
Merge of the V7_3_new_exportation branch.
[helm.git] / helm / ocaml / cic / 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       prerr_endline ("WARNING: " ^ w) ;
45       (raise Warnings : unit)
46   end
47 ;;
48
49 exception EmptyUri of string;;
50
51 (* given the filename of an xml file of a cic object it returns its internal *)
52 (* representation.                                                           *)
53 let annobj_of_xml filename filenamebody =
54  let module Y = Pxp_yacc in
55   try 
56     let root, rootbody =
57      let config = {Y.default_config with Y.warner = new warner} in
58       let doc =
59        Y.parse_document_entity config
60         (Y.from_file ~alt:[PxpUrlResolver.url_resolver] filename)
61         CicParser3.domspec in
62 (* CSC: Until PXP bug is resolved *)
63 PxpUrlResolver.url_resolver#close_all ;
64       let docroot = doc#root in
65        match filenamebody with
66           None -> docroot,None
67         | Some filename ->
68            let docbody =
69             Y.parse_document_entity config
70              (Y.from_file ~alt:[PxpUrlResolver.url_resolver] filename)
71              CicParser3.domspec
72            in
73 (* CSC: Until PXP bug is resolved *)
74 PxpUrlResolver.url_resolver#close_all ;
75             docroot,Some docbody#root
76     in
77      CicParser2.get_term root rootbody
78   with
79    e ->
80      prerr_endline ("Filenames: " ^ filename ^
81       (match filenamebody with None -> "" | Some s -> ", " ^ s)) ;
82      prerr_endline ("Exception: " ^ Pxp_types.string_of_exn e) ;
83      raise e
84 ;;
85
86 let obj_of_xml filename filenamebody =
87  Deannotate.deannotate_obj (annobj_of_xml filename filenamebody)
88 ;;