Commit 4e8b5cd9 authored by Peter Eisentraut's avatar Peter Eisentraut

Simplify handling of XML error messages: Just use the string provided by

libxml as the detail message.

As per <http://archives.postgresql.org/pgsql-hackers/2006-12/msg01087.php>.

For converting error codes to messages, we only need to cover those codes
that we raise ourselves now.
parent a56c5fb0
This diff is collapsed.
...@@ -6,7 +6,9 @@ INSERT INTO xmltest VALUES (1, '<value>one</value>'); ...@@ -6,7 +6,9 @@ INSERT INTO xmltest VALUES (1, '<value>one</value>');
INSERT INTO xmltest VALUES (2, '<value>two</value>'); INSERT INTO xmltest VALUES (2, '<value>two</value>');
INSERT INTO xmltest VALUES (3, '<wrong'); INSERT INTO xmltest VALUES (3, '<wrong');
ERROR: invalid XML content ERROR: invalid XML content
DETAIL: Expected '>' DETAIL: Entity: line 1: parser error : Couldn't find end of Start Tag wrong line 1
<wrong
^
SELECT * FROM xmltest; SELECT * FROM xmltest;
id | data id | data
----+-------------------- ----+--------------------
...@@ -54,7 +56,9 @@ SELECT xmlconcat(1, 2); ...@@ -54,7 +56,9 @@ SELECT xmlconcat(1, 2);
ERROR: argument of XMLCONCAT must be type xml, not type integer ERROR: argument of XMLCONCAT must be type xml, not type integer
SELECT xmlconcat('bad', '<syntax'); SELECT xmlconcat('bad', '<syntax');
ERROR: invalid XML content ERROR: invalid XML content
DETAIL: Expected '>' DETAIL: Entity: line 1: parser error : Couldn't find end of Start Tag syntax line 1
<syntax
^
SELECT xmlconcat('<foo/>', NULL, '<?xml version="1.1" standalone="no"?><bar/>'); SELECT xmlconcat('<foo/>', NULL, '<?xml version="1.1" standalone="no"?><bar/>');
xmlconcat xmlconcat
----------------------------------- -----------------------------------
...@@ -155,7 +159,9 @@ SELECT xmlparse(content '<abc>x</abc>'); ...@@ -155,7 +159,9 @@ SELECT xmlparse(content '<abc>x</abc>');
SELECT xmlparse(document 'abc'); SELECT xmlparse(document 'abc');
ERROR: invalid XML document ERROR: invalid XML document
DETAIL: Start tag expected, '<' not found. DETAIL: Entity: line 1: parser error : Start tag expected, '<' not found
abc
^
SELECT xmlparse(document '<abc>x</abc>'); SELECT xmlparse(document '<abc>x</abc>');
xmlparse xmlparse
-------------- --------------
...@@ -273,7 +279,9 @@ SELECT xml 'abc' IS NOT DOCUMENT; ...@@ -273,7 +279,9 @@ SELECT xml 'abc' IS NOT DOCUMENT;
SELECT '<>' IS NOT DOCUMENT; SELECT '<>' IS NOT DOCUMENT;
ERROR: invalid XML content ERROR: invalid XML content
DETAIL: Element name not found DETAIL: Entity: line 1: parser error : StartTag: invalid element name
<>
^
SELECT xmlagg(data) FROM xmltest; SELECT xmlagg(data) FROM xmltest;
xmlagg xmlagg
-------------------------------------- --------------------------------------
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment