Commit 8fd5b3ed authored by Tom Lane's avatar Tom Lane

Error message editing in contrib (mostly by Joe Conway --- thanks Joe!)

parent f0c5384d
...@@ -247,14 +247,20 @@ __BTREE_GIST_TYPE2__key_cmp(const void *a, const void *b) ...@@ -247,14 +247,20 @@ __BTREE_GIST_TYPE2__key_cmp(const void *a, const void *b)
Datum Datum
__BTREE_GIST_TYPE2__key_in(PG_FUNCTION_ARGS) __BTREE_GIST_TYPE2__key_in(PG_FUNCTION_ARGS)
{ {
elog(ERROR, "Not implemented"); ereport(ERROR,
(errcode(ERRCODE_FEATURE_NOT_SUPPORTED),
errmsg("<datatype>key_in() not implemented")));
PG_RETURN_POINTER(NULL); PG_RETURN_POINTER(NULL);
} }
Datum Datum
__BTREE_GIST_TYPE2__key_out(PG_FUNCTION_ARGS) __BTREE_GIST_TYPE2__key_out(PG_FUNCTION_ARGS)
{ {
elog(ERROR, "Not implemented"); ereport(ERROR,
(errcode(ERRCODE_FEATURE_NOT_SUPPORTED),
errmsg("<datatype>key_out() not implemented")));
PG_RETURN_POINTER(NULL); PG_RETURN_POINTER(NULL);
} }
...@@ -270,13 +270,19 @@ tskey_cmp(const void *a, const void *b) ...@@ -270,13 +270,19 @@ tskey_cmp(const void *a, const void *b)
Datum Datum
tskey_in(PG_FUNCTION_ARGS) tskey_in(PG_FUNCTION_ARGS)
{ {
elog(ERROR, "Not implemented"); ereport(ERROR,
(errcode(ERRCODE_FEATURE_NOT_SUPPORTED),
errmsg("feature not implemented")));
PG_RETURN_POINTER(NULL); PG_RETURN_POINTER(NULL);
} }
Datum Datum
tskey_out(PG_FUNCTION_ARGS) tskey_out(PG_FUNCTION_ARGS)
{ {
elog(ERROR, "Not implemented"); ereport(ERROR,
(errcode(ERRCODE_FEATURE_NOT_SUPPORTED),
errmsg("feature not implemented")));
PG_RETURN_POINTER(NULL); PG_RETURN_POINTER(NULL);
} }
...@@ -3,18 +3,24 @@ ...@@ -3,18 +3,24 @@
-- does not depend on contents of btree_gist.sql. -- does not depend on contents of btree_gist.sql.
-- --
\set ECHO none \set ECHO none
psql:btree_gist.sql:8: NOTICE: ProcedureCreate: type int2key is not yet defined psql:btree_gist.sql:8: NOTICE: type int2key is not yet defined
psql:btree_gist.sql:13: NOTICE: Argument type "int2key" is only a shell DETAIL: Creating a shell type definition.
psql:btree_gist.sql:25: NOTICE: ProcedureCreate: type int4key is not yet defined psql:btree_gist.sql:13: NOTICE: argument type int2key is only a shell
psql:btree_gist.sql:30: NOTICE: Argument type "int4key" is only a shell psql:btree_gist.sql:25: NOTICE: type int4key is not yet defined
psql:btree_gist.sql:42: NOTICE: ProcedureCreate: type int8key is not yet defined DETAIL: Creating a shell type definition.
psql:btree_gist.sql:47: NOTICE: Argument type "int8key" is only a shell psql:btree_gist.sql:30: NOTICE: argument type int4key is only a shell
psql:btree_gist.sql:59: NOTICE: ProcedureCreate: type float4key is not yet defined psql:btree_gist.sql:42: NOTICE: type int8key is not yet defined
psql:btree_gist.sql:64: NOTICE: Argument type "float4key" is only a shell DETAIL: Creating a shell type definition.
psql:btree_gist.sql:77: NOTICE: ProcedureCreate: type float8key is not yet defined psql:btree_gist.sql:47: NOTICE: argument type int8key is only a shell
psql:btree_gist.sql:82: NOTICE: Argument type "float8key" is only a shell psql:btree_gist.sql:59: NOTICE: type float4key is not yet defined
psql:btree_gist.sql:392: NOTICE: ProcedureCreate: type tskey is not yet defined DETAIL: Creating a shell type definition.
psql:btree_gist.sql:397: NOTICE: Argument type "tskey" is only a shell psql:btree_gist.sql:64: NOTICE: argument type float4key is only a shell
psql:btree_gist.sql:77: NOTICE: type float8key is not yet defined
DETAIL: Creating a shell type definition.
psql:btree_gist.sql:82: NOTICE: argument type float8key is only a shell
psql:btree_gist.sql:392: NOTICE: type tskey is not yet defined
DETAIL: Creating a shell type definition.
psql:btree_gist.sql:397: NOTICE: argument type tskey is only a shell
CREATE TABLE int4tmp (b int4); CREATE TABLE int4tmp (b int4);
\copy int4tmp from 'data/test_btree.data' \copy int4tmp from 'data/test_btree.data'
CREATE TABLE int8tmp (b int8); CREATE TABLE int8tmp (b int8);
......
...@@ -4,7 +4,7 @@ ...@@ -4,7 +4,7 @@
* darcy@druid.net * darcy@druid.net
* http://www.druid.net/darcy/ * http://www.druid.net/darcy/
* *
* $Id: chkpass.c,v 1.9 2002/10/26 15:00:59 tgl Exp $ * $Id: chkpass.c,v 1.10 2003/07/24 17:52:12 tgl Exp $
* best viewed with tabs set to 4 * best viewed with tabs set to 4
*/ */
...@@ -84,8 +84,10 @@ chkpass_in(PG_FUNCTION_ARGS) ...@@ -84,8 +84,10 @@ chkpass_in(PG_FUNCTION_ARGS)
if (verify_pass(str) != 0) if (verify_pass(str) != 0)
{ {
elog(ERROR, "chkpass_in: purported CHKPASS \"%s\" is a weak password", ereport(ERROR,
str); (errcode(ERRCODE_DATA_EXCEPTION),
errmsg("password \"%s\" is weak", str)));
PG_RETURN_POINTER(NULL); PG_RETURN_POINTER(NULL);
} }
......
...@@ -2,8 +2,6 @@ ...@@ -2,8 +2,6 @@
#include "postgres.h" #include "postgres.h"
#include "utils/elog.h"
static char *PARSE_BUFFER; static char *PARSE_BUFFER;
static char *PARSE_BUFFER_PTR; static char *PARSE_BUFFER_PTR;
static unsigned int PARSE_BUFFER_SIZE; static unsigned int PARSE_BUFFER_SIZE;
...@@ -26,7 +24,10 @@ set_parse_buffer(char *s) ...@@ -26,7 +24,10 @@ set_parse_buffer(char *s)
PARSE_BUFFER = s; PARSE_BUFFER = s;
PARSE_BUFFER_SIZE = strlen(s); PARSE_BUFFER_SIZE = strlen(s);
if (PARSE_BUFFER_SIZE == 0) if (PARSE_BUFFER_SIZE == 0)
elog(ERROR, "cube_in: can't parse an empty string"); ereport(ERROR,
(errcode(ERRCODE_ZERO_LENGTH_CHARACTER_STRING),
errmsg("can't parse an empty string")));
PARSE_BUFFER_PTR = PARSE_BUFFER; PARSE_BUFFER_PTR = PARSE_BUFFER;
SCANNER_POS = 0; SCANNER_POS = 0;
} }
......
...@@ -11,9 +11,6 @@ ...@@ -11,9 +11,6 @@
#include "cubedata.h" #include "cubedata.h"
#include "buffer.h" #include "buffer.h"
#include "utils/palloc.h"
#include "utils/elog.h"
#undef yylex /* falure to redefine yylex will result in a call to the */ #undef yylex /* falure to redefine yylex will result in a call to the */
#define yylex cube_yylex /* wrong scanner when running inside the postgres backend */ #define yylex cube_yylex /* wrong scanner when running inside the postgres backend */
...@@ -48,19 +45,31 @@ box: ...@@ -48,19 +45,31 @@ box:
if ( c != '\0' ) { if ( c != '\0' ) {
/* Not at EOF */ /* Not at EOF */
reset_parse_buffer(); reset_parse_buffer();
elog(ERROR, "(0) bad cube representation; garbage at or before char %d, ('%c', \\%03o)\n", pos, c, c ); ereport(ERROR,
(errcode(ERRCODE_SYNTAX_ERROR),
errmsg("bad cube representation"),
errdetail("garbage at or before char %d, ('%c', \\%03o)",
pos, c, c)));
YYERROR; YYERROR;
} }
dim = delim_count($2, ',') + 1; dim = delim_count($2, ',') + 1;
if ( (delim_count($4, ',') + 1) != dim ) { if ( (delim_count($4, ',') + 1) != dim ) {
reset_parse_buffer(); reset_parse_buffer();
elog(ERROR, "(1) bad cube representation; different point dimensions in (%s) and (%s)\n", $2, $4); ereport(ERROR,
(errcode(ERRCODE_SYNTAX_ERROR),
errmsg("bad cube representation"),
errdetail("different point dimensions in (%s) and (%s)",
$2, $4)));
YYABORT; YYABORT;
} }
if (dim > CUBE_MAX_DIM) { if (dim > CUBE_MAX_DIM) {
reset_parse_buffer(); reset_parse_buffer();
elog(ERROR, "(8) bad cube representation; more than %d dimensions\n", CUBE_MAX_DIM); ereport(ERROR,
(errcode(ERRCODE_SYNTAX_ERROR),
errmsg("bad cube representation"),
errdetail("more than %d dimensions",
CUBE_MAX_DIM)));
YYABORT; YYABORT;
} }
...@@ -75,7 +84,11 @@ box: ...@@ -75,7 +84,11 @@ box:
if ( c != '\0' ) { /* Not at EOF */ if ( c != '\0' ) { /* Not at EOF */
reset_parse_buffer(); reset_parse_buffer();
elog(ERROR, "(2) bad cube representation; garbage at or before char %d, ('%c', \\%03o)\n", pos, c, c ); ereport(ERROR,
(errcode(ERRCODE_SYNTAX_ERROR),
errmsg("bad cube representation"),
errdetail("garbage at or before char %d, ('%c', \\%03o)",
pos, c, c)));
YYABORT; YYABORT;
} }
...@@ -83,12 +96,20 @@ box: ...@@ -83,12 +96,20 @@ box:
if ( (delim_count($3, ',') + 1) != dim ) { if ( (delim_count($3, ',') + 1) != dim ) {
reset_parse_buffer(); reset_parse_buffer();
elog(ERROR, "(3) bad cube representation; different point dimensions in (%s) and (%s)\n", $1, $3); ereport(ERROR,
(errcode(ERRCODE_SYNTAX_ERROR),
errmsg("bad cube representation"),
errdetail("different point dimensions in (%s) and (%s)",
$1, $3)));
YYABORT; YYABORT;
} }
if (dim > CUBE_MAX_DIM) { if (dim > CUBE_MAX_DIM) {
reset_parse_buffer(); reset_parse_buffer();
elog(ERROR, "(8) bad cube representation; more than %d dimensions\n", CUBE_MAX_DIM); ereport(ERROR,
(errcode(ERRCODE_SYNTAX_ERROR),
errmsg("bad cube representation"),
errdetail("more than %d dimensions",
CUBE_MAX_DIM)));
YYABORT; YYABORT;
} }
...@@ -103,21 +124,33 @@ box: ...@@ -103,21 +124,33 @@ box:
if ( c != '\0') { /* Not at EOF */ if ( c != '\0') { /* Not at EOF */
reset_parse_buffer(); reset_parse_buffer();
elog(ERROR, "(4) bad cube representation; garbage at or before char %d, ('%c', \\%03o)\n", pos, c, c ); ereport(ERROR,
(errcode(ERRCODE_SYNTAX_ERROR),
errmsg("bad cube representation"),
errdetail("garbage at or before char %d, ('%c', \\%03o)",
pos, c, c)));
YYABORT; YYABORT;
} }
if ( yychar != YYEOF) { if ( yychar != YYEOF) {
/* There's still a lookahead token to be parsed */ /* There's still a lookahead token to be parsed */
reset_parse_buffer(); reset_parse_buffer();
elog(ERROR, "(5) bad cube representation; garbage at or before char %d, ('end of input', \\%03o)\n", pos, c); ereport(ERROR,
(errcode(ERRCODE_SYNTAX_ERROR),
errmsg("bad cube representation"),
errdetail("garbage at or before char %d, ('end of input', \\%03o)",
pos, c)));
YYABORT; YYABORT;
} }
dim = delim_count($1, ',') + 1; dim = delim_count($1, ',') + 1;
if (dim > CUBE_MAX_DIM) { if (dim > CUBE_MAX_DIM) {
reset_parse_buffer(); reset_parse_buffer();
elog(ERROR, "(8) bad cube representation; more than %d dimensions\n", CUBE_MAX_DIM); ereport(ERROR,
(errcode(ERRCODE_SYNTAX_ERROR),
errmsg("bad cube representation"),
errdetail("more than %d dimensions",
CUBE_MAX_DIM)));
YYABORT; YYABORT;
} }
...@@ -133,21 +166,33 @@ box: ...@@ -133,21 +166,33 @@ box:
if ( c != '\0') { /* Not at EOF */ if ( c != '\0') { /* Not at EOF */
reset_parse_buffer(); reset_parse_buffer();
elog(ERROR, "(6) bad cube representation; garbage at or before char %d, ('%c', \\%03o)\n", pos, c, c); ereport(ERROR,
(errcode(ERRCODE_SYNTAX_ERROR),
errmsg("bad cube representation"),
errdetail("garbage at or before char %d, ('%c', \\%03o)",
pos, c, c)));
YYABORT; YYABORT;
} }
if ( yychar != YYEOF) { if ( yychar != YYEOF) {
/* There's still a lookahead token to be parsed */ /* There's still a lookahead token to be parsed */
reset_parse_buffer(); reset_parse_buffer();
elog(ERROR, "(7) bad cube representation; garbage at or before char %d, ('end of input', \\%03o)\n", pos, c); ereport(ERROR,
(errcode(ERRCODE_SYNTAX_ERROR),
errmsg("bad cube representation"),
errdetail("garbage at or before char %d, ('end of input', \\%03o)",
pos, c)));
YYABORT; YYABORT;
} }
dim = delim_count($1, ',') + 1; dim = delim_count($1, ',') + 1;
if (dim > CUBE_MAX_DIM) { if (dim > CUBE_MAX_DIM) {
reset_parse_buffer(); reset_parse_buffer();
elog(ERROR, "(8) bad cube representation; more than %d dimensions\n", CUBE_MAX_DIM); ereport(ERROR,
(errcode(ERRCODE_SYNTAX_ERROR),
errmsg("bad cube representation"),
errdetail("more than %d dimensions",
CUBE_MAX_DIM)));
YYABORT; YYABORT;
} }
*((void **)result) = write_point_as_box($1, dim); *((void **)result) = write_point_as_box($1, dim);
...@@ -191,7 +236,7 @@ int cube_yyerror ( char *msg ) { ...@@ -191,7 +236,7 @@ int cube_yyerror ( char *msg ) {
snprintf( snprintf(
buf, buf,
256, 256,
"%s at or before position %d, character ('%c', \\%03o), input: '%s'\n", "%s at or before position %d, character ('%c', \\%03o), input: '%s'",
msg, msg,
position, position,
parse_buffer()[position - 1], parse_buffer()[position - 1],
...@@ -200,7 +245,11 @@ int cube_yyerror ( char *msg ) { ...@@ -200,7 +245,11 @@ int cube_yyerror ( char *msg ) {
); );
reset_parse_buffer(); reset_parse_buffer();
elog(ERROR, "%s", buf); ereport(ERROR,
(errcode(ERRCODE_SYNTAX_ERROR),
errmsg("bad cube representation"),
errdetail("%s", buf)));
return 0; return 0;
} }
......
...@@ -6,8 +6,9 @@ ...@@ -6,8 +6,9 @@
-- does not depend on contents of cube.sql. -- does not depend on contents of cube.sql.
-- --
\set ECHO none \set ECHO none
psql:cube.sql:10: NOTICE: ProcedureCreate: type cube is not yet defined psql:cube.sql:10: NOTICE: type cube is not yet defined
psql:cube.sql:15: NOTICE: Argument type "cube" is only a shell DETAIL: Creating a shell type definition.
psql:cube.sql:15: NOTICE: argument type cube is only a shell
-- --
-- testing the input and output functions -- testing the input and output functions
-- --
...@@ -256,89 +257,89 @@ SELECT '[(0,0,0,0),(1,0,0,0)]'::cube AS cube; ...@@ -256,89 +257,89 @@ SELECT '[(0,0,0,0),(1,0,0,0)]'::cube AS cube;
-- invalid input: parse errors -- invalid input: parse errors
SELECT ''::cube AS cube; SELECT ''::cube AS cube;
ERROR: cube_in: can't parse an empty string ERROR: can't parse an empty string
SELECT 'ABC'::cube AS cube; SELECT 'ABC'::cube AS cube;
ERROR: syntax error at or before position 1, character ('A', \101), input: 'ABC' ERROR: bad cube representation
DETAIL: syntax error at or before position 1, character ('A', \101), input: 'ABC'
SELECT '()'::cube AS cube; SELECT '()'::cube AS cube;
ERROR: syntax error at or before position 2, character (')', \051), input: '()' ERROR: bad cube representation
DETAIL: syntax error at or before position 2, character (')', \051), input: '()'
SELECT '[]'::cube AS cube; SELECT '[]'::cube AS cube;
ERROR: syntax error at or before position 2, character (']', \135), input: '[]' ERROR: bad cube representation
DETAIL: syntax error at or before position 2, character (']', \135), input: '[]'
SELECT '[()]'::cube AS cube; SELECT '[()]'::cube AS cube;
ERROR: syntax error at or before position 3, character (')', \051), input: '[()]' ERROR: bad cube representation
DETAIL: syntax error at or before position 3, character (')', \051), input: '[()]'
SELECT '[(1)]'::cube AS cube; SELECT '[(1)]'::cube AS cube;
ERROR: syntax error at or before position 5, character (']', \135), input: '[(1)]' ERROR: bad cube representation
DETAIL: syntax error at or before position 5, character (']', \135), input: '[(1)]'
SELECT '[(1),]'::cube AS cube; SELECT '[(1),]'::cube AS cube;
ERROR: syntax error at or before position 6, character (']', \135), input: '[(1),]' ERROR: bad cube representation
DETAIL: syntax error at or before position 6, character (']', \135), input: '[(1),]'
SELECT '[(1),2]'::cube AS cube; SELECT '[(1),2]'::cube AS cube;
ERROR: syntax error at or before position 7, character (']', \135), input: '[(1),2]' ERROR: bad cube representation
DETAIL: syntax error at or before position 7, character (']', \135), input: '[(1),2]'
SELECT '[(1),(2),(3)]'::cube AS cube; SELECT '[(1),(2),(3)]'::cube AS cube;
ERROR: syntax error at or before position 9, character (',', \054), input: '[(1),(2),(3)]' ERROR: bad cube representation
DETAIL: syntax error at or before position 9, character (',', \054), input: '[(1),(2),(3)]'
SELECT '1,'::cube AS cube; SELECT '1,'::cube AS cube;
ERROR: syntax error at or before position 2, character (',', \054), input: '1,' ERROR: bad cube representation
DETAIL: syntax error at or before position 2, character (',', \054), input: '1,'
SELECT '1,2,'::cube AS cube; SELECT '1,2,'::cube AS cube;
ERROR: syntax error at or before position 4, character (',', \054), input: '1,2,' ERROR: bad cube representation
DETAIL: syntax error at or before position 4, character (',', \054), input: '1,2,'
SELECT '1,,2'::cube AS cube; SELECT '1,,2'::cube AS cube;
ERROR: syntax error at or before position 3, character (',', \054), input: '1,,2' ERROR: bad cube representation
DETAIL: syntax error at or before position 3, character (',', \054), input: '1,,2'
SELECT '(1,)'::cube AS cube; SELECT '(1,)'::cube AS cube;
ERROR: syntax error at or before position 4, character (')', \051), input: '(1,)' ERROR: bad cube representation
DETAIL: syntax error at or before position 4, character (')', \051), input: '(1,)'
SELECT '(1,2,)'::cube AS cube; SELECT '(1,2,)'::cube AS cube;
ERROR: syntax error at or before position 6, character (')', \051), input: '(1,2,)' ERROR: bad cube representation
DETAIL: syntax error at or before position 6, character (')', \051), input: '(1,2,)'
SELECT '(1,,2)'::cube AS cube; SELECT '(1,,2)'::cube AS cube;
ERROR: syntax error at or before position 4, character (',', \054), input: '(1,,2)' ERROR: bad cube representation
DETAIL: syntax error at or before position 4, character (',', \054), input: '(1,,2)'
-- invalid input: semantic errors and trailing garbage -- invalid input: semantic errors and trailing garbage
SELECT '[(1),(2)],'::cube AS cube; -- 0 SELECT '[(1),(2)],'::cube AS cube; -- 0
ERROR: (0) bad cube representation; garbage at or before char 9, (',', \054) ERROR: bad cube representation
DETAIL: garbage at or before char 9, (',', \054)
SELECT '[(1,2,3),(2,3)]'::cube AS cube; -- 1 SELECT '[(1,2,3),(2,3)]'::cube AS cube; -- 1
ERROR: (1) bad cube representation; different point dimensions in (1,2,3) and (2,3) ERROR: bad cube representation
DETAIL: different point dimensions in (1,2,3) and (2,3)
SELECT '[(1,2),(1,2,3)]'::cube AS cube; -- 1 SELECT '[(1,2),(1,2,3)]'::cube AS cube; -- 1
ERROR: (1) bad cube representation; different point dimensions in (1,2) and (1,2,3) ERROR: bad cube representation
DETAIL: different point dimensions in (1,2) and (1,2,3)
SELECT '(1),(2),'::cube AS cube; -- 2 SELECT '(1),(2),'::cube AS cube; -- 2
ERROR: (2) bad cube representation; garbage at or before char 7, (',', \054) ERROR: bad cube representation
DETAIL: garbage at or before char 7, (',', \054)
SELECT '(1,2,3),(2,3)'::cube AS cube; -- 3 SELECT '(1,2,3),(2,3)'::cube AS cube; -- 3
ERROR: (3) bad cube representation; different point dimensions in (1,2,3) and (2,3) ERROR: bad cube representation
DETAIL: different point dimensions in (1,2,3) and (2,3)
SELECT '(1,2),(1,2,3)'::cube AS cube; -- 3 SELECT '(1,2),(1,2,3)'::cube AS cube; -- 3
ERROR: (3) bad cube representation; different point dimensions in (1,2) and (1,2,3) ERROR: bad cube representation
DETAIL: different point dimensions in (1,2) and (1,2,3)
SELECT '(1,2,3)ab'::cube AS cube; -- 4 SELECT '(1,2,3)ab'::cube AS cube; -- 4
ERROR: (4) bad cube representation; garbage at or before char 8, ('b', \142) ERROR: bad cube representation
DETAIL: garbage at or before char 8, ('b', \142)
SELECT '(1,2,3)a'::cube AS cube; -- 5 SELECT '(1,2,3)a'::cube AS cube; -- 5
ERROR: (5) bad cube representation; garbage at or before char 8, ('end of input', \000) ERROR: bad cube representation
DETAIL: garbage at or before char 8, ('end of input', \000)
SELECT '(1,2)('::cube AS cube; -- 5 SELECT '(1,2)('::cube AS cube; -- 5
ERROR: (5) bad cube representation; garbage at or before char 6, ('end of input', \000) ERROR: bad cube representation
DETAIL: garbage at or before char 6, ('end of input', \000)
SELECT '1,2ab'::cube AS cube; -- 6 SELECT '1,2ab'::cube AS cube; -- 6
ERROR: (6) bad cube representation; garbage at or before char 4, ('b', \142) ERROR: bad cube representation
DETAIL: garbage at or before char 4, ('b', \142)
SELECT '1 e7'::cube AS cube; -- 6 SELECT '1 e7'::cube AS cube; -- 6
ERROR: (6) bad cube representation; garbage at or before char 3, ('7', \067) ERROR: bad cube representation
DETAIL: garbage at or before char 3, ('7', \067)
SELECT '1,2a'::cube AS cube; -- 7 SELECT '1,2a'::cube AS cube; -- 7
ERROR: (7) bad cube representation; garbage at or before char 4, ('end of input', \000) ERROR: bad cube representation
DETAIL: garbage at or before char 4, ('end of input', \000)
SELECT '1..2'::cube AS cube; -- 7 SELECT '1..2'::cube AS cube; -- 7
ERROR: (7) bad cube representation; garbage at or before char 4, ('end of input', \000) ERROR: bad cube representation
DETAIL: garbage at or before char 4, ('end of input', \000)
-- --
-- Testing building cubes from float8 values -- Testing building cubes from float8 values
-- --
...@@ -397,11 +398,11 @@ SELECT '(0)'::text::cube; ...@@ -397,11 +398,11 @@ SELECT '(0)'::text::cube;
-- Testing limit of CUBE_MAX_DIM dimensions check in cube_in. -- Testing limit of CUBE_MAX_DIM dimensions check in cube_in.
-- --
select '(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0)'::cube; select '(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0)'::cube;
ERROR: (8) bad cube representation; more than 100 dimensions ERROR: bad cube representation
DETAIL: more than 100 dimensions
select '(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0),(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0)'::cube; select '(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0),(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0)'::cube;
ERROR: (8) bad cube representation; more than 100 dimensions ERROR: bad cube representation
DETAIL: more than 100 dimensions
-- --
-- testing the operators -- testing the operators
-- --
......
This diff is collapsed.
...@@ -8,7 +8,7 @@ SET search_path = public; ...@@ -8,7 +8,7 @@ SET search_path = public;
-- contents of dblink.sql. -- contents of dblink.sql.
\set ECHO none \set ECHO none
CREATE TABLE foo(f1 int, f2 text, f3 text[], primary key (f1,f2)); CREATE TABLE foo(f1 int, f2 text, f3 text[], primary key (f1,f2));
NOTICE: CREATE TABLE / PRIMARY KEY will create implicit index 'foo_pkey' for table 'foo' NOTICE: CREATE TABLE / PRIMARY KEY will create implicit index "foo_pkey" for table "foo"
INSERT INTO foo VALUES (0,'a','{"a0","b0","c0"}'); INSERT INTO foo VALUES (0,'a','{"a0","b0","c0"}');
INSERT INTO foo VALUES (1,'b','{"a1","b1","c1"}'); INSERT INTO foo VALUES (1,'b','{"a1","b1","c1"}');
INSERT INTO foo VALUES (2,'c','{"a2","b2","c2"}'); INSERT INTO foo VALUES (2,'c','{"a2","b2","c2"}');
...@@ -62,7 +62,7 @@ SELECT dblink_build_sql_delete('foo','1 2',2,'{"0", "a"}'); ...@@ -62,7 +62,7 @@ SELECT dblink_build_sql_delete('foo','1 2',2,'{"0", "a"}');
-- retest using a quoted and schema qualified table -- retest using a quoted and schema qualified table
CREATE SCHEMA "MySchema"; CREATE SCHEMA "MySchema";
CREATE TABLE "MySchema"."Foo"(f1 int, f2 text, f3 text[], primary key (f1,f2)); CREATE TABLE "MySchema"."Foo"(f1 int, f2 text, f3 text[], primary key (f1,f2));
NOTICE: CREATE TABLE / PRIMARY KEY will create implicit index 'Foo_pkey' for table 'Foo' NOTICE: CREATE TABLE / PRIMARY KEY will create implicit index "Foo_pkey" for table "Foo"
INSERT INTO "MySchema"."Foo" VALUES (0,'a','{"a0","b0","c0"}'); INSERT INTO "MySchema"."Foo" VALUES (0,'a','{"a0","b0","c0"}');
-- list the primary key fields -- list the primary key fields
SELECT * SELECT *
...@@ -110,7 +110,7 @@ WHERE t.a > 7; ...@@ -110,7 +110,7 @@ WHERE t.a > 7;
SELECT * SELECT *
FROM dblink('SELECT * FROM foo') AS t(a int, b text, c text[]) FROM dblink('SELECT * FROM foo') AS t(a int, b text, c text[])
WHERE t.a > 7; WHERE t.a > 7;
ERROR: dblink_record: connection not available ERROR: connection not available
-- create a persistent connection -- create a persistent connection
SELECT dblink_connect('dbname=regression'); SELECT dblink_connect('dbname=regression');
dblink_connect dblink_connect
...@@ -172,10 +172,10 @@ SELECT dblink_close('rmt_foo_cursor'); ...@@ -172,10 +172,10 @@ SELECT dblink_close('rmt_foo_cursor');
OK OK
(1 row) (1 row)
-- should generate "cursor not found: rmt_foo_cursor" error -- should generate 'cursor "rmt_foo_cursor" not found' error
SELECT * SELECT *
FROM dblink_fetch('rmt_foo_cursor',4) AS t(a int, b text, c text[]); FROM dblink_fetch('rmt_foo_cursor',4) AS t(a int, b text, c text[]);
ERROR: dblink_fetch: cursor not found: rmt_foo_cursor ERROR: cursor "rmt_foo_cursor" does not exist
-- close the persistent connection -- close the persistent connection
SELECT dblink_disconnect(); SELECT dblink_disconnect();
dblink_disconnect dblink_disconnect
...@@ -187,7 +187,8 @@ SELECT dblink_disconnect(); ...@@ -187,7 +187,8 @@ SELECT dblink_disconnect();
SELECT * SELECT *
FROM dblink('SELECT * FROM foo') AS t(a int, b text, c text[]) FROM dblink('SELECT * FROM foo') AS t(a int, b text, c text[])
WHERE t.a > 7; WHERE t.a > 7;
ERROR: dblink: sql error: no connection to the server ERROR: sql error
DETAIL: no connection to the server
-- put more data into our slave table, first using arbitrary connection syntax -- put more data into our slave table, first using arbitrary connection syntax
-- but truncate the actual return value so we can use diff to check for success -- but truncate the actual return value so we can use diff to check for success
...@@ -276,7 +277,8 @@ SELECT dblink_disconnect(); ...@@ -276,7 +277,8 @@ SELECT dblink_disconnect();
SELECT * SELECT *
FROM dblink('myconn','SELECT * FROM foo') AS t(a int, b text, c text[]) FROM dblink('myconn','SELECT * FROM foo') AS t(a int, b text, c text[])
WHERE t.a > 7; WHERE t.a > 7;
ERROR: dblink: connection error: missing "=" after "myconn" in connection info string ERROR: could not establish connection
DETAIL: missing "=" after "myconn" in connection info string
-- create a named persistent connection -- create a named persistent connection
SELECT dblink_connect('myconn','dbname=regression'); SELECT dblink_connect('myconn','dbname=regression');
...@@ -297,10 +299,9 @@ WHERE t.a > 7; ...@@ -297,10 +299,9 @@ WHERE t.a > 7;
(3 rows) (3 rows)
-- create a second named persistent connection -- create a second named persistent connection
-- should error with "cannot save named connection" -- should error with "duplicate connection name"
SELECT dblink_connect('myconn','dbname=regression'); SELECT dblink_connect('myconn','dbname=regression');
NOTICE: cannot use a connection name more than once ERROR: duplicate connection name
ERROR: dblink_connect: cannot save named connection
-- create a second named persistent connection with a new name -- create a second named persistent connection with a new name
SELECT dblink_connect('myconn2','dbname=regression'); SELECT dblink_connect('myconn2','dbname=regression');
dblink_connect dblink_connect
...@@ -371,10 +372,10 @@ SELECT dblink_close('myconn','rmt_foo_cursor'); ...@@ -371,10 +372,10 @@ SELECT dblink_close('myconn','rmt_foo_cursor');
OK OK
(1 row) (1 row)
-- should generate "cursor not found: rmt_foo_cursor" error -- should generate 'cursor "rmt_foo_cursor" not found' error
SELECT * SELECT *
FROM dblink_fetch('myconn','rmt_foo_cursor',4) AS t(a int, b text, c text[]); FROM dblink_fetch('myconn','rmt_foo_cursor',4) AS t(a int, b text, c text[]);
ERROR: dblink_fetch: cursor not found: rmt_foo_cursor ERROR: cursor "rmt_foo_cursor" does not exist
-- close the named persistent connection -- close the named persistent connection
SELECT dblink_disconnect('myconn'); SELECT dblink_disconnect('myconn');
dblink_disconnect dblink_disconnect
...@@ -386,7 +387,8 @@ SELECT dblink_disconnect('myconn'); ...@@ -386,7 +387,8 @@ SELECT dblink_disconnect('myconn');
SELECT * SELECT *
FROM dblink('myconn','SELECT * FROM foo') AS t(a int, b text, c text[]) FROM dblink('myconn','SELECT * FROM foo') AS t(a int, b text, c text[])
WHERE t.a > 7; WHERE t.a > 7;
ERROR: dblink: connection error: missing "=" after "myconn" in connection info string ERROR: could not establish connection
DETAIL: missing "=" after "myconn" in connection info string
-- create a named persistent connection -- create a named persistent connection
SELECT dblink_connect('myconn','dbname=regression'); SELECT dblink_connect('myconn','dbname=regression');
...@@ -461,6 +463,6 @@ SELECT dblink_disconnect('myconn'); ...@@ -461,6 +463,6 @@ SELECT dblink_disconnect('myconn');
(1 row) (1 row)
-- close the named persistent connection again -- close the named persistent connection again
-- should get "connection named "myconn" not found" error -- should get 'connection "myconn" not available' error
SELECT dblink_disconnect('myconn'); SELECT dblink_disconnect('myconn');
ERROR: dblink_disconnect: connection named "myconn" not found ERROR: connection "myconn" not available
...@@ -98,7 +98,7 @@ FROM dblink_fetch('rmt_foo_cursor',4) AS t(a int, b text, c text[]); ...@@ -98,7 +98,7 @@ FROM dblink_fetch('rmt_foo_cursor',4) AS t(a int, b text, c text[]);
-- close the cursor -- close the cursor
SELECT dblink_close('rmt_foo_cursor'); SELECT dblink_close('rmt_foo_cursor');
-- should generate "cursor not found: rmt_foo_cursor" error -- should generate 'cursor "rmt_foo_cursor" not found' error
SELECT * SELECT *
FROM dblink_fetch('rmt_foo_cursor',4) AS t(a int, b text, c text[]); FROM dblink_fetch('rmt_foo_cursor',4) AS t(a int, b text, c text[]);
...@@ -162,7 +162,7 @@ FROM dblink('myconn','SELECT * FROM foo') AS t(a int, b text, c text[]) ...@@ -162,7 +162,7 @@ FROM dblink('myconn','SELECT * FROM foo') AS t(a int, b text, c text[])
WHERE t.a > 7; WHERE t.a > 7;
-- create a second named persistent connection -- create a second named persistent connection
-- should error with "cannot save named connection" -- should error with "duplicate connection name"
SELECT dblink_connect('myconn','dbname=regression'); SELECT dblink_connect('myconn','dbname=regression');
-- create a second named persistent connection with a new name -- create a second named persistent connection with a new name
...@@ -193,7 +193,7 @@ FROM dblink_fetch('myconn','rmt_foo_cursor',4) AS t(a int, b text, c text[]); ...@@ -193,7 +193,7 @@ FROM dblink_fetch('myconn','rmt_foo_cursor',4) AS t(a int, b text, c text[]);
-- close the cursor -- close the cursor
SELECT dblink_close('myconn','rmt_foo_cursor'); SELECT dblink_close('myconn','rmt_foo_cursor');
-- should generate "cursor not found: rmt_foo_cursor" error -- should generate 'cursor "rmt_foo_cursor" not found' error
SELECT * SELECT *
FROM dblink_fetch('myconn','rmt_foo_cursor',4) AS t(a int, b text, c text[]); FROM dblink_fetch('myconn','rmt_foo_cursor',4) AS t(a int, b text, c text[]);
...@@ -236,5 +236,5 @@ WHERE a = 11; ...@@ -236,5 +236,5 @@ WHERE a = 11;
SELECT dblink_disconnect('myconn'); SELECT dblink_disconnect('myconn');
-- close the named persistent connection again -- close the named persistent connection again
-- should get "connection named "myconn" not found" error -- should get 'connection "myconn" not available' error
SELECT dblink_disconnect('myconn'); SELECT dblink_disconnect('myconn');
/**************************************************************************** /****************************************************************************
* pending.c * pending.c
* $Id: pending.c,v 1.11 2003/03/20 03:58:13 momjian Exp $ * $Id: pending.c,v 1.12 2003/07/24 17:52:20 tgl Exp $
* *
* This file contains a trigger for Postgresql-7.x to record changes to tables * This file contains a trigger for Postgresql-7.x to record changes to tables
* to a pending table for mirroring. * to a pending table for mirroring.
...@@ -127,12 +127,15 @@ recordchange(PG_FUNCTION_ARGS) ...@@ -127,12 +127,15 @@ recordchange(PG_FUNCTION_ARGS)
if (storePending(fullyqualtblname, beforeTuple, afterTuple, tupdesc, trigdata, op)) if (storePending(fullyqualtblname, beforeTuple, afterTuple, tupdesc, trigdata, op))
{ {
/* An error occoured. Skip the operation. */ /* An error occoured. Skip the operation. */
elog(ERROR, "Operation could not be mirrored"); ereport(ERROR,
(errcode(ERRCODE_TRIGGERED_ACTION_EXCEPTION),
errmsg("operation could not be mirrored")));
return PointerGetDatum(NULL); return PointerGetDatum(NULL);
} }
#if defined DEBUG_OUTPUT #if defined DEBUG_OUTPUT
elog(NOTICE, "Returning on success"); elog(NOTICE, "returning on success");
#endif #endif
SPI_pfree(fullyqualtblname); SPI_pfree(fullyqualtblname);
SPI_finish(); SPI_finish();
...@@ -175,7 +178,7 @@ storePending(char *cpTableName, HeapTuple tBeforeTuple, ...@@ -175,7 +178,7 @@ storePending(char *cpTableName, HeapTuple tBeforeTuple,
vpPlan = SPI_prepare(cpQueryBase, 3, taPlanArgTypes); vpPlan = SPI_prepare(cpQueryBase, 3, taPlanArgTypes);
if (vpPlan == NULL) if (vpPlan == NULL)
elog(NOTICE, "Error creating plan"); elog(NOTICE, "error creating plan");
/* SPI_saveplan(vpPlan); */ /* SPI_saveplan(vpPlan); */
saPlanData[0] = PointerGetDatum(cpTableName); saPlanData[0] = PointerGetDatum(cpTableName);
...@@ -218,7 +221,7 @@ storePending(char *cpTableName, HeapTuple tBeforeTuple, ...@@ -218,7 +221,7 @@ storePending(char *cpTableName, HeapTuple tBeforeTuple,
} }
#if defined DEBUG_OUTPUT #if defined DEBUG_OUTPUT
elog(NOTICE, "Done storing keyinfo"); elog(NOTICE, "done storing keyinfo");
#endif #endif
return iResult; return iResult;
...@@ -241,19 +244,21 @@ storeKeyInfo(char *cpTableName, HeapTuple tTupleData, ...@@ -241,19 +244,21 @@ storeKeyInfo(char *cpTableName, HeapTuple tTupleData,
pplan = SPI_prepare(insQuery, 1, saPlanArgTypes); pplan = SPI_prepare(insQuery, 1, saPlanArgTypes);
if (pplan == NULL) if (pplan == NULL)
{ {
elog(NOTICE, "Could not prepare INSERT plan"); elog(NOTICE, "could not prepare INSERT plan");
return -1; return -1;
} }
/* pplan = SPI_saveplan(pplan); */ /* pplan = SPI_saveplan(pplan); */
cpKeyData = packageData(tTupleData, tTupleDesc, tpTrigData, PRIMARY); cpKeyData = packageData(tTupleData, tTupleDesc, tpTrigData, PRIMARY);
if (cpKeyData == NULL) if (cpKeyData == NULL)
{ ereport(ERROR,
elog(ERROR,"Could not determine primary key data"); (errcode(ERRCODE_UNDEFINED_OBJECT),
return -1; /* cpTableName already contains quotes... */
} errmsg("there is no PRIMARY KEY for table %s",
cpTableName)));
#if defined DEBUG_OUTPUT #if defined DEBUG_OUTPUT
elog(NOTICE, "KeyData: %s", cpKeyData); elog(NOTICE, "key data: %s", cpKeyData);
#endif #endif
saPlanData[0] = PointerGetDatum(cpKeyData); saPlanData[0] = PointerGetDatum(cpKeyData);
...@@ -264,11 +269,11 @@ storeKeyInfo(char *cpTableName, HeapTuple tTupleData, ...@@ -264,11 +269,11 @@ storeKeyInfo(char *cpTableName, HeapTuple tTupleData,
if (iRetCode != SPI_OK_INSERT) if (iRetCode != SPI_OK_INSERT)
{ {
elog(NOTICE, "Error inserting row in pendingDelete"); elog(NOTICE, "error inserting row in pendingDelete");
return -1; return -1;
} }
#if defined DEBUG_OUTPUT #if defined DEBUG_OUTPUT
elog(NOTICE, "Insert successful"); elog(NOTICE, "insert successful");
#endif #endif
return 0; return 0;
...@@ -294,11 +299,9 @@ getPrimaryKey(Oid tblOid) ...@@ -294,11 +299,9 @@ getPrimaryKey(Oid tblOid)
query = SPI_palloc(strlen(queryBase) + MAX_OID_LEN + 1); query = SPI_palloc(strlen(queryBase) + MAX_OID_LEN + 1);
sprintf(query, "%s%d", queryBase, tblOid); sprintf(query, "%s%d", queryBase, tblOid);
ret = SPI_exec(query, 1); ret = SPI_exec(query, 1);
SPI_pfree(query);
if (ret != SPI_OK_SELECT || SPI_processed != 1) if (ret != SPI_OK_SELECT || SPI_processed != 1)
{
elog(NOTICE, "Could not select primary index key");
return NULL; return NULL;
}
resTuple = SPI_tuptable->vals[0]; resTuple = SPI_tuptable->vals[0];
resDatum = SPI_getbinval(resTuple, SPI_tuptable->tupdesc, 1, &isNull); resDatum = SPI_getbinval(resTuple, SPI_tuptable->tupdesc, 1, &isNull);
...@@ -307,7 +310,6 @@ getPrimaryKey(Oid tblOid) ...@@ -307,7 +310,6 @@ getPrimaryKey(Oid tblOid)
resultKey = SPI_palloc(sizeof(int2vector)); resultKey = SPI_palloc(sizeof(int2vector));
memcpy(resultKey, tpResultKey, sizeof(int2vector)); memcpy(resultKey, tpResultKey, sizeof(int2vector));
SPI_pfree(query);
return resultKey; return resultKey;
} }
...@@ -329,7 +331,7 @@ storeData(char *cpTableName, HeapTuple tTupleData, TupleDesc tTupleDesc, ...@@ -329,7 +331,7 @@ storeData(char *cpTableName, HeapTuple tTupleData, TupleDesc tTupleDesc,
pplan = SPI_prepare(insQuery, 1, planArgTypes); pplan = SPI_prepare(insQuery, 1, planArgTypes);
if (pplan == NULL) if (pplan == NULL)
{ {
elog(NOTICE, "Could not prepare INSERT plan"); elog(NOTICE, "could not prepare INSERT plan");
return -1; return -1;
} }
...@@ -347,11 +349,11 @@ storeData(char *cpTableName, HeapTuple tTupleData, TupleDesc tTupleDesc, ...@@ -347,11 +349,11 @@ storeData(char *cpTableName, HeapTuple tTupleData, TupleDesc tTupleDesc,
if (iRetValue != SPI_OK_INSERT) if (iRetValue != SPI_OK_INSERT)
{ {
elog(NOTICE, "Error inserting row in pendingDelete"); elog(NOTICE, "error inserting row in pendingDelete");
return -1; return -1;
} }
#if defined DEBUG_OUTPUT #if defined DEBUG_OUTPUT
elog(NOTICE, "Insert successful"); elog(NOTICE, "insert successful");
#endif #endif
return 0; return 0;
...@@ -394,7 +396,7 @@ packageData(HeapTuple tTupleData, TupleDesc tTupleDesc, ...@@ -394,7 +396,7 @@ packageData(HeapTuple tTupleData, TupleDesc tTupleDesc,
} }
#if defined DEBUG_OUTPUT #if defined DEBUG_OUTPUT
if (tpPKeys != NULL) if (tpPKeys != NULL)
elog(NOTICE, "Have primary keys"); elog(NOTICE, "have primary keys");
#endif #endif
cpDataBlock = SPI_palloc(BUFFER_SIZE); cpDataBlock = SPI_palloc(BUFFER_SIZE);
iDataBlockSize = BUFFER_SIZE; iDataBlockSize = BUFFER_SIZE;
...@@ -429,7 +431,7 @@ packageData(HeapTuple tTupleData, TupleDesc tTupleDesc, ...@@ -429,7 +431,7 @@ packageData(HeapTuple tTupleData, TupleDesc tTupleDesc,
* Don't use. * Don't use.
*/ */
#if defined DEBUG_OUTPUT #if defined DEBUG_OUTPUT
elog(NOTICE, "Skipping column"); elog(NOTICE, "skipping column");
#endif #endif
continue; continue;
} }
...@@ -437,7 +439,7 @@ packageData(HeapTuple tTupleData, TupleDesc tTupleDesc, ...@@ -437,7 +439,7 @@ packageData(HeapTuple tTupleData, TupleDesc tTupleDesc,
cpFieldName = DatumGetPointer(NameGetDatum(&tTupleDesc->attrs cpFieldName = DatumGetPointer(NameGetDatum(&tTupleDesc->attrs
[iColumnCounter - 1]->attname)); [iColumnCounter - 1]->attname));
#if defined DEBUG_OUTPUT #if defined DEBUG_OUTPUT
elog(NOTICE, "FieldName: %s", cpFieldName); elog(NOTICE, "field name: %s", cpFieldName);
#endif #endif
while (iDataBlockSize - iUsedDataBlock < strlen(cpFieldName) + 6) while (iDataBlockSize - iUsedDataBlock < strlen(cpFieldName) + 6)
{ {
...@@ -465,8 +467,8 @@ packageData(HeapTuple tTupleData, TupleDesc tTupleDesc, ...@@ -465,8 +467,8 @@ packageData(HeapTuple tTupleData, TupleDesc tTupleDesc,
} }
#if defined DEBUG_OUTPUT #if defined DEBUG_OUTPUT
elog(NOTICE, "FieldData: %s", cpFieldData); elog(NOTICE, "field data: \"%s\"", cpFieldData);
elog(NOTICE, "Starting format loop"); elog(NOTICE, "starting format loop");
#endif #endif
while (*cpUnFormatedPtr != 0) while (*cpUnFormatedPtr != 0)
{ {
...@@ -499,14 +501,14 @@ packageData(HeapTuple tTupleData, TupleDesc tTupleDesc, ...@@ -499,14 +501,14 @@ packageData(HeapTuple tTupleData, TupleDesc tTupleDesc,
sprintf(cpFormatedPtr, "' "); sprintf(cpFormatedPtr, "' ");
iUsedDataBlock = iUsedDataBlock + 2; iUsedDataBlock = iUsedDataBlock + 2;
#if defined DEBUG_OUTPUT #if defined DEBUG_OUTPUT
elog(NOTICE, "DataBlock: %s", cpDataBlock); elog(NOTICE, "data block: \"%s\"", cpDataBlock);
#endif #endif
} /* for iColumnCounter */ } /* for iColumnCounter */
if (tpPKeys != NULL) if (tpPKeys != NULL)
SPI_pfree(tpPKeys); SPI_pfree(tpPKeys);
#if defined DEBUG_OUTPUT #if defined DEBUG_OUTPUT
elog(NOTICE, "Returning: DataBlockSize:%d iUsedDataBlock:%d",iDataBlockSize, elog(NOTICE, "returning DataBlockSize:%d iUsedDataBlock:%d",iDataBlockSize,
iUsedDataBlock); iUsedDataBlock);
#endif #endif
memset(cpDataBlock + iUsedDataBlock, 0, iDataBlockSize - iUsedDataBlock); memset(cpDataBlock + iUsedDataBlock, 0, iDataBlockSize - iUsedDataBlock);
......
...@@ -52,13 +52,17 @@ database_size(PG_FUNCTION_ARGS) ...@@ -52,13 +52,17 @@ database_size(PG_FUNCTION_ARGS)
dbid = get_database_oid(NameStr(*dbname)); dbid = get_database_oid(NameStr(*dbname));
if (!OidIsValid(dbid)) if (!OidIsValid(dbid))
elog(ERROR, "database %s does not exist", NameStr(*dbname)); ereport(ERROR,
(errcode(ERRCODE_UNDEFINED_DATABASE),
errmsg("database \"%s\" does not exist", NameStr(*dbname))));
dbpath = GetDatabasePath(dbid); dbpath = GetDatabasePath(dbid);
dirdesc = opendir(dbpath); dirdesc = opendir(dbpath);
if (!dirdesc) if (!dirdesc)
elog(ERROR, "could not open directory %s: %s", dbpath, strerror(errno)); ereport(ERROR,
(errcode_for_file_access(),
errmsg("could not open directory \"%s\": %m", dbpath)));
totalsize = 0; totalsize = 0;
for (;;) for (;;)
...@@ -71,7 +75,9 @@ database_size(PG_FUNCTION_ARGS) ...@@ -71,7 +75,9 @@ database_size(PG_FUNCTION_ARGS)
if (!direntry) if (!direntry)
{ {
if (errno) if (errno)
elog(ERROR, "error reading directory: %s", strerror(errno)); ereport(ERROR,
(errcode_for_file_access(),
errmsg("error reading directory: %m")));
else else
break; break;
} }
...@@ -79,7 +85,10 @@ database_size(PG_FUNCTION_ARGS) ...@@ -79,7 +85,10 @@ database_size(PG_FUNCTION_ARGS)
fullname = psnprintf(strlen(dbpath) + 1 + strlen(direntry->d_name) + 1, fullname = psnprintf(strlen(dbpath) + 1 + strlen(direntry->d_name) + 1,
"%s/%s", dbpath, direntry->d_name); "%s/%s", dbpath, direntry->d_name);
if (stat(fullname, &statbuf) == -1) if (stat(fullname, &statbuf) == -1)
elog(ERROR, "could not stat %s: %s", fullname, strerror(errno)); ereport(ERROR,
(errcode_for_file_access(),
errmsg("could not stat \"%s\": %m", fullname)));
totalsize += statbuf.st_size; totalsize += statbuf.st_size;
pfree(fullname); pfree(fullname);
} }
...@@ -133,7 +142,9 @@ relation_size(PG_FUNCTION_ARGS) ...@@ -133,7 +142,9 @@ relation_size(PG_FUNCTION_ARGS)
if (errno == ENOENT) if (errno == ENOENT)
break; break;
else else
elog(ERROR, "could not stat %s: %m", fullname); ereport(ERROR,
(errcode_for_file_access(),
errmsg("could not stat \"%s\": %m", fullname)));
} }
totalsize += statbuf.st_size; totalsize += statbuf.st_size;
pfree(fullname); pfree(fullname);
......
...@@ -49,7 +49,7 @@ CREATE OR REPLACE FUNCTION ll_to_earth(float8, float8) ...@@ -49,7 +49,7 @@ CREATE OR REPLACE FUNCTION ll_to_earth(float8, float8)
RETURNS earth RETURNS earth
LANGUAGE 'sql' LANGUAGE 'sql'
IMMUTABLE STRICT IMMUTABLE STRICT
AS 'SELECT cube(cube(cube(earth()*cos(radians($1))*cos(radians($2))),earth()*cos(radians($1))*sin(radians($2))),earth()*sin(radians($1)))'; AS 'SELECT cube(cube(cube(earth()*cos(radians($1))*cos(radians($2))),earth()*cos(radians($1))*sin(radians($2))),earth()*sin(radians($1)))::earth';
CREATE OR REPLACE FUNCTION latitude(earth) CREATE OR REPLACE FUNCTION latitude(earth)
RETURNS float8 RETURNS float8
......
...@@ -6,8 +6,9 @@ ...@@ -6,8 +6,9 @@
-- does not depend on contents of earthdistance.sql or cube.sql. -- does not depend on contents of earthdistance.sql or cube.sql.
-- --
\set ECHO none \set ECHO none
psql:../cube/cube.sql:10: NOTICE: ProcedureCreate: type cube is not yet defined psql:../cube/cube.sql:10: NOTICE: type cube is not yet defined
psql:../cube/cube.sql:15: NOTICE: Argument type "cube" is only a shell DETAIL: Creating a shell type definition.
psql:../cube/cube.sql:15: NOTICE: argument type cube is only a shell
-- --
-- The radius of the Earth we are using. -- The radius of the Earth we are using.
-- --
...@@ -879,9 +880,8 @@ SELECT earth_box(ll_to_earth(90,180), ...@@ -879,9 +880,8 @@ SELECT earth_box(ll_to_earth(90,180),
-- Test the recommended constraints. -- Test the recommended constraints.
-- --
SELECT is_point(ll_to_earth(0,0)); SELECT is_point(ll_to_earth(0,0));
ERROR: Function is_point(earth) does not exist ERROR: function is_point(earth) does not exist
Unable to identify a function that satisfies the given argument types HINT: No function matches the given name and argument types. You may need to add explicit typecasts.
You may need to add explicit typecasts
SELECT cube_dim(ll_to_earth(0,0)) <= 3; SELECT cube_dim(ll_to_earth(0,0)) <= 3;
?column? ?column?
---------- ----------
...@@ -896,9 +896,8 @@ SELECT abs(cube_distance(ll_to_earth(0,0), '(0)'::cube) / earth() - 1) < ...@@ -896,9 +896,8 @@ SELECT abs(cube_distance(ll_to_earth(0,0), '(0)'::cube) / earth() - 1) <
(1 row) (1 row)
SELECT is_point(ll_to_earth(30,60)); SELECT is_point(ll_to_earth(30,60));
ERROR: Function is_point(earth) does not exist ERROR: function is_point(earth) does not exist
Unable to identify a function that satisfies the given argument types HINT: No function matches the given name and argument types. You may need to add explicit typecasts.
You may need to add explicit typecasts
SELECT cube_dim(ll_to_earth(30,60)) <= 3; SELECT cube_dim(ll_to_earth(30,60)) <= 3;
?column? ?column?
---------- ----------
...@@ -913,9 +912,8 @@ SELECT abs(cube_distance(ll_to_earth(30,60), '(0)'::cube) / earth() - 1) < ...@@ -913,9 +912,8 @@ SELECT abs(cube_distance(ll_to_earth(30,60), '(0)'::cube) / earth() - 1) <
(1 row) (1 row)
SELECT is_point(ll_to_earth(60,90)); SELECT is_point(ll_to_earth(60,90));
ERROR: Function is_point(earth) does not exist ERROR: function is_point(earth) does not exist
Unable to identify a function that satisfies the given argument types HINT: No function matches the given name and argument types. You may need to add explicit typecasts.
You may need to add explicit typecasts
SELECT cube_dim(ll_to_earth(60,90)) <= 3; SELECT cube_dim(ll_to_earth(60,90)) <= 3;
?column? ?column?
---------- ----------
...@@ -930,9 +928,8 @@ SELECT abs(cube_distance(ll_to_earth(60,90), '(0)'::cube) / earth() - 1) < ...@@ -930,9 +928,8 @@ SELECT abs(cube_distance(ll_to_earth(60,90), '(0)'::cube) / earth() - 1) <
(1 row) (1 row)
SELECT is_point(ll_to_earth(-30,-90)); SELECT is_point(ll_to_earth(-30,-90));
ERROR: Function is_point(earth) does not exist ERROR: function is_point(earth) does not exist
Unable to identify a function that satisfies the given argument types HINT: No function matches the given name and argument types. You may need to add explicit typecasts.
You may need to add explicit typecasts
SELECT cube_dim(ll_to_earth(-30,-90)) <= 3; SELECT cube_dim(ll_to_earth(-30,-90)) <= 3;
?column? ?column?
---------- ----------
......
...@@ -151,15 +151,21 @@ fti(PG_FUNCTION_ARGS) ...@@ -151,15 +151,21 @@ fti(PG_FUNCTION_ARGS)
*/ */
if (!CALLED_AS_TRIGGER(fcinfo)) if (!CALLED_AS_TRIGGER(fcinfo))
elog(ERROR, "Full Text Indexing: Not fired by trigger manager"); /* internal error */
elog(ERROR, "not fired by trigger manager");
/* It's safe to cast now that we've checked */ /* It's safe to cast now that we've checked */
trigdata = (TriggerData *) fcinfo->context; trigdata = (TriggerData *) fcinfo->context;
if (TRIGGER_FIRED_FOR_STATEMENT(trigdata->tg_event)) if (TRIGGER_FIRED_FOR_STATEMENT(trigdata->tg_event))
elog(ERROR, "Full Text Indexing: Can't process STATEMENT events"); ereport(ERROR,
(errcode(ERRCODE_TRIGGERED_ACTION_EXCEPTION),
errmsg("can't process STATEMENT events")));
if (TRIGGER_FIRED_BEFORE(trigdata->tg_event)) if (TRIGGER_FIRED_BEFORE(trigdata->tg_event))
elog(ERROR, "Full Text Indexing: Must be fired AFTER event"); ereport(ERROR,
(errcode(ERRCODE_TRIGGERED_ACTION_EXCEPTION),
errmsg("must be fired AFTER event")));
if (TRIGGER_FIRED_BY_INSERT(trigdata->tg_event)) if (TRIGGER_FIRED_BY_INSERT(trigdata->tg_event))
isinsert = true; isinsert = true;
...@@ -179,11 +185,14 @@ fti(PG_FUNCTION_ARGS) ...@@ -179,11 +185,14 @@ fti(PG_FUNCTION_ARGS)
rettuple = trigdata->tg_newtuple; rettuple = trigdata->tg_newtuple;
if ((ret = SPI_connect()) < 0) if ((ret = SPI_connect()) < 0)
elog(ERROR, "Full Text Indexing: SPI_connect: Failed, returned %d\n", ret); /* internal error */
elog(ERROR, "SPI_connect failed, returned %d", ret);
nargs = trigger->tgnargs; nargs = trigger->tgnargs;
if (nargs < 2) if (nargs < 2)
elog(ERROR, "Full Text Indexing: Trigger must have at least 2 arguments\n"); ereport(ERROR,
(errcode(ERRCODE_TRIGGERED_ACTION_EXCEPTION),
errmsg("fti trigger must have at least 2 arguments")));
args = trigger->tgargs; args = trigger->tgargs;
indexname = args[0]; indexname = args[0];
...@@ -192,7 +201,10 @@ fti(PG_FUNCTION_ARGS) ...@@ -192,7 +201,10 @@ fti(PG_FUNCTION_ARGS)
/* get oid of current tuple, needed by all, so place here */ /* get oid of current tuple, needed by all, so place here */
oid = HeapTupleGetOid(rettuple); oid = HeapTupleGetOid(rettuple);
if (!OidIsValid(oid)) if (!OidIsValid(oid))
elog(ERROR, "Full Text Indexing: Oid of current tuple is invalid"); ereport(ERROR,
(errcode(ERRCODE_UNDEFINED_COLUMN),
errmsg("OID is not present"),
errhint("Full Text Index requires indexed tables be created WITH OIDS.")));
if (isdelete) if (isdelete)
{ {
...@@ -216,10 +228,12 @@ fti(PG_FUNCTION_ARGS) ...@@ -216,10 +228,12 @@ fti(PG_FUNCTION_ARGS)
snprintf(query, MAX_FTI_QUERY_LENGTH, "DELETE FROM %s WHERE id = $1", indexname); snprintf(query, MAX_FTI_QUERY_LENGTH, "DELETE FROM %s WHERE id = $1", indexname);
pplan = SPI_prepare(query, 1, argtypes); pplan = SPI_prepare(query, 1, argtypes);
if (!pplan) if (!pplan)
elog(ERROR, "Full Text Indexing: SPI_prepare: Returned NULL in delete"); /* internal error */
elog(ERROR, "SPI_prepare returned NULL in delete");
pplan = SPI_saveplan(pplan); pplan = SPI_saveplan(pplan);
if (pplan == NULL) if (pplan == NULL)
elog(ERROR, "Full Text Indexing: SPI_saveplan: Returned NULL in delete"); /* internal error */
elog(ERROR, "SPI_saveplan returned NULL in delete");
plan->splan = (void **) malloc(sizeof(void *)); plan->splan = (void **) malloc(sizeof(void *));
*(plan->splan) = pplan; *(plan->splan) = pplan;
...@@ -230,7 +244,9 @@ fti(PG_FUNCTION_ARGS) ...@@ -230,7 +244,9 @@ fti(PG_FUNCTION_ARGS)
ret = SPI_execp(*(plan->splan), values, NULL, 0); ret = SPI_execp(*(plan->splan), values, NULL, 0);
if (ret != SPI_OK_DELETE) if (ret != SPI_OK_DELETE)
elog(ERROR, "Full Text Indexing: SPI_execp: Error executing plan in delete"); ereport(ERROR,
(errcode(ERRCODE_TRIGGERED_ACTION_EXCEPTION),
errmsg("error executing delete")));
} }
if (isinsert) if (isinsert)
...@@ -267,11 +283,13 @@ fti(PG_FUNCTION_ARGS) ...@@ -267,11 +283,13 @@ fti(PG_FUNCTION_ARGS)
indexname); indexname);
pplan = SPI_prepare(query, 2, argtypes); pplan = SPI_prepare(query, 2, argtypes);
if (!pplan) if (!pplan)
elog(ERROR, "Full Text Indexing: SPI_prepare: Returned NULL in insert"); /* internal error */
elog(ERROR, "SPI_prepare returned NULL in insert");
pplan = SPI_saveplan(pplan); pplan = SPI_saveplan(pplan);
if (pplan == NULL) if (pplan == NULL)
elog(ERROR, "Full Text Indexing: SPI_saveplan: Returned NULL in insert"); /* internal error */
elog(ERROR, "SPI_saveplan returned NULL in insert");
plan->splan = (void **) malloc(sizeof(void *)); plan->splan = (void **) malloc(sizeof(void *));
*(plan->splan) = pplan; *(plan->splan) = pplan;
...@@ -283,7 +301,10 @@ fti(PG_FUNCTION_ARGS) ...@@ -283,7 +301,10 @@ fti(PG_FUNCTION_ARGS)
{ {
colnum = SPI_fnumber(tupdesc, args[i + 1]); colnum = SPI_fnumber(tupdesc, args[i + 1]);
if (colnum == SPI_ERROR_NOATTRIBUTE) if (colnum == SPI_ERROR_NOATTRIBUTE)
elog(ERROR, "Full Text Indexing: SPI_fnumber: Column '%s' of '%s' not found", args[i + 1], indexname); ereport(ERROR,
(errcode(ERRCODE_UNDEFINED_COLUMN),
errmsg("column \"%s\" of \"%s\" does not exist",
args[i + 1], indexname)));
/* Get the char* representation of the column */ /* Get the char* representation of the column */
column = SPI_getvalue(rettuple, tupdesc, colnum); column = SPI_getvalue(rettuple, tupdesc, colnum);
...@@ -317,7 +338,9 @@ fti(PG_FUNCTION_ARGS) ...@@ -317,7 +338,9 @@ fti(PG_FUNCTION_ARGS)
ret = SPI_execp(*(plan->splan), values, NULL, 0); ret = SPI_execp(*(plan->splan), values, NULL, 0);
if (ret != SPI_OK_INSERT) if (ret != SPI_OK_INSERT)
elog(ERROR, "Full Text Indexing: SPI_execp: Error executing plan in insert"); ereport(ERROR,
(errcode(ERRCODE_TRIGGERED_ACTION_EXCEPTION),
errmsg("error executing insert")));
} }
pfree(buff); pfree(buff);
pfree(data); pfree(data);
......
...@@ -84,7 +84,10 @@ levenshtein(PG_FUNCTION_ARGS) ...@@ -84,7 +84,10 @@ levenshtein(PG_FUNCTION_ARGS)
* and memory usage). * and memory usage).
*/ */
if ((cols > MAX_LEVENSHTEIN_STRLEN + 1) || (rows > MAX_LEVENSHTEIN_STRLEN + 1)) if ((cols > MAX_LEVENSHTEIN_STRLEN + 1) || (rows > MAX_LEVENSHTEIN_STRLEN + 1))
elog(ERROR, "levenshtein: Arguments may not exceed %d characters in length", MAX_LEVENSHTEIN_STRLEN); ereport(ERROR,
(errcode(ERRCODE_INVALID_PARAMETER_VALUE),
errmsg("argument exceeds max length: %d",
MAX_LEVENSHTEIN_STRLEN)));
/* /*
* If either rows or cols is 0, the answer is the other value. This * If either rows or cols is 0, the answer is the other value. This
...@@ -214,15 +217,28 @@ metaphone(PG_FUNCTION_ARGS) ...@@ -214,15 +217,28 @@ metaphone(PG_FUNCTION_ARGS)
str_i_len = strlen(str_i); str_i_len = strlen(str_i);
if (str_i_len > MAX_METAPHONE_STRLEN) if (str_i_len > MAX_METAPHONE_STRLEN)
elog(ERROR, "metaphone: Input string must not exceed %d characters", MAX_METAPHONE_STRLEN); ereport(ERROR,
(errcode(ERRCODE_INVALID_PARAMETER_VALUE),
errmsg("argument exceeds max length: %d",
MAX_METAPHONE_STRLEN)));
if (!(str_i_len > 0)) if (!(str_i_len > 0))
elog(ERROR, "metaphone: Input string length must be > 0"); ereport(ERROR,
(errcode(ERRCODE_ZERO_LENGTH_CHARACTER_STRING),
errmsg("argument is empty string")));
reqlen = PG_GETARG_INT32(1); reqlen = PG_GETARG_INT32(1);
if (reqlen > MAX_METAPHONE_STRLEN) if (reqlen > MAX_METAPHONE_STRLEN)
elog(ERROR, "metaphone: Requested Metaphone output length must not exceed %d characters", MAX_METAPHONE_STRLEN); ereport(ERROR,
(errcode(ERRCODE_INVALID_PARAMETER_VALUE),
errmsg("output length exceeds max length: %d",
MAX_METAPHONE_STRLEN)));
if (!(reqlen > 0)) if (!(reqlen > 0))
elog(ERROR, "metaphone: Requested Metaphone output length must be > 0"); ereport(ERROR,
(errcode(ERRCODE_ZERO_LENGTH_CHARACTER_STRING),
errmsg("output cannot be empty string")));
retval = _metaphone(str_i, reqlen, &metaph); retval = _metaphone(str_i, reqlen, &metaph);
if (retval == META_SUCCESS) if (retval == META_SUCCESS)
...@@ -232,6 +248,7 @@ metaphone(PG_FUNCTION_ARGS) ...@@ -232,6 +248,7 @@ metaphone(PG_FUNCTION_ARGS)
} }
else else
{ {
/* internal error */
elog(ERROR, "metaphone: failure"); elog(ERROR, "metaphone: failure");
/* /*
...@@ -315,10 +332,12 @@ _metaphone( ...@@ -315,10 +332,12 @@ _metaphone(
/* Negative phoneme length is meaningless */ /* Negative phoneme length is meaningless */
if (!(max_phonemes > 0)) if (!(max_phonemes > 0))
/* internal error */
elog(ERROR, "metaphone: Requested output length must be > 0"); elog(ERROR, "metaphone: Requested output length must be > 0");
/* Empty/null string is meaningless */ /* Empty/null string is meaningless */
if ((word == NULL) || !(strlen(word) > 0)) if ((word == NULL) || !(strlen(word) > 0))
/* internal error */
elog(ERROR, "metaphone: Input string length must be > 0"); elog(ERROR, "metaphone: Input string length must be > 0");
/*-- Allocate memory for our phoned_phrase --*/ /*-- Allocate memory for our phoned_phrase --*/
......
...@@ -160,8 +160,10 @@ int_agg_state(PG_FUNCTION_ARGS) ...@@ -160,8 +160,10 @@ int_agg_state(PG_FUNCTION_ARGS)
PGARRAY *p = GetPGArray(state, 1); PGARRAY *p = GetPGArray(state, 1);
if (!p) if (!p)
elog(ERROR, "No aggregate storage"); /* internal error */
elog(ERROR, "no aggregate storage");
else if (p->items >= p->lower) else if (p->items >= p->lower)
/* internal error */
elog(ERROR, "aggregate storage too small"); elog(ERROR, "aggregate storage too small");
else else
p->array[p->items++] = value; p->array[p->items++] = value;
...@@ -190,11 +192,13 @@ int_enum(PG_FUNCTION_ARGS) ...@@ -190,11 +192,13 @@ int_enum(PG_FUNCTION_ARGS)
ReturnSetInfo *rsi = (ReturnSetInfo *) fcinfo->resultinfo; ReturnSetInfo *rsi = (ReturnSetInfo *) fcinfo->resultinfo;
if (!rsi || !IsA(rsi, ReturnSetInfo)) if (!rsi || !IsA(rsi, ReturnSetInfo))
elog(ERROR, "No ReturnSetInfo sent! function must be declared returning a 'setof' integer"); ereport(ERROR,
(errcode(ERRCODE_FEATURE_NOT_SUPPORTED),
errmsg("int_enum called in context that cannot accept a set")));
if (!p) if (!p)
{ {
elog(WARNING, "No data sent"); elog(WARNING, "no data sent");
PG_RETURN_NULL(); PG_RETURN_NULL();
} }
...@@ -211,7 +215,8 @@ int_enum(PG_FUNCTION_ARGS) ...@@ -211,7 +215,8 @@ int_enum(PG_FUNCTION_ARGS)
pc->flags = TOASTED; pc->flags = TOASTED;
if (!pc->p) if (!pc->p)
{ {
elog(ERROR, "Error in toaster!!! no detoasting"); /* internal error */
elog(ERROR, "error in toaster; not detoasting");
PG_RETURN_NULL(); PG_RETURN_NULL();
} }
} }
......
...@@ -6,8 +6,6 @@ ...@@ -6,8 +6,6 @@
#include "access/itup.h" #include "access/itup.h"
#include "access/rtree.h" #include "access/rtree.h"
#include "catalog/pg_type.h" #include "catalog/pg_type.h"
#include "utils/elog.h"
#include "utils/palloc.h"
#include "utils/array.h" #include "utils/array.h"
#include "utils/builtins.h" #include "utils/builtins.h"
#include "storage/bufpage.h" #include "storage/bufpage.h"
...@@ -34,7 +32,11 @@ ...@@ -34,7 +32,11 @@
#define ARRPTR(x) ( (int4 *) ARR_DATA_PTR(x) ) #define ARRPTR(x) ( (int4 *) ARR_DATA_PTR(x) )
#define ARRNELEMS(x) ArrayGetNItems( ARR_NDIM(x), ARR_DIMS(x)) #define ARRNELEMS(x) ArrayGetNItems( ARR_NDIM(x), ARR_DIMS(x))
#define ARRISVOID(x) ( (x) ? ( ( ARR_NDIM(x) == NDIM ) ? ( ( ARRNELEMS( x ) ) ? 0 : 1 ) : ( ( ARR_NDIM(x) ) ? (elog(ERROR,"Array is not one-dimensional: %d dimensions",ARRNELEMS( x )),1) : 0 ) ) : 0 ) #define ARRISVOID(x) ( (x) ? ( ( ARR_NDIM(x) == NDIM ) ? ( ( ARRNELEMS( x ) ) ? 0 : 1 ) : ( ( ARR_NDIM(x) ) ? ( \
ereport(ERROR, \
(errcode(ERRCODE_ARRAY_SUBSCRIPT_ERROR), \
errmsg("array must be one-dimensional, not %d dimensions", ARRNELEMS( x )))) \
,1) : 0 ) ) : 0 )
#define SORT(x) \ #define SORT(x) \
do { \ do { \
......
...@@ -177,7 +177,9 @@ makepol(WORKSTATE * state) ...@@ -177,7 +177,9 @@ makepol(WORKSTATE * state)
else else
{ {
if (lenstack == STACKDEPTH) if (lenstack == STACKDEPTH)
elog(ERROR, "Stack too short"); ereport(ERROR,
(errcode(ERRCODE_STATEMENT_TOO_COMPLEX),
errmsg("statement too complex")));
stack[lenstack] = val; stack[lenstack] = val;
lenstack++; lenstack++;
} }
...@@ -202,7 +204,9 @@ makepol(WORKSTATE * state) ...@@ -202,7 +204,9 @@ makepol(WORKSTATE * state)
break; break;
case ERR: case ERR:
default: default:
elog(ERROR, "Syntax error"); ereport(ERROR,
(errcode(ERRCODE_SYNTAX_ERROR),
errmsg("syntax error")));
return ERR; return ERR;
} }
...@@ -359,7 +363,7 @@ findoprnd(ITEM * ptr, int4 *pos) ...@@ -359,7 +363,7 @@ findoprnd(ITEM * ptr, int4 *pos)
{ {
#ifdef BS_DEBUG #ifdef BS_DEBUG
elog(DEBUG3, (ptr[*pos].type == OPR) ? elog(DEBUG3, (ptr[*pos].type == OPR) ?
"%d %c" : "%d %d ", *pos, ptr[*pos].val); "%d %c" : "%d %d", *pos, ptr[*pos].val);
#endif #endif
if (ptr[*pos].type == VAL) if (ptr[*pos].type == VAL)
{ {
...@@ -413,7 +417,9 @@ bqarr_in(PG_FUNCTION_ARGS) ...@@ -413,7 +417,9 @@ bqarr_in(PG_FUNCTION_ARGS)
/* make polish notation (postfix, but in reverse order) */ /* make polish notation (postfix, but in reverse order) */
makepol(&state); makepol(&state);
if (!state.num) if (!state.num)
elog(ERROR, "Empty query"); ereport(ERROR,
(errcode(ERRCODE_INVALID_PARAMETER_VALUE),
errmsg("empty query")));
commonlen = COMPUTESIZE(state.num); commonlen = COMPUTESIZE(state.num);
query = (QUERYTYPE *) palloc(commonlen); query = (QUERYTYPE *) palloc(commonlen);
...@@ -548,7 +554,10 @@ bqarr_out(PG_FUNCTION_ARGS) ...@@ -548,7 +554,10 @@ bqarr_out(PG_FUNCTION_ARGS)
INFIX nrm; INFIX nrm;
if (query->size == 0) if (query->size == 0)
elog(ERROR, "Empty"); ereport(ERROR,
(errcode(ERRCODE_INVALID_PARAMETER_VALUE),
errmsg("empty query")));
nrm.curpol = GETQUERY(query) + query->size - 1; nrm.curpol = GETQUERY(query) + query->size - 1;
nrm.buflen = 32; nrm.buflen = 32;
nrm.cur = nrm.buf = (char *) palloc(sizeof(char) * nrm.buflen); nrm.cur = nrm.buf = (char *) palloc(sizeof(char) * nrm.buflen);
...@@ -703,7 +712,9 @@ querytree(PG_FUNCTION_ARGS) ...@@ -703,7 +712,9 @@ querytree(PG_FUNCTION_ARGS)
int4 len; int4 len;
if (query->size == 0) if (query->size == 0)
elog(ERROR, "Empty"); ereport(ERROR,
(errcode(ERRCODE_INVALID_PARAMETER_VALUE),
errmsg("empty query")));
q = (ITEM *) palloc(sizeof(ITEM) * query->size); q = (ITEM *) palloc(sizeof(ITEM) * query->size);
memcpy((void *) q, GETQUERY(query), sizeof(ITEM) * query->size); memcpy((void *) q, GETQUERY(query), sizeof(ITEM) * query->size);
......
...@@ -243,7 +243,9 @@ sort(PG_FUNCTION_ARGS) ...@@ -243,7 +243,9 @@ sort(PG_FUNCTION_ARGS)
&& (d[3] == 'C' || d[3] == 'c')) && (d[3] == 'C' || d[3] == 'c'))
dir = 0; dir = 0;
if (dir == -1) if (dir == -1)
elog(ERROR, "Invalid second parameter in function sort. It must be 'ASC' or 'DESC'."); ereport(ERROR,
(errcode(ERRCODE_INVALID_PARAMETER_VALUE),
errmsg("second parameter must be \"ASC\" or \"DESC\"")));
QSORT(a, dir); QSORT(a, dir);
PG_RETURN_POINTER(a); PG_RETURN_POINTER(a);
} }
......
...@@ -40,13 +40,17 @@ Datum _intbig_out(PG_FUNCTION_ARGS); ...@@ -40,13 +40,17 @@ Datum _intbig_out(PG_FUNCTION_ARGS);
Datum Datum
_intbig_in(PG_FUNCTION_ARGS) { _intbig_in(PG_FUNCTION_ARGS) {
elog(ERROR, "Not implemented"); ereport(ERROR,
(errcode(ERRCODE_FEATURE_NOT_SUPPORTED),
errmsg("_intbig_in() not implemented")));
PG_RETURN_DATUM(0); PG_RETURN_DATUM(0);
} }
Datum Datum
_intbig_out(PG_FUNCTION_ARGS) { _intbig_out(PG_FUNCTION_ARGS) {
elog(ERROR, "Not implemented"); ereport(ERROR,
(errcode(ERRCODE_FEATURE_NOT_SUPPORTED),
errmsg("_intbig_out() not implemented")));
PG_RETURN_DATUM(0); PG_RETURN_DATUM(0);
} }
......
-- --
-- first, define the datatype. Turn off echoing so that expected file -- first, define the datatype. Turn off echoing so that expected file
-- does not depend on contents of seg.sql. -- does not depend on contents of _int.sql.
-- --
\set ECHO none \set ECHO none
psql:_int.sql:13: NOTICE: ProcedureCreate: type query_int is not yet defined psql:_int.sql:13: NOTICE: type query_int is not yet defined
psql:_int.sql:18: NOTICE: Argument type "query_int" is only a shell DETAIL: Creating a shell type definition.
psql:_int.sql:367: NOTICE: ProcedureCreate: type intbig_gkey is not yet defined psql:_int.sql:18: NOTICE: argument type query_int is only a shell
psql:_int.sql:372: NOTICE: Argument type "intbig_gkey" is only a shell psql:_int.sql:367: NOTICE: type intbig_gkey is not yet defined
DETAIL: Creating a shell type definition.
psql:_int.sql:372: NOTICE: argument type intbig_gkey is only a shell
SELECT intset(1234); SELECT intset(1234);
intset intset
-------- --------
......
-- --
-- first, define the datatype. Turn off echoing so that expected file -- first, define the datatype. Turn off echoing so that expected file
-- does not depend on contents of seg.sql. -- does not depend on contents of _int.sql.
-- --
\set ECHO none \set ECHO none
\i _int.sql \i _int.sql
......
/* /*
* PostgreSQL type definitions for ISBNs. * PostgreSQL type definitions for ISBNs.
* *
* $Id: isbn_issn.c,v 1.5 2002/11/04 17:14:29 tgl Exp $ * $Id: isbn_issn.c,v 1.6 2003/07/24 17:52:29 tgl Exp $
*/ */
#include "postgres.h" #include "postgres.h"
...@@ -48,13 +48,19 @@ isbn_in(char *str) ...@@ -48,13 +48,19 @@ isbn_in(char *str)
if (strlen(str) != 13) if (strlen(str) != 13)
{ {
elog(ERROR, "isbn_in: invalid ISBN \"%s\"", str); ereport(ERROR,
(errcode(ERRCODE_INVALID_PARAMETER_VALUE),
errmsg("invalid ISBN: \"%s\"", str),
errdetail("incorrect length")));
return (NULL); return (NULL);
} }
if (isbn_sum(str) != 0) if (isbn_sum(str) != 0)
{ {
elog(ERROR, "isbn_in: purported ISBN \"%s\" failed checksum", ereport(ERROR,
str); (errcode(ERRCODE_INVALID_PARAMETER_VALUE),
errmsg("invalid ISBN: \"%s\"", str),
errdetail("failed checksum")));
return (NULL); return (NULL);
} }
...@@ -236,13 +242,19 @@ issn_in(char *str) ...@@ -236,13 +242,19 @@ issn_in(char *str)
if (strlen(str) != 9) if (strlen(str) != 9)
{ {
elog(ERROR, "issn_in: invalid ISSN \"%s\"", str); ereport(ERROR,
(errcode(ERRCODE_INVALID_PARAMETER_VALUE),
errmsg("invalid ISSN: \"%s\"", str),
errdetail("incorrect length")));
return (NULL); return (NULL);
} }
if (issn_sum(str) != 0) if (issn_sum(str) != 0)
{ {
elog(ERROR, "issn_in: purported ISSN \"%s\" failed checksum", ereport(ERROR,
str); (errcode(ERRCODE_INVALID_PARAMETER_VALUE),
errmsg("invalid ISSN: \"%s\"", str),
errdetail("failed checksum")));
return (NULL); return (NULL);
} }
......
/* /*
* PostgreSQL type definitions for managed LargeObjects. * PostgreSQL type definitions for managed LargeObjects.
* *
* $Header: /cvsroot/pgsql/contrib/lo/lo.c,v 1.12 2002/08/15 02:58:29 momjian Exp $ * $Header: /cvsroot/pgsql/contrib/lo/lo.c,v 1.13 2003/07/24 17:52:30 tgl Exp $
* *
*/ */
...@@ -57,10 +57,14 @@ lo_in(char *str) ...@@ -57,10 +57,14 @@ lo_in(char *str)
count = sscanf(str, "%u", &oid); count = sscanf(str, "%u", &oid);
if (count < 1) if (count < 1)
elog(ERROR, "lo_in: error in parsing \"%s\"", str); ereport(ERROR,
(errcode(ERRCODE_INVALID_PARAMETER_VALUE),
errmsg("error in parsing \"%s\"", str)));
if (oid == InvalidOid) if (oid == InvalidOid)
elog(ERROR, "lo_in: illegal oid \"%s\"", str); ereport(ERROR,
(errcode(ERRCODE_INVALID_PARAMETER_VALUE),
errmsg("illegal oid: \"%s\"", str)));
} }
else else
{ {
...@@ -70,7 +74,8 @@ lo_in(char *str) ...@@ -70,7 +74,8 @@ lo_in(char *str)
oid = DatumGetObjectId(DirectFunctionCall1(lo_creat, oid = DatumGetObjectId(DirectFunctionCall1(lo_creat,
Int32GetDatum(INV_READ | INV_WRITE))); Int32GetDatum(INV_READ | INV_WRITE)));
if (oid == InvalidOid) if (oid == InvalidOid)
elog(ERROR, "lo_in: InvalidOid returned from lo_creat"); /* internal error */
elog(ERROR, "InvalidOid returned from lo_creat");
} }
result = (Blob *) palloc(sizeof(Blob)); result = (Blob *) palloc(sizeof(Blob));
...@@ -143,7 +148,8 @@ lo_manage(PG_FUNCTION_ARGS) ...@@ -143,7 +148,8 @@ lo_manage(PG_FUNCTION_ARGS)
HeapTuple trigtuple; /* The original value of tuple */ HeapTuple trigtuple; /* The original value of tuple */
if (!CALLED_AS_TRIGGER(fcinfo)) if (!CALLED_AS_TRIGGER(fcinfo))
elog(ERROR, "lo: not fired by trigger manager"); /* internal error */
elog(ERROR, "not fired by trigger manager");
/* /*
* Fetch some values from trigdata * Fetch some values from trigdata
......
...@@ -74,7 +74,9 @@ _ltree_compress(PG_FUNCTION_ARGS) ...@@ -74,7 +74,9 @@ _ltree_compress(PG_FUNCTION_ARGS)
ltree *item = (ltree *) ARR_DATA_PTR(val); ltree *item = (ltree *) ARR_DATA_PTR(val);
if (ARR_NDIM(val) != 1) if (ARR_NDIM(val) != 1)
elog(ERROR, "Dimension of array != 1"); ereport(ERROR,
(errcode(ERRCODE_ARRAY_SUBSCRIPT_ERROR),
errmsg("array must be one-dimensional")));
key = (ltree_gist *) palloc(len); key = (ltree_gist *) palloc(len);
key->len = len; key->len = len;
...@@ -502,7 +504,9 @@ _arrq_cons(ltree_gist *key, ArrayType *_query) { ...@@ -502,7 +504,9 @@ _arrq_cons(ltree_gist *key, ArrayType *_query) {
int num = ArrayGetNItems(ARR_NDIM(_query), ARR_DIMS(_query)); int num = ArrayGetNItems(ARR_NDIM(_query), ARR_DIMS(_query));
if (ARR_NDIM(_query) != 1) if (ARR_NDIM(_query) != 1)
elog(ERROR, "Dimension of array != 1"); ereport(ERROR,
(errcode(ERRCODE_ARRAY_SUBSCRIPT_ERROR),
errmsg("array must be one-dimensional")));
while (num > 0) { while (num > 0) {
if ( gist_qe(key, query) ) if ( gist_qe(key, query) )
...@@ -545,7 +549,8 @@ _ltree_consistent(PG_FUNCTION_ARGS) ...@@ -545,7 +549,8 @@ _ltree_consistent(PG_FUNCTION_ARGS)
res = _arrq_cons(key, (ArrayType *) query); res = _arrq_cons(key, (ArrayType *) query);
break; break;
default: default:
elog(ERROR, "Unknown StrategyNumber: %d", strategy); /* internal error */
elog(ERROR, "unrecognized StrategyNumber: %d", strategy);
} }
PG_RETURN_BOOL(res); PG_RETURN_BOOL(res);
} }
...@@ -44,7 +44,9 @@ array_iterator(ArrayType *la, PGCALL2 callback, void *param, ltree ** found) ...@@ -44,7 +44,9 @@ array_iterator(ArrayType *la, PGCALL2 callback, void *param, ltree ** found)
ltree *item = (ltree *) ARR_DATA_PTR(la); ltree *item = (ltree *) ARR_DATA_PTR(la);
if (ARR_NDIM(la) != 1) if (ARR_NDIM(la) != 1)
elog(ERROR, "Dimension of array != 1"); ereport(ERROR,
(errcode(ERRCODE_ARRAY_SUBSCRIPT_ERROR),
errmsg("array must be one-dimensional")));
if (found) if (found)
*found = NULL; *found = NULL;
...@@ -138,7 +140,9 @@ _lt_q_regex(PG_FUNCTION_ARGS) ...@@ -138,7 +140,9 @@ _lt_q_regex(PG_FUNCTION_ARGS)
int num = ArrayGetNItems(ARR_NDIM(_query), ARR_DIMS(_query)); int num = ArrayGetNItems(ARR_NDIM(_query), ARR_DIMS(_query));
if (ARR_NDIM(_query) != 1) if (ARR_NDIM(_query) != 1)
elog(ERROR, "Dimension of array != 1"); ereport(ERROR,
(errcode(ERRCODE_ARRAY_SUBSCRIPT_ERROR),
errmsg("array must be one-dimensional")));
while (num > 0) { while (num > 0) {
if ( array_iterator(_tree, ltq_regex, (void*)query, NULL) ) { if ( array_iterator(_tree, ltq_regex, (void*)query, NULL) ) {
......
\set ECHO none \set ECHO none
psql:ltree.sql:7: NOTICE: ProcedureCreate: type ltree is not yet defined psql:ltree.sql:7: NOTICE: type ltree is not yet defined
psql:ltree.sql:12: NOTICE: Argument type "ltree" is only a shell DETAIL: Creating a shell type definition.
psql:ltree.sql:299: NOTICE: ProcedureCreate: type lquery is not yet defined psql:ltree.sql:12: NOTICE: argument type ltree is only a shell
psql:ltree.sql:304: NOTICE: Argument type "lquery" is only a shell psql:ltree.sql:299: NOTICE: type lquery is not yet defined
psql:ltree.sql:410: NOTICE: ProcedureCreate: type ltxtquery is not yet defined DETAIL: Creating a shell type definition.
psql:ltree.sql:415: NOTICE: Argument type "ltxtquery" is only a shell psql:ltree.sql:304: NOTICE: argument type lquery is only a shell
psql:ltree.sql:477: NOTICE: ProcedureCreate: type ltree_gist is not yet defined psql:ltree.sql:410: NOTICE: type ltxtquery is not yet defined
psql:ltree.sql:482: NOTICE: Argument type "ltree_gist" is only a shell DETAIL: Creating a shell type definition.
psql:ltree.sql:415: NOTICE: argument type ltxtquery is only a shell
psql:ltree.sql:477: NOTICE: type ltree_gist is not yet defined
DETAIL: Creating a shell type definition.
psql:ltree.sql:482: NOTICE: argument type ltree_gist is only a shell
SELECT ''::ltree; SELECT ''::ltree;
ltree ltree
------- -------
......
...@@ -317,7 +317,9 @@ lt_q_regex(PG_FUNCTION_ARGS) ...@@ -317,7 +317,9 @@ lt_q_regex(PG_FUNCTION_ARGS)
int num = ArrayGetNItems(ARR_NDIM(_query), ARR_DIMS(_query)); int num = ArrayGetNItems(ARR_NDIM(_query), ARR_DIMS(_query));
if (ARR_NDIM(_query) != 1) if (ARR_NDIM(_query) != 1)
elog(ERROR, "Dimension of array != 1"); ereport(ERROR,
(errcode(ERRCODE_ARRAY_SUBSCRIPT_ERROR),
errmsg("array must be one-dimensional")));
while (num > 0) { while (num > 0) {
if (DatumGetBool(DirectFunctionCall2(ltq_regex, if (DatumGetBool(DirectFunctionCall2(ltq_regex,
......
...@@ -21,14 +21,18 @@ Datum ltree_gist_out(PG_FUNCTION_ARGS); ...@@ -21,14 +21,18 @@ Datum ltree_gist_out(PG_FUNCTION_ARGS);
Datum Datum
ltree_gist_in(PG_FUNCTION_ARGS) ltree_gist_in(PG_FUNCTION_ARGS)
{ {
elog(ERROR, "Unimplemented"); ereport(ERROR,
(errcode(ERRCODE_FEATURE_NOT_SUPPORTED),
errmsg("ltree_gist_in() not implemented")));
PG_RETURN_DATUM(0); PG_RETURN_DATUM(0);
} }
Datum Datum
ltree_gist_out(PG_FUNCTION_ARGS) ltree_gist_out(PG_FUNCTION_ARGS)
{ {
elog(ERROR, "Unimplemented"); ereport(ERROR,
(errcode(ERRCODE_FEATURE_NOT_SUPPORTED),
errmsg("ltree_gist_out() not implemented")));
PG_RETURN_DATUM(0); PG_RETURN_DATUM(0);
} }
...@@ -604,7 +608,9 @@ arrq_cons(ltree_gist *key, ArrayType *_query) { ...@@ -604,7 +608,9 @@ arrq_cons(ltree_gist *key, ArrayType *_query) {
int num = ArrayGetNItems(ARR_NDIM(_query), ARR_DIMS(_query)); int num = ArrayGetNItems(ARR_NDIM(_query), ARR_DIMS(_query));
if (ARR_NDIM(_query) != 1) if (ARR_NDIM(_query) != 1)
elog(ERROR, "Dimension of array != 1"); ereport(ERROR,
(errcode(ERRCODE_ARRAY_SUBSCRIPT_ERROR),
errmsg("array must be one-dimensional")));
while (num > 0) { while (num > 0) {
if ( gist_qe(key, query) && gist_between(key, query) ) if ( gist_qe(key, query) && gist_between(key, query) )
...@@ -701,7 +707,8 @@ ltree_consistent(PG_FUNCTION_ARGS) ...@@ -701,7 +707,8 @@ ltree_consistent(PG_FUNCTION_ARGS)
res = arrq_cons(key, (ArrayType *) query); res = arrq_cons(key, (ArrayType *) query);
break; break;
default: default:
elog(ERROR, "Unknown StrategyNumber: %d", strategy); /* internal error */
elog(ERROR, "unrecognized StrategyNumber: %d", strategy);
} }
PG_RETURN_BOOL(res); PG_RETURN_BOOL(res);
} }
...@@ -20,7 +20,11 @@ PG_FUNCTION_INFO_V1(lquery_out); ...@@ -20,7 +20,11 @@ PG_FUNCTION_INFO_V1(lquery_out);
Datum lquery_out(PG_FUNCTION_ARGS); Datum lquery_out(PG_FUNCTION_ARGS);
#define UNCHAR elog(ERROR,"Syntax error in position %d near '%c'", (int)(ptr-buf), *ptr) #define UNCHAR ereport(ERROR, \
(errcode(ERRCODE_SYNTAX_ERROR), \
errmsg("syntax error at position %d near \"%c\"", \
(int)(ptr-buf), *ptr)));
typedef struct typedef struct
{ {
...@@ -73,8 +77,13 @@ ltree_in(PG_FUNCTION_ARGS) ...@@ -73,8 +77,13 @@ ltree_in(PG_FUNCTION_ARGS)
{ {
lptr->len = ptr - lptr->start; lptr->len = ptr - lptr->start;
if (lptr->len > 255) if (lptr->len > 255)
elog(ERROR, "Name of level is too long (%d, must be < 256) in position %d", ereport(ERROR,
lptr->len, (int) (lptr->start - buf)); (errcode(ERRCODE_NAME_TOO_LONG),
errmsg("name of level is too long"),
errdetail("name length is %d, must " \
"be < 256, in position %d",
lptr->len, (int) (lptr->start - buf))));
totallen += MAXALIGN(lptr->len + LEVEL_HDRSIZE); totallen += MAXALIGN(lptr->len + LEVEL_HDRSIZE);
lptr++; lptr++;
state = LTPRS_WAITNAME; state = LTPRS_WAITNAME;
...@@ -83,7 +92,8 @@ ltree_in(PG_FUNCTION_ARGS) ...@@ -83,7 +92,8 @@ ltree_in(PG_FUNCTION_ARGS)
UNCHAR; UNCHAR;
} }
else else
elog(ERROR, "Inner error in parser"); /* internal error */
elog(ERROR, "internal error in parser");
ptr++; ptr++;
} }
...@@ -91,13 +101,21 @@ ltree_in(PG_FUNCTION_ARGS) ...@@ -91,13 +101,21 @@ ltree_in(PG_FUNCTION_ARGS)
{ {
lptr->len = ptr - lptr->start; lptr->len = ptr - lptr->start;
if (lptr->len > 255) if (lptr->len > 255)
elog(ERROR, "Name of level is too long (%d, must be < 256) in position %d", ereport(ERROR,
lptr->len, (int) (lptr->start - buf)); (errcode(ERRCODE_NAME_TOO_LONG),
errmsg("name of level is too long"),
errdetail("name length is %d, must " \
"be < 256, in position %d",
lptr->len, (int) (lptr->start - buf))));
totallen += MAXALIGN(lptr->len + LEVEL_HDRSIZE); totallen += MAXALIGN(lptr->len + LEVEL_HDRSIZE);
lptr++; lptr++;
} }
else if (!(state == LTPRS_WAITNAME && lptr == list)) else if (!(state == LTPRS_WAITNAME && lptr == list))
elog(ERROR, "Unexpected end of line"); ereport(ERROR,
(errcode(ERRCODE_SYNTAX_ERROR),
errmsg("syntax error"),
errdetail("Unexpected end of line.")));
result = (ltree *) palloc(LTREE_HDRSIZE + totallen); result = (ltree *) palloc(LTREE_HDRSIZE + totallen);
result->len = LTREE_HDRSIZE + totallen; result->len = LTREE_HDRSIZE + totallen;
...@@ -261,8 +279,13 @@ lquery_in(PG_FUNCTION_ARGS) ...@@ -261,8 +279,13 @@ lquery_in(PG_FUNCTION_ARGS)
((lptr->flag & LVAR_INCASE) ? 1 : 0) - ((lptr->flag & LVAR_INCASE) ? 1 : 0) -
((lptr->flag & LVAR_ANYEND) ? 1 : 0); ((lptr->flag & LVAR_ANYEND) ? 1 : 0);
if (lptr->len > 255) if (lptr->len > 255)
elog(ERROR, "Name of level is too long (%d, must be < 256) in position %d", ereport(ERROR,
lptr->len, (int) (lptr->start - buf)); (errcode(ERRCODE_NAME_TOO_LONG),
errmsg("name of level is too long"),
errdetail("name length is %d, must " \
"be < 256, in position %d",
lptr->len, (int) (lptr->start - buf))));
state = LQPRS_WAITVAR; state = LQPRS_WAITVAR;
} }
else if (*ptr == '.') else if (*ptr == '.')
...@@ -272,8 +295,13 @@ lquery_in(PG_FUNCTION_ARGS) ...@@ -272,8 +295,13 @@ lquery_in(PG_FUNCTION_ARGS)
((lptr->flag & LVAR_INCASE) ? 1 : 0) - ((lptr->flag & LVAR_INCASE) ? 1 : 0) -
((lptr->flag & LVAR_ANYEND) ? 1 : 0); ((lptr->flag & LVAR_ANYEND) ? 1 : 0);
if (lptr->len > 255) if (lptr->len > 255)
elog(ERROR, "Name of level is too long (%d, must be < 256) in position %d", ereport(ERROR,
lptr->len, (int) (lptr->start - buf)); (errcode(ERRCODE_NAME_TOO_LONG),
errmsg("name of level is too long"),
errdetail("name length is %d, must " \
"be < 256, in position %d",
lptr->len, (int) (lptr->start - buf))));
state = LQPRS_WAITLEVEL; state = LQPRS_WAITLEVEL;
curqlevel = NEXTLEV(curqlevel); curqlevel = NEXTLEV(curqlevel);
} }
...@@ -356,28 +384,44 @@ lquery_in(PG_FUNCTION_ARGS) ...@@ -356,28 +384,44 @@ lquery_in(PG_FUNCTION_ARGS)
UNCHAR; UNCHAR;
} }
else else
elog(ERROR, "Inner error in parser"); /* internal error */
elog(ERROR, "internal error in parser");
ptr++; ptr++;
} }
if (state == LQPRS_WAITDELIM) if (state == LQPRS_WAITDELIM)
{ {
if (lptr->start == ptr) if (lptr->start == ptr)
elog(ERROR, "Unexpected end of line"); ereport(ERROR,
(errcode(ERRCODE_SYNTAX_ERROR),
errmsg("syntax error"),
errdetail("Unexpected end of line.")));
lptr->len = ptr - lptr->start - lptr->len = ptr - lptr->start -
((lptr->flag & LVAR_SUBLEXEM) ? 1 : 0) - ((lptr->flag & LVAR_SUBLEXEM) ? 1 : 0) -
((lptr->flag & LVAR_INCASE) ? 1 : 0) - ((lptr->flag & LVAR_INCASE) ? 1 : 0) -
((lptr->flag & LVAR_ANYEND) ? 1 : 0); ((lptr->flag & LVAR_ANYEND) ? 1 : 0);
if (lptr->len == 0) if (lptr->len == 0)
elog(ERROR, "Unexpected end of line"); ereport(ERROR,
(errcode(ERRCODE_SYNTAX_ERROR),
errmsg("syntax error"),
errdetail("Unexpected end of line.")));
if (lptr->len > 255) if (lptr->len > 255)
elog(ERROR, "Name of level is too long (%d, must be < 256) in position %d", ereport(ERROR,
lptr->len, (int) (lptr->start - buf)); (errcode(ERRCODE_NAME_TOO_LONG),
errmsg("name of level is too long"),
errdetail("name length is %d, must " \
"be < 256, in position %d",
lptr->len, (int) (lptr->start - buf))));
} }
else if (state == LQPRS_WAITOPEN) else if (state == LQPRS_WAITOPEN)
curqlevel->high = 0xffff; curqlevel->high = 0xffff;
else if (state != LQPRS_WAITEND) else if (state != LQPRS_WAITEND)
elog(ERROR, "Unexpected end of line"); ereport(ERROR,
(errcode(ERRCODE_SYNTAX_ERROR),
errmsg("syntax error"),
errdetail("Unexpected end of line.")));
curqlevel = tmpql; curqlevel = tmpql;
totallen = LQUERY_HDRSIZE; totallen = LQUERY_HDRSIZE;
...@@ -394,7 +438,12 @@ lquery_in(PG_FUNCTION_ARGS) ...@@ -394,7 +438,12 @@ lquery_in(PG_FUNCTION_ARGS)
} }
} }
else if (curqlevel->low > curqlevel->high) else if (curqlevel->low > curqlevel->high)
elog(ERROR, "Low limit(%d) is greater than upper(%d)", curqlevel->low, curqlevel->high); ereport(ERROR,
(errcode(ERRCODE_SYNTAX_ERROR),
errmsg("syntax error"),
errdetail("Low limit(%d) is greater than upper(%d).",
curqlevel->low, curqlevel->high)));
curqlevel = NEXTLEV(curqlevel); curqlevel = NEXTLEV(curqlevel);
} }
......
...@@ -197,7 +197,9 @@ inner_subltree(ltree * t, int4 startpos, int4 endpos) ...@@ -197,7 +197,9 @@ inner_subltree(ltree * t, int4 startpos, int4 endpos)
int i; int i;
if (startpos < 0 || endpos < 0 || startpos >= t->numlevel || startpos > endpos) if (startpos < 0 || endpos < 0 || startpos >= t->numlevel || startpos > endpos)
elog(ERROR, "Wrong positions"); ereport(ERROR,
(errcode(ERRCODE_INVALID_PARAMETER_VALUE),
errmsg("invalid positions")));
if (endpos > t->numlevel) if (endpos > t->numlevel)
endpos = t->numlevel; endpos = t->numlevel;
......
...@@ -81,13 +81,17 @@ gettoken_query(QPRS_STATE * state, int4 *val, int4 *lenval, char **strval, uint1 ...@@ -81,13 +81,17 @@ gettoken_query(QPRS_STATE * state, int4 *val, int4 *lenval, char **strval, uint1
*flag = 0; *flag = 0;
} }
else if (!isspace((unsigned int) *(state->buf))) else if (!isspace((unsigned int) *(state->buf)))
elog(ERROR, "Operand syntax error"); ereport(ERROR,
(errcode(ERRCODE_SYNTAX_ERROR),
errmsg("operand syntax error")));
break; break;
case INOPERAND: case INOPERAND:
if (ISALNUM(*(state->buf))) if (ISALNUM(*(state->buf)))
{ {
if (*flag) if (*flag)
elog(ERROR, "Modificators syntax error"); ereport(ERROR,
(errcode(ERRCODE_SYNTAX_ERROR),
errmsg("modificators syntax error")));
(*lenval)++; (*lenval)++;
} }
else if (*(state->buf) == '%') else if (*(state->buf) == '%')
...@@ -142,9 +146,13 @@ pushquery(QPRS_STATE * state, int4 type, int4 val, int4 distance, int4 lenval, u ...@@ -142,9 +146,13 @@ pushquery(QPRS_STATE * state, int4 type, int4 val, int4 distance, int4 lenval, u
tmp->val = val; tmp->val = val;
tmp->flag = flag; tmp->flag = flag;
if (distance > 0xffff) if (distance > 0xffff)
elog(ERROR, "Value is too big"); ereport(ERROR,
(errcode(ERRCODE_INVALID_PARAMETER_VALUE),
errmsg("value is too big")));
if (lenval > 0xff) if (lenval > 0xff)
elog(ERROR, "Operand is too long"); ereport(ERROR,
(errcode(ERRCODE_INVALID_PARAMETER_VALUE),
errmsg("operand is too long")));
tmp->distance = distance; tmp->distance = distance;
tmp->length = lenval; tmp->length = lenval;
tmp->next = state->str; tmp->next = state->str;
...@@ -159,7 +167,9 @@ static void ...@@ -159,7 +167,9 @@ static void
pushval_asis(QPRS_STATE * state, int type, char *strval, int lenval, uint16 flag) pushval_asis(QPRS_STATE * state, int type, char *strval, int lenval, uint16 flag)
{ {
if (lenval > 0xffff) if (lenval > 0xffff)
elog(ERROR, "Word is too long"); ereport(ERROR,
(errcode(ERRCODE_INVALID_PARAMETER_VALUE),
errmsg("word is too long")));
pushquery(state, type, ltree_crc32_sz((uint8 *) strval, lenval), pushquery(state, type, ltree_crc32_sz((uint8 *) strval, lenval),
state->curop - state->op, lenval, flag); state->curop - state->op, lenval, flag);
...@@ -214,7 +224,8 @@ makepol(QPRS_STATE * state) ...@@ -214,7 +224,8 @@ makepol(QPRS_STATE * state)
else else
{ {
if (lenstack == STACKDEPTH) if (lenstack == STACKDEPTH)
elog(ERROR, "Stack too short"); /* internal error */
elog(ERROR, "stack too short");
stack[lenstack] = val; stack[lenstack] = val;
lenstack++; lenstack++;
} }
...@@ -239,7 +250,10 @@ makepol(QPRS_STATE * state) ...@@ -239,7 +250,10 @@ makepol(QPRS_STATE * state)
break; break;
case ERR: case ERR:
default: default:
elog(ERROR, "Syntax error"); ereport(ERROR,
(errcode(ERRCODE_SYNTAX_ERROR),
errmsg("syntax error")));
return ERR; return ERR;
} }
...@@ -314,7 +328,11 @@ queryin(char *buf) ...@@ -314,7 +328,11 @@ queryin(char *buf)
/* parse query & make polish notation (postfix, but in reverse order) */ /* parse query & make polish notation (postfix, but in reverse order) */
makepol(&state); makepol(&state);
if (!state.num) if (!state.num)
elog(ERROR, "Empty query"); ereport(ERROR,
(errcode(ERRCODE_SYNTAX_ERROR),
errmsg("syntax error"),
errdetail("Empty query.")));
/* make finish struct */ /* make finish struct */
commonlen = COMPUTESIZE(state.num, state.sumlen); commonlen = COMPUTESIZE(state.num, state.sumlen);
query = (ltxtquery *) palloc(commonlen); query = (ltxtquery *) palloc(commonlen);
...@@ -483,7 +501,11 @@ ltxtq_out(PG_FUNCTION_ARGS) ...@@ -483,7 +501,11 @@ ltxtq_out(PG_FUNCTION_ARGS)
INFIX nrm; INFIX nrm;
if (query->size == 0) if (query->size == 0)
elog(ERROR, "Empty"); ereport(ERROR,
(errcode(ERRCODE_SYNTAX_ERROR),
errmsg("syntax error"),
errdetail("Empty query.")));
nrm.curpol = GETQUERY(query); nrm.curpol = GETQUERY(query);
nrm.buflen = 32; nrm.buflen = 32;
nrm.cur = nrm.buf = (char *) palloc(sizeof(char) * nrm.buflen); nrm.cur = nrm.buf = (char *) palloc(sizeof(char) * nrm.buflen);
......
...@@ -40,18 +40,22 @@ noup(PG_FUNCTION_ARGS) ...@@ -40,18 +40,22 @@ noup(PG_FUNCTION_ARGS)
/* Called by trigger manager ? */ /* Called by trigger manager ? */
if (!CALLED_AS_TRIGGER(fcinfo)) if (!CALLED_AS_TRIGGER(fcinfo))
/* internal error */
elog(ERROR, "noup: not fired by trigger manager"); elog(ERROR, "noup: not fired by trigger manager");
/* Should be called for ROW trigger */ /* Should be called for ROW trigger */
if (TRIGGER_FIRED_FOR_STATEMENT(trigdata->tg_event)) if (TRIGGER_FIRED_FOR_STATEMENT(trigdata->tg_event))
/* internal error */
elog(ERROR, "noup: can't process STATEMENT events"); elog(ERROR, "noup: can't process STATEMENT events");
/* Not should be called for INSERT */ /* Should not be called for INSERT */
if (TRIGGER_FIRED_BY_INSERT(trigdata->tg_event)) if (TRIGGER_FIRED_BY_INSERT(trigdata->tg_event))
/* internal error */
elog(ERROR, "noup: can't process INSERT events"); elog(ERROR, "noup: can't process INSERT events");
/* Not should be called for DELETE */ /* Should not be called for DELETE */
else if (TRIGGER_FIRED_BY_DELETE(trigdata->tg_event)) else if (TRIGGER_FIRED_BY_DELETE(trigdata->tg_event))
/* internal error */
elog(ERROR, "noup: can't process DELETE events"); elog(ERROR, "noup: can't process DELETE events");
/* check new Tuple */ /* check new Tuple */
...@@ -67,6 +71,7 @@ noup(PG_FUNCTION_ARGS) ...@@ -67,6 +71,7 @@ noup(PG_FUNCTION_ARGS)
/* Connect to SPI manager */ /* Connect to SPI manager */
if ((ret = SPI_connect()) < 0) if ((ret = SPI_connect()) < 0)
/* internal error */
elog(ERROR, "noup: SPI_connect returned %d", ret); elog(ERROR, "noup: SPI_connect returned %d", ret);
/* /*
...@@ -83,6 +88,7 @@ noup(PG_FUNCTION_ARGS) ...@@ -83,6 +88,7 @@ noup(PG_FUNCTION_ARGS)
/* Bad guys may give us un-existing column in CREATE TRIGGER */ /* Bad guys may give us un-existing column in CREATE TRIGGER */
if (fnumber < 0) if (fnumber < 0)
/* internal error */
elog(ERROR, "noup: there is no attribute %s in relation %s", elog(ERROR, "noup: there is no attribute %s in relation %s",
args[i], SPI_getrelname(rel)); args[i], SPI_getrelname(rel));
...@@ -94,7 +100,6 @@ noup(PG_FUNCTION_ARGS) ...@@ -94,7 +100,6 @@ noup(PG_FUNCTION_ARGS)
*/ */
if (!isnull) if (!isnull)
{ {
elog(WARNING, "%s: update not allowed", args[i]); elog(WARNING, "%s: update not allowed", args[i]);
SPI_finish(); SPI_finish();
return PointerGetDatum(NULL); return PointerGetDatum(NULL);
......
...@@ -26,7 +26,7 @@ ...@@ -26,7 +26,7 @@
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
* SUCH DAMAGE. * SUCH DAMAGE.
* *
* $Id: mhash.c,v 1.7 2001/11/20 18:54:07 momjian Exp $ * $Id: mhash.c,v 1.8 2003/07/24 17:52:33 tgl Exp $
*/ */
#include <postgres.h> #include <postgres.h>
...@@ -143,7 +143,10 @@ cipher_init(PX_Cipher * c, const uint8 *key, unsigned klen, const uint8 *iv) ...@@ -143,7 +143,10 @@ cipher_init(PX_Cipher * c, const uint8 *key, unsigned klen, const uint8 *iv)
err = mcrypt_generic_init(ctx, (char *) key, klen, (char *) iv); err = mcrypt_generic_init(ctx, (char *) key, klen, (char *) iv);
if (err < 0) if (err < 0)
elog(ERROR, "mcrypt_generic_init error: %s", mcrypt_strerror(err)); ereport(ERROR,
(errcode(ERRCODE_EXTERNAL_ROUTINE_INVOCATION_EXCEPTION),
errmsg("mcrypt_generic_init error"),
errdetail("%s", mcrypt_strerror(err))));
c->pstat = 1; c->pstat = 1;
return 0; return 0;
...@@ -159,7 +162,10 @@ cipher_encrypt(PX_Cipher * c, const uint8 *data, unsigned dlen, uint8 *res) ...@@ -159,7 +162,10 @@ cipher_encrypt(PX_Cipher * c, const uint8 *data, unsigned dlen, uint8 *res)
err = mcrypt_generic(ctx, res, dlen); err = mcrypt_generic(ctx, res, dlen);
if (err < 0) if (err < 0)
elog(ERROR, "mcrypt_generic error: %s", mcrypt_strerror(err)); ereport(ERROR,
(errcode(ERRCODE_EXTERNAL_ROUTINE_INVOCATION_EXCEPTION),
errmsg("mcrypt_generic error"),
errdetail("%s", mcrypt_strerror(err))));
return 0; return 0;
} }
...@@ -173,7 +179,10 @@ cipher_decrypt(PX_Cipher * c, const uint8 *data, unsigned dlen, uint8 *res) ...@@ -173,7 +179,10 @@ cipher_decrypt(PX_Cipher * c, const uint8 *data, unsigned dlen, uint8 *res)
err = mdecrypt_generic(ctx, res, dlen); err = mdecrypt_generic(ctx, res, dlen);
if (err < 0) if (err < 0)
elog(ERROR, "mdecrypt_generic error: %s", mcrypt_strerror(err)); ereport(ERROR,
(errcode(ERRCODE_EXTERNAL_ROUTINE_INVOCATION_EXCEPTION),
errmsg("mdecrypt_generic error"),
errdetail("%s", mcrypt_strerror(err))));
return 0; return 0;
} }
......
...@@ -26,7 +26,7 @@ ...@@ -26,7 +26,7 @@
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
* SUCH DAMAGE. * SUCH DAMAGE.
* *
* $Id: pgcrypto.c,v 1.12 2001/12/30 23:09:41 tgl Exp $ * $Id: pgcrypto.c,v 1.13 2003/07/24 17:52:33 tgl Exp $
*/ */
#include <postgres.h> #include <postgres.h>
...@@ -202,7 +202,9 @@ pg_gen_salt(PG_FUNCTION_ARGS) ...@@ -202,7 +202,9 @@ pg_gen_salt(PG_FUNCTION_ARGS)
buf[len] = 0; buf[len] = 0;
len = px_gen_salt(buf, buf, 0); len = px_gen_salt(buf, buf, 0);
if (len == 0) if (len == 0)
elog(ERROR, "No such crypt algorithm"); ereport(ERROR,
(errcode(ERRCODE_INVALID_PARAMETER_VALUE),
errmsg("no such crypt algorithm")));
res = (text *) palloc(len + VARHDRSZ); res = (text *) palloc(len + VARHDRSZ);
VARATT_SIZEP(res) = len + VARHDRSZ; VARATT_SIZEP(res) = len + VARHDRSZ;
...@@ -237,7 +239,9 @@ pg_gen_salt_rounds(PG_FUNCTION_ARGS) ...@@ -237,7 +239,9 @@ pg_gen_salt_rounds(PG_FUNCTION_ARGS)
buf[len] = 0; buf[len] = 0;
len = px_gen_salt(buf, buf, rounds); len = px_gen_salt(buf, buf, rounds);
if (len == 0) if (len == 0)
elog(ERROR, "No such crypt algorithm or bad number of rounds"); ereport(ERROR,
(errcode(ERRCODE_INVALID_PARAMETER_VALUE),
errmsg("no such crypt algorithm or bad number of rounds")));
res = (text *) palloc(len + VARHDRSZ); res = (text *) palloc(len + VARHDRSZ);
VARATT_SIZEP(res) = len + VARHDRSZ; VARATT_SIZEP(res) = len + VARHDRSZ;
...@@ -292,7 +296,9 @@ pg_crypt(PG_FUNCTION_ARGS) ...@@ -292,7 +296,9 @@ pg_crypt(PG_FUNCTION_ARGS)
pfree(buf1); pfree(buf1);
if (cres == NULL) if (cres == NULL)
elog(ERROR, "crypt(3) returned NULL"); ereport(ERROR,
(errcode(ERRCODE_EXTERNAL_ROUTINE_INVOCATION_EXCEPTION),
errmsg("crypt(3) returned NULL")));
clen = strlen(cres); clen = strlen(cres);
...@@ -349,7 +355,9 @@ pg_encrypt(PG_FUNCTION_ARGS) ...@@ -349,7 +355,9 @@ pg_encrypt(PG_FUNCTION_ARGS)
if (err) if (err)
{ {
pfree(res); pfree(res);
elog(ERROR, "encrypt error: %d", err); ereport(ERROR,
(errcode(ERRCODE_EXTERNAL_ROUTINE_INVOCATION_EXCEPTION),
errmsg("encrypt error: %d", err)));
} }
VARATT_SIZEP(res) = VARHDRSZ + rlen; VARATT_SIZEP(res) = VARHDRSZ + rlen;
...@@ -393,7 +401,9 @@ pg_decrypt(PG_FUNCTION_ARGS) ...@@ -393,7 +401,9 @@ pg_decrypt(PG_FUNCTION_ARGS)
px_combo_free(c); px_combo_free(c);
if (err) if (err)
elog(ERROR, "decrypt error: %d", err); ereport(ERROR,
(errcode(ERRCODE_EXTERNAL_ROUTINE_INVOCATION_EXCEPTION),
errmsg("decrypt error: %d", err)));
VARATT_SIZEP(res) = VARHDRSZ + rlen; VARATT_SIZEP(res) = VARHDRSZ + rlen;
...@@ -446,7 +456,9 @@ pg_encrypt_iv(PG_FUNCTION_ARGS) ...@@ -446,7 +456,9 @@ pg_encrypt_iv(PG_FUNCTION_ARGS)
px_combo_free(c); px_combo_free(c);
if (err) if (err)
elog(ERROR, "encrypt_iv error: %d", err); ereport(ERROR,
(errcode(ERRCODE_EXTERNAL_ROUTINE_INVOCATION_EXCEPTION),
errmsg("encrypt_iv error: %d", err)));
VARATT_SIZEP(res) = VARHDRSZ + rlen; VARATT_SIZEP(res) = VARHDRSZ + rlen;
...@@ -500,7 +512,9 @@ pg_decrypt_iv(PG_FUNCTION_ARGS) ...@@ -500,7 +512,9 @@ pg_decrypt_iv(PG_FUNCTION_ARGS)
px_combo_free(c); px_combo_free(c);
if (err) if (err)
elog(ERROR, "decrypt_iv error: %d", err); ereport(ERROR,
(errcode(ERRCODE_EXTERNAL_ROUTINE_INVOCATION_EXCEPTION),
errmsg("decrypt_iv error: %d", err)));
VARATT_SIZEP(res) = VARHDRSZ + rlen; VARATT_SIZEP(res) = VARHDRSZ + rlen;
...@@ -551,7 +565,9 @@ find_provider(text *name, ...@@ -551,7 +565,9 @@ find_provider(text *name,
{ {
if (silent) if (silent)
return NULL; return NULL;
elog(ERROR, "%s type does not exist (name too long)", desc); ereport(ERROR,
(errcode(ERRCODE_INVALID_PARAMETER_VALUE),
errmsg("%s type does not exist (name too long)", desc)));
} }
p = VARDATA(name); p = VARDATA(name);
...@@ -562,7 +578,9 @@ find_provider(text *name, ...@@ -562,7 +578,9 @@ find_provider(text *name,
err = provider_lookup(buf, &res); err = provider_lookup(buf, &res);
if (err && !silent) if (err && !silent)
elog(ERROR, "%s type does not exist: '%s'", desc, buf); ereport(ERROR,
(errcode(ERRCODE_INVALID_PARAMETER_VALUE),
errmsg("%s type does not exist: \"%s\"", desc, buf)));
return err ? NULL : res; return err ? NULL : res;
} }
...@@ -57,10 +57,12 @@ _rserv_log_() ...@@ -57,10 +57,12 @@ _rserv_log_()
/* Called by trigger manager ? */ /* Called by trigger manager ? */
if (!CurrentTriggerData) if (!CurrentTriggerData)
/* internal error */
elog(ERROR, "_rserv_log_: triggers are not initialized"); elog(ERROR, "_rserv_log_: triggers are not initialized");
/* Should be called for ROW trigger */ /* Should be called for ROW trigger */
if (TRIGGER_FIRED_FOR_STATEMENT(CurrentTriggerData->tg_event)) if (TRIGGER_FIRED_FOR_STATEMENT(CurrentTriggerData->tg_event))
/* internal error */
elog(ERROR, "_rserv_log_: can't process STATEMENT events"); elog(ERROR, "_rserv_log_: can't process STATEMENT events");
tuple = CurrentTriggerData->tg_trigtuple; tuple = CurrentTriggerData->tg_trigtuple;
...@@ -70,11 +72,13 @@ _rserv_log_() ...@@ -70,11 +72,13 @@ _rserv_log_()
args = trigger->tgargs; args = trigger->tgargs;
if (nargs != 1) /* odd number of arguments! */ if (nargs != 1) /* odd number of arguments! */
/* internal error */
elog(ERROR, "_rserv_log_: need in *one* argument"); elog(ERROR, "_rserv_log_: need in *one* argument");
keynum = atoi(args[0]); keynum = atoi(args[0]);
if (keynum < 0 && keynum != ObjectIdAttributeNumber) if (keynum < 0 && keynum != ObjectIdAttributeNumber)
/* internal error */
elog(ERROR, "_rserv_log_: invalid keynum %d", keynum); elog(ERROR, "_rserv_log_: invalid keynum %d", keynum);
rel = CurrentTriggerData->tg_relation; rel = CurrentTriggerData->tg_relation;
...@@ -98,6 +102,7 @@ _rserv_log_() ...@@ -98,6 +102,7 @@ _rserv_log_()
/* Connect to SPI manager */ /* Connect to SPI manager */
if ((ret = SPI_connect()) < 0) if ((ret = SPI_connect()) < 0)
/* internal error */
elog(ERROR, "_rserv_log_: SPI_connect returned %d", ret); elog(ERROR, "_rserv_log_: SPI_connect returned %d", ret);
if (keynum == ObjectIdAttributeNumber) if (keynum == ObjectIdAttributeNumber)
...@@ -109,13 +114,17 @@ _rserv_log_() ...@@ -109,13 +114,17 @@ _rserv_log_()
key = SPI_getvalue(tuple, tupdesc, keynum); key = SPI_getvalue(tuple, tupdesc, keynum);
if (key == NULL) if (key == NULL)
elog(ERROR, "_rserv_log_: key must be not null"); ereport(ERROR,
(errcode(ERRCODE_NOT_NULL_VIOLATION),
errmsg("key must be not null")));
if (newtuple && keynum != ObjectIdAttributeNumber) if (newtuple && keynum != ObjectIdAttributeNumber)
{ {
newkey = SPI_getvalue(newtuple, tupdesc, keynum); newkey = SPI_getvalue(newtuple, tupdesc, keynum);
if (newkey == NULL) if (newkey == NULL)
elog(ERROR, "_rserv_log_: key must be not null"); ereport(ERROR,
(errcode(ERRCODE_NOT_NULL_VIOLATION),
errmsg("key must be not null")));
if (strcmp(newkey, key) == 0) if (strcmp(newkey, key) == 0)
newkey = NULL; newkey = NULL;
else else
...@@ -137,13 +146,18 @@ _rserv_log_() ...@@ -137,13 +146,18 @@ _rserv_log_()
ret = SPI_exec(sql, 0); ret = SPI_exec(sql, 0);
if (ret < 0) if (ret < 0)
elog(ERROR, "_rserv_log_: SPI_exec(update) returned %d", ret); ereport(ERROR,
(errcode(ERRCODE_TRIGGERED_ACTION_EXCEPTION),
errmsg("SPI_exec(update) returned %d", ret)));
/* /*
* If no tuple was UPDATEd then do INSERT... * If no tuple was UPDATEd then do INSERT...
*/ */
if (SPI_processed > 1) if (SPI_processed > 1)
elog(ERROR, "_rserv_log_: duplicate tuples"); ereport(ERROR,
(errcode(ERRCODE_TRIGGERED_ACTION_EXCEPTION),
errmsg("duplicate tuples")));
else if (SPI_processed == 0) else if (SPI_processed == 0)
{ {
snprintf(sql, 8192, "insert into _RSERV_LOG_ " snprintf(sql, 8192, "insert into _RSERV_LOG_ "
...@@ -158,7 +172,9 @@ _rserv_log_() ...@@ -158,7 +172,9 @@ _rserv_log_()
ret = SPI_exec(sql, 0); ret = SPI_exec(sql, 0);
if (ret < 0) if (ret < 0)
elog(ERROR, "_rserv_log_: SPI_exec(insert) returned %d", ret); ereport(ERROR,
(errcode(ERRCODE_TRIGGERED_ACTION_EXCEPTION),
errmsg("SPI_exec(insert) returned %d", ret)));
} }
if (okey != key && okey != outbuf) if (okey != key && okey != outbuf)
...@@ -182,7 +198,9 @@ _rserv_log_() ...@@ -182,7 +198,9 @@ _rserv_log_()
ret = SPI_exec(sql, 0); ret = SPI_exec(sql, 0);
if (ret < 0) if (ret < 0)
elog(ERROR, "_rserv_log_: SPI_exec returned %d", ret); ereport(ERROR,
(errcode(ERRCODE_TRIGGERED_ACTION_EXCEPTION),
errmsg("SPI_exec returned %d", ret)));
if (okey != newkey && okey != outbuf) if (okey != newkey && okey != outbuf)
pfree(okey); pfree(okey);
...@@ -215,6 +233,7 @@ _rserv_sync_(int32 server) ...@@ -215,6 +233,7 @@ _rserv_sync_(int32 server)
int ret; int ret;
if (SerializableSnapshot == NULL) if (SerializableSnapshot == NULL)
/* internal error */
elog(ERROR, "_rserv_sync_: SerializableSnapshot is NULL"); elog(ERROR, "_rserv_sync_: SerializableSnapshot is NULL");
buf[0] = 0; buf[0] = 0;
...@@ -226,6 +245,7 @@ _rserv_sync_(int32 server) ...@@ -226,6 +245,7 @@ _rserv_sync_(int32 server)
} }
if ((ret = SPI_connect()) < 0) if ((ret = SPI_connect()) < 0)
/* internal error */
elog(ERROR, "_rserv_sync_: SPI_connect returned %d", ret); elog(ERROR, "_rserv_sync_: SPI_connect returned %d", ret);
snprintf(sql, 8192, "insert into _RSERV_SYNC_ " snprintf(sql, 8192, "insert into _RSERV_SYNC_ "
...@@ -236,7 +256,9 @@ _rserv_sync_(int32 server) ...@@ -236,7 +256,9 @@ _rserv_sync_(int32 server)
ret = SPI_exec(sql, 0); ret = SPI_exec(sql, 0);
if (ret < 0) if (ret < 0)
elog(ERROR, "_rserv_sync_: SPI_exec returned %d", ret); ereport(ERROR,
(errcode(ERRCODE_TRIGGERED_ACTION_EXCEPTION),
errmsg("SPI_exec returned %d", ret)));
SPI_finish(); SPI_finish();
......
...@@ -2,8 +2,6 @@ ...@@ -2,8 +2,6 @@
#include "postgres.h" #include "postgres.h"
#include "utils/elog.h"
static char *PARSE_BUFFER; static char *PARSE_BUFFER;
static char *PARSE_BUFFER_PTR; static char *PARSE_BUFFER_PTR;
static unsigned int PARSE_BUFFER_SIZE; static unsigned int PARSE_BUFFER_SIZE;
...@@ -26,7 +24,9 @@ set_parse_buffer(char *s) ...@@ -26,7 +24,9 @@ set_parse_buffer(char *s)
PARSE_BUFFER = s; PARSE_BUFFER = s;
PARSE_BUFFER_SIZE = strlen(s); PARSE_BUFFER_SIZE = strlen(s);
if (PARSE_BUFFER_SIZE == 0) if (PARSE_BUFFER_SIZE == 0)
elog(ERROR, "seg_in: can't parse an empty string"); ereport(ERROR,
(errcode(ERRCODE_ZERO_LENGTH_CHARACTER_STRING),
errmsg("can't parse an empty string")));
PARSE_BUFFER_PTR = PARSE_BUFFER; PARSE_BUFFER_PTR = PARSE_BUFFER;
SCANNER_POS = 0; SCANNER_POS = 0;
} }
......
...@@ -6,8 +6,9 @@ ...@@ -6,8 +6,9 @@
-- does not depend on contents of seg.sql. -- does not depend on contents of seg.sql.
-- --
\set ECHO none \set ECHO none
psql:seg.sql:10: NOTICE: ProcedureCreate: type seg is not yet defined psql:seg.sql:10: NOTICE: type seg is not yet defined
psql:seg.sql:15: NOTICE: Argument type "seg" is only a shell DETAIL: Creating a shell type definition.
psql:seg.sql:15: NOTICE: argument type seg is only a shell
-- --
-- testing the input and output functions -- testing the input and output functions
-- --
...@@ -393,30 +394,38 @@ SELECT '100(+-)1'::seg AS seg; ...@@ -393,30 +394,38 @@ SELECT '100(+-)1'::seg AS seg;
-- invalid input -- invalid input
SELECT ''::seg AS seg; SELECT ''::seg AS seg;
ERROR: seg_in: can't parse an empty string ERROR: can't parse an empty string
SELECT 'ABC'::seg AS seg; SELECT 'ABC'::seg AS seg;
ERROR: syntax error at or near position 1, character ('A', \101), input: 'ABC' ERROR: syntax error
DETAIL: syntax error at or near position 1, character ('A', \101), input: 'ABC'
SELECT '1ABC'::seg AS seg; SELECT '1ABC'::seg AS seg;
ERROR: syntax error at or near position 2, character ('A', \101), input: '1ABC' ERROR: syntax error
DETAIL: syntax error at or near position 2, character ('A', \101), input: '1ABC'
SELECT '1.'::seg AS seg; SELECT '1.'::seg AS seg;
ERROR: syntax error at or near position 2, character ('.', \056), input: '1.' ERROR: syntax error
DETAIL: syntax error at or near position 2, character ('.', \056), input: '1.'
SELECT '1.....'::seg AS seg; SELECT '1.....'::seg AS seg;
ERROR: syntax error at or near position 6, character ('.', \056), input: '1.....' ERROR: syntax error
DETAIL: syntax error at or near position 6, character ('.', \056), input: '1.....'
SELECT '.1'::seg AS seg; SELECT '.1'::seg AS seg;
ERROR: syntax error at or near position 2, character ('1', \061), input: '.1' ERROR: syntax error
DETAIL: syntax error at or near position 2, character ('1', \061), input: '.1'
SELECT '1..2.'::seg AS seg; SELECT '1..2.'::seg AS seg;
ERROR: syntax error at or near position 5, character ('.', \056), input: '1..2.' ERROR: syntax error
DETAIL: syntax error at or near position 5, character ('.', \056), input: '1..2.'
SELECT '1 e7'::seg AS seg; SELECT '1 e7'::seg AS seg;
ERROR: syntax error at or near position 3, character ('e', \145), input: '1 e7' ERROR: syntax error
DETAIL: syntax error at or near position 3, character ('e', \145), input: '1 e7'
SELECT '1e700'::seg AS seg; SELECT '1e700'::seg AS seg;
ERROR: numeric value 1e700 unrepresentable ERROR: syntax error
DETAIL: numeric value 1e700 unrepresentable
-- --
-- testing the operators -- testing the operators
-- --
......
...@@ -10,8 +10,6 @@ ...@@ -10,8 +10,6 @@
#include "access/gist.h" #include "access/gist.h"
#include "access/rtree.h" #include "access/rtree.h"
#include "utils/elog.h"
#include "utils/palloc.h"
#include "utils/builtins.h" #include "utils/builtins.h"
#include "segdata.h" #include "segdata.h"
...@@ -798,7 +796,7 @@ seg_cmp(SEG * a, SEG * b) ...@@ -798,7 +796,7 @@ seg_cmp(SEG * a, SEG * b)
if (b->l_ext == '~') if (b->l_ext == '~')
return 1; return 1;
/* can't get here unless data is corrupt */ /* can't get here unless data is corrupt */
elog(ERROR, "seg_cmp: bogus lower boundary types %d %d", elog(ERROR, "bogus lower boundary types %d %d",
(int) a->l_ext, (int) b->l_ext); (int) a->l_ext, (int) b->l_ext);
} }
...@@ -857,7 +855,7 @@ seg_cmp(SEG * a, SEG * b) ...@@ -857,7 +855,7 @@ seg_cmp(SEG * a, SEG * b)
if (b->u_ext == '~') if (b->u_ext == '~')
return -1; return -1;
/* can't get here unless data is corrupt */ /* can't get here unless data is corrupt */
elog(ERROR, "seg_cmp: bogus upper boundary types %d %d", elog(ERROR, "bogus upper boundary types %d %d",
(int) a->u_ext, (int) b->u_ext); (int) a->u_ext, (int) b->u_ext);
} }
......
...@@ -4,8 +4,6 @@ ...@@ -4,8 +4,6 @@
#include "postgres.h" #include "postgres.h"
#include <math.h> #include <math.h>
#include "utils/elog.h"
#include "segdata.h" #include "segdata.h"
#include "buffer.h" #include "buffer.h"
...@@ -75,7 +73,11 @@ range: ...@@ -75,7 +73,11 @@ range:
((SEG *)result)->upper = $3.val; ((SEG *)result)->upper = $3.val;
if ( ((SEG *)result)->lower > ((SEG *)result)->upper ) { if ( ((SEG *)result)->lower > ((SEG *)result)->upper ) {
reset_parse_buffer(); reset_parse_buffer();
elog(ERROR, "swapped boundaries: %g is greater than %g", ((SEG *)result)->lower, ((SEG *)result)->upper ); ereport(ERROR,
(errcode(ERRCODE_INVALID_PARAMETER_VALUE),
errmsg("swapped boundaries: %g is greater than %g",
((SEG *)result)->lower, ((SEG *)result)->upper)));
YYERROR; YYERROR;
} }
((SEG *)result)->l_sigd = $1.sigd; ((SEG *)result)->l_sigd = $1.sigd;
...@@ -144,7 +146,10 @@ float seg_atof ( char *value ) { ...@@ -144,7 +146,10 @@ float seg_atof ( char *value ) {
if ( errno ) { if ( errno ) {
snprintf(buf, 256, "numeric value %s unrepresentable", value); snprintf(buf, 256, "numeric value %s unrepresentable", value);
reset_parse_buffer(); reset_parse_buffer();
elog(ERROR, "%s", buf); ereport(ERROR,
(errcode(ERRCODE_SYNTAX_ERROR),
errmsg("syntax error"),
errdetail("%s", buf)));
} }
return result; return result;
...@@ -175,7 +180,10 @@ int seg_yyerror ( char *msg ) { ...@@ -175,7 +180,10 @@ int seg_yyerror ( char *msg ) {
); );
reset_parse_buffer(); reset_parse_buffer();
elog(ERROR, "%s", buf); ereport(ERROR,
(errcode(ERRCODE_SYNTAX_ERROR),
errmsg("syntax error"),
errdetail("%s", buf)));
return 0; return 0;
} }
......
...@@ -25,18 +25,22 @@ autoinc(PG_FUNCTION_ARGS) ...@@ -25,18 +25,22 @@ autoinc(PG_FUNCTION_ARGS)
int i; int i;
if (!CALLED_AS_TRIGGER(fcinfo)) if (!CALLED_AS_TRIGGER(fcinfo))
elog(ERROR, "autoinc: not fired by trigger manager"); /* internal error */
elog(ERROR, "not fired by trigger manager");
if (TRIGGER_FIRED_FOR_STATEMENT(trigdata->tg_event)) if (TRIGGER_FIRED_FOR_STATEMENT(trigdata->tg_event))
elog(ERROR, "autoinc: can't process STATEMENT events"); /* internal error */
elog(ERROR, "can't process STATEMENT events");
if (TRIGGER_FIRED_AFTER(trigdata->tg_event)) if (TRIGGER_FIRED_AFTER(trigdata->tg_event))
elog(ERROR, "autoinc: must be fired before event"); /* internal error */
elog(ERROR, "must be fired before event");
if (TRIGGER_FIRED_BY_INSERT(trigdata->tg_event)) if (TRIGGER_FIRED_BY_INSERT(trigdata->tg_event))
rettuple = trigdata->tg_trigtuple; rettuple = trigdata->tg_trigtuple;
else if (TRIGGER_FIRED_BY_UPDATE(trigdata->tg_event)) else if (TRIGGER_FIRED_BY_UPDATE(trigdata->tg_event))
rettuple = trigdata->tg_newtuple; rettuple = trigdata->tg_newtuple;
else else
elog(ERROR, "autoinc: can't process DELETE events"); /* internal error */
elog(ERROR, "can't process DELETE events");
rel = trigdata->tg_relation; rel = trigdata->tg_relation;
relname = SPI_getrelname(rel); relname = SPI_getrelname(rel);
...@@ -45,6 +49,7 @@ autoinc(PG_FUNCTION_ARGS) ...@@ -45,6 +49,7 @@ autoinc(PG_FUNCTION_ARGS)
nargs = trigger->tgnargs; nargs = trigger->tgnargs;
if (nargs <= 0 || nargs % 2 != 0) if (nargs <= 0 || nargs % 2 != 0)
/* internal error */
elog(ERROR, "autoinc (%s): even number gt 0 of arguments was expected", relname); elog(ERROR, "autoinc (%s): even number gt 0 of arguments was expected", relname);
args = trigger->tgargs; args = trigger->tgargs;
...@@ -60,11 +65,16 @@ autoinc(PG_FUNCTION_ARGS) ...@@ -60,11 +65,16 @@ autoinc(PG_FUNCTION_ARGS)
Datum seqname; Datum seqname;
if (attnum < 0) if (attnum < 0)
elog(ERROR, "autoinc (%s): there is no attribute %s", ereport(ERROR,
relname, args[i]); (errcode(ERRCODE_TRIGGERED_ACTION_EXCEPTION),
errmsg("\"%s\" has no attribute \"%s\"",
relname, args[i])));
if (SPI_gettypeid(tupdesc, attnum) != INT4OID) if (SPI_gettypeid(tupdesc, attnum) != INT4OID)
elog(ERROR, "autoinc (%s): attribute %s must be of INT4 type", ereport(ERROR,
relname, args[i]); (errcode(ERRCODE_TRIGGERED_ACTION_EXCEPTION),
errmsg("attribute \"%s\" of \"%s\" must be type INT4",
args[i], relname)));
val = DatumGetInt32(SPI_getbinval(rettuple, tupdesc, attnum, &isnull)); val = DatumGetInt32(SPI_getbinval(rettuple, tupdesc, attnum, &isnull));
...@@ -95,6 +105,7 @@ autoinc(PG_FUNCTION_ARGS) ...@@ -95,6 +105,7 @@ autoinc(PG_FUNCTION_ARGS)
{ {
rettuple = SPI_modifytuple(rel, rettuple, chnattrs, chattrs, newvals, NULL); rettuple = SPI_modifytuple(rel, rettuple, chnattrs, chattrs, newvals, NULL);
if (rettuple == NULL) if (rettuple == NULL)
/* internal error */
elog(ERROR, "autoinc (%s): %d returned by SPI_modifytuple", elog(ERROR, "autoinc (%s): %d returned by SPI_modifytuple",
relname, SPI_result); relname, SPI_result);
} }
......
...@@ -30,10 +30,13 @@ insert_username(PG_FUNCTION_ARGS) ...@@ -30,10 +30,13 @@ insert_username(PG_FUNCTION_ARGS)
/* sanity checks from autoinc.c */ /* sanity checks from autoinc.c */
if (!CALLED_AS_TRIGGER(fcinfo)) if (!CALLED_AS_TRIGGER(fcinfo))
/* internal error */
elog(ERROR, "insert_username: not fired by trigger manager"); elog(ERROR, "insert_username: not fired by trigger manager");
if (TRIGGER_FIRED_FOR_STATEMENT(trigdata->tg_event)) if (TRIGGER_FIRED_FOR_STATEMENT(trigdata->tg_event))
/* internal error */
elog(ERROR, "insert_username: can't process STATEMENT events"); elog(ERROR, "insert_username: can't process STATEMENT events");
if (TRIGGER_FIRED_AFTER(trigdata->tg_event)) if (TRIGGER_FIRED_AFTER(trigdata->tg_event))
/* internal error */
elog(ERROR, "insert_username: must be fired before event"); elog(ERROR, "insert_username: must be fired before event");
if (TRIGGER_FIRED_BY_INSERT(trigdata->tg_event)) if (TRIGGER_FIRED_BY_INSERT(trigdata->tg_event))
...@@ -41,6 +44,7 @@ insert_username(PG_FUNCTION_ARGS) ...@@ -41,6 +44,7 @@ insert_username(PG_FUNCTION_ARGS)
else if (TRIGGER_FIRED_BY_UPDATE(trigdata->tg_event)) else if (TRIGGER_FIRED_BY_UPDATE(trigdata->tg_event))
rettuple = trigdata->tg_newtuple; rettuple = trigdata->tg_newtuple;
else else
/* internal error */
elog(ERROR, "insert_username: can't process DELETE events"); elog(ERROR, "insert_username: can't process DELETE events");
rel = trigdata->tg_relation; rel = trigdata->tg_relation;
...@@ -50,6 +54,7 @@ insert_username(PG_FUNCTION_ARGS) ...@@ -50,6 +54,7 @@ insert_username(PG_FUNCTION_ARGS)
nargs = trigger->tgnargs; nargs = trigger->tgnargs;
if (nargs != 1) if (nargs != 1)
/* internal error */
elog(ERROR, "insert_username (%s): one argument was expected", relname); elog(ERROR, "insert_username (%s): one argument was expected", relname);
args = trigger->tgargs; args = trigger->tgargs;
...@@ -58,10 +63,15 @@ insert_username(PG_FUNCTION_ARGS) ...@@ -58,10 +63,15 @@ insert_username(PG_FUNCTION_ARGS)
attnum = SPI_fnumber(tupdesc, args[0]); attnum = SPI_fnumber(tupdesc, args[0]);
if (attnum < 0) if (attnum < 0)
elog(ERROR, "insert_username (%s): there is no attribute %s", relname, args[0]); ereport(ERROR,
(errcode(ERRCODE_TRIGGERED_ACTION_EXCEPTION),
errmsg("\"%s\" has no attribute \"%s\"", relname, args[0])));
if (SPI_gettypeid(tupdesc, attnum) != TEXTOID) if (SPI_gettypeid(tupdesc, attnum) != TEXTOID)
elog(ERROR, "insert_username (%s): attribute %s must be of TEXT type", ereport(ERROR,
relname, args[0]); (errcode(ERRCODE_TRIGGERED_ACTION_EXCEPTION),
errmsg("attribute \"%s\" of \"%s\" must be type TEXT",
args[0], relname)));
/* create fields containing name */ /* create fields containing name */
newval = DirectFunctionCall1(textin, newval = DirectFunctionCall1(textin,
...@@ -70,7 +80,8 @@ insert_username(PG_FUNCTION_ARGS) ...@@ -70,7 +80,8 @@ insert_username(PG_FUNCTION_ARGS)
/* construct new tuple */ /* construct new tuple */
rettuple = SPI_modifytuple(rel, rettuple, 1, &attnum, &newval, NULL); rettuple = SPI_modifytuple(rel, rettuple, 1, &attnum, &newval, NULL);
if (rettuple == NULL) if (rettuple == NULL)
elog(ERROR, "insert_username (%s): %d returned by SPI_modifytuple", /* internal error */
elog(ERROR, "insert_username (\"%s\"): %d returned by SPI_modifytuple",
relname, SPI_result); relname, SPI_result);
pfree(relname); pfree(relname);
......
...@@ -34,20 +34,25 @@ moddatetime(PG_FUNCTION_ARGS) ...@@ -34,20 +34,25 @@ moddatetime(PG_FUNCTION_ARGS)
TupleDesc tupdesc; /* tuple description */ TupleDesc tupdesc; /* tuple description */
if (!CALLED_AS_TRIGGER(fcinfo)) if (!CALLED_AS_TRIGGER(fcinfo))
elog(ERROR, "moddatetime: not fired by trigger manager."); /* internal error */
elog(ERROR, "moddatetime: not fired by trigger manager");
if (TRIGGER_FIRED_FOR_STATEMENT(trigdata->tg_event)) if (TRIGGER_FIRED_FOR_STATEMENT(trigdata->tg_event))
elog(ERROR, "moddatetime: can't process STATEMENT events."); /* internal error */
elog(ERROR, "moddatetime: can't process STATEMENT events");
if (TRIGGER_FIRED_AFTER(trigdata->tg_event)) if (TRIGGER_FIRED_AFTER(trigdata->tg_event))
elog(ERROR, "moddatetime: must be fired before event."); /* internal error */
elog(ERROR, "moddatetime: must be fired before event");
if (TRIGGER_FIRED_BY_INSERT(trigdata->tg_event)) if (TRIGGER_FIRED_BY_INSERT(trigdata->tg_event))
elog(ERROR, "moddatetime: must be fired before event."); /* internal error */
elog(ERROR, "moddatetime: must be fired before event");
else if (TRIGGER_FIRED_BY_UPDATE(trigdata->tg_event)) else if (TRIGGER_FIRED_BY_UPDATE(trigdata->tg_event))
rettuple = trigdata->tg_newtuple; rettuple = trigdata->tg_newtuple;
else else
elog(ERROR, "moddatetime: can't process DELETE events."); /* internal error */
elog(ERROR, "moddatetime: can't process DELETE events");
rel = trigdata->tg_relation; rel = trigdata->tg_relation;
relname = SPI_getrelname(rel); relname = SPI_getrelname(rel);
...@@ -57,7 +62,8 @@ moddatetime(PG_FUNCTION_ARGS) ...@@ -57,7 +62,8 @@ moddatetime(PG_FUNCTION_ARGS)
nargs = trigger->tgnargs; nargs = trigger->tgnargs;
if (nargs != 1) if (nargs != 1)
elog(ERROR, "moddatetime (%s): A single argument was expected.", relname); /* internal error */
elog(ERROR, "moddatetime (%s): A single argument was expected", relname);
args = trigger->tgargs; args = trigger->tgargs;
/* must be the field layout? */ /* must be the field layout? */
...@@ -81,8 +87,10 @@ moddatetime(PG_FUNCTION_ARGS) ...@@ -81,8 +87,10 @@ moddatetime(PG_FUNCTION_ARGS)
* even exits. The above function must return -1 if name not found? * even exits. The above function must return -1 if name not found?
*/ */
if (attnum < 0) if (attnum < 0)
elog(ERROR, "moddatetime (%s): there is no attribute %s", relname, ereport(ERROR,
args[0]); (errcode(ERRCODE_TRIGGERED_ACTION_EXCEPTION),
errmsg("\"%s\" has no attribute \"%s\"",
relname, args[0])));
/* /*
* OK, this is where we make sure the timestamp field that we are * OK, this is where we make sure the timestamp field that we are
...@@ -90,8 +98,10 @@ moddatetime(PG_FUNCTION_ARGS) ...@@ -90,8 +98,10 @@ moddatetime(PG_FUNCTION_ARGS)
* novel idea !-) * novel idea !-)
*/ */
if (SPI_gettypeid(tupdesc, attnum) != TIMESTAMPOID) if (SPI_gettypeid(tupdesc, attnum) != TIMESTAMPOID)
elog(ERROR, "moddatetime (%s): attribute %s must be of TIMESTAMP type", ereport(ERROR,
relname, args[0]); (errcode(ERRCODE_TRIGGERED_ACTION_EXCEPTION),
errmsg("attribute \"%s\" of \"%s\" must be type TIMESTAMP",
args[0], relname)));
/* 1 is the number of items in the arrays attnum and newdt. /* 1 is the number of items in the arrays attnum and newdt.
attnum is the positional number of the field to be updated. attnum is the positional number of the field to be updated.
...@@ -103,6 +113,7 @@ moddatetime(PG_FUNCTION_ARGS) ...@@ -103,6 +113,7 @@ moddatetime(PG_FUNCTION_ARGS)
rettuple = SPI_modifytuple(rel, rettuple, 1, &attnum, &newdt, NULL); rettuple = SPI_modifytuple(rel, rettuple, 1, &attnum, &newdt, NULL);
if (rettuple == NULL) if (rettuple == NULL)
/* internal error */
elog(ERROR, "moddatetime (%s): %d returned by SPI_modifytuple", elog(ERROR, "moddatetime (%s): %d returned by SPI_modifytuple",
relname, SPI_result); relname, SPI_result);
......
...@@ -59,7 +59,7 @@ check_primary_key(PG_FUNCTION_ARGS) ...@@ -59,7 +59,7 @@ check_primary_key(PG_FUNCTION_ARGS)
int i; int i;
#ifdef DEBUG_QUERY #ifdef DEBUG_QUERY
elog(DEBUG4, "Check_primary_key Enter Function"); elog(DEBUG4, "check_primary_key: Enter Function");
#endif #endif
/* /*
...@@ -68,10 +68,12 @@ check_primary_key(PG_FUNCTION_ARGS) ...@@ -68,10 +68,12 @@ check_primary_key(PG_FUNCTION_ARGS)
/* Called by trigger manager ? */ /* Called by trigger manager ? */
if (!CALLED_AS_TRIGGER(fcinfo)) if (!CALLED_AS_TRIGGER(fcinfo))
/* internal error */
elog(ERROR, "check_primary_key: not fired by trigger manager"); elog(ERROR, "check_primary_key: not fired by trigger manager");
/* Should be called for ROW trigger */ /* Should be called for ROW trigger */
if (TRIGGER_FIRED_FOR_STATEMENT(trigdata->tg_event)) if (TRIGGER_FIRED_FOR_STATEMENT(trigdata->tg_event))
/* internal error */
elog(ERROR, "check_primary_key: can't process STATEMENT events"); elog(ERROR, "check_primary_key: can't process STATEMENT events");
/* If INSERTion then must check Tuple to being inserted */ /* If INSERTion then must check Tuple to being inserted */
...@@ -80,6 +82,7 @@ check_primary_key(PG_FUNCTION_ARGS) ...@@ -80,6 +82,7 @@ check_primary_key(PG_FUNCTION_ARGS)
/* Not should be called for DELETE */ /* Not should be called for DELETE */
else if (TRIGGER_FIRED_BY_DELETE(trigdata->tg_event)) else if (TRIGGER_FIRED_BY_DELETE(trigdata->tg_event))
/* internal error */
elog(ERROR, "check_primary_key: can't process DELETE events"); elog(ERROR, "check_primary_key: can't process DELETE events");
/* If UPDATion the must check new Tuple, not old one */ /* If UPDATion the must check new Tuple, not old one */
...@@ -91,6 +94,7 @@ check_primary_key(PG_FUNCTION_ARGS) ...@@ -91,6 +94,7 @@ check_primary_key(PG_FUNCTION_ARGS)
args = trigger->tgargs; args = trigger->tgargs;
if (nargs % 2 != 1) /* odd number of arguments! */ if (nargs % 2 != 1) /* odd number of arguments! */
/* internal error */
elog(ERROR, "check_primary_key: odd number of arguments should be specified"); elog(ERROR, "check_primary_key: odd number of arguments should be specified");
nkeys = nargs / 2; nkeys = nargs / 2;
...@@ -100,6 +104,7 @@ check_primary_key(PG_FUNCTION_ARGS) ...@@ -100,6 +104,7 @@ check_primary_key(PG_FUNCTION_ARGS)
/* Connect to SPI manager */ /* Connect to SPI manager */
if ((ret = SPI_connect()) < 0) if ((ret = SPI_connect()) < 0)
/* internal error */
elog(ERROR, "check_primary_key: SPI_connect returned %d", ret); elog(ERROR, "check_primary_key: SPI_connect returned %d", ret);
/* /*
...@@ -127,8 +132,10 @@ check_primary_key(PG_FUNCTION_ARGS) ...@@ -127,8 +132,10 @@ check_primary_key(PG_FUNCTION_ARGS)
/* Bad guys may give us un-existing column in CREATE TRIGGER */ /* Bad guys may give us un-existing column in CREATE TRIGGER */
if (fnumber < 0) if (fnumber < 0)
elog(ERROR, "check_primary_key: there is no attribute %s in relation %s", ereport(ERROR,
args[i], SPI_getrelname(rel)); (errcode(ERRCODE_UNDEFINED_COLUMN),
errmsg("there is no attribute \"%s\" in relation \"%s\"",
args[i], SPI_getrelname(rel))));
/* Well, get binary (in internal format) value of column */ /* Well, get binary (in internal format) value of column */
kvals[i] = SPI_getbinval(tuple, tupdesc, fnumber, &isnull); kvals[i] = SPI_getbinval(tuple, tupdesc, fnumber, &isnull);
...@@ -170,6 +177,7 @@ check_primary_key(PG_FUNCTION_ARGS) ...@@ -170,6 +177,7 @@ check_primary_key(PG_FUNCTION_ARGS)
/* Prepare plan for query */ /* Prepare plan for query */
pplan = SPI_prepare(sql, nkeys, argtypes); pplan = SPI_prepare(sql, nkeys, argtypes);
if (pplan == NULL) if (pplan == NULL)
/* internal error */
elog(ERROR, "check_primary_key: SPI_prepare returned %d", SPI_result); elog(ERROR, "check_primary_key: SPI_prepare returned %d", SPI_result);
/* /*
...@@ -179,6 +187,7 @@ check_primary_key(PG_FUNCTION_ARGS) ...@@ -179,6 +187,7 @@ check_primary_key(PG_FUNCTION_ARGS)
*/ */
pplan = SPI_saveplan(pplan); pplan = SPI_saveplan(pplan);
if (pplan == NULL) if (pplan == NULL)
/* internal error */
elog(ERROR, "check_primary_key: SPI_saveplan returned %d", SPI_result); elog(ERROR, "check_primary_key: SPI_saveplan returned %d", SPI_result);
plan->splan = (void **) malloc(sizeof(void *)); plan->splan = (void **) malloc(sizeof(void *));
*(plan->splan) = pplan; *(plan->splan) = pplan;
...@@ -192,14 +201,17 @@ check_primary_key(PG_FUNCTION_ARGS) ...@@ -192,14 +201,17 @@ check_primary_key(PG_FUNCTION_ARGS)
/* we have no NULLs - so we pass ^^^^ here */ /* we have no NULLs - so we pass ^^^^ here */
if (ret < 0) if (ret < 0)
/* internal error */
elog(ERROR, "check_primary_key: SPI_execp returned %d", ret); elog(ERROR, "check_primary_key: SPI_execp returned %d", ret);
/* /*
* If there are no tuples returned by SELECT then ... * If there are no tuples returned by SELECT then ...
*/ */
if (SPI_processed == 0) if (SPI_processed == 0)
elog(ERROR, "%s: tuple references non-existing key in %s", ereport(ERROR,
trigger->tgname, relname); (errcode(ERRCODE_TRIGGERED_ACTION_EXCEPTION),
errmsg("tuple references non-existent key"),
errdetail("Trigger \"%s\" found tuple referencing non-existent key in \"%s\".", trigger->tgname, relname)));
SPI_finish(); SPI_finish();
...@@ -249,7 +261,7 @@ check_foreign_key(PG_FUNCTION_ARGS) ...@@ -249,7 +261,7 @@ check_foreign_key(PG_FUNCTION_ARGS)
r; r;
#ifdef DEBUG_QUERY #ifdef DEBUG_QUERY
elog(DEBUG4, "Check_foreign_key Enter Function"); elog(DEBUG4, "check_foreign_key: Enter Function");
#endif #endif
/* /*
...@@ -258,14 +270,17 @@ check_foreign_key(PG_FUNCTION_ARGS) ...@@ -258,14 +270,17 @@ check_foreign_key(PG_FUNCTION_ARGS)
/* Called by trigger manager ? */ /* Called by trigger manager ? */
if (!CALLED_AS_TRIGGER(fcinfo)) if (!CALLED_AS_TRIGGER(fcinfo))
/* internal error */
elog(ERROR, "check_foreign_key: not fired by trigger manager"); elog(ERROR, "check_foreign_key: not fired by trigger manager");
/* Should be called for ROW trigger */ /* Should be called for ROW trigger */
if (TRIGGER_FIRED_FOR_STATEMENT(trigdata->tg_event)) if (TRIGGER_FIRED_FOR_STATEMENT(trigdata->tg_event))
/* internal error */
elog(ERROR, "check_foreign_key: can't process STATEMENT events"); elog(ERROR, "check_foreign_key: can't process STATEMENT events");
/* Not should be called for INSERT */ /* Not should be called for INSERT */
if (TRIGGER_FIRED_BY_INSERT(trigdata->tg_event)) if (TRIGGER_FIRED_BY_INSERT(trigdata->tg_event))
/* internal error */
elog(ERROR, "check_foreign_key: can't process INSERT events"); elog(ERROR, "check_foreign_key: can't process INSERT events");
/* Have to check tg_trigtuple - tuple being deleted */ /* Have to check tg_trigtuple - tuple being deleted */
...@@ -288,18 +303,22 @@ check_foreign_key(PG_FUNCTION_ARGS) ...@@ -288,18 +303,22 @@ check_foreign_key(PG_FUNCTION_ARGS)
if (nargs < 5) /* nrefs, action, key, Relation, key - at if (nargs < 5) /* nrefs, action, key, Relation, key - at
* least */ * least */
/* internal error */
elog(ERROR, "check_foreign_key: too short %d (< 5) list of arguments", nargs); elog(ERROR, "check_foreign_key: too short %d (< 5) list of arguments", nargs);
nrefs = pg_atoi(args[0], sizeof(int), 0); nrefs = pg_atoi(args[0], sizeof(int), 0);
if (nrefs < 1) if (nrefs < 1)
/* internal error */
elog(ERROR, "check_foreign_key: %d (< 1) number of references specified", nrefs); elog(ERROR, "check_foreign_key: %d (< 1) number of references specified", nrefs);
action = tolower((unsigned char) *(args[1])); action = tolower((unsigned char) *(args[1]));
if (action != 'r' && action != 'c' && action != 's') if (action != 'r' && action != 'c' && action != 's')
/* internal error */
elog(ERROR, "check_foreign_key: invalid action %s", args[1]); elog(ERROR, "check_foreign_key: invalid action %s", args[1]);
nargs -= 2; nargs -= 2;
args += 2; args += 2;
nkeys = (nargs - nrefs) / (nrefs + 1); nkeys = (nargs - nrefs) / (nrefs + 1);
if (nkeys <= 0 || nargs != (nrefs + nkeys * (nrefs + 1))) if (nkeys <= 0 || nargs != (nrefs + nkeys * (nrefs + 1)))
/* internal error */
elog(ERROR, "check_foreign_key: invalid number of arguments %d for %d references", elog(ERROR, "check_foreign_key: invalid number of arguments %d for %d references",
nargs + 2, nrefs); nargs + 2, nrefs);
...@@ -308,6 +327,7 @@ check_foreign_key(PG_FUNCTION_ARGS) ...@@ -308,6 +327,7 @@ check_foreign_key(PG_FUNCTION_ARGS)
/* Connect to SPI manager */ /* Connect to SPI manager */
if ((ret = SPI_connect()) < 0) if ((ret = SPI_connect()) < 0)
/* internal error */
elog(ERROR, "check_foreign_key: SPI_connect returned %d", ret); elog(ERROR, "check_foreign_key: SPI_connect returned %d", ret);
/* /*
...@@ -331,6 +351,7 @@ check_foreign_key(PG_FUNCTION_ARGS) ...@@ -331,6 +351,7 @@ check_foreign_key(PG_FUNCTION_ARGS)
* else - check that we have exactly nrefs plan(s) ready * else - check that we have exactly nrefs plan(s) ready
*/ */
else if (plan->nplans != nrefs) else if (plan->nplans != nrefs)
/* internal error */
elog(ERROR, "%s: check_foreign_key: # of plans changed in meantime", elog(ERROR, "%s: check_foreign_key: # of plans changed in meantime",
trigger->tgname); trigger->tgname);
...@@ -342,8 +363,10 @@ check_foreign_key(PG_FUNCTION_ARGS) ...@@ -342,8 +363,10 @@ check_foreign_key(PG_FUNCTION_ARGS)
/* Bad guys may give us un-existing column in CREATE TRIGGER */ /* Bad guys may give us un-existing column in CREATE TRIGGER */
if (fnumber < 0) if (fnumber < 0)
elog(ERROR, "check_foreign_key: there is no attribute %s in relation %s", ereport(ERROR,
args[i], SPI_getrelname(rel)); (errcode(ERRCODE_UNDEFINED_COLUMN),
errmsg("there is no attribute \"%s\" in relation \"%s\"",
args[i], SPI_getrelname(rel))));
/* Well, get binary (in internal format) value of column */ /* Well, get binary (in internal format) value of column */
kvals[i] = SPI_getbinval(trigtuple, tupdesc, fnumber, &isnull); kvals[i] = SPI_getbinval(trigtuple, tupdesc, fnumber, &isnull);
...@@ -371,6 +394,7 @@ check_foreign_key(PG_FUNCTION_ARGS) ...@@ -371,6 +394,7 @@ check_foreign_key(PG_FUNCTION_ARGS)
/* this shouldn't happen! SPI_ERROR_NOOUTFUNC ? */ /* this shouldn't happen! SPI_ERROR_NOOUTFUNC ? */
if (oldval == NULL) if (oldval == NULL)
/* internal error */
elog(ERROR, "check_foreign_key: SPI_getvalue returned %d", SPI_result); elog(ERROR, "check_foreign_key: SPI_getvalue returned %d", SPI_result);
newval = SPI_getvalue(newtuple, tupdesc, fnumber); newval = SPI_getvalue(newtuple, tupdesc, fnumber);
if (newval == NULL || strcmp(oldval, newval) != 0) if (newval == NULL || strcmp(oldval, newval) != 0)
...@@ -453,7 +477,7 @@ check_foreign_key(PG_FUNCTION_ARGS) ...@@ -453,7 +477,7 @@ check_foreign_key(PG_FUNCTION_ARGS)
strcmp(type, "date") && strcmp(type, "timestamp")) == 0) strcmp(type, "date") && strcmp(type, "timestamp")) == 0)
is_char_type = 1; is_char_type = 1;
#ifdef DEBUG_QUERY #ifdef DEBUG_QUERY
elog(DEBUG4, "Check_foreign_key Debug value %s type %s %d", elog(DEBUG4, "check_foreign_key Debug value %s type %s %d",
nv, type, is_char_type); nv, type, is_char_type);
#endif #endif
...@@ -504,6 +528,7 @@ check_foreign_key(PG_FUNCTION_ARGS) ...@@ -504,6 +528,7 @@ check_foreign_key(PG_FUNCTION_ARGS)
/* Prepare plan for query */ /* Prepare plan for query */
pplan = SPI_prepare(sql, nkeys, argtypes); pplan = SPI_prepare(sql, nkeys, argtypes);
if (pplan == NULL) if (pplan == NULL)
/* internal error */
elog(ERROR, "check_foreign_key: SPI_prepare returned %d", SPI_result); elog(ERROR, "check_foreign_key: SPI_prepare returned %d", SPI_result);
/* /*
...@@ -513,6 +538,7 @@ check_foreign_key(PG_FUNCTION_ARGS) ...@@ -513,6 +538,7 @@ check_foreign_key(PG_FUNCTION_ARGS)
*/ */
pplan = SPI_saveplan(pplan); pplan = SPI_saveplan(pplan);
if (pplan == NULL) if (pplan == NULL)
/* internal error */
elog(ERROR, "check_foreign_key: SPI_saveplan returned %d", SPI_result); elog(ERROR, "check_foreign_key: SPI_saveplan returned %d", SPI_result);
plan->splan[r] = pplan; plan->splan[r] = pplan;
...@@ -521,7 +547,7 @@ check_foreign_key(PG_FUNCTION_ARGS) ...@@ -521,7 +547,7 @@ check_foreign_key(PG_FUNCTION_ARGS)
} }
plan->nplans = nrefs; plan->nplans = nrefs;
#ifdef DEBUG_QUERY #ifdef DEBUG_QUERY
elog(DEBUG4, "Check_foreign_key Debug Query is : %s ", sql); elog(DEBUG4, "check_foreign_key Debug Query is : %s ", sql);
#endif #endif
} }
...@@ -553,22 +579,26 @@ check_foreign_key(PG_FUNCTION_ARGS) ...@@ -553,22 +579,26 @@ check_foreign_key(PG_FUNCTION_ARGS)
/* we have no NULLs - so we pass ^^^^ here */ /* we have no NULLs - so we pass ^^^^ here */
if (ret < 0) if (ret < 0)
elog(ERROR, "check_foreign_key: SPI_execp returned %d", ret); ereport(ERROR,
(errcode(ERRCODE_TRIGGERED_ACTION_EXCEPTION),
errmsg("SPI_execp returned %d", ret)));
/* If action is 'R'estrict ... */ /* If action is 'R'estrict ... */
if (action == 'r') if (action == 'r')
{ {
/* If there is tuple returned by SELECT then ... */ /* If there is tuple returned by SELECT then ... */
if (SPI_processed > 0) if (SPI_processed > 0)
elog(ERROR, "%s: tuple referenced in %s", ereport(ERROR,
trigger->tgname, relname); (errcode(ERRCODE_TRIGGERED_ACTION_EXCEPTION),
errmsg("\"%s\": tuple is referenced in \"%s\"",
trigger->tgname, relname)));
} }
else else
{ {
#ifdef REFINT_VERBOSE #ifdef REFINT_VERBOSE
elog(NOTICE, "%s: %d tuple(s) of %s are %s", elog(NOTICE, "%s: %d tuple(s) of %s are %s",
trigger->tgname, SPI_processed, relname, trigger->tgname, SPI_processed, relname,
(action == 'c') ? "deleted" : "setted to null"); (action == 'c') ? "deleted" : "set to null");
#endif #endif
} }
args += nkeys + 1; /* to the next relation */ args += nkeys + 1; /* to the next relation */
......
...@@ -82,14 +82,17 @@ timetravel(PG_FUNCTION_ARGS) ...@@ -82,14 +82,17 @@ timetravel(PG_FUNCTION_ARGS)
/* Called by trigger manager ? */ /* Called by trigger manager ? */
if (!CALLED_AS_TRIGGER(fcinfo)) if (!CALLED_AS_TRIGGER(fcinfo))
/* internal error */
elog(ERROR, "timetravel: not fired by trigger manager"); elog(ERROR, "timetravel: not fired by trigger manager");
/* Should be called for ROW trigger */ /* Should be called for ROW trigger */
if (TRIGGER_FIRED_FOR_STATEMENT(trigdata->tg_event)) if (TRIGGER_FIRED_FOR_STATEMENT(trigdata->tg_event))
/* internal error */
elog(ERROR, "timetravel: can't process STATEMENT events"); elog(ERROR, "timetravel: can't process STATEMENT events");
/* Should be called BEFORE */ /* Should be called BEFORE */
if (TRIGGER_FIRED_AFTER(trigdata->tg_event)) if (TRIGGER_FIRED_AFTER(trigdata->tg_event))
/* internal error */
elog(ERROR, "timetravel: must be fired before event"); elog(ERROR, "timetravel: must be fired before event");
/* INSERT ? */ /* INSERT ? */
...@@ -117,6 +120,7 @@ timetravel(PG_FUNCTION_ARGS) ...@@ -117,6 +120,7 @@ timetravel(PG_FUNCTION_ARGS)
trigger = trigdata->tg_trigger; trigger = trigdata->tg_trigger;
if (trigger->tgnargs != 2) if (trigger->tgnargs != 2)
/* internal error */
elog(ERROR, "timetravel (%s): invalid (!= 2) number of arguments %d", elog(ERROR, "timetravel (%s): invalid (!= 2) number of arguments %d",
relname, trigger->tgnargs); relname, trigger->tgnargs);
...@@ -128,10 +132,15 @@ timetravel(PG_FUNCTION_ARGS) ...@@ -128,10 +132,15 @@ timetravel(PG_FUNCTION_ARGS)
{ {
attnum[i] = SPI_fnumber(tupdesc, args[i]); attnum[i] = SPI_fnumber(tupdesc, args[i]);
if (attnum[i] < 0) if (attnum[i] < 0)
elog(ERROR, "timetravel (%s): there is no attribute %s", relname, args[i]); ereport(ERROR,
(errcode(ERRCODE_TRIGGERED_ACTION_EXCEPTION),
errmsg("\"%s\" has no attribute \"%s\"",
relname, args[i])));
if (SPI_gettypeid(tupdesc, attnum[i]) != ABSTIMEOID) if (SPI_gettypeid(tupdesc, attnum[i]) != ABSTIMEOID)
elog(ERROR, "timetravel (%s): attributes %s and %s must be of abstime type", ereport(ERROR,
relname, args[0], args[1]); (errcode(ERRCODE_TRIGGERED_ACTION_EXCEPTION),
errmsg("attribute \"%s\" of \"%s\" must be type ABSTIME",
args[i], relname)));
} }
if (isinsert) /* INSERT */ if (isinsert) /* INSERT */
...@@ -153,8 +162,10 @@ timetravel(PG_FUNCTION_ARGS) ...@@ -153,8 +162,10 @@ timetravel(PG_FUNCTION_ARGS)
{ {
if ((chnattrs == 0 && DatumGetInt32(oldon) >= NOEND_ABSTIME) || if ((chnattrs == 0 && DatumGetInt32(oldon) >= NOEND_ABSTIME) ||
(chnattrs > 0 && DatumGetInt32(newvals[0]) >= NOEND_ABSTIME)) (chnattrs > 0 && DatumGetInt32(newvals[0]) >= NOEND_ABSTIME))
elog(ERROR, "timetravel (%s): %s ge %s", ereport(ERROR,
relname, args[0], args[1]); (errcode(ERRCODE_TRIGGERED_ACTION_EXCEPTION),
errmsg("timetravel (%s): %s ge %s",
relname, args[0], args[1])));
newvals[chnattrs] = NOEND_ABSTIME; newvals[chnattrs] = NOEND_ABSTIME;
chattrs[chnattrs] = attnum[1]; chattrs[chnattrs] = attnum[1];
chnattrs++; chnattrs++;
...@@ -165,8 +176,10 @@ timetravel(PG_FUNCTION_ARGS) ...@@ -165,8 +176,10 @@ timetravel(PG_FUNCTION_ARGS)
DatumGetInt32(oldoff)) || DatumGetInt32(oldoff)) ||
(chnattrs > 0 && DatumGetInt32(newvals[0]) >= (chnattrs > 0 && DatumGetInt32(newvals[0]) >=
DatumGetInt32(oldoff))) DatumGetInt32(oldoff)))
elog(ERROR, "timetravel (%s): %s ge %s", ereport(ERROR,
relname, args[0], args[1]); (errcode(ERRCODE_TRIGGERED_ACTION_EXCEPTION),
errmsg("timetravel (%s): %s ge %s",
relname, args[0], args[1])));
} }
pfree(relname); pfree(relname);
...@@ -180,11 +193,16 @@ timetravel(PG_FUNCTION_ARGS) ...@@ -180,11 +193,16 @@ timetravel(PG_FUNCTION_ARGS)
oldon = SPI_getbinval(trigtuple, tupdesc, attnum[0], &isnull); oldon = SPI_getbinval(trigtuple, tupdesc, attnum[0], &isnull);
if (isnull) if (isnull)
elog(ERROR, "timetravel (%s): %s must be NOT NULL", relname, args[0]); ereport(ERROR,
(errcode(ERRCODE_NULL_VALUE_NOT_ALLOWED),
errmsg("\"%s\" must be NOT NULL in \"%s\"",
args[0],relname)));
oldoff = SPI_getbinval(trigtuple, tupdesc, attnum[1], &isnull); oldoff = SPI_getbinval(trigtuple, tupdesc, attnum[1], &isnull);
if (isnull) if (isnull)
elog(ERROR, "timetravel (%s): %s must be NOT NULL", relname, args[1]); ereport(ERROR,
(errcode(ERRCODE_NULL_VALUE_NOT_ALLOWED),
errmsg("\"%s\" must be NOT NULL in \"%s\"",
args[1],relname)));
/* /*
* If DELETE/UPDATE of tuple with stop_date neq INFINITY then say * If DELETE/UPDATE of tuple with stop_date neq INFINITY then say
...@@ -194,14 +212,23 @@ timetravel(PG_FUNCTION_ARGS) ...@@ -194,14 +212,23 @@ timetravel(PG_FUNCTION_ARGS)
{ {
newon = SPI_getbinval(newtuple, tupdesc, attnum[0], &isnull); newon = SPI_getbinval(newtuple, tupdesc, attnum[0], &isnull);
if (isnull) if (isnull)
elog(ERROR, "timetravel (%s): %s must be NOT NULL", relname, args[0]); ereport(ERROR,
(errcode(ERRCODE_NULL_VALUE_NOT_ALLOWED),
errmsg("\"%s\" must be NOT NULL in \"%s\"",
args[0],relname)));
newoff = SPI_getbinval(newtuple, tupdesc, attnum[1], &isnull); newoff = SPI_getbinval(newtuple, tupdesc, attnum[1], &isnull);
if (isnull) if (isnull)
elog(ERROR, "timetravel (%s): %s must be NOT NULL", relname, args[1]); ereport(ERROR,
(errcode(ERRCODE_NULL_VALUE_NOT_ALLOWED),
errmsg("\"%s\" must be NOT NULL in \"%s\"",
args[1],relname)));
if (oldon != newon || oldoff != newoff) if (oldon != newon || oldoff != newoff)
elog(ERROR, "timetravel (%s): you can't change %s and/or %s columns (use set_timetravel)", ereport(ERROR,
relname, args[0], args[1]); (errcode(ERRCODE_TRIGGERED_ACTION_EXCEPTION),
errmsg("cannot change columns \"%s\" or \"%s\" in \"%s\"",
args[0], args[1], relname),
errhint("Use set_timetravel() instead.")));
if (newoff != NOEND_ABSTIME) if (newoff != NOEND_ABSTIME)
{ {
...@@ -219,6 +246,7 @@ timetravel(PG_FUNCTION_ARGS) ...@@ -219,6 +246,7 @@ timetravel(PG_FUNCTION_ARGS)
/* Connect to SPI manager */ /* Connect to SPI manager */
if ((ret = SPI_connect()) < 0) if ((ret = SPI_connect()) < 0)
/* internal error */
elog(ERROR, "timetravel (%s): SPI_connect returned %d", relname, ret); elog(ERROR, "timetravel (%s): SPI_connect returned %d", relname, ret);
/* Fetch tuple values and nulls */ /* Fetch tuple values and nulls */
...@@ -277,6 +305,7 @@ timetravel(PG_FUNCTION_ARGS) ...@@ -277,6 +305,7 @@ timetravel(PG_FUNCTION_ARGS)
/* Prepare plan for query */ /* Prepare plan for query */
pplan = SPI_prepare(sql, natts, ctypes); pplan = SPI_prepare(sql, natts, ctypes);
if (pplan == NULL) if (pplan == NULL)
/* internal error */
elog(ERROR, "timetravel (%s): SPI_prepare returned %d", relname, SPI_result); elog(ERROR, "timetravel (%s): SPI_prepare returned %d", relname, SPI_result);
/* /*
...@@ -286,6 +315,7 @@ timetravel(PG_FUNCTION_ARGS) ...@@ -286,6 +315,7 @@ timetravel(PG_FUNCTION_ARGS)
*/ */
pplan = SPI_saveplan(pplan); pplan = SPI_saveplan(pplan);
if (pplan == NULL) if (pplan == NULL)
/* internal error */
elog(ERROR, "timetravel (%s): SPI_saveplan returned %d", relname, SPI_result); elog(ERROR, "timetravel (%s): SPI_saveplan returned %d", relname, SPI_result);
plan->splan = pplan; plan->splan = pplan;
...@@ -297,6 +327,7 @@ timetravel(PG_FUNCTION_ARGS) ...@@ -297,6 +327,7 @@ timetravel(PG_FUNCTION_ARGS)
ret = SPI_execp(plan->splan, cvals, cnulls, 0); ret = SPI_execp(plan->splan, cvals, cnulls, 0);
if (ret < 0) if (ret < 0)
/* internal error */
elog(ERROR, "timetravel (%s): SPI_execp returned %d", relname, ret); elog(ERROR, "timetravel (%s): SPI_execp returned %d", relname, ret);
/* Tuple to return to upper Executor ... */ /* Tuple to return to upper Executor ... */
......
...@@ -127,7 +127,7 @@ SELECT * FROM crosstab('SELECT rowid, attribute, val FROM ct where rowclass = '' ...@@ -127,7 +127,7 @@ SELECT * FROM crosstab('SELECT rowid, attribute, val FROM ct where rowclass = ''
-- hash based crosstab -- hash based crosstab
-- --
create table cth(id serial, rowid text, rowdt timestamp, attribute text, val text); create table cth(id serial, rowid text, rowdt timestamp, attribute text, val text);
NOTICE: CREATE TABLE will create implicit sequence 'cth_id_seq' for SERIAL column 'cth.id' NOTICE: CREATE TABLE will create implicit sequence "cth_id_seq" for SERIAL column "cth.id"
insert into cth values(DEFAULT,'test1','01 March 2003','temperature','42'); insert into cth values(DEFAULT,'test1','01 March 2003','temperature','42');
insert into cth values(DEFAULT,'test1','01 March 2003','test_result','PASS'); insert into cth values(DEFAULT,'test1','01 March 2003','test_result','PASS');
-- the next line is intentionally left commented and is therefore a "missing" attribute -- the next line is intentionally left commented and is therefore a "missing" attribute
...@@ -186,13 +186,13 @@ SELECT * FROM crosstab( ...@@ -186,13 +186,13 @@ SELECT * FROM crosstab(
'SELECT rowid, rowdt, attribute, val FROM cth ORDER BY 1', 'SELECT rowid, rowdt, attribute, val FROM cth ORDER BY 1',
'SELECT DISTINCT attribute FROM cth WHERE attribute = ''a'' ORDER BY 1') 'SELECT DISTINCT attribute FROM cth WHERE attribute = ''a'' ORDER BY 1')
AS c(rowid text, rowdt timestamp, temperature int4, test_result text, test_startdate timestamp, volts float8); AS c(rowid text, rowdt timestamp, temperature int4, test_result text, test_startdate timestamp, volts float8);
ERROR: load_categories_hash: provided categories SQL must return 1 column of at least one row ERROR: provided "categories" SQL must return 1 column of at least one row
-- if category query generates more than one column, get expected error -- if category query generates more than one column, get expected error
SELECT * FROM crosstab( SELECT * FROM crosstab(
'SELECT rowid, rowdt, attribute, val FROM cth ORDER BY 1', 'SELECT rowid, rowdt, attribute, val FROM cth ORDER BY 1',
'SELECT DISTINCT rowdt, attribute FROM cth ORDER BY 2') 'SELECT DISTINCT rowdt, attribute FROM cth ORDER BY 2')
AS c(rowid text, rowdt timestamp, temperature int4, test_result text, test_startdate timestamp, volts float8); AS c(rowid text, rowdt timestamp, temperature int4, test_result text, test_startdate timestamp, volts float8);
ERROR: load_categories_hash: provided categories SQL must return 1 column of at least one row ERROR: provided "categories" SQL must return 1 column of at least one row
-- --
-- connectby -- connectby
-- --
......
This diff is collapsed.
...@@ -3,14 +3,18 @@ ...@@ -3,14 +3,18 @@
-- does not depend on contents of seg.sql. -- does not depend on contents of seg.sql.
-- --
\set ECHO none \set ECHO none
psql:tsearch.sql:9: NOTICE: ProcedureCreate: type txtidx is not yet defined psql:tsearch.sql:9: NOTICE: type txtidx is not yet defined
psql:tsearch.sql:14: NOTICE: Argument type "txtidx" is only a shell DETAIL: Creating a shell type definition.
psql:tsearch.sql:38: NOTICE: ProcedureCreate: type query_txt is not yet defined psql:tsearch.sql:14: NOTICE: argument type txtidx is only a shell
psql:tsearch.sql:43: NOTICE: Argument type "query_txt" is only a shell psql:tsearch.sql:38: NOTICE: type query_txt is not yet defined
psql:tsearch.sql:55: NOTICE: ProcedureCreate: type mquery_txt is not yet defined DETAIL: Creating a shell type definition.
psql:tsearch.sql:61: NOTICE: Argument type "mquery_txt" is only a shell psql:tsearch.sql:43: NOTICE: argument type query_txt is only a shell
psql:tsearch.sql:156: NOTICE: ProcedureCreate: type gtxtidx is not yet defined psql:tsearch.sql:55: NOTICE: type mquery_txt is not yet defined
psql:tsearch.sql:161: NOTICE: Argument type "gtxtidx" is only a shell DETAIL: Creating a shell type definition.
psql:tsearch.sql:61: NOTICE: argument type mquery_txt is only a shell
psql:tsearch.sql:156: NOTICE: type gtxtidx is not yet defined
DETAIL: Creating a shell type definition.
psql:tsearch.sql:161: NOTICE: argument type gtxtidx is only a shell
--txtidx --txtidx
SELECT '1'::txtidx; SELECT '1'::txtidx;
txtidx txtidx
......
...@@ -5,8 +5,6 @@ ...@@ -5,8 +5,6 @@
#include "access/gist.h" #include "access/gist.h"
#include "access/itup.h" #include "access/itup.h"
#include "access/rtree.h" #include "access/rtree.h"
#include "utils/elog.h"
#include "utils/palloc.h"
#include "utils/array.h" #include "utils/array.h"
#include "utils/builtins.h" #include "utils/builtins.h"
#include "storage/bufpage.h" #include "storage/bufpage.h"
...@@ -60,14 +58,18 @@ Datum gtxtidx_picksplit(PG_FUNCTION_ARGS); ...@@ -60,14 +58,18 @@ Datum gtxtidx_picksplit(PG_FUNCTION_ARGS);
Datum Datum
gtxtidx_in(PG_FUNCTION_ARGS) gtxtidx_in(PG_FUNCTION_ARGS)
{ {
elog(ERROR, "Not implemented"); ereport(ERROR,
(errcode(ERRCODE_FEATURE_NOT_SUPPORTED),
errmsg("gtxtidx_in not implemented")));
PG_RETURN_DATUM(0); PG_RETURN_DATUM(0);
} }
Datum Datum
gtxtidx_out(PG_FUNCTION_ARGS) gtxtidx_out(PG_FUNCTION_ARGS)
{ {
elog(ERROR, "Not implemented"); ereport(ERROR,
(errcode(ERRCODE_FEATURE_NOT_SUPPORTED),
errmsg("gtxtidx_out not implemented")));
PG_RETURN_DATUM(0); PG_RETURN_DATUM(0);
} }
......
...@@ -15,8 +15,6 @@ ...@@ -15,8 +15,6 @@
#include "access/gist.h" #include "access/gist.h"
#include "access/itup.h" #include "access/itup.h"
#include "access/rtree.h" #include "access/rtree.h"
#include "utils/elog.h"
#include "utils/palloc.h"
#include "utils/array.h" #include "utils/array.h"
#include "utils/builtins.h" #include "utils/builtins.h"
#include "storage/bufpage.h" #include "storage/bufpage.h"
...@@ -129,7 +127,9 @@ gettoken_query(QPRS_STATE * state, int4 *val, int4 *lenval, char **strval) ...@@ -129,7 +127,9 @@ gettoken_query(QPRS_STATE * state, int4 *val, int4 *lenval, char **strval)
return VAL; return VAL;
} }
else else
elog(ERROR, "No operand"); ereport(ERROR,
(errcode(ERRCODE_SYNTAX_ERROR),
errmsg("no operand")));
} }
break; break;
case WAITOPERATOR: case WAITOPERATOR:
...@@ -171,9 +171,13 @@ pushquery(QPRS_STATE * state, int4 type, int4 val, int4 distance, int4 lenval) ...@@ -171,9 +171,13 @@ pushquery(QPRS_STATE * state, int4 type, int4 val, int4 distance, int4 lenval)
tmp->type = type; tmp->type = type;
tmp->val = val; tmp->val = val;
if (distance > 0xffff) if (distance > 0xffff)
elog(ERROR, "Value is too big"); ereport(ERROR,
(errcode(ERRCODE_SYNTAX_ERROR),
errmsg("value is too big")));
if (lenval > 0xffff) if (lenval > 0xffff)
elog(ERROR, "Operand is too long"); ereport(ERROR,
(errcode(ERRCODE_SYNTAX_ERROR),
errmsg("operand is too long")));
tmp->distance = distance; tmp->distance = distance;
tmp->length = lenval; tmp->length = lenval;
tmp->next = state->str; tmp->next = state->str;
...@@ -188,7 +192,9 @@ static void ...@@ -188,7 +192,9 @@ static void
pushval_asis(QPRS_STATE * state, int type, char *strval, int lenval) pushval_asis(QPRS_STATE * state, int type, char *strval, int lenval)
{ {
if (lenval > 0xffff) if (lenval > 0xffff)
elog(ERROR, "Word is too long"); ereport(ERROR,
(errcode(ERRCODE_SYNTAX_ERROR),
errmsg("word is too long")));
pushquery(state, type, crc32_sz((uint8 *) strval, lenval), pushquery(state, type, crc32_sz((uint8 *) strval, lenval),
state->curop - state->op, lenval); state->curop - state->op, lenval);
...@@ -226,7 +232,9 @@ pushval_morph(QPRS_STATE * state, int typeval, char *strval, int lenval) ...@@ -226,7 +232,9 @@ pushval_morph(QPRS_STATE * state, int typeval, char *strval, int lenval)
if (tokenlen > 0xffff) if (tokenlen > 0xffff)
{ {
end_parse(); end_parse();
elog(ERROR, "Word is too long"); ereport(ERROR,
(errcode(ERRCODE_SYNTAX_ERROR),
errmsg("word is too long")));
} }
lenlemm = tokenlen; lenlemm = tokenlen;
lemm = lemmatize(token, &lenlemm, type); lemm = lemmatize(token, &lenlemm, type);
...@@ -278,7 +286,8 @@ makepol(QPRS_STATE * state, void (*pushval) (QPRS_STATE *, int, char *, int)) ...@@ -278,7 +286,8 @@ makepol(QPRS_STATE * state, void (*pushval) (QPRS_STATE *, int, char *, int))
else else
{ {
if (lenstack == STACKDEPTH) if (lenstack == STACKDEPTH)
elog(ERROR, "Stack too short"); /* internal error */
elog(ERROR, "stack too short");
stack[lenstack] = val; stack[lenstack] = val;
lenstack++; lenstack++;
} }
...@@ -303,7 +312,10 @@ makepol(QPRS_STATE * state, void (*pushval) (QPRS_STATE *, int, char *, int)) ...@@ -303,7 +312,10 @@ makepol(QPRS_STATE * state, void (*pushval) (QPRS_STATE *, int, char *, int))
break; break;
case ERR: case ERR:
default: default:
elog(ERROR, "Syntax error"); ereport(ERROR,
(errcode(ERRCODE_SYNTAX_ERROR),
errmsg("syntax error")));
return ERR; return ERR;
} }
...@@ -450,7 +462,7 @@ findoprnd(ITEM * ptr, int4 *pos) ...@@ -450,7 +462,7 @@ findoprnd(ITEM * ptr, int4 *pos)
{ {
#ifdef BS_DEBUG #ifdef BS_DEBUG
elog(DEBUG4, (ptr[*pos].type == OPR) ? elog(DEBUG4, (ptr[*pos].type == OPR) ?
"%d %c" : "%d %d ", *pos, ptr[*pos].val); "%d %c" : "%d %d", *pos, ptr[*pos].val);
#endif #endif
if (ptr[*pos].type == VAL || ptr[*pos].type == VALTRUE) if (ptr[*pos].type == VAL || ptr[*pos].type == VALTRUE)
{ {
...@@ -517,7 +529,9 @@ queryin(char *buf, void (*pushval) (QPRS_STATE *, int, char *, int)) ...@@ -517,7 +529,9 @@ queryin(char *buf, void (*pushval) (QPRS_STATE *, int, char *, int))
makepol(&state, pushval); makepol(&state, pushval);
pfree(state.valstate.word); pfree(state.valstate.word);
if (!state.num) if (!state.num)
elog(ERROR, "Empty query"); ereport(ERROR,
(errcode(ERRCODE_SYNTAX_ERROR),
errmsg("empty query")));
/* make finish struct */ /* make finish struct */
commonlen = COMPUTESIZE(state.num, state.sumlen); commonlen = COMPUTESIZE(state.num, state.sumlen);
......
...@@ -8,8 +8,6 @@ ...@@ -8,8 +8,6 @@
#include "access/gist.h" #include "access/gist.h"
#include "access/itup.h" #include "access/itup.h"
#include "utils/elog.h"
#include "utils/palloc.h"
#include "utils/builtins.h" #include "utils/builtins.h"
#include "storage/bufpage.h" #include "storage/bufpage.h"
#include "executor/spi.h" #include "executor/spi.h"
...@@ -128,7 +126,9 @@ gettoken_txtidx(TI_IN_STATE * state) ...@@ -128,7 +126,9 @@ gettoken_txtidx(TI_IN_STATE * state)
oldstate = WAITENDWORD; oldstate = WAITENDWORD;
} }
else if (state->oprisdelim && ISOPERATOR(*(state->prsbuf))) else if (state->oprisdelim && ISOPERATOR(*(state->prsbuf)))
elog(ERROR, "Syntax error"); ereport(ERROR,
(errcode(ERRCODE_SYNTAX_ERROR),
errmsg("syntax error")));
else if (*(state->prsbuf) != ' ') else if (*(state->prsbuf) != ' ')
{ {
*(state->curpos) = *(state->prsbuf); *(state->curpos) = *(state->prsbuf);
...@@ -139,7 +139,9 @@ gettoken_txtidx(TI_IN_STATE * state) ...@@ -139,7 +139,9 @@ gettoken_txtidx(TI_IN_STATE * state)
else if (state->state == WAITNEXTCHAR) else if (state->state == WAITNEXTCHAR)
{ {
if (*(state->prsbuf) == '\0') if (*(state->prsbuf) == '\0')
elog(ERROR, "There is no escaped character"); ereport(ERROR,
(errcode(ERRCODE_SYNTAX_ERROR),
errmsg("there is no escaped character")));
else else
{ {
RESIZEPRSBUF; RESIZEPRSBUF;
...@@ -160,7 +162,9 @@ gettoken_txtidx(TI_IN_STATE * state) ...@@ -160,7 +162,9 @@ gettoken_txtidx(TI_IN_STATE * state)
{ {
RESIZEPRSBUF; RESIZEPRSBUF;
if (state->curpos == state->word) if (state->curpos == state->word)
elog(ERROR, "Syntax error"); ereport(ERROR,
(errcode(ERRCODE_SYNTAX_ERROR),
errmsg("syntax error")));
*(state->curpos) = '\0'; *(state->curpos) = '\0';
return 1; return 1;
} }
...@@ -178,7 +182,9 @@ gettoken_txtidx(TI_IN_STATE * state) ...@@ -178,7 +182,9 @@ gettoken_txtidx(TI_IN_STATE * state)
RESIZEPRSBUF; RESIZEPRSBUF;
*(state->curpos) = '\0'; *(state->curpos) = '\0';
if (state->curpos == state->word) if (state->curpos == state->word)
elog(ERROR, "Syntax error"); ereport(ERROR,
(errcode(ERRCODE_SYNTAX_ERROR),
errmsg("syntax error")));
state->prsbuf++; state->prsbuf++;
return 1; return 1;
} }
...@@ -188,7 +194,9 @@ gettoken_txtidx(TI_IN_STATE * state) ...@@ -188,7 +194,9 @@ gettoken_txtidx(TI_IN_STATE * state)
oldstate = WAITENDCMPLX; oldstate = WAITENDCMPLX;
} }
else if (*(state->prsbuf) == '\0') else if (*(state->prsbuf) == '\0')
elog(ERROR, "Syntax error"); ereport(ERROR,
(errcode(ERRCODE_SYNTAX_ERROR),
errmsg("syntax error")));
else else
{ {
RESIZEPRSBUF; RESIZEPRSBUF;
...@@ -197,7 +205,8 @@ gettoken_txtidx(TI_IN_STATE * state) ...@@ -197,7 +205,8 @@ gettoken_txtidx(TI_IN_STATE * state)
} }
} }
else else
elog(ERROR, "Inner bug :("); /* internal error */
elog(ERROR, "internal error");
state->prsbuf++; state->prsbuf++;
} }
...@@ -241,10 +250,14 @@ txtidx_in(PG_FUNCTION_ARGS) ...@@ -241,10 +250,14 @@ txtidx_in(PG_FUNCTION_ARGS)
cur = tmpbuf + dist; cur = tmpbuf + dist;
} }
if (state.curpos - state.word > 0xffff) if (state.curpos - state.word > 0xffff)
elog(ERROR, "Word is too long"); ereport(ERROR,
(errcode(ERRCODE_SYNTAX_ERROR),
errmsg("word is too long")));
arr[len].len = state.curpos - state.word; arr[len].len = state.curpos - state.word;
if (cur - tmpbuf > 0xffff) if (cur - tmpbuf > 0xffff)
elog(ERROR, "Too long value"); ereport(ERROR,
(errcode(ERRCODE_SYNTAX_ERROR),
errmsg("too long value")));
arr[len].pos = cur - tmpbuf; arr[len].pos = cur - tmpbuf;
memcpy((void *) cur, (void *) state.word, arr[len].len); memcpy((void *) cur, (void *) state.word, arr[len].len);
cur += arr[len].len; cur += arr[len].len;
...@@ -253,7 +266,9 @@ txtidx_in(PG_FUNCTION_ARGS) ...@@ -253,7 +266,9 @@ txtidx_in(PG_FUNCTION_ARGS)
pfree(state.word); pfree(state.word);
if (!len) if (!len)
elog(ERROR, "Void value"); ereport(ERROR,
(errcode(ERRCODE_SYNTAX_ERROR),
errmsg("void value")));
len = uniqueentry(arr, len, tmpbuf, &buflen); len = uniqueentry(arr, len, tmpbuf, &buflen);
totallen = CALCDATASIZE(len, buflen); totallen = CALCDATASIZE(len, buflen);
...@@ -359,7 +374,9 @@ parsetext(PRSTEXT * prs, char *buf, int4 buflen) ...@@ -359,7 +374,9 @@ parsetext(PRSTEXT * prs, char *buf, int4 buflen)
if (tokenlen > 0xffff) if (tokenlen > 0xffff)
{ {
end_parse(); end_parse();
elog(ERROR, "Word is too long"); ereport(ERROR,
(errcode(ERRCODE_SYNTAX_ERROR),
errmsg("word is too long")));
} }
lenlemm = tokenlen; lenlemm = tokenlen;
...@@ -461,7 +478,9 @@ makevalue(PRSTEXT * prs) ...@@ -461,7 +478,9 @@ makevalue(PRSTEXT * prs)
{ {
ptr->len = prs->words[i].len; ptr->len = prs->words[i].len;
if (cur - str > 0xffff) if (cur - str > 0xffff)
elog(ERROR, "Value is too big"); ereport(ERROR,
(errcode(ERRCODE_SYNTAX_ERROR),
errmsg("value is too big")));
ptr->pos = cur - str; ptr->pos = cur - str;
ptr++; ptr++;
memcpy((void *) cur, (void *) prs->words[i].word, prs->words[i].len); memcpy((void *) cur, (void *) prs->words[i].word, prs->words[i].len);
...@@ -512,12 +531,15 @@ tsearch(PG_FUNCTION_ARGS) ...@@ -512,12 +531,15 @@ tsearch(PG_FUNCTION_ARGS)
Datum datum = (Datum) 0; Datum datum = (Datum) 0;
if (!CALLED_AS_TRIGGER(fcinfo)) if (!CALLED_AS_TRIGGER(fcinfo))
/* internal error */
elog(ERROR, "TSearch: Not fired by trigger manager"); elog(ERROR, "TSearch: Not fired by trigger manager");
trigdata = (TriggerData *) fcinfo->context; trigdata = (TriggerData *) fcinfo->context;
if (TRIGGER_FIRED_FOR_STATEMENT(trigdata->tg_event)) if (TRIGGER_FIRED_FOR_STATEMENT(trigdata->tg_event))
/* internal error */
elog(ERROR, "TSearch: Can't process STATEMENT events"); elog(ERROR, "TSearch: Can't process STATEMENT events");
if (TRIGGER_FIRED_AFTER(trigdata->tg_event)) if (TRIGGER_FIRED_AFTER(trigdata->tg_event))
/* internal error */
elog(ERROR, "TSearch: Must be fired BEFORE event"); elog(ERROR, "TSearch: Must be fired BEFORE event");
if (TRIGGER_FIRED_BY_INSERT(trigdata->tg_event)) if (TRIGGER_FIRED_BY_INSERT(trigdata->tg_event))
...@@ -525,18 +547,21 @@ tsearch(PG_FUNCTION_ARGS) ...@@ -525,18 +547,21 @@ tsearch(PG_FUNCTION_ARGS)
else if (TRIGGER_FIRED_BY_UPDATE(trigdata->tg_event)) else if (TRIGGER_FIRED_BY_UPDATE(trigdata->tg_event))
rettuple = trigdata->tg_newtuple; rettuple = trigdata->tg_newtuple;
else else
/* internal error */
elog(ERROR, "TSearch: Unknown event"); elog(ERROR, "TSearch: Unknown event");
trigger = trigdata->tg_trigger; trigger = trigdata->tg_trigger;
rel = trigdata->tg_relation; rel = trigdata->tg_relation;
if (trigger->tgnargs < 2) if (trigger->tgnargs < 2)
/* internal error */
elog(ERROR, "TSearch: format tsearch(txtidx_field, text_field1,...)"); elog(ERROR, "TSearch: format tsearch(txtidx_field, text_field1,...)");
numidxattr = SPI_fnumber(rel->rd_att, trigger->tgargs[0]); numidxattr = SPI_fnumber(rel->rd_att, trigger->tgargs[0]);
if (numidxattr == SPI_ERROR_NOATTRIBUTE) if (numidxattr == SPI_ERROR_NOATTRIBUTE)
elog(ERROR, "TSearch: Can not find txtidx_field"); ereport(ERROR,
(errcode(ERRCODE_UNDEFINED_COLUMN),
errmsg("could not find txtidx_field")));
prs.lenwords = 32; prs.lenwords = 32;
prs.curwords = 0; prs.curwords = 0;
prs.words = (WORD *) palloc(sizeof(WORD) * prs.lenwords); prs.words = (WORD *) palloc(sizeof(WORD) * prs.lenwords);
...@@ -594,6 +619,7 @@ tsearch(PG_FUNCTION_ARGS) ...@@ -594,6 +619,7 @@ tsearch(PG_FUNCTION_ARGS)
} }
if (rettuple == NULL) if (rettuple == NULL)
/* internal error */
elog(ERROR, "TSearch: %d returned by SPI_modifytuple", SPI_result); elog(ERROR, "TSearch: %d returned by SPI_modifytuple", SPI_result);
return PointerGetDatum(rettuple); return PointerGetDatum(rettuple);
......
...@@ -68,7 +68,8 @@ ts_error(int state, const char *format, ...) { ...@@ -68,7 +68,8 @@ ts_error(int state, const char *format, ...) {
} }
va_end(args); va_end(args);
elog(state,buf); /* ?? internal error ?? */
elog(state, "%s", buf);
pfree(buf); pfree(buf);
} }
......
...@@ -258,7 +258,10 @@ Datum ...@@ -258,7 +258,10 @@ Datum
lexize_bycurrent(PG_FUNCTION_ARGS) { lexize_bycurrent(PG_FUNCTION_ARGS) {
Datum res; Datum res;
if ( currect_dictionary_id == 0 ) if ( currect_dictionary_id == 0 )
elog(ERROR, "No currect dictionary. Execute select set_curdict()."); ereport(ERROR,
(errcode(ERRCODE_OBJECT_NOT_IN_PREREQUISITE_STATE),
errmsg("no currect dictionary"),
errhint("Execute select set_curdict().")));
res = DirectFunctionCall3( res = DirectFunctionCall3(
lexize, lexize,
......
...@@ -26,7 +26,9 @@ dex_init(PG_FUNCTION_ARGS) { ...@@ -26,7 +26,9 @@ dex_init(PG_FUNCTION_ARGS) {
DictExample *d = (DictExample*)malloc( sizeof(DictExample) ); DictExample *d = (DictExample*)malloc( sizeof(DictExample) );
if ( !d ) if ( !d )
elog(ERROR, "No memory"); ereport(ERROR,
(errcode(ERRCODE_OUT_OF_MEMORY),
errmsg("out of memory")));
memset(d,0,sizeof(DictExample)); memset(d,0,sizeof(DictExample));
d->stoplist.wordop=lowerstr; d->stoplist.wordop=lowerstr;
......
...@@ -37,11 +37,15 @@ spell_init(PG_FUNCTION_ARGS) { ...@@ -37,11 +37,15 @@ spell_init(PG_FUNCTION_ARGS) {
bool affloaded=false, dictloaded=false, stoploaded=false; bool affloaded=false, dictloaded=false, stoploaded=false;
if ( PG_ARGISNULL(0) || PG_GETARG_POINTER(0)==NULL ) if ( PG_ARGISNULL(0) || PG_GETARG_POINTER(0)==NULL )
elog(ERROR,"ISpell confguration error"); ereport(ERROR,
(errcode(ERRCODE_CONFIG_FILE_ERROR),
errmsg("ISpell confguration error")));
d = (DictISpell*)malloc( sizeof(DictISpell) ); d = (DictISpell*)malloc( sizeof(DictISpell) );
if ( !d ) if ( !d )
elog(ERROR, "No memory"); ereport(ERROR,
(errcode(ERRCODE_OUT_OF_MEMORY),
errmsg("out of memory")));
memset(d,0,sizeof(DictISpell)); memset(d,0,sizeof(DictISpell));
d->stoplist.wordop=lowerstr; d->stoplist.wordop=lowerstr;
...@@ -53,28 +57,40 @@ spell_init(PG_FUNCTION_ARGS) { ...@@ -53,28 +57,40 @@ spell_init(PG_FUNCTION_ARGS) {
if ( strcasecmp("DictFile", pcfg->key) == 0 ) { if ( strcasecmp("DictFile", pcfg->key) == 0 ) {
if ( dictloaded ) { if ( dictloaded ) {
freeDictISpell(d); freeDictISpell(d);
elog(ERROR,"Dictionary already loaded"); ereport(ERROR,
(errcode(ERRCODE_OBJECT_NOT_IN_PREREQUISITE_STATE),
errmsg("dictionary already loaded")));
} }
if ( ImportDictionary(&(d->obj), pcfg->value) ) { if ( ImportDictionary(&(d->obj), pcfg->value) ) {
freeDictISpell(d); freeDictISpell(d);
elog(ERROR,"Can't load dictionary file (%s)", pcfg->value); ereport(ERROR,
(errcode(ERRCODE_CONFIG_FILE_ERROR),
errmsg("could not load dictionary file \"%s\"",
pcfg->value)));
} }
dictloaded=true; dictloaded=true;
} else if ( strcasecmp("AffFile", pcfg->key) == 0 ) { } else if ( strcasecmp("AffFile", pcfg->key) == 0 ) {
if ( affloaded ) { if ( affloaded ) {
freeDictISpell(d); freeDictISpell(d);
elog(ERROR,"Affixes already loaded"); ereport(ERROR,
(errcode(ERRCODE_OBJECT_NOT_IN_PREREQUISITE_STATE),
errmsg("affixes already loaded")));
} }
if ( ImportAffixes(&(d->obj), pcfg->value) ) { if ( ImportAffixes(&(d->obj), pcfg->value) ) {
freeDictISpell(d); freeDictISpell(d);
elog(ERROR,"Can't load affix file (%s)", pcfg->value); ereport(ERROR,
(errcode(ERRCODE_CONFIG_FILE_ERROR),
errmsg("could not load affix file \"%s\"",
pcfg->value)));
} }
affloaded=true; affloaded=true;
} else if ( strcasecmp("StopFile", pcfg->key) == 0 ) { } else if ( strcasecmp("StopFile", pcfg->key) == 0 ) {
text *tmp=char2text(pcfg->value); text *tmp=char2text(pcfg->value);
if ( stoploaded ) { if ( stoploaded ) {
freeDictISpell(d); freeDictISpell(d);
elog(ERROR,"Stop words already loaded"); ereport(ERROR,
(errcode(ERRCODE_OBJECT_NOT_IN_PREREQUISITE_STATE),
errmsg("stop words already loaded")));
} }
readstoplist(tmp, &(d->stoplist)); readstoplist(tmp, &(d->stoplist));
sortstoplist(&(d->stoplist)); sortstoplist(&(d->stoplist));
...@@ -82,7 +98,10 @@ spell_init(PG_FUNCTION_ARGS) { ...@@ -82,7 +98,10 @@ spell_init(PG_FUNCTION_ARGS) {
stoploaded=true; stoploaded=true;
} else { } else {
freeDictISpell(d); freeDictISpell(d);
elog(ERROR,"Unknown option: %s => %s", pcfg->key, pcfg->value); ereport(ERROR,
(errcode(ERRCODE_SYNTAX_ERROR),
errmsg("unrecognized option: %s => %s",
pcfg->key, pcfg->value)));
} }
pfree(pcfg->key); pfree(pcfg->key);
pfree(pcfg->value); pfree(pcfg->value);
...@@ -95,10 +114,14 @@ spell_init(PG_FUNCTION_ARGS) { ...@@ -95,10 +114,14 @@ spell_init(PG_FUNCTION_ARGS) {
SortAffixes(&(d->obj)); SortAffixes(&(d->obj));
} else if ( !affloaded ) { } else if ( !affloaded ) {
freeDictISpell(d); freeDictISpell(d);
elog(ERROR,"No affixes"); ereport(ERROR,
(errcode(ERRCODE_OBJECT_NOT_IN_PREREQUISITE_STATE),
errmsg("no affixes")));
} else { } else {
freeDictISpell(d); freeDictISpell(d);
elog(ERROR,"No dictionary"); ereport(ERROR,
(errcode(ERRCODE_OBJECT_NOT_IN_PREREQUISITE_STATE),
errmsg("no dictionary")));
} }
PG_RETURN_POINTER(d); PG_RETURN_POINTER(d);
......
...@@ -33,7 +33,9 @@ snb_en_init(PG_FUNCTION_ARGS) { ...@@ -33,7 +33,9 @@ snb_en_init(PG_FUNCTION_ARGS) {
DictSnowball *d = (DictSnowball*)malloc( sizeof(DictSnowball) ); DictSnowball *d = (DictSnowball*)malloc( sizeof(DictSnowball) );
if ( !d ) if ( !d )
elog(ERROR, "No memory"); ereport(ERROR,
(errcode(ERRCODE_OUT_OF_MEMORY),
errmsg("out of memory")));
memset(d,0,sizeof(DictSnowball)); memset(d,0,sizeof(DictSnowball));
d->stoplist.wordop=lowerstr; d->stoplist.wordop=lowerstr;
...@@ -47,7 +49,9 @@ snb_en_init(PG_FUNCTION_ARGS) { ...@@ -47,7 +49,9 @@ snb_en_init(PG_FUNCTION_ARGS) {
d->z = english_create_env(); d->z = english_create_env();
if (!d->z) { if (!d->z) {
freestoplist(&(d->stoplist)); freestoplist(&(d->stoplist));
elog(ERROR,"No memory"); ereport(ERROR,
(errcode(ERRCODE_OUT_OF_MEMORY),
errmsg("out of memory")));
} }
d->stem=english_stem; d->stem=english_stem;
...@@ -59,7 +63,9 @@ snb_ru_init(PG_FUNCTION_ARGS) { ...@@ -59,7 +63,9 @@ snb_ru_init(PG_FUNCTION_ARGS) {
DictSnowball *d = (DictSnowball*)malloc( sizeof(DictSnowball) ); DictSnowball *d = (DictSnowball*)malloc( sizeof(DictSnowball) );
if ( !d ) if ( !d )
elog(ERROR, "No memory"); ereport(ERROR,
(errcode(ERRCODE_OUT_OF_MEMORY),
errmsg("out of memory")));
memset(d,0,sizeof(DictSnowball)); memset(d,0,sizeof(DictSnowball));
d->stoplist.wordop=lowerstr; d->stoplist.wordop=lowerstr;
...@@ -73,7 +79,9 @@ snb_ru_init(PG_FUNCTION_ARGS) { ...@@ -73,7 +79,9 @@ snb_ru_init(PG_FUNCTION_ARGS) {
d->z = russian_create_env(); d->z = russian_create_env();
if (!d->z) { if (!d->z) {
freestoplist(&(d->stoplist)); freestoplist(&(d->stoplist));
elog(ERROR,"No memory"); ereport(ERROR,
(errcode(ERRCODE_OUT_OF_MEMORY),
errmsg("out of memory")));
} }
d->stem=russian_stem; d->stem=russian_stem;
......
...@@ -65,21 +65,30 @@ syn_init(PG_FUNCTION_ARGS) { ...@@ -65,21 +65,30 @@ syn_init(PG_FUNCTION_ARGS) {
int slen; int slen;
if ( PG_ARGISNULL(0) || PG_GETARG_POINTER(0)==NULL ) if ( PG_ARGISNULL(0) || PG_GETARG_POINTER(0)==NULL )
elog(ERROR,"NULL config"); ereport(ERROR,
(errcode(ERRCODE_INVALID_PARAMETER_VALUE),
errmsg("NULL config")));
in = PG_GETARG_TEXT_P(0); in = PG_GETARG_TEXT_P(0);
if ( VARSIZE(in) - VARHDRSZ == 0 ) if ( VARSIZE(in) - VARHDRSZ == 0 )
elog(ERROR,"VOID config"); ereport(ERROR,
(errcode(ERRCODE_INVALID_PARAMETER_VALUE),
errmsg("VOID config")));
filename=text2char(in); filename=text2char(in);
PG_FREE_IF_COPY(in, 0); PG_FREE_IF_COPY(in, 0);
if ( (fin=fopen(filename,"r")) == NULL ) if ( (fin=fopen(filename,"r")) == NULL )
elog(ERROR,"Can't open file '%s': %s", filename, strerror(errno)); ereport(ERROR,
(errcode_for_file_access(),
errmsg("could not open file \"%s\": %m",
filename)));
d = (DictSyn*)malloc( sizeof(DictSyn) ); d = (DictSyn*)malloc( sizeof(DictSyn) );
if ( !d ) { if ( !d ) {
fclose(fin); fclose(fin);
elog(ERROR, "No memory"); ereport(ERROR,
(errcode(ERRCODE_OUT_OF_MEMORY),
errmsg("out of memory")));
} }
memset(d,0,sizeof(DictSyn)); memset(d,0,sizeof(DictSyn));
...@@ -92,7 +101,9 @@ syn_init(PG_FUNCTION_ARGS) { ...@@ -92,7 +101,9 @@ syn_init(PG_FUNCTION_ARGS) {
d->syn=(Syn*)realloc( d->syn, sizeof(Syn)*d->len ); d->syn=(Syn*)realloc( d->syn, sizeof(Syn)*d->len );
if ( !d->syn ) { if ( !d->syn ) {
fclose(fin); fclose(fin);
elog(ERROR, "No memory"); ereport(ERROR,
(errcode(ERRCODE_OUT_OF_MEMORY),
errmsg("out of memory")));
} }
} }
...@@ -112,7 +123,9 @@ syn_init(PG_FUNCTION_ARGS) { ...@@ -112,7 +123,9 @@ syn_init(PG_FUNCTION_ARGS) {
d->syn[cur].out=strdup(lowerstr(starto)); d->syn[cur].out=strdup(lowerstr(starto));
if ( !(d->syn[cur].in && d->syn[cur].out) ) { if ( !(d->syn[cur].in && d->syn[cur].out) ) {
fclose(fin); fclose(fin);
elog(ERROR, "No memory"); ereport(ERROR,
(errcode(ERRCODE_OUT_OF_MEMORY),
errmsg("out of memory")));
} }
cur++; cur++;
......
...@@ -28,7 +28,9 @@ dinit_CFG_MODNAME(PG_FUNCTION_ARGS) { ...@@ -28,7 +28,9 @@ dinit_CFG_MODNAME(PG_FUNCTION_ARGS) {
DictSnowball *d = (DictSnowball*)malloc( sizeof(DictSnowball) ); DictSnowball *d = (DictSnowball*)malloc( sizeof(DictSnowball) );
if ( !d ) if ( !d )
elog(ERROR, "No memory"); ereport(ERROR,
(errcode(ERRCODE_OUT_OF_MEMORY),
errmsg("out of memory")));
memset(d,0,sizeof(DictSnowball)); memset(d,0,sizeof(DictSnowball));
d->stoplist.wordop=lowerstr; d->stoplist.wordop=lowerstr;
...@@ -42,7 +44,9 @@ dinit_CFG_MODNAME(PG_FUNCTION_ARGS) { ...@@ -42,7 +44,9 @@ dinit_CFG_MODNAME(PG_FUNCTION_ARGS) {
d->z = CFG_PREFIX_create_env(); d->z = CFG_PREFIX_create_env();
if (!d->z) { if (!d->z) {
freestoplist(&(d->stoplist)); freestoplist(&(d->stoplist));
elog(ERROR,"No memory"); ereport(ERROR,
(errcode(ERRCODE_OUT_OF_MEMORY),
errmsg("out of memory")));
} }
d->stem=CFG_PREFIX_stem; d->stem=CFG_PREFIX_stem;
......
...@@ -26,7 +26,9 @@ HASINIT dinit_CFG_MODNAME(PG_FUNCTION_ARGS) { ...@@ -26,7 +26,9 @@ HASINIT dinit_CFG_MODNAME(PG_FUNCTION_ARGS) {
HASINIT DictExample *d = (DictExample*)malloc( sizeof(DictExample) ); HASINIT DictExample *d = (DictExample*)malloc( sizeof(DictExample) );
HASINIT HASINIT
HASINIT if ( !d ) HASINIT if ( !d )
HASINIT elog(ERROR, "No memory"); HASINIT ereport(ERROR,
HASINIT (errcode(ERRCODE_OUT_OF_MEMORY),
HASINIT errmsg("out of memory")));
HASINIT memset(d,0,sizeof(DictExample)); HASINIT memset(d,0,sizeof(DictExample));
HASINIT HASINIT
HASINIT d->stoplist.wordop=lowerstr; HASINIT d->stoplist.wordop=lowerstr;
......
...@@ -5,8 +5,6 @@ ...@@ -5,8 +5,6 @@
#include "access/gist.h" #include "access/gist.h"
#include "access/itup.h" #include "access/itup.h"
#include "access/rtree.h" #include "access/rtree.h"
#include "utils/elog.h"
#include "utils/palloc.h"
#include "utils/array.h" #include "utils/array.h"
#include "utils/builtins.h" #include "utils/builtins.h"
#include "storage/bufpage.h" #include "storage/bufpage.h"
...@@ -60,14 +58,18 @@ Datum gtsvector_picksplit(PG_FUNCTION_ARGS); ...@@ -60,14 +58,18 @@ Datum gtsvector_picksplit(PG_FUNCTION_ARGS);
Datum Datum
gtsvector_in(PG_FUNCTION_ARGS) gtsvector_in(PG_FUNCTION_ARGS)
{ {
elog(ERROR, "Not implemented"); ereport(ERROR,
(errcode(ERRCODE_FEATURE_NOT_SUPPORTED),
errmsg("gtsvector_in not implemented")));
PG_RETURN_DATUM(0); PG_RETURN_DATUM(0);
} }
Datum Datum
gtsvector_out(PG_FUNCTION_ARGS) gtsvector_out(PG_FUNCTION_ARGS)
{ {
elog(ERROR, "Not implemented"); ereport(ERROR,
(errcode(ERRCODE_FEATURE_NOT_SUPPORTED),
errmsg("gtsvector_out not implemented")));
PG_RETURN_DATUM(0); PG_RETURN_DATUM(0);
} }
......
...@@ -75,11 +75,15 @@ AddSpell(IspellDict * Conf,const char * word,const char *flag){ ...@@ -75,11 +75,15 @@ AddSpell(IspellDict * Conf,const char * word,const char *flag){
Conf->Spell=(SPELL *)malloc(Conf->mspell*sizeof(SPELL)); Conf->Spell=(SPELL *)malloc(Conf->mspell*sizeof(SPELL));
} }
if ( Conf->Spell == NULL ) if ( Conf->Spell == NULL )
elog(ERROR,"No memory for AddSpell"); ereport(ERROR,
(errcode(ERRCODE_OUT_OF_MEMORY),
errmsg("out of memory")));
} }
Conf->Spell[Conf->nspell].word=strdup(word); Conf->Spell[Conf->nspell].word=strdup(word);
if ( !Conf->Spell[Conf->nspell].word ) if ( !Conf->Spell[Conf->nspell].word )
elog(ERROR,"No memory for AddSpell"); ereport(ERROR,
(errcode(ERRCODE_OUT_OF_MEMORY),
errmsg("out of memory")));
strncpy(Conf->Spell[Conf->nspell].flag,flag,10); strncpy(Conf->Spell[Conf->nspell].flag,flag,10);
Conf->nspell++; Conf->nspell++;
return(0); return(0);
...@@ -177,7 +181,9 @@ AddAffix(IspellDict * Conf,int flag,const char *mask,const char *find,const char ...@@ -177,7 +181,9 @@ AddAffix(IspellDict * Conf,int flag,const char *mask,const char *find,const char
Conf->Affix = (AFFIX*)malloc(Conf->maffixes * sizeof(AFFIX)); Conf->Affix = (AFFIX*)malloc(Conf->maffixes * sizeof(AFFIX));
} }
if ( Conf->Affix == NULL ) if ( Conf->Affix == NULL )
elog(ERROR,"No memory for AddAffix"); ereport(ERROR,
(errcode(ERRCODE_OUT_OF_MEMORY),
errmsg("out of memory")));
} }
if (type=='s') { if (type=='s') {
sprintf(Conf->Affix[Conf->naffixes].mask,"%s$",mask); sprintf(Conf->Affix[Conf->naffixes].mask,"%s$",mask);
......
...@@ -58,7 +58,11 @@ parse_cfgdict(text *in, Map **m) { ...@@ -58,7 +58,11 @@ parse_cfgdict(text *in, Map **m) {
begin=ptr; begin=ptr;
state=CS_INKEY; state=CS_INKEY;
} else if ( !isspace(*ptr) ) } else if ( !isspace(*ptr) )
elog(ERROR,"Syntax error in position %d near '%c'", ptr-VARDATA(in), *ptr); ereport(ERROR,
(errcode(ERRCODE_SYNTAX_ERROR),
errmsg("syntax error"),
errdetail("Syntax error in position %d near \"%c\"",
ptr-VARDATA(in), *ptr)));
} else if (state==CS_INKEY) { } else if (state==CS_INKEY) {
if ( isspace(*ptr) ) { if ( isspace(*ptr) ) {
mptr->key=nstrdup(begin, ptr-begin); mptr->key=nstrdup(begin, ptr-begin);
...@@ -67,12 +71,20 @@ parse_cfgdict(text *in, Map **m) { ...@@ -67,12 +71,20 @@ parse_cfgdict(text *in, Map **m) {
mptr->key=nstrdup(begin, ptr-begin); mptr->key=nstrdup(begin, ptr-begin);
state=CS_WAITVALUE; state=CS_WAITVALUE;
} else if ( !isalpha(*ptr) ) } else if ( !isalpha(*ptr) )
elog(ERROR,"Syntax error in position %d near '%c'", ptr-VARDATA(in), *ptr); ereport(ERROR,
(errcode(ERRCODE_SYNTAX_ERROR),
errmsg("syntax error"),
errdetail("Syntax error in position %d near \"%c\"",
ptr-VARDATA(in), *ptr)));
} else if ( state==CS_WAITEQ ) { } else if ( state==CS_WAITEQ ) {
if ( *ptr=='=' ) if ( *ptr=='=' )
state=CS_WAITVALUE; state=CS_WAITVALUE;
else if ( !isspace(*ptr) ) else if ( !isspace(*ptr) )
elog(ERROR,"Syntax error in position %d near '%c'", ptr-VARDATA(in), *ptr); ereport(ERROR,
(errcode(ERRCODE_SYNTAX_ERROR),
errmsg("syntax error"),
errdetail("Syntax error in position %d near \"%c\"",
ptr-VARDATA(in), *ptr)));
} else if ( state==CS_WAITVALUE ) { } else if ( state==CS_WAITVALUE ) {
if ( *ptr=='"' ) { if ( *ptr=='"' ) {
begin=ptr+1; begin=ptr+1;
...@@ -99,13 +111,21 @@ parse_cfgdict(text *in, Map **m) { ...@@ -99,13 +111,21 @@ parse_cfgdict(text *in, Map **m) {
if ( *ptr==',' ) if ( *ptr==',' )
state=CS_WAITKEY; state=CS_WAITKEY;
else if ( !isspace(*ptr) ) else if ( !isspace(*ptr) )
elog(ERROR,"Syntax error in position %d near '%c'", ptr-VARDATA(in), *ptr); ereport(ERROR,
(errcode(ERRCODE_SYNTAX_ERROR),
errmsg("syntax error"),
errdetail("Syntax error in position %d near \"%c\"",
ptr-VARDATA(in), *ptr)));
} else if ( state == CS_INESC ) { } else if ( state == CS_INESC ) {
state=CS_INVALUE; state=CS_INVALUE;
} else if ( state == CS_IN2ESC ) { } else if ( state == CS_IN2ESC ) {
state=CS_IN2VALUE; state=CS_IN2VALUE;
} else } else
elog(ERROR,"Bad parser state: %d at position %d near '%c'", state, ptr-VARDATA(in), *ptr); ereport(ERROR,
(errcode(ERRCODE_SYNTAX_ERROR),
errmsg("bad parser state"),
errdetail("%d at position %d near \"%c\"",
state, ptr-VARDATA(in), *ptr)));
ptr++; ptr++;
} }
...@@ -113,7 +133,9 @@ parse_cfgdict(text *in, Map **m) { ...@@ -113,7 +133,9 @@ parse_cfgdict(text *in, Map **m) {
mptr->value = nstrdup(begin, ptr-begin); mptr->value = nstrdup(begin, ptr-begin);
mptr++; mptr++;
} else if ( !(state==CS_WAITDELIM || state==CS_WAITKEY) ) } else if ( !(state==CS_WAITDELIM || state==CS_WAITKEY) )
elog(ERROR,"Unexpected end of line"); ereport(ERROR,
(errcode(ERRCODE_SYNTAX_ERROR),
errmsg("unexpected end of line")));
} }
...@@ -16,8 +16,6 @@ ...@@ -16,8 +16,6 @@
#include "access/gist.h" #include "access/gist.h"
#include "access/itup.h" #include "access/itup.h"
#include "access/rtree.h" #include "access/rtree.h"
#include "utils/elog.h"
#include "utils/palloc.h"
#include "utils/array.h" #include "utils/array.h"
#include "utils/builtins.h" #include "utils/builtins.h"
#include "storage/bufpage.h" #include "storage/bufpage.h"
...@@ -149,7 +147,9 @@ gettoken_query(QPRS_STATE * state, int4 *val, int4 *lenval, char **strval, int2 ...@@ -149,7 +147,9 @@ gettoken_query(QPRS_STATE * state, int4 *val, int4 *lenval, char **strval, int2
(state->buf)++; (state->buf)++;
return OPEN; return OPEN;
} else if ( *(state->buf) == ':' ) { } else if ( *(state->buf) == ':' ) {
elog(ERROR,"Error at start of operand"); ereport(ERROR,
(errcode(ERRCODE_SYNTAX_ERROR),
errmsg("error at start of operand")));
} else if (*(state->buf) != ' ') { } else if (*(state->buf) != ' ') {
state->valstate.prsbuf = state->buf; state->valstate.prsbuf = state->buf;
state->state = WAITOPERATOR; state->state = WAITOPERATOR;
...@@ -161,7 +161,9 @@ gettoken_query(QPRS_STATE * state, int4 *val, int4 *lenval, char **strval, int2 ...@@ -161,7 +161,9 @@ gettoken_query(QPRS_STATE * state, int4 *val, int4 *lenval, char **strval, int2
return VAL; return VAL;
} }
else else
elog(ERROR, "No operand"); ereport(ERROR,
(errcode(ERRCODE_SYNTAX_ERROR),
errmsg("no operand")));
} }
break; break;
case WAITOPERATOR: case WAITOPERATOR:
...@@ -204,9 +206,13 @@ pushquery(QPRS_STATE * state, int4 type, int4 val, int4 distance, int4 lenval, i ...@@ -204,9 +206,13 @@ pushquery(QPRS_STATE * state, int4 type, int4 val, int4 distance, int4 lenval, i
tmp->type = type; tmp->type = type;
tmp->val = val; tmp->val = val;
if (distance >= MAXSTRPOS) if (distance >= MAXSTRPOS)
elog(ERROR, "Value is too big"); ereport(ERROR,
(errcode(ERRCODE_SYNTAX_ERROR),
errmsg("value is too big")));
if (lenval >= MAXSTRLEN) if (lenval >= MAXSTRLEN)
elog(ERROR, "Operand is too long"); ereport(ERROR,
(errcode(ERRCODE_SYNTAX_ERROR),
errmsg("operand is too long")));
tmp->distance = distance; tmp->distance = distance;
tmp->length = lenval; tmp->length = lenval;
tmp->next = state->str; tmp->next = state->str;
...@@ -221,7 +227,9 @@ static void ...@@ -221,7 +227,9 @@ static void
pushval_asis(QPRS_STATE * state, int type, char *strval, int lenval, int2 weight) pushval_asis(QPRS_STATE * state, int type, char *strval, int lenval, int2 weight)
{ {
if (lenval >= MAXSTRLEN) if (lenval >= MAXSTRLEN)
elog(ERROR, "Word is too long"); ereport(ERROR,
(errcode(ERRCODE_SYNTAX_ERROR),
errmsg("word is too long")));
pushquery(state, type, crc32_sz((uint8 *) strval, lenval), pushquery(state, type, crc32_sz((uint8 *) strval, lenval),
state->curop - state->op, lenval, weight); state->curop - state->op, lenval, weight);
...@@ -305,7 +313,8 @@ makepol(QPRS_STATE * state, void (*pushval) (QPRS_STATE *, int, char *, int, int ...@@ -305,7 +313,8 @@ makepol(QPRS_STATE * state, void (*pushval) (QPRS_STATE *, int, char *, int, int
else else
{ {
if (lenstack == STACKDEPTH) if (lenstack == STACKDEPTH)
elog(ERROR, "Stack too short"); /* internal error */
elog(ERROR, "stack too short");
stack[lenstack] = val; stack[lenstack] = val;
lenstack++; lenstack++;
} }
...@@ -330,7 +339,9 @@ makepol(QPRS_STATE * state, void (*pushval) (QPRS_STATE *, int, char *, int, int ...@@ -330,7 +339,9 @@ makepol(QPRS_STATE * state, void (*pushval) (QPRS_STATE *, int, char *, int, int
break; break;
case ERR: case ERR:
default: default:
elog(ERROR, "Syntax error"); ereport(ERROR,
(errcode(ERRCODE_SYNTAX_ERROR),
errmsg("syntax error")));
return ERR; return ERR;
} }
...@@ -493,7 +504,7 @@ findoprnd(ITEM * ptr, int4 *pos) ...@@ -493,7 +504,7 @@ findoprnd(ITEM * ptr, int4 *pos)
{ {
#ifdef BS_DEBUG #ifdef BS_DEBUG
elog(DEBUG3, (ptr[*pos].type == OPR) ? elog(DEBUG3, (ptr[*pos].type == OPR) ?
"%d %c" : "%d %d ", *pos, ptr[*pos].val); "%d %c" : "%d %d", *pos, ptr[*pos].val);
#endif #endif
if (ptr[*pos].type == VAL || ptr[*pos].type == VALTRUE) if (ptr[*pos].type == VAL || ptr[*pos].type == VALTRUE)
{ {
...@@ -561,7 +572,9 @@ queryin(char *buf, void (*pushval) (QPRS_STATE *, int, char *, int, int2), int c ...@@ -561,7 +572,9 @@ queryin(char *buf, void (*pushval) (QPRS_STATE *, int, char *, int, int2), int c
makepol(&state, pushval); makepol(&state, pushval);
pfree(state.valstate.word); pfree(state.valstate.word);
if (!state.num) if (!state.num)
elog(ERROR, "Empty query"); ereport(ERROR,
(errcode(ERRCODE_SYNTAX_ERROR),
errmsg("empty query")));
/* make finish struct */ /* make finish struct */
commonlen = COMPUTESIZE(state.num, state.sumlen); commonlen = COMPUTESIZE(state.num, state.sumlen);
......
...@@ -7,8 +7,6 @@ ...@@ -7,8 +7,6 @@
#include "access/gist.h" #include "access/gist.h"
#include "access/itup.h" #include "access/itup.h"
#include "utils/elog.h"
#include "utils/palloc.h"
#include "utils/builtins.h" #include "utils/builtins.h"
#include "fmgr.h" #include "fmgr.h"
#include "funcapi.h" #include "funcapi.h"
...@@ -217,7 +215,8 @@ calc_rank(float *w, tsvector *t, QUERYTYPE *q, int4 method) { ...@@ -217,7 +215,8 @@ calc_rank(float *w, tsvector *t, QUERYTYPE *q, int4 method) {
case 1: res /= log((float)cnt_length(t)); break; case 1: res /= log((float)cnt_length(t)); break;
case 2: res /= (float)cnt_length(t); break; case 2: res /= (float)cnt_length(t); break;
default: default:
elog(ERROR,"Unknown normalization method: %d",method); /* internal error */
elog(ERROR,"unrecognized normalization method: %d", method);
} }
return res; return res;
...@@ -234,14 +233,21 @@ rank(PG_FUNCTION_ARGS) { ...@@ -234,14 +233,21 @@ rank(PG_FUNCTION_ARGS) {
int i; int i;
if ( ARR_NDIM(win) != 1 ) if ( ARR_NDIM(win) != 1 )
elog(ERROR,"Array of weight is not one dimentional"); ereport(ERROR,
(errcode(ERRCODE_ARRAY_SUBSCRIPT_ERROR),
errmsg("array of weight must be one-dimensional")));
if ( ARRNELEMS(win) < lengthof(weights) ) if ( ARRNELEMS(win) < lengthof(weights) )
elog(ERROR,"Array of weight is too short"); ereport(ERROR,
(errcode(ERRCODE_ARRAY_SUBSCRIPT_ERROR),
errmsg("array of weight is too short")));
for(i=0;i<lengthof(weights);i++) { for(i=0;i<lengthof(weights);i++) {
ws[ i ] = ( ((float4*)ARR_DATA_PTR(win))[i] >= 0 ) ? ((float4*)ARR_DATA_PTR(win))[i] : weights[i]; ws[ i ] = ( ((float4*)ARR_DATA_PTR(win))[i] >= 0 ) ? ((float4*)ARR_DATA_PTR(win))[i] : weights[i];
if ( ws[ i ] > 1.0 ) if ( ws[ i ] > 1.0 )
elog(ERROR,"Weight out of range"); ereport(ERROR,
(errcode(ERRCODE_INVALID_PARAMETER_VALUE),
errmsg("weight out of range")));
} }
if ( PG_NARGS() == 4 ) if ( PG_NARGS() == 4 )
...@@ -462,7 +468,8 @@ rank_cd(PG_FUNCTION_ARGS) { ...@@ -462,7 +468,8 @@ rank_cd(PG_FUNCTION_ARGS) {
case 1: res /= log((float)cnt_length(txt)); break; case 1: res /= log((float)cnt_length(txt)); break;
case 2: res /= (float)cnt_length(txt); break; case 2: res /= (float)cnt_length(txt); break;
default: default:
elog(ERROR,"Unknown normalization method: %d",method); /* internal error */
elog(ERROR,"unrecognized normalization method: %d", method);
} }
pfree(doc); pfree(doc);
...@@ -527,7 +534,9 @@ get_covers(PG_FUNCTION_ARGS) { ...@@ -527,7 +534,9 @@ get_covers(PG_FUNCTION_ARGS) {
for(i=0;i<txt->size;i++) { for(i=0;i<txt->size;i++) {
if (!pptr[i].haspos) if (!pptr[i].haspos)
elog(ERROR,"No pos info"); ereport(ERROR,
(errcode(ERRCODE_SYNTAX_ERROR),
errmsg("no pos info")));
dlen += POSDATALEN(txt,&(pptr[i])); dlen += POSDATALEN(txt,&(pptr[i]));
} }
......
...@@ -22,13 +22,17 @@ addSNMap( SNMap *map, char *key, Oid value ) { ...@@ -22,13 +22,17 @@ addSNMap( SNMap *map, char *key, Oid value ) {
int len = (map->reallen) ? 2*map->reallen : 16; int len = (map->reallen) ? 2*map->reallen : 16;
tmp=(SNMapEntry*)realloc(map->list, sizeof(SNMapEntry) * len); tmp=(SNMapEntry*)realloc(map->list, sizeof(SNMapEntry) * len);
if ( !tmp ) if ( !tmp )
elog(ERROR, "No memory"); ereport(ERROR,
(errcode(ERRCODE_OUT_OF_MEMORY),
errmsg("out of memory")));
map->reallen=len; map->reallen=len;
map->list=tmp; map->list=tmp;
} }
map->list[ map->len ].key = strdup(key); map->list[ map->len ].key = strdup(key);
if ( ! map->list[ map->len ].key ) if ( ! map->list[ map->len ].key )
elog(ERROR, "No memory"); ereport(ERROR,
(errcode(ERRCODE_OUT_OF_MEMORY),
errmsg("out of memory")));
map->list[ map->len ].value=value; map->list[ map->len ].value=value;
map->len++; map->len++;
if ( map->len>1 ) qsort(map->list, map->len, sizeof(SNMapEntry), compareSNMapEntry); if ( map->len>1 ) qsort(map->list, map->len, sizeof(SNMapEntry), compareSNMapEntry);
......
...@@ -46,7 +46,11 @@ readstoplist(text *in, StopList *s) { ...@@ -46,7 +46,11 @@ readstoplist(text *in, StopList *s) {
int reallen=0; int reallen=0;
if ( (hin=fopen(filename,"r")) == NULL ) if ( (hin=fopen(filename,"r")) == NULL )
elog(ERROR,"Can't open file '%s': %s", filename, strerror(errno)); ereport(ERROR,
(errcode(ERRCODE_CONFIG_FILE_ERROR),
errmsg("could not open file \"%s\": %m",
filename)));
while( fgets(buf,STOPBUFLEN,hin) ) { while( fgets(buf,STOPBUFLEN,hin) ) {
buf[strlen(buf)-1] = '\0'; buf[strlen(buf)-1] = '\0';
if ( *buf=='\0' ) continue; if ( *buf=='\0' ) continue;
...@@ -58,7 +62,9 @@ readstoplist(text *in, StopList *s) { ...@@ -58,7 +62,9 @@ readstoplist(text *in, StopList *s) {
if (!tmp) { if (!tmp) {
freestoplist(s); freestoplist(s);
fclose(hin); fclose(hin);
elog(ERROR,"Not enough memory"); ereport(ERROR,
(errcode(ERRCODE_OUT_OF_MEMORY),
errmsg("out of memory")));
} }
stop=tmp; stop=tmp;
} }
...@@ -67,7 +73,9 @@ readstoplist(text *in, StopList *s) { ...@@ -67,7 +73,9 @@ readstoplist(text *in, StopList *s) {
if ( !stop[s->len] ) { if ( !stop[s->len] ) {
freestoplist(s); freestoplist(s);
fclose(hin); fclose(hin);
elog(ERROR,"Not enough memory"); ereport(ERROR,
(errcode(ERRCODE_OUT_OF_MEMORY),
errmsg("out of memory")));
} }
if ( s->wordop ) if ( s->wordop )
stop[s->len]=(s->wordop)(stop[s->len]); stop[s->len]=(s->wordop)(stop[s->len]);
......
...@@ -85,7 +85,9 @@ init_cfg(Oid id, TSCfgInfo *cfg) { ...@@ -85,7 +85,9 @@ init_cfg(Oid id, TSCfgInfo *cfg) {
cfg->len=lexid+1; cfg->len=lexid+1;
cfg->map = (ListDictionary*)malloc( sizeof(ListDictionary)*cfg->len ); cfg->map = (ListDictionary*)malloc( sizeof(ListDictionary)*cfg->len );
if ( !cfg->map ) if ( !cfg->map )
ts_error(ERROR,"No memory"); ereport(ERROR,
(errcode(ERRCODE_OUT_OF_MEMORY),
errmsg("out of memory")));
memset( cfg->map, 0, sizeof(ListDictionary)*cfg->len ); memset( cfg->map, 0, sizeof(ListDictionary)*cfg->len );
} }
...@@ -206,18 +208,25 @@ name2id_cfg(text *name) { ...@@ -206,18 +208,25 @@ name2id_cfg(text *name) {
if ( !plan_name2id ) { if ( !plan_name2id ) {
plan_name2id = SPI_saveplan( SPI_prepare( "select oid from pg_ts_cfg where ts_name = $1" , 1, arg ) ); plan_name2id = SPI_saveplan( SPI_prepare( "select oid from pg_ts_cfg where ts_name = $1" , 1, arg ) );
if ( !plan_name2id ) if ( !plan_name2id )
/* internal error */
elog(ERROR, "SPI_prepare() failed"); elog(ERROR, "SPI_prepare() failed");
} }
stat = SPI_execp(plan_name2id, pars, " ", 1); stat = SPI_execp(plan_name2id, pars, " ", 1);
if ( stat < 0 ) if ( stat < 0 )
/* internal error */
elog (ERROR, "SPI_execp return %d", stat); elog (ERROR, "SPI_execp return %d", stat);
if ( SPI_processed > 0 ) { if ( SPI_processed > 0 ) {
id=DatumGetObjectId( SPI_getbinval(SPI_tuptable->vals[0], SPI_tuptable->tupdesc, 1, &isnull) ); id=DatumGetObjectId( SPI_getbinval(SPI_tuptable->vals[0], SPI_tuptable->tupdesc, 1, &isnull) );
if ( isnull ) if ( isnull )
elog(ERROR, "Null id for tsearch config"); ereport(ERROR,
(errcode(ERRCODE_CONFIG_FILE_ERROR),
errmsg("null id for tsearch config")));
} else } else
elog(ERROR, "No tsearch config"); ereport(ERROR,
(errcode(ERRCODE_CONFIG_FILE_ERROR),
errmsg("no tsearch config")));
SPI_finish(); SPI_finish();
addSNMap_t( &(CList.name2id_map), name, id ); addSNMap_t( &(CList.name2id_map), name, id );
return id; return id;
...@@ -245,8 +254,9 @@ parsetext_v2(TSCfgInfo *cfg, PRSTEXT * prs, char *buf, int4 buflen) { ...@@ -245,8 +254,9 @@ parsetext_v2(TSCfgInfo *cfg, PRSTEXT * prs, char *buf, int4 buflen) {
PointerGetDatum(&lenlemm))) ) != 0 ) { PointerGetDatum(&lenlemm))) ) != 0 ) {
if ( lenlemm >= MAXSTRLEN ) if ( lenlemm >= MAXSTRLEN )
elog(ERROR, "Word is too long"); ereport(ERROR,
(errcode(ERRCODE_SYNTAX_ERROR),
errmsg("word is too long")));
if ( type >= cfg->len ) /* skip this type of lexem */ if ( type >= cfg->len ) /* skip this type of lexem */
continue; continue;
...@@ -352,7 +362,9 @@ hlparsetext(TSCfgInfo *cfg, HLPRSTEXT * prs, QUERYTYPE *query, char *buf, int4 b ...@@ -352,7 +362,9 @@ hlparsetext(TSCfgInfo *cfg, HLPRSTEXT * prs, QUERYTYPE *query, char *buf, int4 b
PointerGetDatum(&lenlemm))) ) != 0 ) { PointerGetDatum(&lenlemm))) ) != 0 ) {
if ( lenlemm >= MAXSTRLEN ) if ( lenlemm >= MAXSTRLEN )
elog(ERROR, "Word is too long"); ereport(ERROR,
(errcode(ERRCODE_SYNTAX_ERROR),
errmsg("word is too long")));
hladdword(prs,lemm,lenlemm,type); hladdword(prs,lemm,lenlemm,type);
...@@ -451,6 +463,7 @@ get_currcfg(void) { ...@@ -451,6 +463,7 @@ get_currcfg(void) {
if ( !plan_getcfg_bylocale ) { if ( !plan_getcfg_bylocale ) {
plan_getcfg_bylocale=SPI_saveplan( SPI_prepare( "select oid from pg_ts_cfg where locale = $1 ", 1, arg ) ); plan_getcfg_bylocale=SPI_saveplan( SPI_prepare( "select oid from pg_ts_cfg where locale = $1 ", 1, arg ) );
if ( !plan_getcfg_bylocale ) if ( !plan_getcfg_bylocale )
/* internal error */
elog(ERROR, "SPI_prepare() failed"); elog(ERROR, "SPI_prepare() failed");
} }
...@@ -459,11 +472,14 @@ get_currcfg(void) { ...@@ -459,11 +472,14 @@ get_currcfg(void) {
stat = SPI_execp(plan_getcfg_bylocale, pars, " ", 1); stat = SPI_execp(plan_getcfg_bylocale, pars, " ", 1);
if ( stat < 0 ) if ( stat < 0 )
/* internal error */
elog (ERROR, "SPI_execp return %d", stat); elog (ERROR, "SPI_execp return %d", stat);
if ( SPI_processed > 0 ) if ( SPI_processed > 0 )
current_cfg_id = DatumGetObjectId( SPI_getbinval(SPI_tuptable->vals[0], SPI_tuptable->tupdesc, 1, &isnull) ); current_cfg_id = DatumGetObjectId( SPI_getbinval(SPI_tuptable->vals[0], SPI_tuptable->tupdesc, 1, &isnull) );
else else
elog(ERROR,"Can't find tsearch config by locale"); ereport(ERROR,
(errcode(ERRCODE_CONFIG_FILE_ERROR),
errmsg("could not find tsearch config by locale")));
pfree(DatumGetPointer(pars[0])); pfree(DatumGetPointer(pars[0]));
SPI_finish(); SPI_finish();
......
...@@ -23,7 +23,9 @@ PG_FUNCTION_INFO_V1(tsstat_out); ...@@ -23,7 +23,9 @@ PG_FUNCTION_INFO_V1(tsstat_out);
Datum tsstat_out(PG_FUNCTION_ARGS); Datum tsstat_out(PG_FUNCTION_ARGS);
Datum Datum
tsstat_out(PG_FUNCTION_ARGS) { tsstat_out(PG_FUNCTION_ARGS) {
elog(ERROR,"Unimplemented"); ereport(ERROR,
(errcode(ERRCODE_FEATURE_NOT_SUPPORTED),
errmsg("tsstat_out not implemented")));
PG_RETURN_NULL(); PG_RETURN_NULL();
} }
...@@ -316,13 +318,16 @@ get_ti_Oid(void) { ...@@ -316,13 +318,16 @@ get_ti_Oid(void) {
int ret; int ret;
bool isnull; bool isnull;
if ( (ret = SPI_exec("select oid from pg_type where typname='tsvector'",1)) < 0 ) if ( (ret = SPI_exec("select oid from pg_type where typname='tsvector'",1)) < 0 )
/* internal error */
elog(ERROR, "SPI_exec to get tsvector oid returns %d", ret); elog(ERROR, "SPI_exec to get tsvector oid returns %d", ret);
if ( SPI_processed<0 ) if ( SPI_processed<0 )
/* internal error */
elog(ERROR, "There is no tsvector type"); elog(ERROR, "There is no tsvector type");
tiOid = DatumGetObjectId( SPI_getbinval(SPI_tuptable->vals[0], SPI_tuptable->tupdesc, 1, &isnull) ); tiOid = DatumGetObjectId( SPI_getbinval(SPI_tuptable->vals[0], SPI_tuptable->tupdesc, 1, &isnull) );
if ( tiOid==InvalidOid ) if ( tiOid==InvalidOid )
/* internal error */
elog(ERROR, "tsvector type has InvalidOid"); elog(ERROR, "tsvector type has InvalidOid");
} }
...@@ -339,18 +344,22 @@ ts_stat_sql(text *txt) { ...@@ -339,18 +344,22 @@ ts_stat_sql(text *txt) {
get_ti_Oid(); get_ti_Oid();
if ( (plan = SPI_prepare(query,0,NULL))==NULL ) if ( (plan = SPI_prepare(query,0,NULL))==NULL )
/* internal error */
elog(ERROR, "SPI_prepare('%s') returns NULL",query); elog(ERROR, "SPI_prepare('%s') returns NULL",query);
if ( (portal = SPI_cursor_open(NULL, plan, NULL, NULL)) == NULL ) if ( (portal = SPI_cursor_open(NULL, plan, NULL, NULL)) == NULL )
/* internal error */
elog(ERROR, "SPI_cursor_open('%s') returns NULL",query); elog(ERROR, "SPI_cursor_open('%s') returns NULL",query);
SPI_cursor_fetch(portal, true, 100); SPI_cursor_fetch(portal, true, 100);
if ( SPI_tuptable->tupdesc->natts != 1 ) if ( SPI_tuptable->tupdesc->natts != 1 )
elog(ERROR, "Number of fields doesn't equal to 1"); /* internal error */
elog(ERROR, "number of fields doesn't equal to 1");
if ( SPI_gettypeid(SPI_tuptable->tupdesc, 1) != tiOid ) if ( SPI_gettypeid(SPI_tuptable->tupdesc, 1) != tiOid )
elog(ERROR, "Column isn't of tsvector type"); /* internal error */
elog(ERROR, "column isn't of tsvector type");
stat=palloc(STATHDRSIZE); stat=palloc(STATHDRSIZE);
stat->len=STATHDRSIZE; stat->len=STATHDRSIZE;
......
...@@ -8,8 +8,6 @@ ...@@ -8,8 +8,6 @@
#include "access/gist.h" #include "access/gist.h"
#include "access/itup.h" #include "access/itup.h"
#include "utils/elog.h"
#include "utils/palloc.h"
#include "utils/builtins.h" #include "utils/builtins.h"
#include "storage/bufpage.h" #include "storage/bufpage.h"
#include "executor/spi.h" #include "executor/spi.h"
...@@ -190,7 +188,9 @@ gettoken_tsvector(TI_IN_STATE * state) ...@@ -190,7 +188,9 @@ gettoken_tsvector(TI_IN_STATE * state)
oldstate = WAITENDWORD; oldstate = WAITENDWORD;
} }
else if (state->oprisdelim && ISOPERATOR(*(state->prsbuf))) else if (state->oprisdelim && ISOPERATOR(*(state->prsbuf)))
elog(ERROR, "Syntax error"); ereport(ERROR,
(errcode(ERRCODE_SYNTAX_ERROR),
errmsg("syntax error")));
else if (*(state->prsbuf) != ' ') else if (*(state->prsbuf) != ' ')
{ {
*(state->curpos) = *(state->prsbuf); *(state->curpos) = *(state->prsbuf);
...@@ -201,7 +201,9 @@ gettoken_tsvector(TI_IN_STATE * state) ...@@ -201,7 +201,9 @@ gettoken_tsvector(TI_IN_STATE * state)
else if (state->state == WAITNEXTCHAR) else if (state->state == WAITNEXTCHAR)
{ {
if (*(state->prsbuf) == '\0') if (*(state->prsbuf) == '\0')
elog(ERROR, "There is no escaped character"); ereport(ERROR,
(errcode(ERRCODE_SYNTAX_ERROR),
errmsg("there is no escaped character")));
else else
{ {
RESIZEPRSBUF; RESIZEPRSBUF;
...@@ -222,12 +224,16 @@ gettoken_tsvector(TI_IN_STATE * state) ...@@ -222,12 +224,16 @@ gettoken_tsvector(TI_IN_STATE * state)
{ {
RESIZEPRSBUF; RESIZEPRSBUF;
if (state->curpos == state->word) if (state->curpos == state->word)
elog(ERROR, "Syntax error"); ereport(ERROR,
(errcode(ERRCODE_SYNTAX_ERROR),
errmsg("syntax error")));
*(state->curpos) = '\0'; *(state->curpos) = '\0';
return 1; return 1;
} else if ( *(state->prsbuf) == ':' ) { } else if ( *(state->prsbuf) == ':' ) {
if (state->curpos == state->word) if (state->curpos == state->word)
elog(ERROR, "Syntax error"); ereport(ERROR,
(errcode(ERRCODE_SYNTAX_ERROR),
errmsg("syntax error")));
*(state->curpos) = '\0'; *(state->curpos) = '\0';
if ( state->oprisdelim ) if ( state->oprisdelim )
return 1; return 1;
...@@ -248,7 +254,9 @@ gettoken_tsvector(TI_IN_STATE * state) ...@@ -248,7 +254,9 @@ gettoken_tsvector(TI_IN_STATE * state)
RESIZEPRSBUF; RESIZEPRSBUF;
*(state->curpos) = '\0'; *(state->curpos) = '\0';
if (state->curpos == state->word) if (state->curpos == state->word)
elog(ERROR, "Syntax error"); ereport(ERROR,
(errcode(ERRCODE_SYNTAX_ERROR),
errmsg("syntax error")));
if ( state->oprisdelim ) { if ( state->oprisdelim ) {
state->prsbuf++; state->prsbuf++;
return 1; return 1;
...@@ -261,7 +269,9 @@ gettoken_tsvector(TI_IN_STATE * state) ...@@ -261,7 +269,9 @@ gettoken_tsvector(TI_IN_STATE * state)
oldstate = WAITENDCMPLX; oldstate = WAITENDCMPLX;
} }
else if (*(state->prsbuf) == '\0') else if (*(state->prsbuf) == '\0')
elog(ERROR, "Syntax error"); ereport(ERROR,
(errcode(ERRCODE_SYNTAX_ERROR),
errmsg("syntax error")));
else else
{ {
RESIZEPRSBUF; RESIZEPRSBUF;
...@@ -286,36 +296,51 @@ gettoken_tsvector(TI_IN_STATE * state) ...@@ -286,36 +296,51 @@ gettoken_tsvector(TI_IN_STATE * state)
( *(uint16*)(state->pos) )++; ( *(uint16*)(state->pos) )++;
state->pos[ *(uint16*)(state->pos) ].pos = LIMITPOS(atoi(state->prsbuf)); state->pos[ *(uint16*)(state->pos) ].pos = LIMITPOS(atoi(state->prsbuf));
if ( state->pos[ *(uint16*)(state->pos) ].pos == 0 ) if ( state->pos[ *(uint16*)(state->pos) ].pos == 0 )
elog(ERROR,"Wrong position info"); ereport(ERROR,
(errcode(ERRCODE_SYNTAX_ERROR),
errmsg("wrong position info")));
state->pos[ *(uint16*)(state->pos) ].weight = 0; state->pos[ *(uint16*)(state->pos) ].weight = 0;
state->state = WAITPOSDELIM; state->state = WAITPOSDELIM;
} else } else
elog(ERROR,"Syntax error"); ereport(ERROR,
(errcode(ERRCODE_SYNTAX_ERROR),
errmsg("syntax error")));
} else if (state->state == WAITPOSDELIM) { } else if (state->state == WAITPOSDELIM) {
if ( *(state->prsbuf) == ',' ) { if ( *(state->prsbuf) == ',' ) {
state->state = INPOSINFO; state->state = INPOSINFO;
} else if ( tolower(*(state->prsbuf)) == 'a' || *(state->prsbuf)=='*' ) { } else if ( tolower(*(state->prsbuf)) == 'a' || *(state->prsbuf)=='*' ) {
if ( state->pos[ *(uint16*)(state->pos) ].weight ) if ( state->pos[ *(uint16*)(state->pos) ].weight )
elog(ERROR,"Syntax error"); ereport(ERROR,
(errcode(ERRCODE_SYNTAX_ERROR),
errmsg("syntax error")));
state->pos[ *(uint16*)(state->pos) ].weight = 3; state->pos[ *(uint16*)(state->pos) ].weight = 3;
} else if ( tolower(*(state->prsbuf)) == 'b' ) { } else if ( tolower(*(state->prsbuf)) == 'b' ) {
if ( state->pos[ *(uint16*)(state->pos) ].weight ) if ( state->pos[ *(uint16*)(state->pos) ].weight )
elog(ERROR,"Syntax error"); ereport(ERROR,
(errcode(ERRCODE_SYNTAX_ERROR),
errmsg("syntax error")));
state->pos[ *(uint16*)(state->pos) ].weight = 2; state->pos[ *(uint16*)(state->pos) ].weight = 2;
} else if ( tolower(*(state->prsbuf)) == 'c' ) { } else if ( tolower(*(state->prsbuf)) == 'c' ) {
if ( state->pos[ *(uint16*)(state->pos) ].weight ) if ( state->pos[ *(uint16*)(state->pos) ].weight )
elog(ERROR,"Syntax error"); ereport(ERROR,
(errcode(ERRCODE_SYNTAX_ERROR),
errmsg("syntax error")));
state->pos[ *(uint16*)(state->pos) ].weight = 1; state->pos[ *(uint16*)(state->pos) ].weight = 1;
} else if ( tolower(*(state->prsbuf)) == 'd' ) { } else if ( tolower(*(state->prsbuf)) == 'd' ) {
if ( state->pos[ *(uint16*)(state->pos) ].weight ) if ( state->pos[ *(uint16*)(state->pos) ].weight )
elog(ERROR,"Syntax error"); ereport(ERROR,
(errcode(ERRCODE_SYNTAX_ERROR),
errmsg("syntax error")));
state->pos[ *(uint16*)(state->pos) ].weight = 0; state->pos[ *(uint16*)(state->pos) ].weight = 0;
} else if ( isspace(*(state->prsbuf)) || *(state->prsbuf) == '\0' ) { } else if ( isspace(*(state->prsbuf)) || *(state->prsbuf) == '\0' ) {
return 1; return 1;
} else if ( !isdigit(*(state->prsbuf)) ) } else if ( !isdigit(*(state->prsbuf)) )
elog(ERROR,"Syntax error"); ereport(ERROR,
(errcode(ERRCODE_SYNTAX_ERROR),
errmsg("syntax error")));
} else } else
elog(ERROR, "Inner bug :("); /* internal error */
elog(ERROR, "internal error");
state->prsbuf++; state->prsbuf++;
} }
...@@ -360,10 +385,14 @@ tsvector_in(PG_FUNCTION_ARGS) ...@@ -360,10 +385,14 @@ tsvector_in(PG_FUNCTION_ARGS)
cur = tmpbuf + dist; cur = tmpbuf + dist;
} }
if (state.curpos - state.word >= MAXSTRLEN) if (state.curpos - state.word >= MAXSTRLEN)
elog(ERROR, "Word is too long"); ereport(ERROR,
(errcode(ERRCODE_SYNTAX_ERROR),
errmsg("word is too long")));
arr[len].entry.len= state.curpos - state.word; arr[len].entry.len= state.curpos - state.word;
if (cur - tmpbuf > MAXSTRPOS) if (cur - tmpbuf > MAXSTRPOS)
elog(ERROR, "Too long value"); ereport(ERROR,
(errcode(ERRCODE_SYNTAX_ERROR),
errmsg("too long value")));
arr[len].entry.pos=cur - tmpbuf; arr[len].entry.pos=cur - tmpbuf;
memcpy((void *) cur, (void *) state.word, arr[len].entry.len); memcpy((void *) cur, (void *) state.word, arr[len].entry.len);
cur += arr[len].entry.len; cur += arr[len].entry.len;
...@@ -583,7 +612,9 @@ makevalue(PRSTEXT * prs) ...@@ -583,7 +612,9 @@ makevalue(PRSTEXT * prs)
{ {
ptr->len = prs->words[i].len; ptr->len = prs->words[i].len;
if (cur - str > MAXSTRPOS) if (cur - str > MAXSTRPOS)
elog(ERROR, "Value is too big"); ereport(ERROR,
(errcode(ERRCODE_SYNTAX_ERROR),
errmsg("value is too big")));
ptr->pos= cur - str; ptr->pos= cur - str;
memcpy((void *) cur, (void *) prs->words[i].word, prs->words[i].len); memcpy((void *) cur, (void *) prs->words[i].word, prs->words[i].len);
pfree(prs->words[i].word); pfree(prs->words[i].word);
...@@ -701,12 +732,15 @@ tsearch2(PG_FUNCTION_ARGS) ...@@ -701,12 +732,15 @@ tsearch2(PG_FUNCTION_ARGS)
Oid funcoid = InvalidOid; Oid funcoid = InvalidOid;
if (!CALLED_AS_TRIGGER(fcinfo)) if (!CALLED_AS_TRIGGER(fcinfo))
/* internal error */
elog(ERROR, "TSearch: Not fired by trigger manager"); elog(ERROR, "TSearch: Not fired by trigger manager");
trigdata = (TriggerData *) fcinfo->context; trigdata = (TriggerData *) fcinfo->context;
if (TRIGGER_FIRED_FOR_STATEMENT(trigdata->tg_event)) if (TRIGGER_FIRED_FOR_STATEMENT(trigdata->tg_event))
/* internal error */
elog(ERROR, "TSearch: Can't process STATEMENT events"); elog(ERROR, "TSearch: Can't process STATEMENT events");
if (TRIGGER_FIRED_AFTER(trigdata->tg_event)) if (TRIGGER_FIRED_AFTER(trigdata->tg_event))
/* internal error */
elog(ERROR, "TSearch: Must be fired BEFORE event"); elog(ERROR, "TSearch: Must be fired BEFORE event");
if (TRIGGER_FIRED_BY_INSERT(trigdata->tg_event)) if (TRIGGER_FIRED_BY_INSERT(trigdata->tg_event))
...@@ -714,17 +748,21 @@ tsearch2(PG_FUNCTION_ARGS) ...@@ -714,17 +748,21 @@ tsearch2(PG_FUNCTION_ARGS)
else if (TRIGGER_FIRED_BY_UPDATE(trigdata->tg_event)) else if (TRIGGER_FIRED_BY_UPDATE(trigdata->tg_event))
rettuple = trigdata->tg_newtuple; rettuple = trigdata->tg_newtuple;
else else
/* internal error */
elog(ERROR, "TSearch: Unknown event"); elog(ERROR, "TSearch: Unknown event");
trigger = trigdata->tg_trigger; trigger = trigdata->tg_trigger;
rel = trigdata->tg_relation; rel = trigdata->tg_relation;
if (trigger->tgnargs < 2) if (trigger->tgnargs < 2)
/* internal error */
elog(ERROR, "TSearch: format tsearch2(tsvector_field, text_field1,...)"); elog(ERROR, "TSearch: format tsearch2(tsvector_field, text_field1,...)");
numidxattr = SPI_fnumber(rel->rd_att, trigger->tgargs[0]); numidxattr = SPI_fnumber(rel->rd_att, trigger->tgargs[0]);
if (numidxattr == SPI_ERROR_NOATTRIBUTE) if (numidxattr == SPI_ERROR_NOATTRIBUTE)
elog(ERROR, "TSearch: Can not find tsvector_field"); ereport(ERROR,
(errcode(ERRCODE_UNDEFINED_COLUMN),
errmsg("cannot find tsvector_field")));
prs.lenwords = 32; prs.lenwords = 32;
prs.curwords = 0; prs.curwords = 0;
...@@ -745,7 +783,11 @@ tsearch2(PG_FUNCTION_ARGS) ...@@ -745,7 +783,11 @@ tsearch2(PG_FUNCTION_ARGS)
{ {
funcoid=findFunc(trigger->tgargs[i]); funcoid=findFunc(trigger->tgargs[i]);
if ( funcoid==InvalidOid ) if ( funcoid==InvalidOid )
elog(ERROR,"TSearch: can't find function or field '%s'",trigger->tgargs[i]); ereport(ERROR,
(errcode(ERRCODE_UNDEFINED_COLUMN),
errmsg("cannot find function or field \"%s\"",
trigger->tgargs[i])));
continue; continue;
} }
oidtype = SPI_gettypeid(rel->rd_att, numattr); oidtype = SPI_gettypeid(rel->rd_att, numattr);
...@@ -798,6 +840,7 @@ tsearch2(PG_FUNCTION_ARGS) ...@@ -798,6 +840,7 @@ tsearch2(PG_FUNCTION_ARGS)
} }
if (rettuple == NULL) if (rettuple == NULL)
/* internal error */
elog(ERROR, "TSearch: %d returned by SPI_modifytuple", SPI_result); elog(ERROR, "TSearch: %d returned by SPI_modifytuple", SPI_result);
return PointerGetDatum(rettuple); return PointerGetDatum(rettuple);
......
...@@ -6,8 +6,6 @@ ...@@ -6,8 +6,6 @@
#include "access/gist.h" #include "access/gist.h"
#include "access/itup.h" #include "access/itup.h"
#include "utils/elog.h"
#include "utils/palloc.h"
#include "utils/builtins.h" #include "utils/builtins.h"
#include "storage/bufpage.h" #include "storage/bufpage.h"
#include "executor/spi.h" #include "executor/spi.h"
...@@ -79,7 +77,8 @@ setweight(PG_FUNCTION_ARGS) ...@@ -79,7 +77,8 @@ setweight(PG_FUNCTION_ARGS)
case 'b': w=2; break; case 'b': w=2; break;
case 'c': w=1; break; case 'c': w=1; break;
case 'd': w=0; break; case 'd': w=0; break;
default: elog(ERROR,"Unknown weight"); /* internal error */
default: elog(ERROR,"unrecognized weight");
} }
out=(tsvector*)palloc(in->len); out=(tsvector*)palloc(in->len);
......
...@@ -195,11 +195,17 @@ prsd_headline(PG_FUNCTION_ARGS) { ...@@ -195,11 +195,17 @@ prsd_headline(PG_FUNCTION_ARGS) {
pfree(map); pfree(map);
if ( min_words >= max_words ) if ( min_words >= max_words )
elog(ERROR,"Must be MinWords < MaxWords"); ereport(ERROR,
(errcode(ERRCODE_INVALID_PARAMETER_VALUE),
errmsg("must be MinWords < MaxWords")));
if ( min_words<=0 ) if ( min_words<=0 )
elog(ERROR,"Must be MinWords > 0"); ereport(ERROR,
(errcode(ERRCODE_INVALID_PARAMETER_VALUE),
errmsg("must be MinWords > 0")));
if ( shortword<0 ) if ( shortword<0 )
elog(ERROR,"Must be ShortWord >= 0"); ereport(ERROR,
(errcode(ERRCODE_INVALID_PARAMETER_VALUE),
errmsg("must be ShortWord >= 0")));
} }
while( hlCover(prs,query,&p,&q) ) { while( hlCover(prs,query,&p,&q) ) {
......
...@@ -68,7 +68,9 @@ pgxml_parse(PG_FUNCTION_ARGS) ...@@ -68,7 +68,9 @@ pgxml_parse(PG_FUNCTION_ARGS)
p = XML_ParserCreate_MM(NULL, &mhs, NULL); p = XML_ParserCreate_MM(NULL, &mhs, NULL);
if (!p) if (!p)
{ {
elog(ERROR, "pgxml: Could not create expat parser"); ereport(ERROR,
(errcode(ERRCODE_EXTERNAL_ROUTINE_EXCEPTION),
errmsg("could not create expat parser")));
PG_RETURN_NULL(); /* seems appropriate if we couldn't parse */ PG_RETURN_NULL(); /* seems appropriate if we couldn't parse */
} }
...@@ -141,7 +143,9 @@ build_xpath_results(text *doc, text *pathstr) ...@@ -141,7 +143,9 @@ build_xpath_results(text *doc, text *pathstr)
p = XML_ParserCreate_MM(NULL, &mhs, NULL); p = XML_ParserCreate_MM(NULL, &mhs, NULL);
if (!p) if (!p)
{ {
elog(ERROR, "pgxml: Could not create expat parser"); ereport(ERROR,
(errcode(ERRCODE_EXTERNAL_ROUTINE_EXCEPTION),
errmsg("could not create expat parser")));
pfree(xpr); pfree(xpr);
pfree(udata->path); pfree(udata->path);
pfree(udata); pfree(udata);
...@@ -267,7 +271,7 @@ pgxml_starthandler(void *userData, const XML_Char * name, ...@@ -267,7 +271,7 @@ pgxml_starthandler(void *userData, const XML_Char * name,
char sepstr[] = "/"; char sepstr[] = "/";
if ((strlen(name) + strlen(UD->currentpath)) > MAXPATHLENGTH - 2) if ((strlen(name) + strlen(UD->currentpath)) > MAXPATHLENGTH - 2)
elog(WARNING, "Path too long"); elog(WARNING, "path too long");
else else
{ {
strncat(UD->currentpath, sepstr, 1); strncat(UD->currentpath, sepstr, 1);
...@@ -297,12 +301,13 @@ pgxml_endhandler(void *userData, const XML_Char * name) ...@@ -297,12 +301,13 @@ pgxml_endhandler(void *userData, const XML_Char * name)
sepptr = strrchr(UD->currentpath, '/'); sepptr = strrchr(UD->currentpath, '/');
if (sepptr == NULL) if (sepptr == NULL)
{ {
elog(ERROR, "There's a problem..."); /* internal error */
elog(ERROR, "did not find '/'");
sepptr = UD->currentpath; sepptr = UD->currentpath;
} }
if (strcmp(name, sepptr + 1) != 0) if (strcmp(name, sepptr + 1) != 0)
{ {
elog(WARNING, "Wanted [%s], got [%s]", sepptr, name); elog(WARNING, "wanted [%s], got [%s]", sepptr, name);
/* unmatched entry, so do nothing */ /* unmatched entry, so do nothing */
} }
else else
......
...@@ -7,7 +7,7 @@ ...@@ -7,7 +7,7 @@
* Portions Copyright (c) 1996-2002, PostgreSQL Global Development Group * Portions Copyright (c) 1996-2002, PostgreSQL Global Development Group
* Portions Copyright (c) 1994, Regents of the University of California * Portions Copyright (c) 1994, Regents of the University of California
* *
* $Id: elog.h,v 1.55 2003/07/22 22:14:57 tgl Exp $ * $Id: elog.h,v 1.56 2003/07/24 17:52:49 tgl Exp $
* *
*------------------------------------------------------------------------- *-------------------------------------------------------------------------
*/ */
...@@ -100,6 +100,9 @@ ...@@ -100,6 +100,9 @@
#define ERRCODE_TRANSACTION_RESOLUTION_UNKNOWN MAKE_SQLSTATE('0','8', '0','0','7') #define ERRCODE_TRANSACTION_RESOLUTION_UNKNOWN MAKE_SQLSTATE('0','8', '0','0','7')
#define ERRCODE_PROTOCOL_VIOLATION MAKE_SQLSTATE('0','8', 'P','0','1') #define ERRCODE_PROTOCOL_VIOLATION MAKE_SQLSTATE('0','8', 'P','0','1')
/* Class 09 - Triggered Action Exception */
#define ERRCODE_TRIGGERED_ACTION_EXCEPTION MAKE_SQLSTATE('0','9', '0','0','0')
/* Class 0A - Feature Not Supported */ /* Class 0A - Feature Not Supported */
#define ERRCODE_FEATURE_NOT_SUPPORTED MAKE_SQLSTATE('0','A', '0','0','0') #define ERRCODE_FEATURE_NOT_SUPPORTED MAKE_SQLSTATE('0','A', '0','0','0')
......
...@@ -63,26 +63,29 @@ insert into fkeys2 values (40, '4', 5); ...@@ -63,26 +63,29 @@ insert into fkeys2 values (40, '4', 5);
insert into fkeys2 values (50, '5', 3); insert into fkeys2 values (50, '5', 3);
-- no key in pkeys -- no key in pkeys
insert into fkeys2 values (70, '5', 3); insert into fkeys2 values (70, '5', 3);
ERROR: check_fkeys2_pkey_exist: tuple references non-existing key in pkeys ERROR: tuple references non-existent key
DETAIL: Trigger "check_fkeys2_pkey_exist" found tuple referencing non-existent key in "pkeys".
insert into fkeys values (10, '1', 2); insert into fkeys values (10, '1', 2);
insert into fkeys values (30, '3', 3); insert into fkeys values (30, '3', 3);
insert into fkeys values (40, '4', 2); insert into fkeys values (40, '4', 2);
insert into fkeys values (50, '5', 2); insert into fkeys values (50, '5', 2);
-- no key in pkeys -- no key in pkeys
insert into fkeys values (70, '5', 1); insert into fkeys values (70, '5', 1);
ERROR: check_fkeys_pkey_exist: tuple references non-existing key in pkeys ERROR: tuple references non-existent key
DETAIL: Trigger "check_fkeys_pkey_exist" found tuple referencing non-existent key in "pkeys".
-- no key in fkeys2 -- no key in fkeys2
insert into fkeys values (60, '6', 4); insert into fkeys values (60, '6', 4);
ERROR: check_fkeys_pkey2_exist: tuple references non-existing key in fkeys2 ERROR: tuple references non-existent key
DETAIL: Trigger "check_fkeys_pkey2_exist" found tuple referencing non-existent key in "fkeys2".
delete from pkeys where pkey1 = 30 and pkey2 = '3'; delete from pkeys where pkey1 = 30 and pkey2 = '3';
NOTICE: check_pkeys_fkey_cascade: 1 tuple(s) of fkeys are deleted NOTICE: check_pkeys_fkey_cascade: 1 tuple(s) of fkeys are deleted
ERROR: check_fkeys2_fkey_restrict: tuple referenced in fkeys ERROR: "check_fkeys2_fkey_restrict": tuple is referenced in "fkeys"
delete from pkeys where pkey1 = 40 and pkey2 = '4'; delete from pkeys where pkey1 = 40 and pkey2 = '4';
NOTICE: check_pkeys_fkey_cascade: 1 tuple(s) of fkeys are deleted NOTICE: check_pkeys_fkey_cascade: 1 tuple(s) of fkeys are deleted
NOTICE: check_pkeys_fkey_cascade: 1 tuple(s) of fkeys2 are deleted NOTICE: check_pkeys_fkey_cascade: 1 tuple(s) of fkeys2 are deleted
update pkeys set pkey1 = 7, pkey2 = '70' where pkey1 = 50 and pkey2 = '5'; update pkeys set pkey1 = 7, pkey2 = '70' where pkey1 = 50 and pkey2 = '5';
NOTICE: check_pkeys_fkey_cascade: 1 tuple(s) of fkeys are deleted NOTICE: check_pkeys_fkey_cascade: 1 tuple(s) of fkeys are deleted
ERROR: check_fkeys2_fkey_restrict: tuple referenced in fkeys ERROR: "check_fkeys2_fkey_restrict": tuple is referenced in "fkeys"
update pkeys set pkey1 = 7, pkey2 = '70' where pkey1 = 10 and pkey2 = '1'; update pkeys set pkey1 = 7, pkey2 = '70' where pkey1 = 10 and pkey2 = '1';
NOTICE: check_pkeys_fkey_cascade: 1 tuple(s) of fkeys are deleted NOTICE: check_pkeys_fkey_cascade: 1 tuple(s) of fkeys are deleted
NOTICE: check_pkeys_fkey_cascade: 1 tuple(s) of fkeys2 are deleted NOTICE: check_pkeys_fkey_cascade: 1 tuple(s) of fkeys2 are deleted
......
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