diff options
author | drh <drh@noemail.net> | 2015-08-20 19:55:58 +0000 |
---|---|---|
committer | drh <drh@noemail.net> | 2015-08-20 19:55:58 +0000 |
commit | 7fcdd06949d63b23ba756b2377fa466e136dd72d (patch) | |
tree | 7a91f962a075682b5bace5d0d4cc5c30b5e9bd85 /src/main.c | |
parent | cbd8db35f58c647f63ae05d153a148efb4ed8ef3 (diff) | |
parent | b81fba193079eb6276b3fc94849d847b47c5544e (diff) | |
download | sqlite-7fcdd06949d63b23ba756b2377fa466e136dd72d.tar.gz sqlite-7fcdd06949d63b23ba756b2377fa466e136dd72d.zip |
Add support for table-valued functions in the FROM clause implemented as
virtual tables.
FossilOrigin-Name: 9b718b06b156163ae34115b6c5f6d163a7ee7cc3
Diffstat (limited to 'src/main.c')
-rw-r--r-- | src/main.c | 9 |
1 files changed, 8 insertions, 1 deletions
diff --git a/src/main.c b/src/main.c index 36206eec8..575cad92c 100644 --- a/src/main.c +++ b/src/main.c @@ -932,17 +932,23 @@ static void functionDestroy(sqlite3 *db, FuncDef *p){ static void disconnectAllVtab(sqlite3 *db){ #ifndef SQLITE_OMIT_VIRTUALTABLE int i; + HashElem *p; sqlite3BtreeEnterAll(db); for(i=0; i<db->nDb; i++){ Schema *pSchema = db->aDb[i].pSchema; if( db->aDb[i].pSchema ){ - HashElem *p; for(p=sqliteHashFirst(&pSchema->tblHash); p; p=sqliteHashNext(p)){ Table *pTab = (Table *)sqliteHashData(p); if( IsVirtual(pTab) ) sqlite3VtabDisconnect(db, pTab); } } } + for(p=sqliteHashFirst(&db->aModule); p; p=sqliteHashNext(p)){ + Module *pMod = (Module *)sqliteHashData(p); + if( pMod->pEpoTab ){ + sqlite3VtabDisconnect(db, pMod->pEpoTab); + } + } sqlite3VtabUnlockList(db); sqlite3BtreeLeaveAll(db); #else @@ -1120,6 +1126,7 @@ void sqlite3LeaveMutexAndCloseZombie(sqlite3 *db){ if( pMod->xDestroy ){ pMod->xDestroy(pMod->pAux); } + sqlite3VtabEponymousTableClear(db, pMod); sqlite3DbFree(db, pMod); } sqlite3HashClear(&db->aModule); |