Lines Matching refs:pCur

5912   series_cursor *pCur;  in seriesOpen()  local
5914 pCur = sqlite3_malloc( sizeof(*pCur) ); in seriesOpen()
5915 if( pCur==0 ) return SQLITE_NOMEM; in seriesOpen()
5916 memset(pCur, 0, sizeof(*pCur)); in seriesOpen()
5917 *ppCursor = &pCur->base; in seriesOpen()
5934 series_cursor *pCur = (series_cursor*)cur; in seriesNext() local
5935 progressSequence( & pCur->ss ); in seriesNext()
5948 series_cursor *pCur = (series_cursor*)cur; in seriesColumn() local
5951 case SERIES_COLUMN_START: x = pCur->ss.iBase; break; in seriesColumn()
5952 case SERIES_COLUMN_STOP: x = pCur->ss.iTerm; break; in seriesColumn()
5953 case SERIES_COLUMN_STEP: x = pCur->ss.iStep; break; in seriesColumn()
5954 default: x = pCur->ss.iValueNow; break; in seriesColumn()
5969 series_cursor *pCur = (series_cursor*)cur; in seriesRowid() local
5970 sqlite3_uint64 n = pCur->ss.uSeqIndexNow; in seriesRowid()
5980 series_cursor *pCur = (series_cursor*)cur; in seriesEof() local
5981 return !pCur->ss.isNotEOF; in seriesEof()
6019 series_cursor *pCur = (series_cursor *)pVtabCursor; in seriesFilter() local
6023 pCur->ss.iBase = sqlite3_value_int64(argv[i++]); in seriesFilter()
6025 pCur->ss.iBase = 0; in seriesFilter()
6028 pCur->ss.iTerm = sqlite3_value_int64(argv[i++]); in seriesFilter()
6030 pCur->ss.iTerm = 0xffffffff; in seriesFilter()
6033 pCur->ss.iStep = sqlite3_value_int64(argv[i++]); in seriesFilter()
6034 if( pCur->ss.iStep==0 ){ in seriesFilter()
6035 pCur->ss.iStep = 1; in seriesFilter()
6036 }else if( pCur->ss.iStep<0 ){ in seriesFilter()
6040 pCur->ss.iStep = 1; in seriesFilter()
6048 pCur->ss.iBase += pCur->ss.iStep*iOffset; in seriesFilter()
6052 iTerm = pCur->ss.iBase + (iLimit - 1)*pCur->ss.iStep; in seriesFilter()
6053 if( pCur->ss.iStep<0 ){ in seriesFilter()
6054 if( iTerm>pCur->ss.iTerm ) pCur->ss.iTerm = iTerm; in seriesFilter()
6056 if( iTerm<pCur->ss.iTerm ) pCur->ss.iTerm = iTerm; in seriesFilter()
6064 pCur->ss.iBase = 1; in seriesFilter()
6065 pCur->ss.iTerm = 0; in seriesFilter()
6066 pCur->ss.iStep = 1; in seriesFilter()
6071 pCur->ss.isReversing = pCur->ss.iStep > 0; in seriesFilter()
6073 pCur->ss.isReversing = pCur->ss.iStep < 0; in seriesFilter()
6075 setupSequence( &pCur->ss ); in seriesFilter()
7790 fsdir_cursor *pCur; in fsdirOpen() local
7792 pCur = sqlite3_malloc( sizeof(*pCur) ); in fsdirOpen()
7793 if( pCur==0 ) return SQLITE_NOMEM; in fsdirOpen()
7794 memset(pCur, 0, sizeof(*pCur)); in fsdirOpen()
7795 pCur->iLvl = -1; in fsdirOpen()
7796 *ppCursor = &pCur->base; in fsdirOpen()
7804 static void fsdirResetCursor(fsdir_cursor *pCur){ in fsdirResetCursor() argument
7806 for(i=0; i<=pCur->iLvl; i++){ in fsdirResetCursor()
7807 FsdirLevel *pLvl = &pCur->aLvl[i]; in fsdirResetCursor()
7811 sqlite3_free(pCur->zPath); in fsdirResetCursor()
7812 sqlite3_free(pCur->aLvl); in fsdirResetCursor()
7813 pCur->aLvl = 0; in fsdirResetCursor()
7814 pCur->zPath = 0; in fsdirResetCursor()
7815 pCur->zBase = 0; in fsdirResetCursor()
7816 pCur->nBase = 0; in fsdirResetCursor()
7817 pCur->nLvl = 0; in fsdirResetCursor()
7818 pCur->iLvl = -1; in fsdirResetCursor()
7819 pCur->iRowid = 1; in fsdirResetCursor()
7826 fsdir_cursor *pCur = (fsdir_cursor*)cur; in fsdirClose() local
7828 fsdirResetCursor(pCur); in fsdirClose()
7829 sqlite3_free(pCur); in fsdirClose()
7837 static void fsdirSetErrmsg(fsdir_cursor *pCur, const char *zFmt, ...){ in fsdirSetErrmsg() argument
7840 pCur->base.pVtab->zErrMsg = sqlite3_vmprintf(zFmt, ap); in fsdirSetErrmsg()
7849 fsdir_cursor *pCur = (fsdir_cursor*)cur; in fsdirNext() local
7850 mode_t m = pCur->sStat.st_mode; in fsdirNext()
7852 pCur->iRowid++; in fsdirNext()
7855 int iNew = pCur->iLvl + 1; in fsdirNext()
7857 if( iNew>=pCur->nLvl ){ in fsdirNext()
7860 FsdirLevel *aNew = (FsdirLevel*)sqlite3_realloc64(pCur->aLvl, nByte); in fsdirNext()
7862 memset(&aNew[pCur->nLvl], 0, sizeof(FsdirLevel)*(nNew-pCur->nLvl)); in fsdirNext()
7863 pCur->aLvl = aNew; in fsdirNext()
7864 pCur->nLvl = nNew; in fsdirNext()
7866 pCur->iLvl = iNew; in fsdirNext()
7867 pLvl = &pCur->aLvl[iNew]; in fsdirNext()
7869 pLvl->zDir = pCur->zPath; in fsdirNext()
7870 pCur->zPath = 0; in fsdirNext()
7873 fsdirSetErrmsg(pCur, "cannot read directory: %s", pCur->zPath); in fsdirNext()
7878 while( pCur->iLvl>=0 ){ in fsdirNext()
7879 FsdirLevel *pLvl = &pCur->aLvl[pCur->iLvl]; in fsdirNext()
7886 sqlite3_free(pCur->zPath); in fsdirNext()
7887 pCur->zPath = sqlite3_mprintf("%s/%s", pLvl->zDir, pEntry->d_name); in fsdirNext()
7888 if( pCur->zPath==0 ) return SQLITE_NOMEM; in fsdirNext()
7889 if( fileLinkStat(pCur->zPath, &pCur->sStat) ){ in fsdirNext()
7890 fsdirSetErrmsg(pCur, "cannot stat file: %s", pCur->zPath); in fsdirNext()
7899 pCur->iLvl--; in fsdirNext()
7903 sqlite3_free(pCur->zPath); in fsdirNext()
7904 pCur->zPath = 0; in fsdirNext()
7917 fsdir_cursor *pCur = (fsdir_cursor*)cur; in fsdirColumn() local
7920 sqlite3_result_text(ctx, &pCur->zPath[pCur->nBase], -1, SQLITE_TRANSIENT); in fsdirColumn()
7925 sqlite3_result_int64(ctx, pCur->sStat.st_mode); in fsdirColumn()
7929 sqlite3_result_int64(ctx, pCur->sStat.st_mtime); in fsdirColumn()
7933 mode_t m = pCur->sStat.st_mode; in fsdirColumn()
7944 n = readlink(pCur->zPath, aBuf, nBuf); in fsdirColumn()
7959 readFileContents(ctx, pCur->zPath); in fsdirColumn()
7978 fsdir_cursor *pCur = (fsdir_cursor*)cur; in fsdirRowid() local
7979 *pRowid = pCur->iRowid; in fsdirRowid()
7988 fsdir_cursor *pCur = (fsdir_cursor*)cur; in fsdirEof() local
7989 return (pCur->zPath==0); in fsdirEof()
8004 fsdir_cursor *pCur = (fsdir_cursor*)cur; in fsdirFilter() local
8006 fsdirResetCursor(pCur); in fsdirFilter()
8009 fsdirSetErrmsg(pCur, "table function fsdir requires an argument"); in fsdirFilter()
8016 fsdirSetErrmsg(pCur, "table function fsdir requires a non-NULL argument"); in fsdirFilter()
8020 pCur->zBase = (const char*)sqlite3_value_text(argv[1]); in fsdirFilter()
8022 if( pCur->zBase ){ in fsdirFilter()
8023 pCur->nBase = (int)strlen(pCur->zBase)+1; in fsdirFilter()
8024 pCur->zPath = sqlite3_mprintf("%s/%s", pCur->zBase, zDir); in fsdirFilter()
8026 pCur->zPath = sqlite3_mprintf("%s", zDir); in fsdirFilter()
8029 if( pCur->zPath==0 ){ in fsdirFilter()
8032 if( fileLinkStat(pCur->zPath, &pCur->sStat) ){ in fsdirFilter()
8033 fsdirSetErrmsg(pCur, "cannot stat file: %s", pCur->zPath); in fsdirFilter()
8345 completion_cursor *pCur; in completionOpen() local
8346 pCur = sqlite3_malloc( sizeof(*pCur) ); in completionOpen()
8347 if( pCur==0 ) return SQLITE_NOMEM; in completionOpen()
8348 memset(pCur, 0, sizeof(*pCur)); in completionOpen()
8349 pCur->db = ((completion_vtab*)p)->db; in completionOpen()
8350 *ppCursor = &pCur->base; in completionOpen()
8357 static void completionCursorReset(completion_cursor *pCur){ in completionCursorReset() argument
8358 sqlite3_free(pCur->zPrefix); pCur->zPrefix = 0; pCur->nPrefix = 0; in completionCursorReset()
8359 sqlite3_free(pCur->zLine); pCur->zLine = 0; pCur->nLine = 0; in completionCursorReset()
8360 sqlite3_finalize(pCur->pStmt); pCur->pStmt = 0; in completionCursorReset()
8361 pCur->j = 0; in completionCursorReset()
8388 completion_cursor *pCur = (completion_cursor*)cur; in completionNext() local
8391 pCur->iRowid++; in completionNext()
8392 while( pCur->ePhase!=COMPLETION_EOF ){ in completionNext()
8393 switch( pCur->ePhase ){ in completionNext()
8395 if( pCur->j >= sqlite3_keyword_count() ){ in completionNext()
8396 pCur->zCurrentRow = 0; in completionNext()
8397 pCur->ePhase = COMPLETION_DATABASES; in completionNext()
8399 sqlite3_keyword_name(pCur->j++, &pCur->zCurrentRow, &pCur->szRow); in completionNext()
8405 if( pCur->pStmt==0 ){ in completionNext()
8406 sqlite3_prepare_v2(pCur->db, "PRAGMA database_list", -1, in completionNext()
8407 &pCur->pStmt, 0); in completionNext()
8414 if( pCur->pStmt==0 ){ in completionNext()
8418 sqlite3_prepare_v2(pCur->db, "PRAGMA database_list", -1, &pS2, 0); in completionNext()
8430 sqlite3_prepare_v2(pCur->db, zSql, -1, &pCur->pStmt, 0); in completionNext()
8438 if( pCur->pStmt==0 ){ in completionNext()
8442 sqlite3_prepare_v2(pCur->db, "PRAGMA database_list", -1, &pS2, 0); in completionNext()
8456 sqlite3_prepare_v2(pCur->db, zSql, -1, &pCur->pStmt, 0); in completionNext()
8466 if( pCur->zCurrentRow==0 ) continue; in completionNext()
8468 if( sqlite3_step(pCur->pStmt)==SQLITE_ROW ){ in completionNext()
8470 pCur->zCurrentRow = (const char*)sqlite3_column_text(pCur->pStmt, iCol); in completionNext()
8471 pCur->szRow = sqlite3_column_bytes(pCur->pStmt, iCol); in completionNext()
8474 sqlite3_finalize(pCur->pStmt); in completionNext()
8475 pCur->pStmt = 0; in completionNext()
8476 pCur->ePhase = eNextPhase; in completionNext()
8480 if( pCur->nPrefix==0 ) break; in completionNext()
8481 if( pCur->nPrefix<=pCur->szRow in completionNext()
8482 && sqlite3_strnicmp(pCur->zPrefix, pCur->zCurrentRow, pCur->nPrefix)==0 in completionNext()
8500 completion_cursor *pCur = (completion_cursor*)cur; in completionColumn() local
8503 sqlite3_result_text(ctx, pCur->zCurrentRow, pCur->szRow,SQLITE_TRANSIENT); in completionColumn()
8507 sqlite3_result_text(ctx, pCur->zPrefix, -1, SQLITE_TRANSIENT); in completionColumn()
8511 sqlite3_result_text(ctx, pCur->zLine, -1, SQLITE_TRANSIENT); in completionColumn()
8515 sqlite3_result_int(ctx, pCur->ePhase); in completionColumn()
8527 completion_cursor *pCur = (completion_cursor*)cur; in completionRowid() local
8528 *pRowid = pCur->iRowid; in completionRowid()
8537 completion_cursor *pCur = (completion_cursor*)cur; in completionEof() local
8538 return pCur->ePhase >= COMPLETION_EOF; in completionEof()
8552 completion_cursor *pCur = (completion_cursor *)pVtabCursor; in completionFilter() local
8556 completionCursorReset(pCur); in completionFilter()
8558 pCur->nPrefix = sqlite3_value_bytes(argv[iArg]); in completionFilter()
8559 if( pCur->nPrefix>0 ){ in completionFilter()
8560 pCur->zPrefix = sqlite3_mprintf("%s", sqlite3_value_text(argv[iArg])); in completionFilter()
8561 if( pCur->zPrefix==0 ) return SQLITE_NOMEM; in completionFilter()
8566 pCur->nLine = sqlite3_value_bytes(argv[iArg]); in completionFilter()
8567 if( pCur->nLine>0 ){ in completionFilter()
8568 pCur->zLine = sqlite3_mprintf("%s", sqlite3_value_text(argv[iArg])); in completionFilter()
8569 if( pCur->zLine==0 ) return SQLITE_NOMEM; in completionFilter()
8572 if( pCur->zLine!=0 && pCur->zPrefix==0 ){ in completionFilter()
8573 int i = pCur->nLine; in completionFilter()
8574 while( i>0 && (isalnum(pCur->zLine[i-1]) || pCur->zLine[i-1]=='_') ){ in completionFilter()
8577 pCur->nPrefix = pCur->nLine - i; in completionFilter()
8578 if( pCur->nPrefix>0 ){ in completionFilter()
8579 pCur->zPrefix = sqlite3_mprintf("%.*s", pCur->nPrefix, pCur->zLine + i); in completionFilter()
8580 if( pCur->zPrefix==0 ) return SQLITE_NOMEM; in completionFilter()
8583 pCur->iRowid = 0; in completionFilter()
8584 pCur->ePhase = COMPLETION_FIRST_PHASE; in completionFilter()