1
0
mirror of https://github.com/postgres/postgres.git synced 2025-10-25 13:17:41 +03:00

Reenabled parentheses for grouping multiple rule actions and

added this syntax to rules regression test so it will show up
if someone breaks it again.

Jan
This commit is contained in:
Jan Wieck
1999-02-07 19:02:20 +00:00
parent ef590e101e
commit 28fc5d7b83
3 changed files with 34 additions and 37 deletions

View File

@@ -10,7 +10,7 @@
* *
* *
* IDENTIFICATION * IDENTIFICATION
* $Header: /cvsroot/pgsql/src/backend/parser/gram.y,v 2.52 1999/02/06 20:27:34 tgl Exp $ * $Header: /cvsroot/pgsql/src/backend/parser/gram.y,v 2.53 1999/02/07 19:02:19 wieck Exp $
* *
* HISTORY * HISTORY
* AUTHOR DATE MAJOR EVENT * AUTHOR DATE MAJOR EVENT
@@ -132,7 +132,7 @@ Oid param_type(int t); /* used in parse_expr.c */
CreatedbStmt, DestroydbStmt, VacuumStmt, CursorStmt, SubSelect, CreatedbStmt, DestroydbStmt, VacuumStmt, CursorStmt, SubSelect,
UpdateStmt, InsertStmt, select_w_o_sort, SelectStmt, NotifyStmt, DeleteStmt, UpdateStmt, InsertStmt, select_w_o_sort, SelectStmt, NotifyStmt, DeleteStmt,
ClusterStmt, ExplainStmt, VariableSetStmt, VariableShowStmt, VariableResetStmt, ClusterStmt, ExplainStmt, VariableSetStmt, VariableShowStmt, VariableResetStmt,
CreateUserStmt, AlterUserStmt, DropUserStmt CreateUserStmt, AlterUserStmt, DropUserStmt, RuleActionStmt
%type <str> opt_database1, opt_database2, location, encoding %type <str> opt_database1, opt_database2, location, encoding
@@ -163,7 +163,7 @@ Oid param_type(int t); /* used in parse_expr.c */
result, relation_name_list, OptTableElementList, result, relation_name_list, OptTableElementList,
OptInherit, definition, OptInherit, definition,
opt_with, func_args, func_args_list, opt_with, func_args, func_args_list,
oper_argtypes, OptStmtList, OptStmtBlock, OptStmtMulti, oper_argtypes, RuleActionList, RuleActionBlock, RuleActionMulti,
opt_column_list, columnList, opt_va_list, va_list, opt_column_list, columnList, opt_va_list, va_list,
sort_clause, sortby_list, index_params, index_list, name_list, sort_clause, sortby_list, index_params, index_list, name_list,
from_clause, from_list, opt_array_bounds, nest_array_bounds, from_clause, from_list, opt_array_bounds, nest_array_bounds,
@@ -2058,7 +2058,7 @@ opt_column: COLUMN { $$ = COLUMN; }
RuleStmt: CREATE RULE name AS RuleStmt: CREATE RULE name AS
{ QueryIsRule=TRUE; } { QueryIsRule=TRUE; }
ON event TO event_object where_clause ON event TO event_object where_clause
DO opt_instead OptStmtList DO opt_instead RuleActionList
{ {
RuleStmt *n = makeNode(RuleStmt); RuleStmt *n = makeNode(RuleStmt);
n->rulename = $3; n->rulename = $3;
@@ -2071,34 +2071,31 @@ RuleStmt: CREATE RULE name AS
} }
; ;
OptStmtList: NOTHING { $$ = NIL; } RuleActionList: NOTHING { $$ = NIL; }
| OptimizableStmt { $$ = lcons($1, NIL); } | SelectStmt { $$ = lcons($1, NIL); }
| '[' OptStmtBlock ']' { $$ = $2; } | RuleActionStmt { $$ = lcons($1, NIL); }
/***S*I*D***/ | '[' RuleActionBlock ']' { $$ = $2; }
/* We comment this out because it produces a shift / reduce conflict | '(' RuleActionBlock ')' { $$ = $2; }
* with the select_w_o_sort rule */
/* | '(' OptStmtBlock ')' { $$ = $2; } */
; ;
OptStmtBlock: OptStmtMulti RuleActionBlock: RuleActionMulti { $$ = $1; }
{ $$ = $1; } | RuleActionStmt { $$ = lcons($1, NIL); }
| OptimizableStmt
{ $$ = lcons($1, NIL); }
; ;
OptStmtMulti: OptStmtMulti OptimizableStmt ';' RuleActionMulti: RuleActionMulti RuleActionStmt
{ $$ = lappend($1, $2); } { $$ = lappend($1, $2); }
/***S*I***/ | RuleActionMulti RuleActionStmt ';'
/* We comment the next rule because it seems to be redundant { $$ = lappend($1, $2); }
* and produces 16 shift/reduce conflicts with the new SelectStmt rule | RuleActionStmt ';'
* needed for EXCEPT and INTERSECT. So far I did not notice any
* violations by removing the rule! */
/* | OptStmtMulti OptimizableStmt
{ $$ = lappend($1, $2); } */
| OptimizableStmt ';'
{ $$ = lcons($1, NIL); } { $$ = lcons($1, NIL); }
; ;
RuleActionStmt: InsertStmt
| UpdateStmt
| DeleteStmt
| NotifyStmt
;
event_object: relation_name '.' attr_name event_object: relation_name '.' attr_name
{ {
$$ = makeNode(Attr); $$ = makeNode(Attr);

View File

@@ -13,16 +13,16 @@ QUERY: create table rtest_system (sysname text, sysdesc text);
QUERY: create table rtest_interface (sysname text, ifname text); QUERY: create table rtest_interface (sysname text, ifname text);
QUERY: create table rtest_person (pname text, pdesc text); QUERY: create table rtest_person (pname text, pdesc text);
QUERY: create table rtest_admin (pname text, sysname text); QUERY: create table rtest_admin (pname text, sysname text);
QUERY: create rule rtest_sys_upd1 as on update to rtest_system do QUERY: create rule rtest_sys_upd as on update to rtest_system do (
update rtest_interface set sysname = new.sysname update rtest_interface set sysname = new.sysname
where sysname = current.sysname; where sysname = current.sysname;
QUERY: create rule rtest_sys_upd2 as on update to rtest_system do
update rtest_admin set sysname = new.sysname update rtest_admin set sysname = new.sysname
where sysname = current.sysname; where sysname = current.sysname
QUERY: create rule rtest_sys_del1 as on delete to rtest_system do );
QUERY: create rule rtest_sys_del as on delete to rtest_system do (
delete from rtest_interface where sysname = current.sysname; delete from rtest_interface where sysname = current.sysname;
QUERY: create rule rtest_sys_del2 as on delete to rtest_system do
delete from rtest_admin where sysname = current.sysname; delete from rtest_admin where sysname = current.sysname;
);
QUERY: create rule rtest_pers_upd as on update to rtest_person do QUERY: create rule rtest_pers_upd as on update to rtest_person do
update rtest_admin set pname = new.pname where pname = current.pname; update rtest_admin set pname = new.pname where pname = current.pname;
QUERY: create rule rtest_pers_del as on delete to rtest_person do QUERY: create rule rtest_pers_del as on delete to rtest_person do

View File

@@ -24,26 +24,26 @@ create rule rtest_v1_del as on delete to rtest_v1 do instead
-- Tables and rules for the constraint update/delete test -- Tables and rules for the constraint update/delete test
-- --
-- Note: -- Note:
-- psql prevents from putting colons into brackets as -- Now that we have multiple action rule support, we check
-- required for multi action rules. So we define single -- both possible syntaxes to define them (The last action
-- rules for each action required for now -- can but must not have a semicolon at the end).
-- --
create table rtest_system (sysname text, sysdesc text); create table rtest_system (sysname text, sysdesc text);
create table rtest_interface (sysname text, ifname text); create table rtest_interface (sysname text, ifname text);
create table rtest_person (pname text, pdesc text); create table rtest_person (pname text, pdesc text);
create table rtest_admin (pname text, sysname text); create table rtest_admin (pname text, sysname text);
create rule rtest_sys_upd1 as on update to rtest_system do create rule rtest_sys_upd as on update to rtest_system do (
update rtest_interface set sysname = new.sysname update rtest_interface set sysname = new.sysname
where sysname = current.sysname; where sysname = current.sysname;
create rule rtest_sys_upd2 as on update to rtest_system do
update rtest_admin set sysname = new.sysname update rtest_admin set sysname = new.sysname
where sysname = current.sysname; where sysname = current.sysname
);
create rule rtest_sys_del1 as on delete to rtest_system do create rule rtest_sys_del as on delete to rtest_system do (
delete from rtest_interface where sysname = current.sysname; delete from rtest_interface where sysname = current.sysname;
create rule rtest_sys_del2 as on delete to rtest_system do
delete from rtest_admin where sysname = current.sysname; delete from rtest_admin where sysname = current.sysname;
);
create rule rtest_pers_upd as on update to rtest_person do create rule rtest_pers_upd as on update to rtest_person do
update rtest_admin set pname = new.pname where pname = current.pname; update rtest_admin set pname = new.pname where pname = current.pname;