|
|
d8894c |
Subject: [PATCH] Do not allow a virtual table to be renamed into the name of
|
|
|
d8894c |
one of its shadows.
|
|
|
d8894c |
|
|
|
d8894c |
---
|
|
|
d8894c |
src/alter.c | 5 ++++-
|
|
|
a417f0 |
src/build.c | 29 +++++++++++++++++++++++------
|
|
|
d8894c |
src/sqliteInt.h | 5 +++++
|
|
|
a417f0 |
3 files changed, 32 insertions(+), 7 deletions(-)
|
|
|
d8894c |
|
|
|
d8894c |
diff --git a/src/alter.c b/src/alter.c
|
|
|
d8894c |
index 1280e90..0fa24c0 100644
|
|
|
d8894c |
--- a/src/alter.c
|
|
|
d8894c |
+++ b/src/alter.c
|
|
|
d8894c |
@@ -117,7 +117,10 @@ void sqlite3AlterRenameTable(
|
|
|
d8894c |
/* Check that a table or index named 'zName' does not already exist
|
|
|
d8894c |
** in database iDb. If so, this is an error.
|
|
|
d8894c |
*/
|
|
|
d8894c |
- if( sqlite3FindTable(db, zName, zDb) || sqlite3FindIndex(db, zName, zDb) ){
|
|
|
d8894c |
+ if( sqlite3FindTable(db, zName, zDb)
|
|
|
d8894c |
+ || sqlite3FindIndex(db, zName, zDb)
|
|
|
d8894c |
+ || sqlite3IsShadowTableOf(db, pTab, zName)
|
|
|
d8894c |
+ ){
|
|
|
d8894c |
sqlite3ErrorMsg(pParse,
|
|
|
d8894c |
"there is already another table or index with this name: %s", zName);
|
|
|
d8894c |
goto exit_rename_table;
|
|
|
d8894c |
diff --git a/src/build.c b/src/build.c
|
|
|
a417f0 |
index e0fed8a..afe4171 100644
|
|
|
d8894c |
--- a/src/build.c
|
|
|
d8894c |
+++ b/src/build.c
|
|
|
a417f0 |
@@ -1899,6 +1899,28 @@ static void convertToWithoutRowidTable(Parse *pParse, Table *pTab){
|
|
|
d8894c |
recomputeColumnsNotIndexed(pPk);
|
|
|
d8894c |
}
|
|
|
d8894c |
|
|
|
d8894c |
+
|
|
|
d8894c |
+#ifndef SQLITE_OMIT_VIRTUALTABLE
|
|
|
d8894c |
+/*
|
|
|
d8894c |
+** Return true if pTab is a virtual table and zName is a shadow table name
|
|
|
d8894c |
+** for that virtual table.
|
|
|
d8894c |
+*/
|
|
|
d8894c |
+int sqlite3IsShadowTableOf(sqlite3 *db, Table *pTab, const char *zName){
|
|
|
d8894c |
+ int nName; /* Length of zName */
|
|
|
a417f0 |
+ Module *pMod; /* Module for the virtual table */
|
|
|
d8894c |
+
|
|
|
d8894c |
+ if( !IsVirtual(pTab) ) return 0;
|
|
|
d8894c |
+ nName = sqlite3Strlen30(pTab->zName);
|
|
|
d8894c |
+ if( sqlite3_strnicmp(zName, pTab->zName, nName)!=0 ) return 0;
|
|
|
d8894c |
+ if( zName[nName]!='_' ) return 0;
|
|
|
a417f0 |
+ pMod = (Module*)sqlite3HashFind(&db->aModule, pTab->azModuleArg[0]);
|
|
|
d8894c |
+ if( pMod==0 ) return 0;
|
|
|
d8894c |
+ if( pMod->pModule->iVersion<3 ) return 0;
|
|
|
d8894c |
+ if( pMod->pModule->xShadowName==0 ) return 0;
|
|
|
d8894c |
+ return pMod->pModule->xShadowName(zName+nName+1);
|
|
|
d8894c |
+}
|
|
|
d8894c |
+#endif /* ifndef SQLITE_OMIT_VIRTUALTABLE */
|
|
|
d8894c |
+
|
|
|
d8894c |
#ifndef SQLITE_OMIT_VIRTUALTABLE
|
|
|
d8894c |
/*
|
|
|
d8894c |
** Return true if zName is a shadow table name in the current database
|
|
|
a417f0 |
@@ -1910,7 +1932,6 @@ static void convertToWithoutRowidTable(Parse *pParse, Table *pTab){
|
|
|
d8894c |
static int isShadowTableName(sqlite3 *db, char *zName){
|
|
|
d8894c |
char *zTail; /* Pointer to the last "_" in zName */
|
|
|
d8894c |
Table *pTab; /* Table that zName is a shadow of */
|
|
|
d8894c |
- Module *pMod; /* Module for the virtual table */
|
|
|
d8894c |
|
|
|
d8894c |
zTail = strrchr(zName, '_');
|
|
|
d8894c |
if( zTail==0 ) return 0;
|
|
|
a417f0 |
@@ -1919,11 +1940,7 @@ static int isShadowTableName(sqlite3 *db, char *zName){
|
|
|
d8894c |
*zTail = '_';
|
|
|
d8894c |
if( pTab==0 ) return 0;
|
|
|
d8894c |
if( !IsVirtual(pTab) ) return 0;
|
|
|
d8894c |
- pMod = (Module*)sqlite3HashFind(&db->aModule, pTab->azModuleArg[0]);
|
|
|
d8894c |
- if( pMod==0 ) return 0;
|
|
|
d8894c |
- if( pMod->pModule->iVersion<3 ) return 0;
|
|
|
d8894c |
- if( pMod->pModule->xShadowName==0 ) return 0;
|
|
|
d8894c |
- return pMod->pModule->xShadowName(zTail+1);
|
|
|
d8894c |
+ return sqlite3IsShadowTableOf(db, pTab, zName);
|
|
|
d8894c |
}
|
|
|
d8894c |
#else
|
|
|
d8894c |
# define isShadowTableName(x,y) 0
|
|
|
d8894c |
diff --git a/src/sqliteInt.h b/src/sqliteInt.h
|
|
|
d8894c |
index b7d3571..76337f7 100644
|
|
|
d8894c |
--- a/src/sqliteInt.h
|
|
|
d8894c |
+++ b/src/sqliteInt.h
|
|
|
d8894c |
@@ -4407,6 +4407,11 @@ void sqlite3AutoLoadExtensions(sqlite3*);
|
|
|
d8894c |
);
|
|
|
d8894c |
# define sqlite3VtabInSync(db) ((db)->nVTrans>0 && (db)->aVTrans==0)
|
|
|
d8894c |
#endif
|
|
|
d8894c |
+#ifndef SQLITE_OMIT_VIRTUALTABLE
|
|
|
d8894c |
+ int sqlite3IsShadowTableOf(sqlite3*,Table*,const char*);
|
|
|
d8894c |
+#else
|
|
|
d8894c |
+# define sqlite3IsShadowTableOf(A,B,C) 0
|
|
|
d8894c |
+#endif
|
|
|
d8894c |
int sqlite3VtabEponymousTableInit(Parse*,Module*);
|
|
|
d8894c |
void sqlite3VtabEponymousTableClear(sqlite3*,Module*);
|
|
|
d8894c |
void sqlite3VtabMakeWritable(Parse*,Table*);
|
|
|
d8894c |
--
|
|
|
d8894c |
2.24.1
|
|
|
d8894c |
|