1
0
mirror of https://github.com/sqlite/sqlite.git synced 2025-11-06 15:49:35 +03:00

Continuing incremental enhancements of SELECT code generation:

Remove the Select.affinity field.  Use SelectDest.affSdst instead.

FossilOrigin-Name: cf40b7b5ebdacc3215d769aadacce8c9e7e9dfbb
This commit is contained in:
drh
2012-09-20 15:41:31 +00:00
parent 2c79733f3c
commit 634d81dee0
4 changed files with 20 additions and 19 deletions

View File

@@ -1,5 +1,5 @@
C Refactoring\sof\sDISTINCT\scode.\s\sChange\sthe\sname\sof\sthe\slocal\svariable\n"distinct"\sto\s"distinctTab".\s\sGenerate\scleaner\scode\sw/o\sunnecessary\sP4\nand\sP5\svalues\son\sthe\sOP_Null\sfor\sWHERE_DISTINCT_ORDERED. C Continuing\sincremental\senhancements\sof\sSELECT\scode\sgeneration:\nRemove\sthe\sSelect.affinity\sfield.\s\sUse\sSelectDest.affSdst\sinstead.
D 2012-09-20T14:26:22.088 D 2012-09-20T15:41:31.865
F Makefile.arm-wince-mingw32ce-gcc d6df77f1f48d690bd73162294bbba7f59507c72f F Makefile.arm-wince-mingw32ce-gcc d6df77f1f48d690bd73162294bbba7f59507c72f
F Makefile.in 5f4f26109f9d80829122e0e09f9cda008fa065fb F Makefile.in 5f4f26109f9d80829122e0e09f9cda008fa065fb
F Makefile.linux-gcc 91d710bdc4998cb015f39edf3cb314ec4f4d7e23 F Makefile.linux-gcc 91d710bdc4998cb015f39edf3cb314ec4f4d7e23
@@ -174,12 +174,12 @@ F src/printf.c 4a9f882f1c1787a8b494a2987765acf9d97ac21f
F src/random.c cd4a67b3953b88019f8cd4ccd81394a8ddfaba50 F src/random.c cd4a67b3953b88019f8cd4ccd81394a8ddfaba50
F src/resolve.c 9e28280ec98035f31900fdd1db01f86f68ca6c32 F src/resolve.c 9e28280ec98035f31900fdd1db01f86f68ca6c32
F src/rowset.c 64655f1a627c9c212d9ab497899e7424a34222e0 F src/rowset.c 64655f1a627c9c212d9ab497899e7424a34222e0
F src/select.c 7878dd564f5ec107e9b58af5f3eeb27ac640770b F src/select.c 7c6d028755131a47c0521a8b697428ebd382dbd3
F src/shell.c 87953c5d9c73d9494db97d1607e2e2280418f261 F src/shell.c 87953c5d9c73d9494db97d1607e2e2280418f261
F src/sqlite.h.in c76c38f9635590ff5844684a7976843878327137 F src/sqlite.h.in c76c38f9635590ff5844684a7976843878327137
F src/sqlite3.rc fea433eb0a59f4c9393c8e6d76a6e2596b1fe0c0 F src/sqlite3.rc fea433eb0a59f4c9393c8e6d76a6e2596b1fe0c0
F src/sqlite3ext.h 6904f4aadf976f95241311fbffb00823075d9477 F src/sqlite3ext.h 6904f4aadf976f95241311fbffb00823075d9477
F src/sqliteInt.h bcfaf463a0fecda2d10efd68a52fea11f1cff388 F src/sqliteInt.h a9708835335a62d691602f25dacaab9cdab53613
F src/sqliteLimit.h 164b0e6749d31e0daa1a4589a169d31c0dec7b3d F src/sqliteLimit.h 164b0e6749d31e0daa1a4589a169d31c0dec7b3d
F src/status.c 35939e7e03abf1b7577ce311f48f682c40de3208 F src/status.c 35939e7e03abf1b7577ce311f48f682c40de3208
F src/table.c 2cd62736f845d82200acfa1287e33feb3c15d62e F src/table.c 2cd62736f845d82200acfa1287e33feb3c15d62e
@@ -1016,7 +1016,7 @@ F tool/vdbe-compress.tcl f12c884766bd14277f4fcedcae07078011717381
F tool/warnings-clang.sh f6aa929dc20ef1f856af04a730772f59283631d4 F tool/warnings-clang.sh f6aa929dc20ef1f856af04a730772f59283631d4
F tool/warnings.sh fbc018d67fd7395f440c28f33ef0f94420226381 F tool/warnings.sh fbc018d67fd7395f440c28f33ef0f94420226381
F tool/win/sqlite.vsix 67d8a99aceb56384a81b3f30d6c71743146d2cc9 F tool/win/sqlite.vsix 67d8a99aceb56384a81b3f30d6c71743146d2cc9
P 94b48064db3cbb43e911fdf7183218b08146ec10 P 0cda241a2bcb3c6f2ae6c48f522780bc4eddfc02
R 5e2afb7573559eb5eba9ed47e068d0d2 R 70c119f908e0321bfe68ed5f9f70b2c3
U drh U drh
Z 5042a680f6b5da609676733ff0c80d03 Z 768851de231def4398f466b3e6b7ba54

View File

@@ -1 +1 @@
0cda241a2bcb3c6f2ae6c48f522780bc4eddfc02 cf40b7b5ebdacc3215d769aadacce8c9e7e9dfbb

View File

@@ -655,7 +655,8 @@ static void selectInnerLoop(
*/ */
case SRT_Set: { case SRT_Set: {
assert( nColumn==1 ); assert( nColumn==1 );
p->affinity = sqlite3CompareAffinity(pEList->a[0].pExpr, pDest->affSdst); pDest->affSdst =
sqlite3CompareAffinity(pEList->a[0].pExpr, pDest->affSdst);
if( pOrderBy ){ if( pOrderBy ){
/* At first glance you would think we could optimize out the /* At first glance you would think we could optimize out the
** ORDER BY in this case since the order of entries in the set ** ORDER BY in this case since the order of entries in the set
@@ -664,7 +665,7 @@ static void selectInnerLoop(
pushOntoSorter(pParse, pOrderBy, p, regResult); pushOntoSorter(pParse, pOrderBy, p, regResult);
}else{ }else{
int r1 = sqlite3GetTempReg(pParse); int r1 = sqlite3GetTempReg(pParse);
sqlite3VdbeAddOp4(v, OP_MakeRecord, regResult, 1, r1, &p->affinity, 1); sqlite3VdbeAddOp4(v, OP_MakeRecord, regResult,1,r1, &pDest->affSdst, 1);
sqlite3ExprCacheAffinityChange(pParse, regResult, 1); sqlite3ExprCacheAffinityChange(pParse, regResult, 1);
sqlite3VdbeAddOp2(v, OP_IdxInsert, iParm, r1); sqlite3VdbeAddOp2(v, OP_IdxInsert, iParm, r1);
sqlite3ReleaseTempReg(pParse, r1); sqlite3ReleaseTempReg(pParse, r1);
@@ -931,7 +932,8 @@ static void generateSortTail(
#ifndef SQLITE_OMIT_SUBQUERY #ifndef SQLITE_OMIT_SUBQUERY
case SRT_Set: { case SRT_Set: {
assert( nColumn==1 ); assert( nColumn==1 );
sqlite3VdbeAddOp4(v, OP_MakeRecord, regRow, 1, regRowid, &p->affinity, 1); sqlite3VdbeAddOp4(v, OP_MakeRecord, regRow, 1, regRowid,
&pDest->affSdst, 1);
sqlite3ExprCacheAffinityChange(pParse, regRow, 1); sqlite3ExprCacheAffinityChange(pParse, regRow, 1);
sqlite3VdbeAddOp2(v, OP_IdxInsert, iParm, regRowid); sqlite3VdbeAddOp2(v, OP_IdxInsert, iParm, regRowid);
break; break;
@@ -2001,10 +2003,10 @@ static int generateOutputSubroutine(
case SRT_Set: { case SRT_Set: {
int r1; int r1;
assert( pIn->nSdst==1 ); assert( pIn->nSdst==1 );
p->affinity = pDest->affSdst =
sqlite3CompareAffinity(p->pEList->a[0].pExpr, pDest->affSdst); sqlite3CompareAffinity(p->pEList->a[0].pExpr, pDest->affSdst);
r1 = sqlite3GetTempReg(pParse); r1 = sqlite3GetTempReg(pParse);
sqlite3VdbeAddOp4(v, OP_MakeRecord, pIn->iSdst, 1, r1, &p->affinity, 1); sqlite3VdbeAddOp4(v, OP_MakeRecord, pIn->iSdst, 1, r1, &pDest->affSdst,1);
sqlite3ExprCacheAffinityChange(pParse, pIn->iSdst, 1); sqlite3ExprCacheAffinityChange(pParse, pIn->iSdst, 1);
sqlite3VdbeAddOp2(v, OP_IdxInsert, pDest->iSDParm, r1); sqlite3VdbeAddOp2(v, OP_IdxInsert, pDest->iSDParm, r1);
sqlite3ReleaseTempReg(pParse, r1); sqlite3ReleaseTempReg(pParse, r1);

View File

@@ -661,6 +661,7 @@ typedef struct Parse Parse;
typedef struct RowSet RowSet; typedef struct RowSet RowSet;
typedef struct Savepoint Savepoint; typedef struct Savepoint Savepoint;
typedef struct Select Select; typedef struct Select Select;
typedef struct SelectDest SelectDest;
typedef struct SrcList SrcList; typedef struct SrcList SrcList;
typedef struct StrAccum StrAccum; typedef struct StrAccum StrAccum;
typedef struct Table Table; typedef struct Table Table;
@@ -2065,7 +2066,6 @@ struct NameContext {
struct Select { struct Select {
ExprList *pEList; /* The fields of the result */ ExprList *pEList; /* The fields of the result */
u8 op; /* One of: TK_UNION TK_ALL TK_INTERSECT TK_EXCEPT */ u8 op; /* One of: TK_UNION TK_ALL TK_INTERSECT TK_EXCEPT */
char affinity; /* MakeRecord with this affinity for SRT_Set */
u16 selFlags; /* Various SF_* values */ u16 selFlags; /* Various SF_* values */
int iLimit, iOffset; /* Memory registers holding LIMIT & OFFSET counters */ int iLimit, iOffset; /* Memory registers holding LIMIT & OFFSET counters */
int addrOpenEphm[3]; /* OP_OpenEphem opcodes related to this select */ int addrOpenEphm[3]; /* OP_OpenEphem opcodes related to this select */
@@ -2116,13 +2116,12 @@ struct Select {
#define SRT_Coroutine 10 /* Generate a single row of result */ #define SRT_Coroutine 10 /* Generate a single row of result */
/* /*
** A structure used to customize the behavior of sqlite3Select(). See ** An instance of this object describes where to put of the results of
** comments above sqlite3Select() for details. ** a SELECT statement.
*/ */
typedef struct SelectDest SelectDest;
struct SelectDest { struct SelectDest {
u8 eDest; /* How to dispose of the results */ u8 eDest; /* How to dispose of the results. On of SRT_* above. */
u8 affSdst; /* Affinity used when eDest==SRT_Set */ char affSdst; /* Affinity used when eDest==SRT_Set */
int iSDParm; /* A parameter used by the eDest disposal method */ int iSDParm; /* A parameter used by the eDest disposal method */
int iSdst; /* Base register where results are written */ int iSdst; /* Base register where results are written */
int nSdst; /* Number of registers allocated */ int nSdst; /* Number of registers allocated */