Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
P
Postgres FD Implementation
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Abuhujair Javed
Postgres FD Implementation
Commits
2f8f76bc
Commit
2f8f76bc
authored
Jan 14, 2007
by
Peter Eisentraut
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Add support for xmlval IS DOCUMENT expression.
parent
62c06186
Changes
11
Show whitespace changes
Inline
Side-by-side
Showing
11 changed files
with
156 additions
and
11 deletions
+156
-11
src/backend/executor/execQual.c
src/backend/executor/execQual.c
+20
-1
src/backend/parser/gram.y
src/backend/parser/gram.y
+21
-1
src/backend/parser/parse_expr.c
src/backend/parser/parse_expr.c
+9
-2
src/backend/parser/parse_target.c
src/backend/parser/parse_target.c
+4
-1
src/backend/utils/adt/ruleutils.c
src/backend/utils/adt/ruleutils.c
+8
-2
src/backend/utils/adt/xml.c
src/backend/utils/adt/xml.c
+45
-1
src/include/nodes/primnodes.h
src/include/nodes/primnodes.h
+3
-2
src/include/utils/xml.h
src/include/utils/xml.h
+2
-1
src/test/regress/expected/xml.out
src/test/regress/expected/xml.out
+27
-0
src/test/regress/expected/xml_1.out
src/test/regress/expected/xml_1.out
+10
-0
src/test/regress/sql/xml.sql
src/test/regress/sql/xml.sql
+7
-0
No files found.
src/backend/executor/execQual.c
View file @
2f8f76bc
...
...
@@ -8,7 +8,7 @@
*
*
* IDENTIFICATION
* $PostgreSQL: pgsql/src/backend/executor/execQual.c,v 1.20
6 2007/01/12 21:47:26
petere Exp $
* $PostgreSQL: pgsql/src/backend/executor/execQual.c,v 1.20
7 2007/01/14 13:11:53
petere Exp $
*
*-------------------------------------------------------------------------
*/
...
...
@@ -2808,6 +2808,25 @@ ExecEvalXml(XmlExprState *xmlExpr, ExprContext *econtext,
standalone
));
}
break
;
case
IS_DOCUMENT
:
{
ExprState
*
e
;
/* optional argument is known to be xml */
Assert
(
list_length
(
xmlExpr
->
args
)
==
1
);
e
=
(
ExprState
*
)
linitial
(
xmlExpr
->
args
);
value
=
ExecEvalExpr
(
e
,
econtext
,
&
isnull
,
NULL
);
if
(
isnull
)
return
(
Datum
)
0
;
else
{
*
isNull
=
false
;
return
BoolGetDatum
(
xml_is_document
(
DatumGetXmlP
(
value
)));
}
}
break
;
}
if
(
*
isNull
)
...
...
src/backend/parser/gram.y
View file @
2f8f76bc
...
...
@@ -11,7 +11,7 @@
*
*
* IDENTIFICATION
* $PostgreSQL: pgsql/src/backend/parser/gram.y,v 2.57
3 2007/01/09 02:14:14 tgl
Exp $
* $PostgreSQL: pgsql/src/backend/parser/gram.y,v 2.57
4 2007/01/14 13:11:53 petere
Exp $
*
* HISTORY
* AUTHOR DATE MAJOR EVENT
...
...
@@ -7147,6 +7147,16 @@ a_expr: c_expr { $$ = $1; }
(errcode(ERRCODE_FEATURE_NOT_SUPPORTED),
errmsg("UNIQUE predicate is not yet implemented")));
}
| a_expr IS DOCUMENT_P %prec IS
{
$$ = makeXmlExpr(IS_DOCUMENT, NULL, NIL, list_make1($1));
}
| a_expr IS NOT DOCUMENT_P %prec IS
{
$$ = (Node *) makeA_Expr(AEXPR_NOT, NIL, NULL,
makeXmlExpr(IS_DOCUMENT, NULL, NIL, list_make1($1)),
@2);
}
;
/*
...
...
@@ -7207,6 +7217,16 @@ b_expr: c_expr
{
$$ = (Node *) makeSimpleA_Expr(AEXPR_OF, "<>", $1, (Node *) $6, @2);
}
| b_expr IS DOCUMENT_P %prec IS
{
$$ = makeXmlExpr(IS_DOCUMENT, NULL, NIL, list_make1($1));
}
| b_expr IS NOT DOCUMENT_P %prec IS
{
$$ = (Node *) makeA_Expr(AEXPR_NOT, NIL, NULL,
makeXmlExpr(IS_DOCUMENT, NULL, NIL, list_make1($1)),
@2);
}
;
/*
...
...
src/backend/parser/parse_expr.c
View file @
2f8f76bc
...
...
@@ -8,7 +8,7 @@
*
*
* IDENTIFICATION
* $PostgreSQL: pgsql/src/backend/parser/parse_expr.c,v 1.20
7 2007/01/12 22:09:49
petere Exp $
* $PostgreSQL: pgsql/src/backend/parser/parse_expr.c,v 1.20
8 2007/01/14 13:11:53
petere Exp $
*
*-------------------------------------------------------------------------
*/
...
...
@@ -1483,6 +1483,10 @@ transformXmlExpr(ParseState *pstate, XmlExpr *x)
else
newe
=
coerce_to_boolean
(
pstate
,
newe
,
"XMLROOT"
);
break
;
case
IS_DOCUMENT
:
newe
=
coerce_to_specific_type
(
pstate
,
newe
,
XMLOID
,
"IS DOCUMENT"
);
break
;
}
newx
->
args
=
lappend
(
newx
->
args
,
newe
);
i
++
;
...
...
@@ -1782,6 +1786,9 @@ exprType(Node *expr)
type
=
((
MinMaxExpr
*
)
expr
)
->
minmaxtype
;
break
;
case
T_XmlExpr
:
if
(((
XmlExpr
*
)
expr
)
->
op
==
IS_DOCUMENT
)
type
=
BOOLOID
;
else
type
=
XMLOID
;
break
;
case
T_NullIfExpr
:
...
...
src/backend/parser/parse_target.c
View file @
2f8f76bc
...
...
@@ -8,7 +8,7 @@
*
*
* IDENTIFICATION
* $PostgreSQL: pgsql/src/backend/parser/parse_target.c,v 1.15
2 2007/01/05 22:19:34 momjian
Exp $
* $PostgreSQL: pgsql/src/backend/parser/parse_target.c,v 1.15
3 2007/01/14 13:11:54 petere
Exp $
*
*-------------------------------------------------------------------------
*/
...
...
@@ -1337,6 +1337,9 @@ FigureColnameInternal(Node *node, char **name)
case
IS_XMLROOT
:
*
name
=
"xmlroot"
;
return
2
;
case
IS_DOCUMENT
:
/* nothing */
break
;
}
break
;
default:
...
...
src/backend/utils/adt/ruleutils.c
View file @
2f8f76bc
...
...
@@ -2,7 +2,7 @@
* ruleutils.c - Functions to convert stored expressions/querytrees
* back to source text
*
* $PostgreSQL: pgsql/src/backend/utils/adt/ruleutils.c,v 1.24
1 2007/01/09 02:14:14 tgl
Exp $
* $PostgreSQL: pgsql/src/backend/utils/adt/ruleutils.c,v 1.24
2 2007/01/14 13:11:54 petere
Exp $
**********************************************************************/
#include "postgres.h"
...
...
@@ -3847,6 +3847,8 @@ get_rule_expr(Node *node, deparse_context *context,
case
IS_XMLROOT
:
appendStringInfoString
(
buf
,
"XMLROOT("
);
break
;
case
IS_DOCUMENT
:
break
;
}
if
(
xexpr
->
name
)
{
...
...
@@ -3888,6 +3890,7 @@ get_rule_expr(Node *node, deparse_context *context,
case
IS_XMLELEMENT
:
case
IS_XMLFOREST
:
case
IS_XMLPI
:
case
IS_DOCUMENT
:
/* no extra decoration needed */
get_rule_expr
((
Node
*
)
xexpr
->
args
,
context
,
true
);
break
;
...
...
@@ -3943,6 +3946,9 @@ get_rule_expr(Node *node, deparse_context *context,
}
}
if
(
xexpr
->
op
==
IS_DOCUMENT
)
appendStringInfoString
(
buf
,
" IS DOCUMENT"
);
else
appendStringInfoChar
(
buf
,
')'
);
}
break
;
...
...
src/backend/utils/adt/xml.c
View file @
2f8f76bc
...
...
@@ -7,7 +7,7 @@
* Portions Copyright (c) 1996-2007, PostgreSQL Global Development Group
* Portions Copyright (c) 1994, Regents of the University of California
*
* $PostgreSQL: pgsql/src/backend/utils/adt/xml.c,v 1.1
6 2007/01/12 21:47:26
petere Exp $
* $PostgreSQL: pgsql/src/backend/utils/adt/xml.c,v 1.1
7 2007/01/14 13:11:54
petere Exp $
*
*-------------------------------------------------------------------------
*/
...
...
@@ -515,6 +515,50 @@ xmlvalidate(PG_FUNCTION_ARGS)
}
bool
xml_is_document
(
xmltype
*
arg
)
{
#ifdef USE_LIBXML
bool
result
;
xmlDocPtr
doc
=
NULL
;
MemoryContext
ccxt
=
CurrentMemoryContext
;
PG_TRY
();
{
doc
=
xml_parse
((
text
*
)
arg
,
true
,
true
);
result
=
true
;
}
PG_CATCH
();
{
ErrorData
*
errdata
;
MemoryContext
ecxt
;
ecxt
=
MemoryContextSwitchTo
(
ccxt
);
errdata
=
CopyErrorData
();
if
(
errdata
->
sqlerrcode
==
ERRCODE_INVALID_XML_DOCUMENT
)
{
FlushErrorState
();
result
=
false
;
}
else
{
MemoryContextSwitchTo
(
ecxt
);
PG_RE_THROW
();
}
}
PG_END_TRY
();
if
(
doc
)
xmlFreeDoc
(
doc
);
return
result
;
#else
/* not USE_LIBXML */
NO_XML_SUPPORT
();
return
false
;
#endif
/* not USE_LIBXML */
}
#ifdef USE_LIBXML
/*
...
...
src/include/nodes/primnodes.h
View file @
2f8f76bc
...
...
@@ -10,7 +10,7 @@
* Portions Copyright (c) 1996-2007, PostgreSQL Global Development Group
* Portions Copyright (c) 1994, Regents of the University of California
*
* $PostgreSQL: pgsql/src/include/nodes/primnodes.h,v 1.12
2 2007/01/05 22:19:56 momjian
Exp $
* $PostgreSQL: pgsql/src/include/nodes/primnodes.h,v 1.12
3 2007/01/14 13:11:54 petere
Exp $
*
*-------------------------------------------------------------------------
*/
...
...
@@ -725,7 +725,8 @@ typedef enum XmlExprOp
IS_XMLFOREST
,
/* XMLFOREST(xml_attributes) */
IS_XMLPARSE
,
/* XMLPARSE(text, is_doc, preserve_ws) */
IS_XMLPI
,
/* XMLPI(name [, args]) */
IS_XMLROOT
/* XMLROOT(xml, version, standalone) */
IS_XMLROOT
,
/* XMLROOT(xml, version, standalone) */
IS_DOCUMENT
/* xmlval IS DOCUMENT */
}
XmlExprOp
;
typedef
struct
XmlExpr
...
...
src/include/utils/xml.h
View file @
2f8f76bc
...
...
@@ -7,7 +7,7 @@
* Portions Copyright (c) 1996-2007, PostgreSQL Global Development Group
* Portions Copyright (c) 1994, Regents of the University of California
*
* $PostgreSQL: pgsql/src/include/utils/xml.h,v 1.
9 2007/01/12 21:47:27
petere Exp $
* $PostgreSQL: pgsql/src/include/utils/xml.h,v 1.
10 2007/01/14 13:11:54
petere Exp $
*
*-------------------------------------------------------------------------
*/
...
...
@@ -37,6 +37,7 @@ extern xmltype *xmlelement(XmlExprState *xmlExpr, ExprContext *econtext);
extern
xmltype
*
xmlparse
(
text
*
data
,
bool
is_doc
,
bool
preserve_whitespace
);
extern
xmltype
*
xmlpi
(
char
*
target
,
text
*
arg
,
bool
arg_is_null
,
bool
*
result_is_null
);
extern
xmltype
*
xmlroot
(
xmltype
*
data
,
text
*
version
,
int
standalone
);
extern
bool
xml_is_document
(
xmltype
*
arg
);
extern
char
*
map_sql_identifier_to_xml_name
(
char
*
ident
,
bool
fully_escaped
);
extern
char
*
map_xml_name_to_sql_identifier
(
char
*
name
);
...
...
src/test/regress/expected/xml.out
View file @
2f8f76bc
...
...
@@ -228,6 +228,33 @@ SELECT xmlserialize(content data as character varying) FROM xmltest;
<value>two</value>
(2 rows)
SELECT xml '<foo>bar</foo>' IS DOCUMENT;
?column?
----------
t
(1 row)
SELECT xml '<foo>bar</foo><bar>foo</bar>' IS DOCUMENT;
?column?
----------
f
(1 row)
SELECT xml '<abc/>' IS NOT DOCUMENT;
?column?
----------
f
(1 row)
SELECT xml 'abc' IS NOT DOCUMENT;
?column?
----------
t
(1 row)
SELECT '<>' IS NOT DOCUMENT;
ERROR: invalid XML content
DETAIL: Element name not found
-- Check mapping SQL identifier to XML name
SELECT xmlpi(name ":::_xml_abc135.%-&_");
xmlpi
...
...
src/test/regress/expected/xml_1.out
View file @
2f8f76bc
...
...
@@ -107,6 +107,16 @@ SELECT xmlserialize(content data as character varying) FROM xmltest;
------
(0 rows)
SELECT xml '<foo>bar</foo>' IS DOCUMENT;
ERROR: no XML support in this installation
SELECT xml '<foo>bar</foo><bar>foo</bar>' IS DOCUMENT;
ERROR: no XML support in this installation
SELECT xml '<abc/>' IS NOT DOCUMENT;
ERROR: no XML support in this installation
SELECT xml 'abc' IS NOT DOCUMENT;
ERROR: no XML support in this installation
SELECT '<>' IS NOT DOCUMENT;
ERROR: no XML support in this installation
-- Check mapping SQL identifier to XML name
SELECT xmlpi(name ":::_xml_abc135.%-&_");
ERROR: no XML support in this installation
...
...
src/test/regress/sql/xml.sql
View file @
2f8f76bc
...
...
@@ -86,6 +86,13 @@ SELECT xmlroot (
SELECT
xmlserialize
(
content
data
as
character
varying
)
FROM
xmltest
;
SELECT
xml
'<foo>bar</foo>'
IS
DOCUMENT
;
SELECT
xml
'<foo>bar</foo><bar>foo</bar>'
IS
DOCUMENT
;
SELECT
xml
'<abc/>'
IS
NOT
DOCUMENT
;
SELECT
xml
'abc'
IS
NOT
DOCUMENT
;
SELECT
'<>'
IS
NOT
DOCUMENT
;
-- Check mapping SQL identifier to XML name
SELECT
xmlpi
(
name
":::_xml_abc135.%-&_"
);
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment