Commit 55c3391d authored by Tom Lane's avatar Tom Lane

Be pickier about converting between Name and Datum.

We were misapplying NameGetDatum() to plain C strings in some places.
This worked, because it was just a pointer cast anyway, but it's a type
cheat in some sense.  Use CStringGetDatum instead, and modify the
NameGetDatum macro so it won't compile if applied to something that's
not a pointer to NameData.  This should result in no changes to
generated code, but it is logically cleaner.

Mark Dilger, tweaked a bit by me

Discussion: <EFD8AC94-4C1F-40C1-A5EA-304080089C1B@gmail.com>
parent fdc79e19
...@@ -1260,7 +1260,7 @@ movedb(const char *dbname, const char *tblspcname) ...@@ -1260,7 +1260,7 @@ movedb(const char *dbname, const char *tblspcname)
ScanKeyInit(&scankey, ScanKeyInit(&scankey,
Anum_pg_database_datname, Anum_pg_database_datname,
BTEqualStrategyNumber, F_NAMEEQ, BTEqualStrategyNumber, F_NAMEEQ,
NameGetDatum(dbname)); CStringGetDatum(dbname));
sysscan = systable_beginscan(pgdbrel, DatabaseNameIndexId, true, sysscan = systable_beginscan(pgdbrel, DatabaseNameIndexId, true,
NULL, 1, &scankey); NULL, 1, &scankey);
oldtuple = systable_getnext(sysscan); oldtuple = systable_getnext(sysscan);
...@@ -1486,7 +1486,7 @@ AlterDatabase(ParseState *pstate, AlterDatabaseStmt *stmt, bool isTopLevel) ...@@ -1486,7 +1486,7 @@ AlterDatabase(ParseState *pstate, AlterDatabaseStmt *stmt, bool isTopLevel)
ScanKeyInit(&scankey, ScanKeyInit(&scankey,
Anum_pg_database_datname, Anum_pg_database_datname,
BTEqualStrategyNumber, F_NAMEEQ, BTEqualStrategyNumber, F_NAMEEQ,
NameGetDatum(stmt->dbname)); CStringGetDatum(stmt->dbname));
scan = systable_beginscan(rel, DatabaseNameIndexId, true, scan = systable_beginscan(rel, DatabaseNameIndexId, true,
NULL, 1, &scankey); NULL, 1, &scankey);
tuple = systable_getnext(scan); tuple = systable_getnext(scan);
...@@ -1603,7 +1603,7 @@ AlterDatabaseOwner(const char *dbname, Oid newOwnerId) ...@@ -1603,7 +1603,7 @@ AlterDatabaseOwner(const char *dbname, Oid newOwnerId)
ScanKeyInit(&scankey, ScanKeyInit(&scankey,
Anum_pg_database_datname, Anum_pg_database_datname,
BTEqualStrategyNumber, F_NAMEEQ, BTEqualStrategyNumber, F_NAMEEQ,
NameGetDatum(dbname)); CStringGetDatum(dbname));
scan = systable_beginscan(rel, DatabaseNameIndexId, true, scan = systable_beginscan(rel, DatabaseNameIndexId, true,
NULL, 1, &scankey); NULL, 1, &scankey);
tuple = systable_getnext(scan); tuple = systable_getnext(scan);
...@@ -1743,7 +1743,7 @@ get_db_info(const char *name, LOCKMODE lockmode, ...@@ -1743,7 +1743,7 @@ get_db_info(const char *name, LOCKMODE lockmode,
ScanKeyInit(&scanKey, ScanKeyInit(&scanKey,
Anum_pg_database_datname, Anum_pg_database_datname,
BTEqualStrategyNumber, F_NAMEEQ, BTEqualStrategyNumber, F_NAMEEQ,
NameGetDatum(name)); CStringGetDatum(name));
scan = systable_beginscan(relation, DatabaseNameIndexId, true, scan = systable_beginscan(relation, DatabaseNameIndexId, true,
NULL, 1, &scanKey); NULL, 1, &scanKey);
......
...@@ -463,7 +463,7 @@ find_language_template(const char *languageName) ...@@ -463,7 +463,7 @@ find_language_template(const char *languageName)
ScanKeyInit(&key, ScanKeyInit(&key,
Anum_pg_pltemplate_tmplname, Anum_pg_pltemplate_tmplname,
BTEqualStrategyNumber, F_NAMEEQ, BTEqualStrategyNumber, F_NAMEEQ,
NameGetDatum(languageName)); CStringGetDatum(languageName));
scan = systable_beginscan(rel, PLTemplateNameIndexId, true, scan = systable_beginscan(rel, PLTemplateNameIndexId, true,
NULL, 1, &key); NULL, 1, &key);
......
...@@ -3503,7 +3503,7 @@ AlterTypeNamespaceInternal(Oid typeOid, Oid nspOid, ...@@ -3503,7 +3503,7 @@ AlterTypeNamespaceInternal(Oid typeOid, Oid nspOid,
/* check for duplicate name (more friendly than unique-index failure) */ /* check for duplicate name (more friendly than unique-index failure) */
if (SearchSysCacheExists2(TYPENAMENSP, if (SearchSysCacheExists2(TYPENAMENSP,
CStringGetDatum(NameStr(typform->typname)), NameGetDatum(&typform->typname),
ObjectIdGetDatum(nspOid))) ObjectIdGetDatum(nspOid)))
ereport(ERROR, ereport(ERROR,
(errcode(ERRCODE_DUPLICATE_OBJECT), (errcode(ERRCODE_DUPLICATE_OBJECT),
......
...@@ -600,7 +600,7 @@ typedef Datum *DatumPtr; ...@@ -600,7 +600,7 @@ typedef Datum *DatumPtr;
* value has adequate lifetime. * value has adequate lifetime.
*/ */
#define NameGetDatum(X) PointerGetDatum(X) #define NameGetDatum(X) CStringGetDatum(NameStr(*(X)))
/* /*
* DatumGetInt64 * DatumGetInt64
......
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