| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
|
|
| #include "sqliteInt.h" |
|
|
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| int sqlite3_exec( |
| sqlite3 *db, |
| const char *zSql, |
| sqlite3_callback xCallback, |
| void *pArg, |
| char **pzErrMsg |
| ){ |
| int rc = SQLITE_OK; |
| const char *zLeftover; |
| sqlite3_stmt *pStmt = 0; |
| char **azCols = 0; |
| int callbackIsInit; |
|
|
| if( !sqlite3SafetyCheckOk(db) ) return SQLITE_MISUSE_BKPT; |
| if( zSql==0 ) zSql = ""; |
|
|
| sqlite3_mutex_enter(db->mutex); |
| sqlite3Error(db, SQLITE_OK); |
| while( rc==SQLITE_OK && zSql[0] ){ |
| int nCol = 0; |
| char **azVals = 0; |
|
|
| pStmt = 0; |
| rc = sqlite3_prepare_v2(db, zSql, -1, &pStmt, &zLeftover); |
| assert( rc==SQLITE_OK || pStmt==0 ); |
| if( rc!=SQLITE_OK ){ |
| continue; |
| } |
| if( !pStmt ){ |
| |
| zSql = zLeftover; |
| continue; |
| } |
| callbackIsInit = 0; |
|
|
| while( 1 ){ |
| int i; |
| rc = sqlite3_step(pStmt); |
|
|
| |
| if( xCallback && (SQLITE_ROW==rc || |
| (SQLITE_DONE==rc && !callbackIsInit |
| && db->flags&SQLITE_NullCallback)) ){ |
| if( !callbackIsInit ){ |
| nCol = sqlite3_column_count(pStmt); |
| azCols = sqlite3DbMallocRaw(db, (2*nCol+1)*sizeof(const char*)); |
| if( azCols==0 ){ |
| goto exec_out; |
| } |
| for(i=0; i<nCol; i++){ |
| azCols[i] = (char *)sqlite3_column_name(pStmt, i); |
| |
| |
| assert( azCols[i]!=0 ); |
| } |
| callbackIsInit = 1; |
| } |
| if( rc==SQLITE_ROW ){ |
| azVals = &azCols[nCol]; |
| for(i=0; i<nCol; i++){ |
| azVals[i] = (char *)sqlite3_column_text(pStmt, i); |
| if( !azVals[i] && sqlite3_column_type(pStmt, i)!=SQLITE_NULL ){ |
| sqlite3OomFault(db); |
| goto exec_out; |
| } |
| } |
| azVals[i] = 0; |
| } |
| if( xCallback(pArg, nCol, azVals, azCols) ){ |
| |
| |
| |
| rc = SQLITE_ABORT; |
| sqlite3VdbeFinalize((Vdbe *)pStmt); |
| pStmt = 0; |
| sqlite3Error(db, SQLITE_ABORT); |
| goto exec_out; |
| } |
| } |
|
|
| if( rc!=SQLITE_ROW ){ |
| rc = sqlite3VdbeFinalize((Vdbe *)pStmt); |
| pStmt = 0; |
| zSql = zLeftover; |
| while( sqlite3Isspace(zSql[0]) ) zSql++; |
| break; |
| } |
| } |
|
|
| sqlite3DbFree(db, azCols); |
| azCols = 0; |
| } |
|
|
| exec_out: |
| if( pStmt ) sqlite3VdbeFinalize((Vdbe *)pStmt); |
| sqlite3DbFree(db, azCols); |
|
|
| rc = sqlite3ApiExit(db, rc); |
| if( rc!=SQLITE_OK && pzErrMsg ){ |
| *pzErrMsg = sqlite3DbStrDup(0, sqlite3_errmsg(db)); |
| if( *pzErrMsg==0 ){ |
| rc = SQLITE_NOMEM_BKPT; |
| sqlite3Error(db, SQLITE_NOMEM); |
| } |
| }else if( pzErrMsg ){ |
| *pzErrMsg = 0; |
| } |
|
|
| assert( (rc&db->errMask)==rc ); |
| sqlite3_mutex_leave(db->mutex); |
| return rc; |
| } |
|
|