Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(1142)

Side by Side Diff: third_party/sqlite/src/tool/showjournal.c

Issue 901033002: Import SQLite 3.8.7.4. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Chromium changes to support SQLite 3.8.7.4. Created 5 years, 10 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 /* 1 /*
2 ** A utility for printing an SQLite database journal. 2 ** A utility for printing an SQLite database journal.
3 */ 3 */
4 #include <stdio.h> 4 #include <stdio.h>
5 #include <ctype.h> 5 #include <ctype.h>
6 #include <stdlib.h> 6 #include <stdlib.h>
7 #include <string.h> 7 #include <string.h>
8 8
9 /* 9 /*
10 ** state information 10 ** state information
11 */ 11 */
12 static int pageSize = 1024; 12 static int pageSize = 1024;
13 static int sectorSize = 512; 13 static int sectorSize = 512;
14 static FILE *db = 0; 14 static FILE *db = 0;
15 static int showPageContent = 0;
16 static int fileSize = 0; 15 static int fileSize = 0;
17 static unsigned cksumNonce = 0; 16 static unsigned cksumNonce = 0;
18 17
19 /* Report a memory allocation error */ 18 /* Report a memory allocation error */
20 static void out_of_memory(void){ 19 static void out_of_memory(void){
21 fprintf(stderr,"Out of memory...\n"); 20 fprintf(stderr,"Out of memory...\n");
22 exit(1); 21 exit(1);
23 } 22 }
24 23
25 /* 24 /*
26 ** Read N bytes of memory starting at iOfst into space obtained 25 ** Read N bytes of memory starting at iOfst into space obtained
27 ** from malloc(). 26 ** from malloc().
28 */ 27 */
29 static char *read_content(int N, int iOfst){ 28 static unsigned char *read_content(int N, int iOfst){
30 int got; 29 int got;
31 char *pBuf = malloc(N); 30 unsigned char *pBuf = malloc(N);
32 if( pBuf==0 ) out_of_memory(); 31 if( pBuf==0 ) out_of_memory();
33 fseek(db, iOfst, SEEK_SET); 32 fseek(db, iOfst, SEEK_SET);
34 got = fread(pBuf, 1, N, db); 33 got = fread(pBuf, 1, N, db);
35 if( got<0 ){ 34 if( got<0 ){
36 fprintf(stderr, "I/O error reading %d bytes from %d\n", N, iOfst); 35 fprintf(stderr, "I/O error reading %d bytes from %d\n", N, iOfst);
37 memset(pBuf, 0, N); 36 memset(pBuf, 0, N);
38 }else if( got<N ){ 37 }else if( got<N ){
39 fprintf(stderr, "Short read: got only %d of %d bytes from %d\n", 38 fprintf(stderr, "Short read: got only %d of %d bytes from %d\n",
40 got, N, iOfst); 39 got, N, iOfst);
41 memset(&pBuf[got], 0, N-got); 40 memset(&pBuf[got], 0, N-got);
42 } 41 }
43 return pBuf; 42 return pBuf;
44 } 43 }
45 44
46 /* Print a line of decode output showing a 4-byte integer. 45 /* Print a line of decode output showing a 4-byte integer.
47 */ 46 */
48 static unsigned print_decode_line( 47 static unsigned print_decode_line(
49 unsigned char *aData, /* Content being decoded */ 48 const unsigned char *aData, /* Content being decoded */
50 int ofst, int nByte, /* Start and size of decode */ 49 int ofst, int nByte, /* Start and size of decode */
51 const char *zMsg /* Message to append */ 50 const char *zMsg /* Message to append */
52 ){ 51 ){
53 int i, j; 52 int i, j;
54 unsigned val = aData[ofst]; 53 unsigned val = aData[ofst];
55 char zBuf[100]; 54 char zBuf[100];
56 sprintf(zBuf, " %03x: %02x", ofst, aData[ofst]); 55 sprintf(zBuf, " %05x: %02x", ofst, aData[ofst]);
57 i = strlen(zBuf); 56 i = strlen(zBuf);
58 for(j=1; j<4; j++){ 57 for(j=1; j<4; j++){
59 if( j>=nByte ){ 58 if( j>=nByte ){
60 sprintf(&zBuf[i], " "); 59 sprintf(&zBuf[i], " ");
61 }else{ 60 }else{
62 sprintf(&zBuf[i], " %02x", aData[ofst+j]); 61 sprintf(&zBuf[i], " %02x", aData[ofst+j]);
63 val = val*256 + aData[ofst+j]; 62 val = val*256 + aData[ofst+j];
64 } 63 }
65 i += strlen(&zBuf[i]); 64 i += strlen(&zBuf[i]);
66 } 65 }
67 sprintf(&zBuf[i], " %10u", val); 66 sprintf(&zBuf[i], " %10u", val);
68 printf("%s %s\n", zBuf, zMsg); 67 printf("%s %s\n", zBuf, zMsg);
69 return val; 68 return val;
70 } 69 }
71 70
72 /* 71 /*
73 ** Read and print a journal header. Store key information (page size, etc) 72 ** Read and print a journal header. Store key information (page size, etc)
74 ** in global variables. 73 ** in global variables.
75 */ 74 */
76 static unsigned decode_journal_header(int iOfst){ 75 static unsigned decode_journal_header(int iOfst){
77 char *pHdr = read_content(64, iOfst); 76 unsigned char *pHdr = read_content(64, iOfst);
78 unsigned nPage; 77 unsigned nPage;
79 printf("Header at offset %d:\n", iOfst); 78 printf("Header at offset %d:\n", iOfst);
80 print_decode_line(pHdr, 0, 4, "Header part 1 (3654616569)"); 79 print_decode_line(pHdr, 0, 4, "Header part 1 (3654616569)");
81 print_decode_line(pHdr, 4, 4, "Header part 2 (547447767)"); 80 print_decode_line(pHdr, 4, 4, "Header part 2 (547447767)");
82 nPage = 81 nPage =
83 print_decode_line(pHdr, 8, 4, "page count"); 82 print_decode_line(pHdr, 8, 4, "page count");
84 cksumNonce = 83 cksumNonce =
85 print_decode_line(pHdr, 12, 4, "chksum nonce"); 84 print_decode_line(pHdr, 12, 4, "chksum nonce");
86 print_decode_line(pHdr, 16, 4, "initial database size in pages"); 85 print_decode_line(pHdr, 16, 4, "initial database size in pages");
87 sectorSize = 86 sectorSize =
88 print_decode_line(pHdr, 20, 4, "sector size"); 87 print_decode_line(pHdr, 20, 4, "sector size");
89 pageSize = 88 pageSize =
90 print_decode_line(pHdr, 24, 4, "page size"); 89 print_decode_line(pHdr, 24, 4, "page size");
91 print_decode_line(pHdr, 28, 4, "zero"); 90 print_decode_line(pHdr, 28, 4, "zero");
92 print_decode_line(pHdr, 32, 4, "zero"); 91 print_decode_line(pHdr, 32, 4, "zero");
93 print_decode_line(pHdr, 36, 4, "zero"); 92 print_decode_line(pHdr, 36, 4, "zero");
94 print_decode_line(pHdr, 40, 4, "zero"); 93 print_decode_line(pHdr, 40, 4, "zero");
95 free(pHdr); 94 free(pHdr);
96 return nPage; 95 return nPage;
97 } 96 }
98 97
99 static void print_page(int iOfst){ 98 static void print_page(int iOfst){
100 unsigned char *aData; 99 unsigned char *aData;
101 char zTitle[50]; 100 char zTitle[50];
102 aData = read_content(pageSize+8, iOfst); 101 aData = read_content(pageSize+8, iOfst);
103 sprintf(zTitle, "page number for page at offset %d", iOfst); 102 sprintf(zTitle, "page number for page at offset %d", iOfst);
104 print_decode_line(aData, 0, 4, zTitle); 103 print_decode_line(aData-iOfst, iOfst, 4, zTitle);
105 free(aData); 104 free(aData);
106 } 105 }
107 106
108 int main(int argc, char **argv){ 107 int main(int argc, char **argv){
109 int rc;
110 int nPage, cnt; 108 int nPage, cnt;
111 int iOfst; 109 int iOfst;
112 if( argc!=2 ){ 110 if( argc!=2 ){
113 fprintf(stderr,"Usage: %s FILENAME\n", argv[0]); 111 fprintf(stderr,"Usage: %s FILENAME\n", argv[0]);
114 exit(1); 112 exit(1);
115 } 113 }
116 db = fopen(argv[1], "rb"); 114 db = fopen(argv[1], "rb");
117 if( db==0 ){ 115 if( db==0 ){
118 fprintf(stderr,"%s: can't open %s\n", argv[0], argv[1]); 116 fprintf(stderr,"%s: can't open %s\n", argv[0], argv[1]);
119 exit(1); 117 exit(1);
120 } 118 }
121 fseek(db, 0, SEEK_END); 119 fseek(db, 0, SEEK_END);
122 fileSize = ftell(db); 120 fileSize = ftell(db);
123 printf("journal file size: %d bytes\n", fileSize); 121 printf("journal file size: %d bytes\n", fileSize);
124 fseek(db, 0, SEEK_SET); 122 fseek(db, 0, SEEK_SET);
125 iOfst = 0; 123 iOfst = 0;
126 while( iOfst<fileSize ){ 124 while( iOfst<fileSize ){
127 cnt = nPage = (int)decode_journal_header(iOfst); 125 cnt = nPage = (int)decode_journal_header(iOfst);
128 if( cnt==0 ){ 126 if( cnt==0 ){
129 cnt = (fileSize - sectorSize)/(pageSize+8); 127 cnt = (fileSize - sectorSize)/(pageSize+8);
130 } 128 }
131 iOfst += sectorSize; 129 iOfst += sectorSize;
132 while( cnt && iOfst<fileSize ){ 130 while( cnt && iOfst<fileSize ){
133 print_page(iOfst); 131 print_page(iOfst);
134 iOfst += pageSize+8; 132 iOfst += pageSize+8;
135 } 133 }
136 iOfst = (iOfst/sectorSize + 1)*sectorSize; 134 iOfst = (iOfst/sectorSize + 1)*sectorSize;
137 } 135 }
138 fclose(db); 136 fclose(db);
137 return 0;
139 } 138 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698