aboutsummaryrefslogtreecommitdiff
path: root/src/expr.c
diff options
context:
space:
mode:
authordan <dan@noemail.net>2019-07-22 16:33:02 +0000
committerdan <dan@noemail.net>2019-07-22 16:33:02 +0000
commit7f6f12bdd35c55d9f98b6eefbe2d40c4a85aab87 (patch)
treec90be8f5173dfe1513abdfe7ae4a356f4f82bd9c /src/expr.c
parent1e60261cfbc34cdad2625241ba6e5bedfb2e6716 (diff)
parent75b0821e999cb14d4081a6ff8090e28e49e5bc7e (diff)
downloadsqlite-7f6f12bdd35c55d9f98b6eefbe2d40c4a85aab87.tar.gz
sqlite-7f6f12bdd35c55d9f98b6eefbe2d40c4a85aab87.zip
Remove Window objects from the corresponding Select.pWin list when they are deleted, as they are, for example, when the ORDER BY clause is optimized out.
FossilOrigin-Name: fd7316cda0fdfe86985f41a97dff3beba188606ec9bc6fef38a686a6976a6e01
Diffstat (limited to 'src/expr.c')
-rw-r--r--src/expr.c13
1 files changed, 10 insertions, 3 deletions
diff --git a/src/expr.c b/src/expr.c
index 56b3148ed..571e9e494 100644
--- a/src/expr.c
+++ b/src/expr.c
@@ -1326,10 +1326,17 @@ static With *withDup(sqlite3 *db, With *p){
*/
static int gatherSelectWindowsCallback(Walker *pWalker, Expr *pExpr){
if( pExpr->op==TK_FUNCTION && ExprHasProperty(pExpr, EP_WinFunc) ){
- assert( pExpr->y.pWin );
+ Select *pSelect = pWalker->u.pSelect;
+ Window *pWin = pExpr->y.pWin;
+ assert( pWin );
assert( IsWindowFunc(pExpr) );
- pExpr->y.pWin->pNextWin = pWalker->u.pSelect->pWin;
- pWalker->u.pSelect->pWin = pExpr->y.pWin;
+ if( pSelect->pWin ){
+ *pSelect->pWin->ppThis = pSelect->pWin->pNextWin;
+ pSelect->pWin->ppThis = &pWin->pNextWin;
+ }
+ pWin->pNextWin = pSelect->pWin;
+ pWin->ppThis = &pSelect->pWin;
+ pSelect->pWin = pWin;
}
return WRC_Continue;
}