diff options
| author | ppedrot | 2011-11-25 16:17:53 +0000 |
|---|---|---|
| committer | ppedrot | 2011-11-25 16:17:53 +0000 |
| commit | 624f4dc573c5f7d974af41cbae2b85457ff0f3bb (patch) | |
| tree | 749182f5fae0aa1c41fc7154b2723874e7d091d0 /lib/xml_parser.ml | |
| parent | aadd90837e8e0eb015e4e4999394ca56f55f70b8 (diff) | |
Cleaning up XML parsing
git-svn-id: svn+ssh://scm.gforge.inria.fr/svn/coq/trunk@14729 85f007b7-540e-0410-9357-904b9bb8a0f7
Diffstat (limited to 'lib/xml_parser.ml')
| -rw-r--r-- | lib/xml_parser.ml | 13 |
1 files changed, 12 insertions, 1 deletions
diff --git a/lib/xml_parser.ml b/lib/xml_parser.ml index 0463c6e30b..bf931d75bb 100644 --- a/lib/xml_parser.ml +++ b/lib/xml_parser.ml @@ -144,7 +144,13 @@ and | None -> raise (Internal_error EOFExpected) | Some s -> raise (Internal_error (EndOfTagExpected s)) -let read_xml s = read_node s +let rec read_xml s = + let node = read_node s in + match node with + | Element _ -> node + | PCData c -> + if is_blank c then read_xml s + else raise (Xml_lexer.Error Xml_lexer.ENodeExpected) let convert = function | Xml_lexer.EUnterminatedComment -> UnterminatedComment @@ -225,3 +231,8 @@ let pos source = emin = min; emax = max; } + +let () = _raises (fun x p -> + (* local cast : Xml.error_msg -> error_msg *) + Error (x, pos p)) + (fun f -> File_not_found f) |
