blob: 0048397e9ede9832642a11c55890effe4b7a775c [file] [log] [blame]
drh16a9b832007-05-05 18:39:25 +00001/*
2** 2007 May 05
3**
4** The author disclaims copyright to this source code. In place of
5** a legal notice, here is a blessing:
6**
7** May you do good and not evil.
8** May you find forgiveness for yourself and forgive others.
9** May you share freely, never taking more than you give.
10**
11*************************************************************************
12** Code for testing the btree.c module in SQLite. This code
13** is not included in the SQLite library. It is used for automated
14** testing of the SQLite library.
drh16a9b832007-05-05 18:39:25 +000015*/
16#include "btreeInt.h"
17#include <tcl.h>
18
19/*
drh16a9b832007-05-05 18:39:25 +000020** Usage: sqlite3_shared_cache_report
21**
22** Return a list of file that are shared and the number of
23** references to each file.
24*/
25int sqlite3BtreeSharedCacheReport(
26 void * clientData,
27 Tcl_Interp *interp,
28 int objc,
29 Tcl_Obj *CONST objv[]
30){
31#ifndef SQLITE_OMIT_SHARED_CACHE
drhe53831d2007-08-17 01:14:38 +000032 extern BtShared *sqlite3SharedCacheList;
33 BtShared *pBt;
34 Tcl_Obj *pRet = Tcl_NewObj();
drh78f82d12008-09-02 00:52:52 +000035 for(pBt=GLOBAL(BtShared*,sqlite3SharedCacheList); pBt; pBt=pBt->pNext){
drhe53831d2007-08-17 01:14:38 +000036 const char *zFile = sqlite3PagerFilename(pBt->pPager);
37 Tcl_ListObjAppendElement(interp, pRet, Tcl_NewStringObj(zFile, -1));
38 Tcl_ListObjAppendElement(interp, pRet, Tcl_NewIntObj(pBt->nRef));
drh16a9b832007-05-05 18:39:25 +000039 }
drhe53831d2007-08-17 01:14:38 +000040 Tcl_SetObjResult(interp, pRet);
drh16a9b832007-05-05 18:39:25 +000041#endif
42 return TCL_OK;
43}
44
45/*
46** Print debugging information about all cursors to standard output.
47*/
48void sqlite3BtreeCursorList(Btree *p){
drh85e9e222008-07-15 00:27:34 +000049#ifdef SQLITE_DEBUG
drh16a9b832007-05-05 18:39:25 +000050 BtCursor *pCur;
51 BtShared *pBt = p->pBt;
52 for(pCur=pBt->pCursor; pCur; pCur=pCur->pNext){
danielk197771d5d2c2008-09-29 11:49:47 +000053 MemPage *pPage = pCur->apPage[pCur->iPage];
drh16a9b832007-05-05 18:39:25 +000054 char *zMode = pCur->wrFlag ? "rw" : "ro";
55 sqlite3DebugPrintf("CURSOR %p rooted at %4d(%s) currently at %d.%d%s\n",
56 pCur, pCur->pgnoRoot, zMode,
danielk197771d5d2c2008-09-29 11:49:47 +000057 pPage ? pPage->pgno : 0, pCur->aiIdx[pCur->iPage],
drh16a9b832007-05-05 18:39:25 +000058 (pCur->eState==CURSOR_VALID) ? "" : " eof"
59 );
60 }
drh85e9e222008-07-15 00:27:34 +000061#endif
drh16a9b832007-05-05 18:39:25 +000062}