Commit fc6d1006 authored by Robert Haas's avatar Robert Haas

Further consolidation of DROP statement handling.

This gets rid of an impressive amount of duplicative code, with only
minimal behavior changes.  DROP FOREIGN DATA WRAPPER now requires object
ownership rather than superuser privileges, matching the documentation
we already have.  We also eliminate the historical warning about dropping
a built-in function as unuseful.  All operations are now performed in the
same order for all object types handled by dropcmds.c.

KaiGai Kohei, with minor revisions by me
parent 709aca59
...@@ -208,58 +208,9 @@ DefineAggregate(List *name, List *args, bool oldstyle, List *parameters) ...@@ -208,58 +208,9 @@ DefineAggregate(List *name, List *args, bool oldstyle, List *parameters)
/* /*
* RemoveAggregate * RenameAggregate
* Deletes an aggregate. * Rename an aggregate.
*/ */
void
RemoveAggregate(RemoveFuncStmt *stmt)
{
List *aggName = stmt->name;
List *aggArgs = stmt->args;
Oid procOid;
HeapTuple tup;
ObjectAddress object;
/* Look up function and make sure it's an aggregate */
procOid = LookupAggNameTypeNames(aggName, aggArgs, stmt->missing_ok);
if (!OidIsValid(procOid))
{
/* we only get here if stmt->missing_ok is true */
ereport(NOTICE,
(errmsg("aggregate %s(%s) does not exist, skipping",
NameListToString(aggName),
TypeNameListToString(aggArgs))));
return;
}
/*
* Find the function tuple, do permissions and validity checks
*/
tup = SearchSysCache1(PROCOID, ObjectIdGetDatum(procOid));
if (!HeapTupleIsValid(tup)) /* should not happen */
elog(ERROR, "cache lookup failed for function %u", procOid);
/* Permission check: must own agg or its namespace */
if (!pg_proc_ownercheck(procOid, GetUserId()) &&
!pg_namespace_ownercheck(((Form_pg_proc) GETSTRUCT(tup))->pronamespace,
GetUserId()))
aclcheck_error(ACLCHECK_NOT_OWNER, ACL_KIND_PROC,
NameListToString(aggName));
ReleaseSysCache(tup);
/*
* Do the deletion
*/
object.classId = ProcedureRelationId;
object.objectId = procOid;
object.objectSubId = 0;
performDeletion(&object, stmt->behavior);
}
void void
RenameAggregate(List *name, List *args, const char *newname) RenameAggregate(List *name, List *args, const char *newname)
{ {
......
...@@ -20,13 +20,17 @@ ...@@ -20,13 +20,17 @@
#include "catalog/namespace.h" #include "catalog/namespace.h"
#include "catalog/objectaddress.h" #include "catalog/objectaddress.h"
#include "catalog/pg_class.h" #include "catalog/pg_class.h"
#include "catalog/pg_proc.h"
#include "commands/defrem.h" #include "commands/defrem.h"
#include "miscadmin.h" #include "miscadmin.h"
#include "nodes/makefuncs.h" #include "nodes/makefuncs.h"
#include "parser/parse_type.h" #include "parser/parse_type.h"
#include "utils/acl.h" #include "utils/acl.h"
#include "utils/builtins.h"
#include "utils/syscache.h"
static void does_not_exist_skipping(ObjectType objtype, List *objname); static void does_not_exist_skipping(ObjectType objtype,
List *objname, List *objargs);
/* /*
* Drop one or more objects. * Drop one or more objects.
...@@ -44,6 +48,7 @@ RemoveObjects(DropStmt *stmt) ...@@ -44,6 +48,7 @@ RemoveObjects(DropStmt *stmt)
{ {
ObjectAddresses *objects; ObjectAddresses *objects;
ListCell *cell1; ListCell *cell1;
ListCell *cell2 = NULL;
objects = new_object_addresses(); objects = new_object_addresses();
...@@ -51,12 +56,19 @@ RemoveObjects(DropStmt *stmt) ...@@ -51,12 +56,19 @@ RemoveObjects(DropStmt *stmt)
{ {
ObjectAddress address; ObjectAddress address;
List *objname = lfirst(cell1); List *objname = lfirst(cell1);
List *objargs = NIL;
Relation relation = NULL; Relation relation = NULL;
Oid namespaceId; Oid namespaceId;
if (stmt->arguments)
{
cell2 = (!cell2 ? list_head(stmt->arguments) : lnext(cell2));
objargs = lfirst(cell2);
}
/* Get an ObjectAddress for the object. */ /* Get an ObjectAddress for the object. */
address = get_object_address(stmt->removeType, address = get_object_address(stmt->removeType,
objname, NIL, objname, objargs,
&relation, &relation,
AccessExclusiveLock, AccessExclusiveLock,
stmt->missing_ok); stmt->missing_ok);
...@@ -64,16 +76,40 @@ RemoveObjects(DropStmt *stmt) ...@@ -64,16 +76,40 @@ RemoveObjects(DropStmt *stmt)
/* Issue NOTICE if supplied object was not found. */ /* Issue NOTICE if supplied object was not found. */
if (!OidIsValid(address.objectId)) if (!OidIsValid(address.objectId))
{ {
does_not_exist_skipping(stmt->removeType, objname); does_not_exist_skipping(stmt->removeType, objname, objargs);
continue; continue;
} }
/*
* Although COMMENT ON FUNCTION, SECURITY LABEL ON FUNCTION, etc. are
* happy to operate on an aggregate as on any other function, we have
* historically not allowed this for DROP FUNCTION.
*/
if (stmt->removeType == OBJECT_FUNCTION)
{
Oid funcOid = address.objectId;
HeapTuple tup;
tup = SearchSysCache1(PROCOID, ObjectIdGetDatum(funcOid));
if (!HeapTupleIsValid(tup)) /* should not happen */
elog(ERROR, "cache lookup failed for function %u", funcOid);
if (((Form_pg_proc) GETSTRUCT(tup))->proisagg)
ereport(ERROR,
(errcode(ERRCODE_WRONG_OBJECT_TYPE),
errmsg("\"%s\" is an aggregate function",
NameListToString(objname)),
errhint("Use DROP AGGREGATE to drop aggregate functions.")));
ReleaseSysCache(tup);
}
/* Check permissions. */ /* Check permissions. */
namespaceId = get_object_namespace(&address); namespaceId = get_object_namespace(&address);
if (!OidIsValid(namespaceId) || if (!OidIsValid(namespaceId) ||
!pg_namespace_ownercheck(namespaceId, GetUserId())) !pg_namespace_ownercheck(namespaceId, GetUserId()))
check_object_ownership(GetUserId(), stmt->removeType, address, check_object_ownership(GetUserId(), stmt->removeType, address,
objname, NIL, relation); objname, objargs, relation);
/* Release any relcache reference count, but keep lock until commit. */ /* Release any relcache reference count, but keep lock until commit. */
if (relation) if (relation)
...@@ -94,10 +130,11 @@ RemoveObjects(DropStmt *stmt) ...@@ -94,10 +130,11 @@ RemoveObjects(DropStmt *stmt)
* get_object_address() will throw an ERROR. * get_object_address() will throw an ERROR.
*/ */
static void static void
does_not_exist_skipping(ObjectType objtype, List *objname) does_not_exist_skipping(ObjectType objtype, List *objname, List *objargs)
{ {
const char *msg = NULL; const char *msg = NULL;
char *name = NULL; char *name = NULL;
char *args = NULL;
switch (objtype) switch (objtype)
{ {
...@@ -138,10 +175,68 @@ does_not_exist_skipping(ObjectType objtype, List *objname) ...@@ -138,10 +175,68 @@ does_not_exist_skipping(ObjectType objtype, List *objname)
msg = gettext_noop("extension \"%s\" does not exist, skipping"); msg = gettext_noop("extension \"%s\" does not exist, skipping");
name = NameListToString(objname); name = NameListToString(objname);
break; break;
case OBJECT_FUNCTION:
msg = gettext_noop("function %s(%s) does not exist, skipping");
name = NameListToString(objname);
args = TypeNameListToString(objargs);
break;
case OBJECT_AGGREGATE:
msg = gettext_noop("aggregate %s(%s) does not exist, skipping");
name = NameListToString(objname);
args = TypeNameListToString(objargs);
break;
case OBJECT_OPERATOR:
msg = gettext_noop("operator %s does not exist, skipping");
name = NameListToString(objname);
break;
case OBJECT_LANGUAGE:
msg = gettext_noop("language \"%s\" does not exist, skipping");
name = NameListToString(objname);
break;
case OBJECT_CAST:
msg = gettext_noop("cast from type %s to type %s does not exist, skipping");
name = format_type_be(typenameTypeId(NULL,
(TypeName *) linitial(objname)));
args = format_type_be(typenameTypeId(NULL,
(TypeName *) linitial(objargs)));
break;
case OBJECT_TRIGGER:
msg = gettext_noop("trigger \"%s\" for table \"%s\" does not exist, skipping");
name = strVal(llast(objname));
args = NameListToString(list_truncate(objname,
list_length(objname) - 1));
break;
case OBJECT_RULE:
msg = gettext_noop("rule \"%s\" for relation \"%s\" does not exist, skipping");
name = strVal(llast(objname));
args = NameListToString(list_truncate(objname,
list_length(objname) - 1));
break;
case OBJECT_FDW:
msg = gettext_noop("foreign-data wrapper \"%s\" does not exist, skipping");
name = NameListToString(objname);
break;
case OBJECT_FOREIGN_SERVER:
msg = gettext_noop("server \"%s\" does not exist, skipping");
name = NameListToString(objname);
break;
case OBJECT_OPCLASS:
msg = gettext_noop("operator class \"%s\" does not exist for access method \"%s\", skipping");
name = NameListToString(objname);
args = strVal(linitial(objargs));
break;
case OBJECT_OPFAMILY:
msg = gettext_noop("operator family \"%s\" does not exist for access method \"%s\", skipping");
name = NameListToString(objname);
args = strVal(linitial(objargs));
break;
default: default:
elog(ERROR, "unexpected object type (%d)", (int)objtype); elog(ERROR, "unexpected object type (%d)", (int)objtype);
break; break;
} }
ereport(NOTICE, (errmsg(msg, name))); if (!args)
ereport(NOTICE, (errmsg(msg, name)));
else
ereport(NOTICE, (errmsg(msg, name, args)));
} }
...@@ -685,50 +685,6 @@ AlterForeignDataWrapper(AlterFdwStmt *stmt) ...@@ -685,50 +685,6 @@ AlterForeignDataWrapper(AlterFdwStmt *stmt)
} }
/*
* Drop foreign-data wrapper
*/
void
RemoveForeignDataWrapper(DropFdwStmt *stmt)
{
Oid fdwId;
ObjectAddress object;
fdwId = get_foreign_data_wrapper_oid(stmt->fdwname, true);
if (!superuser())
ereport(ERROR,
(errcode(ERRCODE_INSUFFICIENT_PRIVILEGE),
errmsg("permission denied to drop foreign-data wrapper \"%s\"",
stmt->fdwname),
errhint("Must be superuser to drop a foreign-data wrapper.")));
if (!OidIsValid(fdwId))
{
if (!stmt->missing_ok)
ereport(ERROR,
(errcode(ERRCODE_UNDEFINED_OBJECT),
errmsg("foreign-data wrapper \"%s\" does not exist",
stmt->fdwname)));
/* IF EXISTS specified, just note it */
ereport(NOTICE,
(errmsg("foreign-data wrapper \"%s\" does not exist, skipping",
stmt->fdwname)));
return;
}
/*
* Do the deletion
*/
object.classId = ForeignDataWrapperRelationId;
object.objectId = fdwId;
object.objectSubId = 0;
performDeletion(&object, stmt->behavior);
}
/* /*
* Drop foreign-data wrapper by OID * Drop foreign-data wrapper by OID
*/ */
...@@ -957,45 +913,6 @@ AlterForeignServer(AlterForeignServerStmt *stmt) ...@@ -957,45 +913,6 @@ AlterForeignServer(AlterForeignServerStmt *stmt)
} }
/*
* Drop foreign server
*/
void
RemoveForeignServer(DropForeignServerStmt *stmt)
{
Oid srvId;
ObjectAddress object;
srvId = get_foreign_server_oid(stmt->servername, true);
if (!OidIsValid(srvId))
{
/* Server not found, complain or notice */
if (!stmt->missing_ok)
ereport(ERROR,
(errcode(ERRCODE_UNDEFINED_OBJECT),
errmsg("server \"%s\" does not exist", stmt->servername)));
/* IF EXISTS specified, just note it */
ereport(NOTICE,
(errmsg("server \"%s\" does not exist, skipping",
stmt->servername)));
return;
}
/* Only allow DROP if the server is owned by the user. */
if (!pg_foreign_server_ownercheck(srvId, GetUserId()))
aclcheck_error(ACLCHECK_NOT_OWNER, ACL_KIND_FOREIGN_SERVER,
stmt->servername);
object.classId = ForeignServerRelationId;
object.objectId = srvId;
object.objectSubId = 0;
performDeletion(&object, stmt->behavior);
}
/* /*
* Drop foreign server by OID * Drop foreign server by OID
*/ */
......
...@@ -960,72 +960,6 @@ CreateFunction(CreateFunctionStmt *stmt, const char *queryString) ...@@ -960,72 +960,6 @@ CreateFunction(CreateFunctionStmt *stmt, const char *queryString)
} }
/*
* RemoveFunction
* Deletes a function.
*/
void
RemoveFunction(RemoveFuncStmt *stmt)
{
List *functionName = stmt->name;
List *argTypes = stmt->args; /* list of TypeName nodes */
Oid funcOid;
HeapTuple tup;
ObjectAddress object;
/*
* Find the function, do permissions and validity checks
*/
funcOid = LookupFuncNameTypeNames(functionName, argTypes, stmt->missing_ok);
if (!OidIsValid(funcOid))
{
/* can only get here if stmt->missing_ok */
ereport(NOTICE,
(errmsg("function %s(%s) does not exist, skipping",
NameListToString(functionName),
TypeNameListToString(argTypes))));
return;
}
tup = SearchSysCache1(PROCOID, ObjectIdGetDatum(funcOid));
if (!HeapTupleIsValid(tup)) /* should not happen */
elog(ERROR, "cache lookup failed for function %u", funcOid);
/* Permission check: must own func or its namespace */
if (!pg_proc_ownercheck(funcOid, GetUserId()) &&
!pg_namespace_ownercheck(((Form_pg_proc) GETSTRUCT(tup))->pronamespace,
GetUserId()))
aclcheck_error(ACLCHECK_NOT_OWNER, ACL_KIND_PROC,
NameListToString(functionName));
if (((Form_pg_proc) GETSTRUCT(tup))->proisagg)
ereport(ERROR,
(errcode(ERRCODE_WRONG_OBJECT_TYPE),
errmsg("\"%s\" is an aggregate function",
NameListToString(functionName)),
errhint("Use DROP AGGREGATE to drop aggregate functions.")));
if (((Form_pg_proc) GETSTRUCT(tup))->prolang == INTERNALlanguageId)
{
/* "Helpful" NOTICE when removing a builtin function ... */
ereport(NOTICE,
(errcode(ERRCODE_WARNING),
errmsg("removing built-in function \"%s\"",
NameListToString(functionName))));
}
ReleaseSysCache(tup);
/*
* Do the deletion
*/
object.classId = ProcedureRelationId;
object.objectId = funcOid;
object.objectSubId = 0;
performDeletion(&object, stmt->behavior);
}
/* /*
* Guts of function deletion. * Guts of function deletion.
* *
...@@ -1772,51 +1706,6 @@ CreateCast(CreateCastStmt *stmt) ...@@ -1772,51 +1706,6 @@ CreateCast(CreateCastStmt *stmt)
heap_close(relation, RowExclusiveLock); heap_close(relation, RowExclusiveLock);
} }
/*
* DROP CAST
*/
void
DropCast(DropCastStmt *stmt)
{
Oid sourcetypeid;
Oid targettypeid;
ObjectAddress object;
/* when dropping a cast, the types must exist even if you use IF EXISTS */
sourcetypeid = typenameTypeId(NULL, stmt->sourcetype);
targettypeid = typenameTypeId(NULL, stmt->targettype);
object.classId = CastRelationId;
object.objectId = get_cast_oid(sourcetypeid, targettypeid,
stmt->missing_ok);
object.objectSubId = 0;
if (!OidIsValid(object.objectId))
{
ereport(NOTICE,
(errmsg("cast from type %s to type %s does not exist, skipping",
format_type_be(sourcetypeid),
format_type_be(targettypeid))));
return;
}
/* Permission check */
if (!pg_type_ownercheck(sourcetypeid, GetUserId())
&& !pg_type_ownercheck(targettypeid, GetUserId()))
ereport(ERROR,
(errcode(ERRCODE_INSUFFICIENT_PRIVILEGE),
errmsg("must be owner of type %s or type %s",
format_type_be(sourcetypeid),
format_type_be(targettypeid))));
/*
* Do the deletion
*/
performDeletion(&object, stmt->behavior);
}
/* /*
* get_cast_oid - given two type OIDs, look up a cast OID * get_cast_oid - given two type OIDs, look up a cast OID
* *
......
...@@ -1543,104 +1543,6 @@ dropProcedures(List *opfamilyname, Oid amoid, Oid opfamilyoid, ...@@ -1543,104 +1543,6 @@ dropProcedures(List *opfamilyname, Oid amoid, Oid opfamilyoid,
} }
} }
/*
* RemoveOpClass
* Deletes an opclass.
*/
void
RemoveOpClass(RemoveOpClassStmt *stmt)
{
Oid amID,
opcID;
HeapTuple tuple;
ObjectAddress object;
/* Get the access method's OID. */
amID = get_am_oid(stmt->amname, false);
/* Look up the opclass. */
tuple = OpClassCacheLookup(amID, stmt->opclassname, stmt->missing_ok);
if (!HeapTupleIsValid(tuple))
{
ereport(NOTICE,
(errmsg("operator class \"%s\" does not exist for access method \"%s\", skipping",
NameListToString(stmt->opclassname), stmt->amname)));
return;
}
opcID = HeapTupleGetOid(tuple);
/* Permission check: must own opclass or its namespace */
if (!pg_opclass_ownercheck(opcID, GetUserId()) &&
!pg_namespace_ownercheck(((Form_pg_opclass) GETSTRUCT(tuple))->opcnamespace,
GetUserId()))
aclcheck_error(ACLCHECK_NOT_OWNER, ACL_KIND_OPCLASS,
NameListToString(stmt->opclassname));
ReleaseSysCache(tuple);
/*
* Do the deletion
*/
object.classId = OperatorClassRelationId;
object.objectId = opcID;
object.objectSubId = 0;
performDeletion(&object, stmt->behavior);
}
/*
* RemoveOpFamily
* Deletes an opfamily.
*/
void
RemoveOpFamily(RemoveOpFamilyStmt *stmt)
{
Oid amID,
opfID;
HeapTuple tuple;
ObjectAddress object;
/*
* Get the access method's OID.
*/
amID = get_am_oid(stmt->amname, false);
/*
* Look up the opfamily.
*/
tuple = OpFamilyCacheLookup(amID, stmt->opfamilyname, stmt->missing_ok);
if (!HeapTupleIsValid(tuple))
{
ereport(NOTICE,
(errmsg("operator family \"%s\" does not exist for access method \"%s\", skipping",
NameListToString(stmt->opfamilyname), stmt->amname)));
return;
}
opfID = HeapTupleGetOid(tuple);
/* Permission check: must own opfamily or its namespace */
if (!pg_opfamily_ownercheck(opfID, GetUserId()) &&
!pg_namespace_ownercheck(((Form_pg_opfamily) GETSTRUCT(tuple))->opfnamespace,
GetUserId()))
aclcheck_error(ACLCHECK_NOT_OWNER, ACL_KIND_OPFAMILY,
NameListToString(stmt->opfamilyname));
ReleaseSysCache(tuple);
/*
* Do the deletion
*/
object.classId = OperatorFamilyRelationId;
object.objectId = opfID;
object.objectSubId = 0;
performDeletion(&object, stmt->behavior);
}
/* /*
* Deletion subroutines for use by dependency.c. * Deletion subroutines for use by dependency.c.
*/ */
......
...@@ -290,56 +290,6 @@ DefineOperator(List *names, List *parameters) ...@@ -290,56 +290,6 @@ DefineOperator(List *names, List *parameters)
} }
/*
* RemoveOperator
* Deletes an operator.
*/
void
RemoveOperator(RemoveFuncStmt *stmt)
{
List *operatorName = stmt->name;
TypeName *typeName1 = (TypeName *) linitial(stmt->args);
TypeName *typeName2 = (TypeName *) lsecond(stmt->args);
Oid operOid;
HeapTuple tup;
ObjectAddress object;
Assert(list_length(stmt->args) == 2);
operOid = LookupOperNameTypeNames(NULL, operatorName,
typeName1, typeName2,
stmt->missing_ok, -1);
if (stmt->missing_ok && !OidIsValid(operOid))
{
ereport(NOTICE,
(errmsg("operator %s does not exist, skipping",
NameListToString(operatorName))));
return;
}
tup = SearchSysCache1(OPEROID, ObjectIdGetDatum(operOid));
if (!HeapTupleIsValid(tup)) /* should not happen */
elog(ERROR, "cache lookup failed for operator %u", operOid);
/* Permission check: must own operator or its namespace */
if (!pg_oper_ownercheck(operOid, GetUserId()) &&
!pg_namespace_ownercheck(((Form_pg_operator) GETSTRUCT(tup))->oprnamespace,
GetUserId()))
aclcheck_error(ACLCHECK_NOT_OWNER, ACL_KIND_OPER,
NameListToString(operatorName));
ReleaseSysCache(tup);
/*
* Do the deletion
*/
object.classId = OperatorRelationId;
object.objectId = operOid;
object.objectSubId = 0;
performDeletion(&object, stmt->behavior);
}
/* /*
* Guts of operator deletion. * Guts of operator deletion.
*/ */
......
...@@ -507,43 +507,6 @@ PLTemplateExists(const char *languageName) ...@@ -507,43 +507,6 @@ PLTemplateExists(const char *languageName)
return (find_language_template(languageName) != NULL); return (find_language_template(languageName) != NULL);
} }
/* ---------------------------------------------------------------------
* DROP PROCEDURAL LANGUAGE
* ---------------------------------------------------------------------
*/
void
DropProceduralLanguage(DropPLangStmt *stmt)
{
Oid oid;
ObjectAddress object;
oid = get_language_oid(stmt->plname, stmt->missing_ok);
if (!OidIsValid(oid))
{
ereport(NOTICE,
(errmsg("language \"%s\" does not exist, skipping",
stmt->plname)));
return;
}
/*
* Check permission
*/
if (!pg_language_ownercheck(oid, GetUserId()))
aclcheck_error(ACLCHECK_NOT_OWNER, ACL_KIND_LANGUAGE,
stmt->plname);
object.classId = LanguageRelationId;
object.objectId = oid;
object.objectSubId = 0;
/*
* Do the deletion
*/
performDeletion(&object, stmt->behavior);
}
/* /*
* Guts of language dropping. * Guts of language dropping.
*/ */
......
...@@ -1026,42 +1026,6 @@ ConvertTriggerToFK(CreateTrigStmt *stmt, Oid funcoid) ...@@ -1026,42 +1026,6 @@ ConvertTriggerToFK(CreateTrigStmt *stmt, Oid funcoid)
} }
} }
/*
* DropTrigger - drop an individual trigger by name
*/
void
DropTrigger(RangeVar *relation, const char *trigname, DropBehavior behavior,
bool missing_ok)
{
Oid relid;
ObjectAddress object;
/* lock level should match RemoveTriggerById */
relid = RangeVarGetRelid(relation, AccessExclusiveLock, false, false);
object.classId = TriggerRelationId;
object.objectId = get_trigger_oid(relid, trigname, missing_ok);
object.objectSubId = 0;
if (!OidIsValid(object.objectId))
{
ereport(NOTICE,
(errmsg("trigger \"%s\" for table \"%s\" does not exist, skipping",
trigname, get_rel_name(relid))));
return;
}
if (!pg_class_ownercheck(relid, GetUserId()))
aclcheck_error(ACLCHECK_NOT_OWNER, ACL_KIND_CLASS,
get_rel_name(relid));
/*
* Do the deletion
*/
performDeletion(&object, behavior);
}
/* /*
* Guts of trigger deletion. * Guts of trigger deletion.
*/ */
......
...@@ -2755,6 +2755,7 @@ _copyDropStmt(DropStmt *from) ...@@ -2755,6 +2755,7 @@ _copyDropStmt(DropStmt *from)
DropStmt *newnode = makeNode(DropStmt); DropStmt *newnode = makeNode(DropStmt);
COPY_NODE_FIELD(objects); COPY_NODE_FIELD(objects);
COPY_NODE_FIELD(arguments);
COPY_SCALAR_FIELD(removeType); COPY_SCALAR_FIELD(removeType);
COPY_SCALAR_FIELD(behavior); COPY_SCALAR_FIELD(behavior);
COPY_SCALAR_FIELD(missing_ok); COPY_SCALAR_FIELD(missing_ok);
...@@ -2878,20 +2879,6 @@ _copyAlterFunctionStmt(AlterFunctionStmt *from) ...@@ -2878,20 +2879,6 @@ _copyAlterFunctionStmt(AlterFunctionStmt *from)
return newnode; return newnode;
} }
static RemoveFuncStmt *
_copyRemoveFuncStmt(RemoveFuncStmt *from)
{
RemoveFuncStmt *newnode = makeNode(RemoveFuncStmt);
COPY_SCALAR_FIELD(kind);
COPY_NODE_FIELD(name);
COPY_NODE_FIELD(args);
COPY_SCALAR_FIELD(behavior);
COPY_SCALAR_FIELD(missing_ok);
return newnode;
}
static DoStmt * static DoStmt *
_copyDoStmt(DoStmt *from) _copyDoStmt(DoStmt *from)
{ {
...@@ -2902,32 +2889,6 @@ _copyDoStmt(DoStmt *from) ...@@ -2902,32 +2889,6 @@ _copyDoStmt(DoStmt *from)
return newnode; return newnode;
} }
static RemoveOpClassStmt *
_copyRemoveOpClassStmt(RemoveOpClassStmt *from)
{
RemoveOpClassStmt *newnode = makeNode(RemoveOpClassStmt);
COPY_NODE_FIELD(opclassname);
COPY_STRING_FIELD(amname);
COPY_SCALAR_FIELD(behavior);
COPY_SCALAR_FIELD(missing_ok);
return newnode;
}
static RemoveOpFamilyStmt *
_copyRemoveOpFamilyStmt(RemoveOpFamilyStmt *from)
{
RemoveOpFamilyStmt *newnode = makeNode(RemoveOpFamilyStmt);
COPY_NODE_FIELD(opfamilyname);
COPY_STRING_FIELD(amname);
COPY_SCALAR_FIELD(behavior);
COPY_SCALAR_FIELD(missing_ok);
return newnode;
}
static RenameStmt * static RenameStmt *
_copyRenameStmt(RenameStmt *from) _copyRenameStmt(RenameStmt *from)
{ {
...@@ -3391,18 +3352,6 @@ _copyAlterFdwStmt(AlterFdwStmt *from) ...@@ -3391,18 +3352,6 @@ _copyAlterFdwStmt(AlterFdwStmt *from)
return newnode; return newnode;
} }
static DropFdwStmt *
_copyDropFdwStmt(DropFdwStmt *from)
{
DropFdwStmt *newnode = makeNode(DropFdwStmt);
COPY_STRING_FIELD(fdwname);
COPY_SCALAR_FIELD(missing_ok);
COPY_SCALAR_FIELD(behavior);
return newnode;
}
static CreateForeignServerStmt * static CreateForeignServerStmt *
_copyCreateForeignServerStmt(CreateForeignServerStmt *from) _copyCreateForeignServerStmt(CreateForeignServerStmt *from)
{ {
...@@ -3430,18 +3379,6 @@ _copyAlterForeignServerStmt(AlterForeignServerStmt *from) ...@@ -3430,18 +3379,6 @@ _copyAlterForeignServerStmt(AlterForeignServerStmt *from)
return newnode; return newnode;
} }
static DropForeignServerStmt *
_copyDropForeignServerStmt(DropForeignServerStmt *from)
{
DropForeignServerStmt *newnode = makeNode(DropForeignServerStmt);
COPY_STRING_FIELD(servername);
COPY_SCALAR_FIELD(missing_ok);
COPY_SCALAR_FIELD(behavior);
return newnode;
}
static CreateUserMappingStmt * static CreateUserMappingStmt *
_copyCreateUserMappingStmt(CreateUserMappingStmt *from) _copyCreateUserMappingStmt(CreateUserMappingStmt *from)
{ {
...@@ -3513,20 +3450,6 @@ _copyCreateTrigStmt(CreateTrigStmt *from) ...@@ -3513,20 +3450,6 @@ _copyCreateTrigStmt(CreateTrigStmt *from)
return newnode; return newnode;
} }
static DropPropertyStmt *
_copyDropPropertyStmt(DropPropertyStmt *from)
{
DropPropertyStmt *newnode = makeNode(DropPropertyStmt);
COPY_NODE_FIELD(relation);
COPY_STRING_FIELD(property);
COPY_SCALAR_FIELD(removeType);
COPY_SCALAR_FIELD(behavior);
COPY_SCALAR_FIELD(missing_ok);
return newnode;
}
static CreatePLangStmt * static CreatePLangStmt *
_copyCreatePLangStmt(CreatePLangStmt *from) _copyCreatePLangStmt(CreatePLangStmt *from)
{ {
...@@ -3542,18 +3465,6 @@ _copyCreatePLangStmt(CreatePLangStmt *from) ...@@ -3542,18 +3465,6 @@ _copyCreatePLangStmt(CreatePLangStmt *from)
return newnode; return newnode;
} }
static DropPLangStmt *
_copyDropPLangStmt(DropPLangStmt *from)
{
DropPLangStmt *newnode = makeNode(DropPLangStmt);
COPY_STRING_FIELD(plname);
COPY_SCALAR_FIELD(behavior);
COPY_SCALAR_FIELD(missing_ok);
return newnode;
}
static CreateRoleStmt * static CreateRoleStmt *
_copyCreateRoleStmt(CreateRoleStmt *from) _copyCreateRoleStmt(CreateRoleStmt *from)
{ {
...@@ -3678,19 +3589,6 @@ _copyCreateCastStmt(CreateCastStmt *from) ...@@ -3678,19 +3589,6 @@ _copyCreateCastStmt(CreateCastStmt *from)
return newnode; return newnode;
} }
static DropCastStmt *
_copyDropCastStmt(DropCastStmt *from)
{
DropCastStmt *newnode = makeNode(DropCastStmt);
COPY_NODE_FIELD(sourcetype);
COPY_NODE_FIELD(targettype);
COPY_SCALAR_FIELD(behavior);
COPY_SCALAR_FIELD(missing_ok);
return newnode;
}
static PrepareStmt * static PrepareStmt *
_copyPrepareStmt(PrepareStmt *from) _copyPrepareStmt(PrepareStmt *from)
{ {
...@@ -4266,18 +4164,9 @@ copyObject(void *from) ...@@ -4266,18 +4164,9 @@ copyObject(void *from)
case T_AlterFunctionStmt: case T_AlterFunctionStmt:
retval = _copyAlterFunctionStmt(from); retval = _copyAlterFunctionStmt(from);
break; break;
case T_RemoveFuncStmt:
retval = _copyRemoveFuncStmt(from);
break;
case T_DoStmt: case T_DoStmt:
retval = _copyDoStmt(from); retval = _copyDoStmt(from);
break; break;
case T_RemoveOpClassStmt:
retval = _copyRemoveOpClassStmt(from);
break;
case T_RemoveOpFamilyStmt:
retval = _copyRemoveOpFamilyStmt(from);
break;
case T_RenameStmt: case T_RenameStmt:
retval = _copyRenameStmt(from); retval = _copyRenameStmt(from);
break; break;
...@@ -4392,18 +4281,12 @@ copyObject(void *from) ...@@ -4392,18 +4281,12 @@ copyObject(void *from)
case T_AlterFdwStmt: case T_AlterFdwStmt:
retval = _copyAlterFdwStmt(from); retval = _copyAlterFdwStmt(from);
break; break;
case T_DropFdwStmt:
retval = _copyDropFdwStmt(from);
break;
case T_CreateForeignServerStmt: case T_CreateForeignServerStmt:
retval = _copyCreateForeignServerStmt(from); retval = _copyCreateForeignServerStmt(from);
break; break;
case T_AlterForeignServerStmt: case T_AlterForeignServerStmt:
retval = _copyAlterForeignServerStmt(from); retval = _copyAlterForeignServerStmt(from);
break; break;
case T_DropForeignServerStmt:
retval = _copyDropForeignServerStmt(from);
break;
case T_CreateUserMappingStmt: case T_CreateUserMappingStmt:
retval = _copyCreateUserMappingStmt(from); retval = _copyCreateUserMappingStmt(from);
break; break;
...@@ -4419,15 +4302,9 @@ copyObject(void *from) ...@@ -4419,15 +4302,9 @@ copyObject(void *from)
case T_CreateTrigStmt: case T_CreateTrigStmt:
retval = _copyCreateTrigStmt(from); retval = _copyCreateTrigStmt(from);
break; break;
case T_DropPropertyStmt:
retval = _copyDropPropertyStmt(from);
break;
case T_CreatePLangStmt: case T_CreatePLangStmt:
retval = _copyCreatePLangStmt(from); retval = _copyCreatePLangStmt(from);
break; break;
case T_DropPLangStmt:
retval = _copyDropPLangStmt(from);
break;
case T_CreateRoleStmt: case T_CreateRoleStmt:
retval = _copyCreateRoleStmt(from); retval = _copyCreateRoleStmt(from);
break; break;
...@@ -4461,9 +4338,6 @@ copyObject(void *from) ...@@ -4461,9 +4338,6 @@ copyObject(void *from)
case T_CreateCastStmt: case T_CreateCastStmt:
retval = _copyCreateCastStmt(from); retval = _copyCreateCastStmt(from);
break; break;
case T_DropCastStmt:
retval = _copyDropCastStmt(from);
break;
case T_PrepareStmt: case T_PrepareStmt:
retval = _copyPrepareStmt(from); retval = _copyPrepareStmt(from);
break; break;
......
...@@ -1182,6 +1182,7 @@ static bool ...@@ -1182,6 +1182,7 @@ static bool
_equalDropStmt(DropStmt *a, DropStmt *b) _equalDropStmt(DropStmt *a, DropStmt *b)
{ {
COMPARE_NODE_FIELD(objects); COMPARE_NODE_FIELD(objects);
COMPARE_NODE_FIELD(arguments);
COMPARE_SCALAR_FIELD(removeType); COMPARE_SCALAR_FIELD(removeType);
COMPARE_SCALAR_FIELD(behavior); COMPARE_SCALAR_FIELD(behavior);
COMPARE_SCALAR_FIELD(missing_ok); COMPARE_SCALAR_FIELD(missing_ok);
...@@ -1289,18 +1290,6 @@ _equalAlterFunctionStmt(AlterFunctionStmt *a, AlterFunctionStmt *b) ...@@ -1289,18 +1290,6 @@ _equalAlterFunctionStmt(AlterFunctionStmt *a, AlterFunctionStmt *b)
return true; return true;
} }
static bool
_equalRemoveFuncStmt(RemoveFuncStmt *a, RemoveFuncStmt *b)
{
COMPARE_SCALAR_FIELD(kind);
COMPARE_NODE_FIELD(name);
COMPARE_NODE_FIELD(args);
COMPARE_SCALAR_FIELD(behavior);
COMPARE_SCALAR_FIELD(missing_ok);
return true;
}
static bool static bool
_equalDoStmt(DoStmt *a, DoStmt *b) _equalDoStmt(DoStmt *a, DoStmt *b)
{ {
...@@ -1309,28 +1298,6 @@ _equalDoStmt(DoStmt *a, DoStmt *b) ...@@ -1309,28 +1298,6 @@ _equalDoStmt(DoStmt *a, DoStmt *b)
return true; return true;
} }
static bool
_equalRemoveOpClassStmt(RemoveOpClassStmt *a, RemoveOpClassStmt *b)
{
COMPARE_NODE_FIELD(opclassname);
COMPARE_STRING_FIELD(amname);
COMPARE_SCALAR_FIELD(behavior);
COMPARE_SCALAR_FIELD(missing_ok);
return true;
}
static bool
_equalRemoveOpFamilyStmt(RemoveOpFamilyStmt *a, RemoveOpFamilyStmt *b)
{
COMPARE_NODE_FIELD(opfamilyname);
COMPARE_STRING_FIELD(amname);
COMPARE_SCALAR_FIELD(behavior);
COMPARE_SCALAR_FIELD(missing_ok);
return true;
}
static bool static bool
_equalRenameStmt(RenameStmt *a, RenameStmt *b) _equalRenameStmt(RenameStmt *a, RenameStmt *b)
{ {
...@@ -1719,16 +1686,6 @@ _equalAlterFdwStmt(AlterFdwStmt *a, AlterFdwStmt *b) ...@@ -1719,16 +1686,6 @@ _equalAlterFdwStmt(AlterFdwStmt *a, AlterFdwStmt *b)
return true; return true;
} }
static bool
_equalDropFdwStmt(DropFdwStmt *a, DropFdwStmt *b)
{
COMPARE_STRING_FIELD(fdwname);
COMPARE_SCALAR_FIELD(missing_ok);
COMPARE_SCALAR_FIELD(behavior);
return true;
}
static bool static bool
_equalCreateForeignServerStmt(CreateForeignServerStmt *a, CreateForeignServerStmt *b) _equalCreateForeignServerStmt(CreateForeignServerStmt *a, CreateForeignServerStmt *b)
{ {
...@@ -1752,16 +1709,6 @@ _equalAlterForeignServerStmt(AlterForeignServerStmt *a, AlterForeignServerStmt * ...@@ -1752,16 +1709,6 @@ _equalAlterForeignServerStmt(AlterForeignServerStmt *a, AlterForeignServerStmt *
return true; return true;
} }
static bool
_equalDropForeignServerStmt(DropForeignServerStmt *a, DropForeignServerStmt *b)
{
COMPARE_STRING_FIELD(servername);
COMPARE_SCALAR_FIELD(missing_ok);
COMPARE_SCALAR_FIELD(behavior);
return true;
}
static bool static bool
_equalCreateUserMappingStmt(CreateUserMappingStmt *a, CreateUserMappingStmt *b) _equalCreateUserMappingStmt(CreateUserMappingStmt *a, CreateUserMappingStmt *b)
{ {
...@@ -1824,18 +1771,6 @@ _equalCreateTrigStmt(CreateTrigStmt *a, CreateTrigStmt *b) ...@@ -1824,18 +1771,6 @@ _equalCreateTrigStmt(CreateTrigStmt *a, CreateTrigStmt *b)
return true; return true;
} }
static bool
_equalDropPropertyStmt(DropPropertyStmt *a, DropPropertyStmt *b)
{
COMPARE_NODE_FIELD(relation);
COMPARE_STRING_FIELD(property);
COMPARE_SCALAR_FIELD(removeType);
COMPARE_SCALAR_FIELD(behavior);
COMPARE_SCALAR_FIELD(missing_ok);
return true;
}
static bool static bool
_equalCreatePLangStmt(CreatePLangStmt *a, CreatePLangStmt *b) _equalCreatePLangStmt(CreatePLangStmt *a, CreatePLangStmt *b)
{ {
...@@ -1849,16 +1784,6 @@ _equalCreatePLangStmt(CreatePLangStmt *a, CreatePLangStmt *b) ...@@ -1849,16 +1784,6 @@ _equalCreatePLangStmt(CreatePLangStmt *a, CreatePLangStmt *b)
return true; return true;
} }
static bool
_equalDropPLangStmt(DropPLangStmt *a, DropPLangStmt *b)
{
COMPARE_STRING_FIELD(plname);
COMPARE_SCALAR_FIELD(behavior);
COMPARE_SCALAR_FIELD(missing_ok);
return true;
}
static bool static bool
_equalCreateRoleStmt(CreateRoleStmt *a, CreateRoleStmt *b) _equalCreateRoleStmt(CreateRoleStmt *a, CreateRoleStmt *b)
{ {
...@@ -1963,17 +1888,6 @@ _equalCreateCastStmt(CreateCastStmt *a, CreateCastStmt *b) ...@@ -1963,17 +1888,6 @@ _equalCreateCastStmt(CreateCastStmt *a, CreateCastStmt *b)
return true; return true;
} }
static bool
_equalDropCastStmt(DropCastStmt *a, DropCastStmt *b)
{
COMPARE_NODE_FIELD(sourcetype);
COMPARE_NODE_FIELD(targettype);
COMPARE_SCALAR_FIELD(behavior);
COMPARE_SCALAR_FIELD(missing_ok);
return true;
}
static bool static bool
_equalPrepareStmt(PrepareStmt *a, PrepareStmt *b) _equalPrepareStmt(PrepareStmt *a, PrepareStmt *b)
{ {
...@@ -2793,18 +2707,9 @@ equal(void *a, void *b) ...@@ -2793,18 +2707,9 @@ equal(void *a, void *b)
case T_AlterFunctionStmt: case T_AlterFunctionStmt:
retval = _equalAlterFunctionStmt(a, b); retval = _equalAlterFunctionStmt(a, b);
break; break;
case T_RemoveFuncStmt:
retval = _equalRemoveFuncStmt(a, b);
break;
case T_DoStmt: case T_DoStmt:
retval = _equalDoStmt(a, b); retval = _equalDoStmt(a, b);
break; break;
case T_RemoveOpClassStmt:
retval = _equalRemoveOpClassStmt(a, b);
break;
case T_RemoveOpFamilyStmt:
retval = _equalRemoveOpFamilyStmt(a, b);
break;
case T_RenameStmt: case T_RenameStmt:
retval = _equalRenameStmt(a, b); retval = _equalRenameStmt(a, b);
break; break;
...@@ -2919,18 +2824,12 @@ equal(void *a, void *b) ...@@ -2919,18 +2824,12 @@ equal(void *a, void *b)
case T_AlterFdwStmt: case T_AlterFdwStmt:
retval = _equalAlterFdwStmt(a, b); retval = _equalAlterFdwStmt(a, b);
break; break;
case T_DropFdwStmt:
retval = _equalDropFdwStmt(a, b);
break;
case T_CreateForeignServerStmt: case T_CreateForeignServerStmt:
retval = _equalCreateForeignServerStmt(a, b); retval = _equalCreateForeignServerStmt(a, b);
break; break;
case T_AlterForeignServerStmt: case T_AlterForeignServerStmt:
retval = _equalAlterForeignServerStmt(a, b); retval = _equalAlterForeignServerStmt(a, b);
break; break;
case T_DropForeignServerStmt:
retval = _equalDropForeignServerStmt(a, b);
break;
case T_CreateUserMappingStmt: case T_CreateUserMappingStmt:
retval = _equalCreateUserMappingStmt(a, b); retval = _equalCreateUserMappingStmt(a, b);
break; break;
...@@ -2946,15 +2845,9 @@ equal(void *a, void *b) ...@@ -2946,15 +2845,9 @@ equal(void *a, void *b)
case T_CreateTrigStmt: case T_CreateTrigStmt:
retval = _equalCreateTrigStmt(a, b); retval = _equalCreateTrigStmt(a, b);
break; break;
case T_DropPropertyStmt:
retval = _equalDropPropertyStmt(a, b);
break;
case T_CreatePLangStmt: case T_CreatePLangStmt:
retval = _equalCreatePLangStmt(a, b); retval = _equalCreatePLangStmt(a, b);
break; break;
case T_DropPLangStmt:
retval = _equalDropPLangStmt(a, b);
break;
case T_CreateRoleStmt: case T_CreateRoleStmt:
retval = _equalCreateRoleStmt(a, b); retval = _equalCreateRoleStmt(a, b);
break; break;
...@@ -2988,9 +2881,6 @@ equal(void *a, void *b) ...@@ -2988,9 +2881,6 @@ equal(void *a, void *b)
case T_CreateCastStmt: case T_CreateCastStmt:
retval = _equalCreateCastStmt(a, b); retval = _equalCreateCastStmt(a, b);
break; break;
case T_DropCastStmt:
retval = _equalDropCastStmt(a, b);
break;
case T_PrepareStmt: case T_PrepareStmt:
retval = _equalPrepareStmt(a, b); retval = _equalPrepareStmt(a, b);
break; break;
......
This diff is collapsed.
...@@ -30,71 +30,6 @@ ...@@ -30,71 +30,6 @@
#include "utils/syscache.h" #include "utils/syscache.h"
#include "utils/tqual.h" #include "utils/tqual.h"
/*
* RemoveRewriteRule
*
* Delete a rule given its name.
*/
void
RemoveRewriteRule(RangeVar *relation, const char *ruleName,
DropBehavior behavior, bool missing_ok)
{
HeapTuple tuple;
Oid eventRelationOid;
Oid owningRel;
ObjectAddress object;
/* lock level should match RemoveRewriteRuleById */
owningRel = RangeVarGetRelid(relation, AccessExclusiveLock,
false, false);
/*
* Find the tuple for the target rule.
*/
tuple = SearchSysCache2(RULERELNAME,
ObjectIdGetDatum(owningRel),
PointerGetDatum(ruleName));
/*
* complain if no rule with such name exists
*/
if (!HeapTupleIsValid(tuple))
{
if (!missing_ok)
ereport(ERROR,
(errcode(ERRCODE_UNDEFINED_OBJECT),
errmsg("rule \"%s\" for relation \"%s\" does not exist",
ruleName, get_rel_name(owningRel))));
else
ereport(NOTICE,
(errmsg("rule \"%s\" for relation \"%s\" does not exist, skipping",
ruleName, get_rel_name(owningRel))));
return;
}
/*
* Verify user has appropriate permissions.
*/
eventRelationOid = ((Form_pg_rewrite) GETSTRUCT(tuple))->ev_class;
Assert(eventRelationOid == owningRel);
if (!pg_class_ownercheck(eventRelationOid, GetUserId()))
aclcheck_error(ACLCHECK_NOT_OWNER, ACL_KIND_CLASS,
get_rel_name(eventRelationOid));
/*
* Do the deletion
*/
object.classId = RewriteRelationId;
object.objectId = HeapTupleGetOid(tuple);
object.objectSubId = 0;
ReleaseSysCache(tuple);
performDeletion(&object, behavior);
}
/* /*
* Guts of rule deletion. * Guts of rule deletion.
*/ */
......
...@@ -205,16 +205,10 @@ check_xact_readonly(Node *parsetree) ...@@ -205,16 +205,10 @@ check_xact_readonly(Node *parsetree)
case T_CreateRangeStmt: case T_CreateRangeStmt:
case T_AlterEnumStmt: case T_AlterEnumStmt:
case T_ViewStmt: case T_ViewStmt:
case T_DropCastStmt:
case T_DropStmt: case T_DropStmt:
case T_DropdbStmt: case T_DropdbStmt:
case T_DropTableSpaceStmt: case T_DropTableSpaceStmt:
case T_RemoveFuncStmt:
case T_DropRoleStmt: case T_DropRoleStmt:
case T_DropPLangStmt:
case T_RemoveOpClassStmt:
case T_RemoveOpFamilyStmt:
case T_DropPropertyStmt:
case T_GrantStmt: case T_GrantStmt:
case T_GrantRoleStmt: case T_GrantRoleStmt:
case T_AlterDefaultPrivilegesStmt: case T_AlterDefaultPrivilegesStmt:
...@@ -228,10 +222,8 @@ check_xact_readonly(Node *parsetree) ...@@ -228,10 +222,8 @@ check_xact_readonly(Node *parsetree)
case T_AlterExtensionContentsStmt: case T_AlterExtensionContentsStmt:
case T_CreateFdwStmt: case T_CreateFdwStmt:
case T_AlterFdwStmt: case T_AlterFdwStmt:
case T_DropFdwStmt:
case T_CreateForeignServerStmt: case T_CreateForeignServerStmt:
case T_AlterForeignServerStmt: case T_AlterForeignServerStmt:
case T_DropForeignServerStmt:
case T_CreateUserMappingStmt: case T_CreateUserMappingStmt:
case T_AlterUserMappingStmt: case T_AlterUserMappingStmt:
case T_DropUserMappingStmt: case T_DropUserMappingStmt:
...@@ -616,10 +608,6 @@ standard_ProcessUtility(Node *parsetree, ...@@ -616,10 +608,6 @@ standard_ProcessUtility(Node *parsetree,
AlterForeignDataWrapper((AlterFdwStmt *) parsetree); AlterForeignDataWrapper((AlterFdwStmt *) parsetree);
break; break;
case T_DropFdwStmt:
RemoveForeignDataWrapper((DropFdwStmt *) parsetree);
break;
case T_CreateForeignServerStmt: case T_CreateForeignServerStmt:
CreateForeignServer((CreateForeignServerStmt *) parsetree); CreateForeignServer((CreateForeignServerStmt *) parsetree);
break; break;
...@@ -628,10 +616,6 @@ standard_ProcessUtility(Node *parsetree, ...@@ -628,10 +616,6 @@ standard_ProcessUtility(Node *parsetree,
AlterForeignServer((AlterForeignServerStmt *) parsetree); AlterForeignServer((AlterForeignServerStmt *) parsetree);
break; break;
case T_DropForeignServerStmt:
RemoveForeignServer((DropForeignServerStmt *) parsetree);
break;
case T_CreateUserMappingStmt: case T_CreateUserMappingStmt:
CreateUserMapping((CreateUserMappingStmt *) parsetree); CreateUserMapping((CreateUserMappingStmt *) parsetree);
break; break;
...@@ -947,29 +931,6 @@ standard_ProcessUtility(Node *parsetree, ...@@ -947,29 +931,6 @@ standard_ProcessUtility(Node *parsetree,
AlterSequence((AlterSeqStmt *) parsetree); AlterSequence((AlterSeqStmt *) parsetree);
break; break;
case T_RemoveFuncStmt:
{
RemoveFuncStmt *stmt = (RemoveFuncStmt *) parsetree;
switch (stmt->kind)
{
case OBJECT_FUNCTION:
RemoveFunction(stmt);
break;
case OBJECT_AGGREGATE:
RemoveAggregate(stmt);
break;
case OBJECT_OPERATOR:
RemoveOperator(stmt);
break;
default:
elog(ERROR, "unrecognized object type: %d",
(int) stmt->kind);
break;
}
}
break;
case T_DoStmt: case T_DoStmt:
ExecuteDoStmt((DoStmt *) parsetree); ExecuteDoStmt((DoStmt *) parsetree);
break; break;
...@@ -1079,38 +1040,10 @@ standard_ProcessUtility(Node *parsetree, ...@@ -1079,38 +1040,10 @@ standard_ProcessUtility(Node *parsetree,
InvalidOid, InvalidOid, false); InvalidOid, InvalidOid, false);
break; break;
case T_DropPropertyStmt:
{
DropPropertyStmt *stmt = (DropPropertyStmt *) parsetree;
switch (stmt->removeType)
{
case OBJECT_RULE:
/* RemoveRewriteRule checks permissions */
RemoveRewriteRule(stmt->relation, stmt->property,
stmt->behavior, stmt->missing_ok);
break;
case OBJECT_TRIGGER:
/* DropTrigger checks permissions */
DropTrigger(stmt->relation, stmt->property,
stmt->behavior, stmt->missing_ok);
break;
default:
elog(ERROR, "unrecognized object type: %d",
(int) stmt->removeType);
break;
}
}
break;
case T_CreatePLangStmt: case T_CreatePLangStmt:
CreateProceduralLanguage((CreatePLangStmt *) parsetree); CreateProceduralLanguage((CreatePLangStmt *) parsetree);
break; break;
case T_DropPLangStmt:
DropProceduralLanguage((DropPLangStmt *) parsetree);
break;
/* /*
* ******************************** DOMAIN statements **** * ******************************** DOMAIN statements ****
*/ */
...@@ -1220,10 +1153,6 @@ standard_ProcessUtility(Node *parsetree, ...@@ -1220,10 +1153,6 @@ standard_ProcessUtility(Node *parsetree,
CreateCast((CreateCastStmt *) parsetree); CreateCast((CreateCastStmt *) parsetree);
break; break;
case T_DropCastStmt:
DropCast((DropCastStmt *) parsetree);
break;
case T_CreateOpClassStmt: case T_CreateOpClassStmt:
DefineOpClass((CreateOpClassStmt *) parsetree); DefineOpClass((CreateOpClassStmt *) parsetree);
break; break;
...@@ -1236,14 +1165,6 @@ standard_ProcessUtility(Node *parsetree, ...@@ -1236,14 +1165,6 @@ standard_ProcessUtility(Node *parsetree,
AlterOpFamily((AlterOpFamilyStmt *) parsetree); AlterOpFamily((AlterOpFamilyStmt *) parsetree);
break; break;
case T_RemoveOpClassStmt:
RemoveOpClass((RemoveOpClassStmt *) parsetree);
break;
case T_RemoveOpFamilyStmt:
RemoveOpFamily((RemoveOpFamilyStmt *) parsetree);
break;
case T_AlterTSDictionaryStmt: case T_AlterTSDictionaryStmt:
AlterTSDictionary((AlterTSDictionaryStmt *) parsetree); AlterTSDictionary((AlterTSDictionaryStmt *) parsetree);
break; break;
...@@ -1674,10 +1595,6 @@ CreateCommandTag(Node *parsetree) ...@@ -1674,10 +1595,6 @@ CreateCommandTag(Node *parsetree)
tag = "ALTER FOREIGN DATA WRAPPER"; tag = "ALTER FOREIGN DATA WRAPPER";
break; break;
case T_DropFdwStmt:
tag = "DROP FOREIGN DATA WRAPPER";
break;
case T_CreateForeignServerStmt: case T_CreateForeignServerStmt:
tag = "CREATE SERVER"; tag = "CREATE SERVER";
break; break;
...@@ -1686,10 +1603,6 @@ CreateCommandTag(Node *parsetree) ...@@ -1686,10 +1603,6 @@ CreateCommandTag(Node *parsetree)
tag = "ALTER SERVER"; tag = "ALTER SERVER";
break; break;
case T_DropForeignServerStmt:
tag = "DROP SERVER";
break;
case T_CreateUserMappingStmt: case T_CreateUserMappingStmt:
tag = "CREATE USER MAPPING"; tag = "CREATE USER MAPPING";
break; break;
...@@ -1754,6 +1667,39 @@ CreateCommandTag(Node *parsetree) ...@@ -1754,6 +1667,39 @@ CreateCommandTag(Node *parsetree)
case OBJECT_EXTENSION: case OBJECT_EXTENSION:
tag = "DROP EXTENSION"; tag = "DROP EXTENSION";
break; break;
case OBJECT_FUNCTION:
tag = "DROP FUNCTION";
break;
case OBJECT_AGGREGATE:
tag = "DROP AGGREGATE";
break;
case OBJECT_OPERATOR:
tag = "DROP OPERATOR";
break;
case OBJECT_LANGUAGE:
tag = "DROP LANGUAGE";
break;
case OBJECT_CAST:
tag = "DROP CAST";
break;
case OBJECT_TRIGGER:
tag = "DROP TRIGGER";
break;
case OBJECT_RULE:
tag = "DROP RULE";
break;
case OBJECT_FDW:
tag = "DROP FOREIGN DATA WRAPPER";
break;
case OBJECT_FOREIGN_SERVER:
tag = "DROP SERVER";
break;
case OBJECT_OPCLASS:
tag = "DROP OPERATOR CLASS";
break;
case OBJECT_OPFAMILY:
tag = "DROP OPERATOR FAMILY";
break;
default: default:
tag = "???"; tag = "???";
} }
...@@ -1891,23 +1837,6 @@ CreateCommandTag(Node *parsetree) ...@@ -1891,23 +1837,6 @@ CreateCommandTag(Node *parsetree)
tag = "ALTER SEQUENCE"; tag = "ALTER SEQUENCE";
break; break;
case T_RemoveFuncStmt:
switch (((RemoveFuncStmt *) parsetree)->kind)
{
case OBJECT_FUNCTION:
tag = "DROP FUNCTION";
break;
case OBJECT_AGGREGATE:
tag = "DROP AGGREGATE";
break;
case OBJECT_OPERATOR:
tag = "DROP OPERATOR";
break;
default:
tag = "???";
}
break;
case T_DoStmt: case T_DoStmt:
tag = "DO"; tag = "DO";
break; break;
...@@ -2002,28 +1931,10 @@ CreateCommandTag(Node *parsetree) ...@@ -2002,28 +1931,10 @@ CreateCommandTag(Node *parsetree)
tag = "CREATE TRIGGER"; tag = "CREATE TRIGGER";
break; break;
case T_DropPropertyStmt:
switch (((DropPropertyStmt *) parsetree)->removeType)
{
case OBJECT_TRIGGER:
tag = "DROP TRIGGER";
break;
case OBJECT_RULE:
tag = "DROP RULE";
break;
default:
tag = "???";
}
break;
case T_CreatePLangStmt: case T_CreatePLangStmt:
tag = "CREATE LANGUAGE"; tag = "CREATE LANGUAGE";
break; break;
case T_DropPLangStmt:
tag = "DROP LANGUAGE";
break;
case T_CreateRoleStmt: case T_CreateRoleStmt:
tag = "CREATE ROLE"; tag = "CREATE ROLE";
break; break;
...@@ -2072,10 +1983,6 @@ CreateCommandTag(Node *parsetree) ...@@ -2072,10 +1983,6 @@ CreateCommandTag(Node *parsetree)
tag = "CREATE CAST"; tag = "CREATE CAST";
break; break;
case T_DropCastStmt:
tag = "DROP CAST";
break;
case T_CreateOpClassStmt: case T_CreateOpClassStmt:
tag = "CREATE OPERATOR CLASS"; tag = "CREATE OPERATOR CLASS";
break; break;
...@@ -2088,14 +1995,6 @@ CreateCommandTag(Node *parsetree) ...@@ -2088,14 +1995,6 @@ CreateCommandTag(Node *parsetree)
tag = "ALTER OPERATOR FAMILY"; tag = "ALTER OPERATOR FAMILY";
break; break;
case T_RemoveOpClassStmt:
tag = "DROP OPERATOR CLASS";
break;
case T_RemoveOpFamilyStmt:
tag = "DROP OPERATOR FAMILY";
break;
case T_AlterTSDictionaryStmt: case T_AlterTSDictionaryStmt:
tag = "ALTER TEXT SEARCH DICTIONARY"; tag = "ALTER TEXT SEARCH DICTIONARY";
break; break;
...@@ -2306,10 +2205,8 @@ GetCommandLogLevel(Node *parsetree) ...@@ -2306,10 +2205,8 @@ GetCommandLogLevel(Node *parsetree)
case T_CreateFdwStmt: case T_CreateFdwStmt:
case T_AlterFdwStmt: case T_AlterFdwStmt:
case T_DropFdwStmt:
case T_CreateForeignServerStmt: case T_CreateForeignServerStmt:
case T_AlterForeignServerStmt: case T_AlterForeignServerStmt:
case T_DropForeignServerStmt:
case T_CreateUserMappingStmt: case T_CreateUserMappingStmt:
case T_AlterUserMappingStmt: case T_AlterUserMappingStmt:
case T_DropUserMappingStmt: case T_DropUserMappingStmt:
...@@ -2446,10 +2343,6 @@ GetCommandLogLevel(Node *parsetree) ...@@ -2446,10 +2343,6 @@ GetCommandLogLevel(Node *parsetree)
lev = LOGSTMT_DDL; lev = LOGSTMT_DDL;
break; break;
case T_RemoveFuncStmt:
lev = LOGSTMT_DDL;
break;
case T_DoStmt: case T_DoStmt:
lev = LOGSTMT_ALL; lev = LOGSTMT_ALL;
break; break;
...@@ -2533,18 +2426,10 @@ GetCommandLogLevel(Node *parsetree) ...@@ -2533,18 +2426,10 @@ GetCommandLogLevel(Node *parsetree)
lev = LOGSTMT_DDL; lev = LOGSTMT_DDL;
break; break;
case T_DropPropertyStmt:
lev = LOGSTMT_DDL;
break;
case T_CreatePLangStmt: case T_CreatePLangStmt:
lev = LOGSTMT_DDL; lev = LOGSTMT_DDL;
break; break;
case T_DropPLangStmt:
lev = LOGSTMT_DDL;
break;
case T_CreateDomainStmt: case T_CreateDomainStmt:
lev = LOGSTMT_DDL; lev = LOGSTMT_DDL;
break; break;
...@@ -2597,10 +2482,6 @@ GetCommandLogLevel(Node *parsetree) ...@@ -2597,10 +2482,6 @@ GetCommandLogLevel(Node *parsetree)
lev = LOGSTMT_DDL; lev = LOGSTMT_DDL;
break; break;
case T_DropCastStmt:
lev = LOGSTMT_DDL;
break;
case T_CreateOpClassStmt: case T_CreateOpClassStmt:
lev = LOGSTMT_DDL; lev = LOGSTMT_DDL;
break; break;
...@@ -2613,14 +2494,6 @@ GetCommandLogLevel(Node *parsetree) ...@@ -2613,14 +2494,6 @@ GetCommandLogLevel(Node *parsetree)
lev = LOGSTMT_DDL; lev = LOGSTMT_DDL;
break; break;
case T_RemoveOpClassStmt:
lev = LOGSTMT_DDL;
break;
case T_RemoveOpFamilyStmt:
lev = LOGSTMT_DDL;
break;
case T_AlterTSDictionaryStmt: case T_AlterTSDictionaryStmt:
lev = LOGSTMT_DDL; lev = LOGSTMT_DDL;
break; break;
......
...@@ -61,7 +61,6 @@ extern Oid GetDefaultOpClass(Oid type_id, Oid am_id); ...@@ -61,7 +61,6 @@ extern Oid GetDefaultOpClass(Oid type_id, Oid am_id);
/* commands/functioncmds.c */ /* commands/functioncmds.c */
extern void CreateFunction(CreateFunctionStmt *stmt, const char *queryString); extern void CreateFunction(CreateFunctionStmt *stmt, const char *queryString);
extern void RemoveFunction(RemoveFuncStmt *stmt);
extern void RemoveFunctionById(Oid funcOid); extern void RemoveFunctionById(Oid funcOid);
extern void SetFunctionReturnType(Oid funcOid, Oid newRetType); extern void SetFunctionReturnType(Oid funcOid, Oid newRetType);
extern void SetFunctionArgType(Oid funcOid, int argIndex, Oid newArgType); extern void SetFunctionArgType(Oid funcOid, int argIndex, Oid newArgType);
...@@ -70,7 +69,6 @@ extern void AlterFunctionOwner(List *name, List *argtypes, Oid newOwnerId); ...@@ -70,7 +69,6 @@ extern void AlterFunctionOwner(List *name, List *argtypes, Oid newOwnerId);
extern void AlterFunctionOwner_oid(Oid procOid, Oid newOwnerId); extern void AlterFunctionOwner_oid(Oid procOid, Oid newOwnerId);
extern void AlterFunction(AlterFunctionStmt *stmt); extern void AlterFunction(AlterFunctionStmt *stmt);
extern void CreateCast(CreateCastStmt *stmt); extern void CreateCast(CreateCastStmt *stmt);
extern void DropCast(DropCastStmt *stmt);
extern void DropCastById(Oid castOid); extern void DropCastById(Oid castOid);
extern void AlterFunctionNamespace(List *name, List *argtypes, bool isagg, extern void AlterFunctionNamespace(List *name, List *argtypes, bool isagg,
const char *newschema); const char *newschema);
...@@ -80,7 +78,6 @@ extern Oid get_cast_oid(Oid sourcetypeid, Oid targettypeid, bool missing_ok); ...@@ -80,7 +78,6 @@ extern Oid get_cast_oid(Oid sourcetypeid, Oid targettypeid, bool missing_ok);
/* commands/operatorcmds.c */ /* commands/operatorcmds.c */
extern void DefineOperator(List *names, List *parameters); extern void DefineOperator(List *names, List *parameters);
extern void RemoveOperator(RemoveFuncStmt *stmt);
extern void RemoveOperatorById(Oid operOid); extern void RemoveOperatorById(Oid operOid);
extern void AlterOperatorOwner(List *name, TypeName *typeName1, extern void AlterOperatorOwner(List *name, TypeName *typeName1,
TypeName *typename2, Oid newOwnerId); TypeName *typename2, Oid newOwnerId);
...@@ -91,7 +88,6 @@ extern Oid AlterOperatorNamespace_oid(Oid operOid, Oid newNspOid); ...@@ -91,7 +88,6 @@ extern Oid AlterOperatorNamespace_oid(Oid operOid, Oid newNspOid);
/* commands/aggregatecmds.c */ /* commands/aggregatecmds.c */
extern void DefineAggregate(List *name, List *args, bool oldstyle, extern void DefineAggregate(List *name, List *args, bool oldstyle,
List *parameters); List *parameters);
extern void RemoveAggregate(RemoveFuncStmt *stmt);
extern void RenameAggregate(List *name, List *args, const char *newname); extern void RenameAggregate(List *name, List *args, const char *newname);
extern void AlterAggregateOwner(List *name, List *args, Oid newOwnerId); extern void AlterAggregateOwner(List *name, List *args, Oid newOwnerId);
...@@ -99,8 +95,6 @@ extern void AlterAggregateOwner(List *name, List *args, Oid newOwnerId); ...@@ -99,8 +95,6 @@ extern void AlterAggregateOwner(List *name, List *args, Oid newOwnerId);
extern void DefineOpClass(CreateOpClassStmt *stmt); extern void DefineOpClass(CreateOpClassStmt *stmt);
extern void DefineOpFamily(CreateOpFamilyStmt *stmt); extern void DefineOpFamily(CreateOpFamilyStmt *stmt);
extern void AlterOpFamily(AlterOpFamilyStmt *stmt); extern void AlterOpFamily(AlterOpFamilyStmt *stmt);
extern void RemoveOpClass(RemoveOpClassStmt *stmt);
extern void RemoveOpFamily(RemoveOpFamilyStmt *stmt);
extern void RemoveOpClassById(Oid opclassOid); extern void RemoveOpClassById(Oid opclassOid);
extern void RemoveOpFamilyById(Oid opfamilyOid); extern void RemoveOpFamilyById(Oid opfamilyOid);
extern void RemoveAmOpEntryById(Oid entryOid); extern void RemoveAmOpEntryById(Oid entryOid);
...@@ -156,11 +150,9 @@ extern void AlterForeignServerOwner(const char *name, Oid newOwnerId); ...@@ -156,11 +150,9 @@ extern void AlterForeignServerOwner(const char *name, Oid newOwnerId);
extern void AlterForeignDataWrapperOwner(const char *name, Oid newOwnerId); extern void AlterForeignDataWrapperOwner(const char *name, Oid newOwnerId);
extern void CreateForeignDataWrapper(CreateFdwStmt *stmt); extern void CreateForeignDataWrapper(CreateFdwStmt *stmt);
extern void AlterForeignDataWrapper(AlterFdwStmt *stmt); extern void AlterForeignDataWrapper(AlterFdwStmt *stmt);
extern void RemoveForeignDataWrapper(DropFdwStmt *stmt);
extern void RemoveForeignDataWrapperById(Oid fdwId); extern void RemoveForeignDataWrapperById(Oid fdwId);
extern void CreateForeignServer(CreateForeignServerStmt *stmt); extern void CreateForeignServer(CreateForeignServerStmt *stmt);
extern void AlterForeignServer(AlterForeignServerStmt *stmt); extern void AlterForeignServer(AlterForeignServerStmt *stmt);
extern void RemoveForeignServer(DropForeignServerStmt *stmt);
extern void RemoveForeignServerById(Oid srvId); extern void RemoveForeignServerById(Oid srvId);
extern void CreateUserMapping(CreateUserMappingStmt *stmt); extern void CreateUserMapping(CreateUserMappingStmt *stmt);
extern void AlterUserMapping(AlterUserMappingStmt *stmt); extern void AlterUserMapping(AlterUserMappingStmt *stmt);
......
...@@ -15,7 +15,6 @@ ...@@ -15,7 +15,6 @@
#include "nodes/parsenodes.h" #include "nodes/parsenodes.h"
extern void CreateProceduralLanguage(CreatePLangStmt *stmt); extern void CreateProceduralLanguage(CreatePLangStmt *stmt);
extern void DropProceduralLanguage(DropPLangStmt *stmt);
extern void DropProceduralLanguageById(Oid langOid); extern void DropProceduralLanguageById(Oid langOid);
extern void RenameLanguage(const char *oldname, const char *newname); extern void RenameLanguage(const char *oldname, const char *newname);
extern void AlterLanguageOwner(const char *name, Oid newOwnerId); extern void AlterLanguageOwner(const char *name, Oid newOwnerId);
......
...@@ -112,8 +112,6 @@ extern Oid CreateTrigger(CreateTrigStmt *stmt, const char *queryString, ...@@ -112,8 +112,6 @@ extern Oid CreateTrigger(CreateTrigStmt *stmt, const char *queryString,
Oid constraintOid, Oid indexOid, Oid constraintOid, Oid indexOid,
bool isInternal); bool isInternal);
extern void DropTrigger(RangeVar *relation, const char *trigname,
DropBehavior behavior, bool missing_ok);
extern void RemoveTriggerById(Oid trigOid); extern void RemoveTriggerById(Oid trigOid);
extern Oid get_trigger_oid(Oid relid, const char *name, bool missing_ok); extern Oid get_trigger_oid(Oid relid, const char *name, bool missing_ok);
......
...@@ -291,7 +291,6 @@ typedef enum NodeTag ...@@ -291,7 +291,6 @@ typedef enum NodeTag
T_IndexStmt, T_IndexStmt,
T_CreateFunctionStmt, T_CreateFunctionStmt,
T_AlterFunctionStmt, T_AlterFunctionStmt,
T_RemoveFuncStmt,
T_DoStmt, T_DoStmt,
T_RenameStmt, T_RenameStmt,
T_RuleStmt, T_RuleStmt,
...@@ -312,9 +311,7 @@ typedef enum NodeTag ...@@ -312,9 +311,7 @@ typedef enum NodeTag
T_VariableShowStmt, T_VariableShowStmt,
T_DiscardStmt, T_DiscardStmt,
T_CreateTrigStmt, T_CreateTrigStmt,
T_DropPropertyStmt,
T_CreatePLangStmt, T_CreatePLangStmt,
T_DropPLangStmt,
T_CreateRoleStmt, T_CreateRoleStmt,
T_AlterRoleStmt, T_AlterRoleStmt,
T_DropRoleStmt, T_DropRoleStmt,
...@@ -328,12 +325,9 @@ typedef enum NodeTag ...@@ -328,12 +325,9 @@ typedef enum NodeTag
T_AlterRoleSetStmt, T_AlterRoleSetStmt,
T_CreateConversionStmt, T_CreateConversionStmt,
T_CreateCastStmt, T_CreateCastStmt,
T_DropCastStmt,
T_CreateOpClassStmt, T_CreateOpClassStmt,
T_CreateOpFamilyStmt, T_CreateOpFamilyStmt,
T_AlterOpFamilyStmt, T_AlterOpFamilyStmt,
T_RemoveOpClassStmt,
T_RemoveOpFamilyStmt,
T_PrepareStmt, T_PrepareStmt,
T_ExecuteStmt, T_ExecuteStmt,
T_DeallocateStmt, T_DeallocateStmt,
...@@ -352,10 +346,8 @@ typedef enum NodeTag ...@@ -352,10 +346,8 @@ typedef enum NodeTag
T_AlterTSConfigurationStmt, T_AlterTSConfigurationStmt,
T_CreateFdwStmt, T_CreateFdwStmt,
T_AlterFdwStmt, T_AlterFdwStmt,
T_DropFdwStmt,
T_CreateForeignServerStmt, T_CreateForeignServerStmt,
T_AlterForeignServerStmt, T_AlterForeignServerStmt,
T_DropForeignServerStmt,
T_CreateUserMappingStmt, T_CreateUserMappingStmt,
T_AlterUserMappingStmt, T_AlterUserMappingStmt,
T_DropUserMappingStmt, T_DropUserMappingStmt,
......
...@@ -1612,7 +1612,7 @@ typedef struct AlterExtensionContentsStmt ...@@ -1612,7 +1612,7 @@ typedef struct AlterExtensionContentsStmt
} AlterExtensionContentsStmt; } AlterExtensionContentsStmt;
/* ---------------------- /* ----------------------
* Create/Drop FOREIGN DATA WRAPPER Statements * Create/Alter FOREIGN DATA WRAPPER Statements
* ---------------------- * ----------------------
*/ */
...@@ -1632,16 +1632,8 @@ typedef struct AlterFdwStmt ...@@ -1632,16 +1632,8 @@ typedef struct AlterFdwStmt
List *options; /* generic options to FDW */ List *options; /* generic options to FDW */
} AlterFdwStmt; } AlterFdwStmt;
typedef struct DropFdwStmt
{
NodeTag type;
char *fdwname; /* foreign-data wrapper name */
bool missing_ok; /* don't complain if missing */
DropBehavior behavior; /* drop behavior - cascade/restrict */
} DropFdwStmt;
/* ---------------------- /* ----------------------
* Create/Drop FOREIGN SERVER Statements * Create/Alter FOREIGN SERVER Statements
* ---------------------- * ----------------------
*/ */
...@@ -1664,14 +1656,6 @@ typedef struct AlterForeignServerStmt ...@@ -1664,14 +1656,6 @@ typedef struct AlterForeignServerStmt
bool has_version; /* version specified */ bool has_version; /* version specified */
} AlterForeignServerStmt; } AlterForeignServerStmt;
typedef struct DropForeignServerStmt
{
NodeTag type;
char *servername; /* server name */
bool missing_ok; /* ignore missing servers */
DropBehavior behavior; /* drop behavior - cascade/restrict */
} DropForeignServerStmt;
/* ---------------------- /* ----------------------
* Create FOREIGN TABLE Statements * Create FOREIGN TABLE Statements
* ---------------------- * ----------------------
...@@ -1739,7 +1723,7 @@ typedef struct CreateTrigStmt ...@@ -1739,7 +1723,7 @@ typedef struct CreateTrigStmt
} CreateTrigStmt; } CreateTrigStmt;
/* ---------------------- /* ----------------------
* Create/Drop PROCEDURAL LANGUAGE Statements * Create PROCEDURAL LANGUAGE Statements
* ---------------------- * ----------------------
*/ */
typedef struct CreatePLangStmt typedef struct CreatePLangStmt
...@@ -1753,14 +1737,6 @@ typedef struct CreatePLangStmt ...@@ -1753,14 +1737,6 @@ typedef struct CreatePLangStmt
bool pltrusted; /* PL is trusted */ bool pltrusted; /* PL is trusted */
} CreatePLangStmt; } CreatePLangStmt;
typedef struct DropPLangStmt
{
NodeTag type;
char *plname; /* PL name */
DropBehavior behavior; /* RESTRICT or CASCADE behavior */
bool missing_ok; /* skip error if missing? */
} DropPLangStmt;
/* ---------------------- /* ----------------------
* Create/Alter/Drop Role Statements * Create/Alter/Drop Role Statements
* *
...@@ -1921,29 +1897,12 @@ typedef struct DropStmt ...@@ -1921,29 +1897,12 @@ typedef struct DropStmt
{ {
NodeTag type; NodeTag type;
List *objects; /* list of sublists of names (as Values) */ List *objects; /* list of sublists of names (as Values) */
List *arguments; /* list of sublists of arguments (as Values) */
ObjectType removeType; /* object type */ ObjectType removeType; /* object type */
DropBehavior behavior; /* RESTRICT or CASCADE behavior */ DropBehavior behavior; /* RESTRICT or CASCADE behavior */
bool missing_ok; /* skip error if object is missing? */ bool missing_ok; /* skip error if object is missing? */
} DropStmt; } DropStmt;
/* ----------------------
* Drop Rule|Trigger Statement
*
* In general this may be used for dropping any property of a relation;
* for example, someday soon we may have DROP ATTRIBUTE.
* ----------------------
*/
typedef struct DropPropertyStmt
{
NodeTag type;
RangeVar *relation; /* owning relation */
char *property; /* name of rule, trigger, etc */
ObjectType removeType; /* OBJECT_RULE or OBJECT_TRIGGER */
DropBehavior behavior; /* RESTRICT or CASCADE behavior */
bool missing_ok; /* skip error if missing? */
} DropPropertyStmt;
/* ---------------------- /* ----------------------
* Truncate Table Statement * Truncate Table Statement
* ---------------------- * ----------------------
...@@ -2117,20 +2076,6 @@ typedef struct AlterFunctionStmt ...@@ -2117,20 +2076,6 @@ typedef struct AlterFunctionStmt
List *actions; /* list of DefElem */ List *actions; /* list of DefElem */
} AlterFunctionStmt; } AlterFunctionStmt;
/* ----------------------
* Drop {Function|Aggregate|Operator} Statement
* ----------------------
*/
typedef struct RemoveFuncStmt
{
NodeTag type;
ObjectType kind; /* function, aggregate, operator */
List *name; /* qualified name of object to drop */
List *args; /* types of the arguments */
DropBehavior behavior; /* RESTRICT or CASCADE behavior */
bool missing_ok; /* skip error if missing? */
} RemoveFuncStmt;
/* ---------------------- /* ----------------------
* DO Statement * DO Statement
* *
...@@ -2151,32 +2096,6 @@ typedef struct InlineCodeBlock ...@@ -2151,32 +2096,6 @@ typedef struct InlineCodeBlock
bool langIsTrusted; /* trusted property of the language */ bool langIsTrusted; /* trusted property of the language */
} InlineCodeBlock; } InlineCodeBlock;
/* ----------------------
* Drop Operator Class Statement
* ----------------------
*/
typedef struct RemoveOpClassStmt
{
NodeTag type;
List *opclassname; /* qualified name (list of Value strings) */
char *amname; /* name of index AM opclass is for */
DropBehavior behavior; /* RESTRICT or CASCADE behavior */
bool missing_ok; /* skip error if missing? */
} RemoveOpClassStmt;
/* ----------------------
* Drop Operator Family Statement
* ----------------------
*/
typedef struct RemoveOpFamilyStmt
{
NodeTag type;
List *opfamilyname; /* qualified name (list of Value strings) */
char *amname; /* name of index AM opfamily is for */
DropBehavior behavior; /* RESTRICT or CASCADE behavior */
bool missing_ok; /* skip error if missing? */
} RemoveOpFamilyStmt;
/* ---------------------- /* ----------------------
* Alter Object Rename Statement * Alter Object Rename Statement
* ---------------------- * ----------------------
...@@ -2557,20 +2476,6 @@ typedef struct CreateCastStmt ...@@ -2557,20 +2476,6 @@ typedef struct CreateCastStmt
bool inout; bool inout;
} CreateCastStmt; } CreateCastStmt;
/* ----------------------
* DROP CAST Statement
* ----------------------
*/
typedef struct DropCastStmt
{
NodeTag type;
TypeName *sourcetype;
TypeName *targettype;
DropBehavior behavior;
bool missing_ok; /* skip error if missing? */
} DropCastStmt;
/* ---------------------- /* ----------------------
* PREPARE Statement * PREPARE Statement
* ---------------------- * ----------------------
......
...@@ -16,9 +16,6 @@ ...@@ -16,9 +16,6 @@
#include "nodes/parsenodes.h" #include "nodes/parsenodes.h"
extern void RemoveRewriteRule(RangeVar *relation, const char *ruleName,
DropBehavior behavior, bool missing_ok);
extern void RemoveRewriteRuleById(Oid ruleOid); extern void RemoveRewriteRuleById(Oid ruleOid);
#endif /* REWRITEREMOVE_H */ #endif /* REWRITEREMOVE_H */
...@@ -195,13 +195,8 @@ DROP ROLE regress_test_role_super; -- ERROR ...@@ -195,13 +195,8 @@ DROP ROLE regress_test_role_super; -- ERROR
ERROR: role "regress_test_role_super" cannot be dropped because some objects depend on it ERROR: role "regress_test_role_super" cannot be dropped because some objects depend on it
DETAIL: owner of foreign-data wrapper foo DETAIL: owner of foreign-data wrapper foo
SET ROLE regress_test_role_super; SET ROLE regress_test_role_super;
DROP FOREIGN DATA WRAPPER foo; -- ERROR
ERROR: permission denied to drop foreign-data wrapper "foo"
HINT: Must be superuser to drop a foreign-data wrapper.
RESET ROLE;
ALTER ROLE regress_test_role_super SUPERUSER;
DROP FOREIGN DATA WRAPPER foo; DROP FOREIGN DATA WRAPPER foo;
DROP ROLE regress_test_role_super; RESET ROLE;
\dew+ \dew+
List of foreign-data wrappers List of foreign-data wrappers
Name | Owner | Handler | Validator | Access privileges | FDW Options | Description Name | Owner | Handler | Validator | Access privileges | FDW Options | Description
...@@ -244,8 +239,7 @@ user mapping for foreign_data_user depends on server s1 ...@@ -244,8 +239,7 @@ user mapping for foreign_data_user depends on server s1
HINT: Use DROP ... CASCADE to drop the dependent objects too. HINT: Use DROP ... CASCADE to drop the dependent objects too.
SET ROLE regress_test_role; SET ROLE regress_test_role;
DROP FOREIGN DATA WRAPPER foo CASCADE; -- ERROR DROP FOREIGN DATA WRAPPER foo CASCADE; -- ERROR
ERROR: permission denied to drop foreign-data wrapper "foo" ERROR: must be owner of foreign-data wrapper foo
HINT: Must be superuser to drop a foreign-data wrapper.
RESET ROLE; RESET ROLE;
DROP FOREIGN DATA WRAPPER foo CASCADE; DROP FOREIGN DATA WRAPPER foo CASCADE;
NOTICE: drop cascades to 2 other objects NOTICE: drop cascades to 2 other objects
...@@ -1009,8 +1003,7 @@ ALTER FOREIGN DATA WRAPPER foo OWNER TO unprivileged_role; -- ERROR ...@@ -1009,8 +1003,7 @@ ALTER FOREIGN DATA WRAPPER foo OWNER TO unprivileged_role; -- ERROR
ERROR: permission denied to change owner of foreign-data wrapper "foo" ERROR: permission denied to change owner of foreign-data wrapper "foo"
HINT: Must be superuser to change owner of a foreign-data wrapper. HINT: Must be superuser to change owner of a foreign-data wrapper.
DROP FOREIGN DATA WRAPPER foo; -- ERROR DROP FOREIGN DATA WRAPPER foo; -- ERROR
ERROR: permission denied to drop foreign-data wrapper "foo" ERROR: must be owner of foreign-data wrapper foo
HINT: Must be superuser to drop a foreign-data wrapper.
GRANT USAGE ON FOREIGN DATA WRAPPER foo TO regress_test_role; -- ERROR GRANT USAGE ON FOREIGN DATA WRAPPER foo TO regress_test_role; -- ERROR
ERROR: permission denied for foreign-data wrapper foo ERROR: permission denied for foreign-data wrapper foo
CREATE SERVER s9 FOREIGN DATA WRAPPER foo; -- ERROR CREATE SERVER s9 FOREIGN DATA WRAPPER foo; -- ERROR
...@@ -1040,8 +1033,7 @@ ALTER FOREIGN DATA WRAPPER foo OPTIONS (gotcha 'true'); -- ERROR ...@@ -1040,8 +1033,7 @@ ALTER FOREIGN DATA WRAPPER foo OPTIONS (gotcha 'true'); -- ERROR
ERROR: permission denied to alter foreign-data wrapper "foo" ERROR: permission denied to alter foreign-data wrapper "foo"
HINT: Must be superuser to alter a foreign-data wrapper. HINT: Must be superuser to alter a foreign-data wrapper.
DROP FOREIGN DATA WRAPPER foo; -- ERROR DROP FOREIGN DATA WRAPPER foo; -- ERROR
ERROR: permission denied to drop foreign-data wrapper "foo" ERROR: must be owner of foreign-data wrapper foo
HINT: Must be superuser to drop a foreign-data wrapper.
GRANT USAGE ON FOREIGN DATA WRAPPER postgresql TO regress_test_role; -- WARNING GRANT USAGE ON FOREIGN DATA WRAPPER postgresql TO regress_test_role; -- WARNING
WARNING: no privileges were granted for "postgresql" WARNING: no privileges were granted for "postgresql"
GRANT USAGE ON FOREIGN DATA WRAPPER foo TO regress_test_role; GRANT USAGE ON FOREIGN DATA WRAPPER foo TO regress_test_role;
......
...@@ -91,11 +91,8 @@ DROP FOREIGN DATA WRAPPER IF EXISTS nonexistent; ...@@ -91,11 +91,8 @@ DROP FOREIGN DATA WRAPPER IF EXISTS nonexistent;
DROP ROLE regress_test_role_super; -- ERROR DROP ROLE regress_test_role_super; -- ERROR
SET ROLE regress_test_role_super; SET ROLE regress_test_role_super;
DROP FOREIGN DATA WRAPPER foo; -- ERROR
RESET ROLE;
ALTER ROLE regress_test_role_super SUPERUSER;
DROP FOREIGN DATA WRAPPER foo; DROP FOREIGN DATA WRAPPER foo;
DROP ROLE regress_test_role_super; RESET ROLE;
\dew+ \dew+
CREATE FOREIGN DATA WRAPPER foo; CREATE FOREIGN DATA WRAPPER foo;
......
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