SQLite Android Bindings
Hex Artifact Content
Not logged in

Artifact 0d99d1b0e01edfc4b7c35aca79feb602102034bd:


0000: 2f 2a 0a 20 2a 20 43 6f 70 79 72 69 67 68 74 20  /*. * Copyright 
0010: 28 43 29 20 32 30 30 37 20 54 68 65 20 41 6e 64  (C) 2007 The And
0020: 72 6f 69 64 20 4f 70 65 6e 20 53 6f 75 72 63 65  roid Open Source
0030: 20 50 72 6f 6a 65 63 74 0a 20 2a 0a 20 2a 20 4c   Project. *. * L
0040: 69 63 65 6e 73 65 64 20 75 6e 64 65 72 20 74 68  icensed under th
0050: 65 20 41 70 61 63 68 65 20 4c 69 63 65 6e 73 65  e Apache License
0060: 2c 20 56 65 72 73 69 6f 6e 20 32 2e 30 20 28 74  , Version 2.0 (t
0070: 68 65 20 22 4c 69 63 65 6e 73 65 22 29 3b 0a 20  he "License");. 
0080: 2a 20 79 6f 75 20 6d 61 79 20 6e 6f 74 20 75 73  * you may not us
0090: 65 20 74 68 69 73 20 66 69 6c 65 20 65 78 63 65  e this file exce
00a0: 70 74 20 69 6e 20 63 6f 6d 70 6c 69 61 6e 63 65  pt in compliance
00b0: 20 77 69 74 68 20 74 68 65 20 4c 69 63 65 6e 73   with the Licens
00c0: 65 2e 0a 20 2a 20 59 6f 75 20 6d 61 79 20 6f 62  e.. * You may ob
00d0: 74 61 69 6e 20 61 20 63 6f 70 79 20 6f 66 20 74  tain a copy of t
00e0: 68 65 20 4c 69 63 65 6e 73 65 20 61 74 0a 20 2a  he License at. *
00f0: 0a 20 2a 20 20 20 20 20 20 68 74 74 70 3a 2f 2f  . *      http://
0100: 77 77 77 2e 61 70 61 63 68 65 2e 6f 72 67 2f 6c  www.apache.org/l
0110: 69 63 65 6e 73 65 73 2f 4c 49 43 45 4e 53 45 2d  icenses/LICENSE-
0120: 32 2e 30 0a 20 2a 0a 20 2a 20 55 6e 6c 65 73 73  2.0. *. * Unless
0130: 20 72 65 71 75 69 72 65 64 20 62 79 20 61 70 70   required by app
0140: 6c 69 63 61 62 6c 65 20 6c 61 77 20 6f 72 20 61  licable law or a
0150: 67 72 65 65 64 20 74 6f 20 69 6e 20 77 72 69 74  greed to in writ
0160: 69 6e 67 2c 20 73 6f 66 74 77 61 72 65 0a 20 2a  ing, software. *
0170: 20 64 69 73 74 72 69 62 75 74 65 64 20 75 6e 64   distributed und
0180: 65 72 20 74 68 65 20 4c 69 63 65 6e 73 65 20 69  er the License i
0190: 73 20 64 69 73 74 72 69 62 75 74 65 64 20 6f 6e  s distributed on
01a0: 20 61 6e 20 22 41 53 20 49 53 22 20 42 41 53 49   an "AS IS" BASI
01b0: 53 2c 0a 20 2a 20 57 49 54 48 4f 55 54 20 57 41  S,. * WITHOUT WA
01c0: 52 52 41 4e 54 49 45 53 20 4f 52 20 43 4f 4e 44  RRANTIES OR COND
01d0: 49 54 49 4f 4e 53 20 4f 46 20 41 4e 59 20 4b 49  ITIONS OF ANY KI
01e0: 4e 44 2c 20 65 69 74 68 65 72 20 65 78 70 72 65  ND, either expre
01f0: 73 73 20 6f 72 20 69 6d 70 6c 69 65 64 2e 0a 20  ss or implied.. 
0200: 2a 20 53 65 65 20 74 68 65 20 4c 69 63 65 6e 73  * See the Licens
0210: 65 20 66 6f 72 20 74 68 65 20 73 70 65 63 69 66  e for the specif
0220: 69 63 20 6c 61 6e 67 75 61 67 65 20 67 6f 76 65  ic language gove
0230: 72 6e 69 6e 67 20 70 65 72 6d 69 73 73 69 6f 6e  rning permission
0240: 73 20 61 6e 64 0a 20 2a 20 6c 69 6d 69 74 61 74  s and. * limitat
0250: 69 6f 6e 73 20 75 6e 64 65 72 20 74 68 65 20 4c  ions under the L
0260: 69 63 65 6e 73 65 2e 0a 20 2a 2f 0a 2f 2a 0a 2a  icense.. */./*.*
0270: 2a 20 4d 6f 64 69 66 69 65 64 20 74 6f 20 73 75  * Modified to su
0280: 70 70 6f 72 74 20 53 51 4c 69 74 65 20 65 78 74  pport SQLite ext
0290: 65 6e 73 69 6f 6e 73 20 62 79 20 74 68 65 20 53  ensions by the S
02a0: 51 4c 69 74 65 20 64 65 76 65 6c 6f 70 65 72 73  QLite developers
02b0: 3a 20 0a 2a 2a 20 73 71 6c 69 74 65 2d 64 65 76  : .** sqlite-dev
02c0: 40 73 71 6c 69 74 65 2e 6f 72 67 2e 0a 2a 2f 0a  @sqlite.org..*/.
02d0: 0a 23 64 65 66 69 6e 65 20 4c 4f 47 5f 54 41 47  .#define LOG_TAG
02e0: 20 22 53 51 4c 69 74 65 44 65 62 75 67 22 0a 0a   "SQLiteDebug"..
02f0: 23 69 6e 63 6c 75 64 65 20 3c 6a 6e 69 2e 68 3e  #include <jni.h>
0300: 0a 23 69 6e 63 6c 75 64 65 20 3c 4a 4e 49 48 65  .#include <JNIHe
0310: 6c 70 2e 68 3e 0a 23 69 6e 63 6c 75 64 65 20 3c  lp.h>.#include <
0320: 41 4c 6f 67 2d 70 72 69 76 2e 68 3e 0a 0a 23 69  ALog-priv.h>..#i
0330: 6e 63 6c 75 64 65 20 3c 73 74 64 69 6f 2e 68 3e  nclude <stdio.h>
0340: 0a 23 69 6e 63 6c 75 64 65 20 3c 73 74 64 6c 69  .#include <stdli
0350: 62 2e 68 3e 0a 23 69 6e 63 6c 75 64 65 20 3c 73  b.h>.#include <s
0360: 74 72 69 6e 67 2e 68 3e 0a 23 69 6e 63 6c 75 64  tring.h>.#includ
0370: 65 20 3c 75 6e 69 73 74 64 2e 68 3e 0a 0a 23 69  e <unistd.h>..#i
0380: 6e 63 6c 75 64 65 20 3c 73 71 6c 69 74 65 33 2e  nclude <sqlite3.
0390: 68 3e 0a 0a 6e 61 6d 65 73 70 61 63 65 20 61 6e  h>..namespace an
03a0: 64 72 6f 69 64 20 7b 0a 0a 73 74 61 74 69 63 20  droid {..static 
03b0: 73 74 72 75 63 74 20 7b 0a 20 20 20 20 6a 66 69  struct {.    jfi
03c0: 65 6c 64 49 44 20 6d 65 6d 6f 72 79 55 73 65 64  eldID memoryUsed
03d0: 3b 0a 20 20 20 20 6a 66 69 65 6c 64 49 44 20 70  ;.    jfieldID p
03e0: 61 67 65 43 61 63 68 65 4f 76 65 72 66 6c 6f 77  ageCacheOverflow
03f0: 3b 0a 20 20 20 20 6a 66 69 65 6c 64 49 44 20 6c  ;.    jfieldID l
0400: 61 72 67 65 73 74 4d 65 6d 41 6c 6c 6f 63 3b 0a  argestMemAlloc;.
0410: 7d 20 67 53 51 4c 69 74 65 44 65 62 75 67 50 61  } gSQLiteDebugPa
0420: 67 65 72 53 74 61 74 73 43 6c 61 73 73 49 6e 66  gerStatsClassInf
0430: 6f 3b 0a 0a 73 74 61 74 69 63 20 76 6f 69 64 20  o;..static void 
0440: 6e 61 74 69 76 65 47 65 74 50 61 67 65 72 53 74  nativeGetPagerSt
0450: 61 74 73 28 4a 4e 49 45 6e 76 20 2a 65 6e 76 2c  ats(JNIEnv *env,
0460: 20 6a 6f 62 6a 65 63 74 20 63 6c 61 7a 7a 2c 20   jobject clazz, 
0470: 6a 6f 62 6a 65 63 74 20 73 74 61 74 73 4f 62 6a  jobject statsObj
0480: 29 0a 7b 0a 20 20 20 20 69 6e 74 20 6d 65 6d 6f  ).{.    int memo
0490: 72 79 55 73 65 64 3b 0a 20 20 20 20 69 6e 74 20  ryUsed;.    int 
04a0: 70 61 67 65 43 61 63 68 65 4f 76 65 72 66 6c 6f  pageCacheOverflo
04b0: 77 3b 0a 20 20 20 20 69 6e 74 20 6c 61 72 67 65  w;.    int large
04c0: 73 74 4d 65 6d 41 6c 6c 6f 63 3b 0a 20 20 20 20  stMemAlloc;.    
04d0: 69 6e 74 20 75 6e 75 73 65 64 3b 0a 0a 20 20 20  int unused;..   
04e0: 20 73 71 6c 69 74 65 33 5f 73 74 61 74 75 73 28   sqlite3_status(
04f0: 53 51 4c 49 54 45 5f 53 54 41 54 55 53 5f 4d 45  SQLITE_STATUS_ME
0500: 4d 4f 52 59 5f 55 53 45 44 2c 20 26 6d 65 6d 6f  MORY_USED, &memo
0510: 72 79 55 73 65 64 2c 20 26 75 6e 75 73 65 64 2c  ryUsed, &unused,
0520: 20 30 29 3b 0a 20 20 20 20 73 71 6c 69 74 65 33   0);.    sqlite3
0530: 5f 73 74 61 74 75 73 28 53 51 4c 49 54 45 5f 53  _status(SQLITE_S
0540: 54 41 54 55 53 5f 4d 41 4c 4c 4f 43 5f 53 49 5a  TATUS_MALLOC_SIZ
0550: 45 2c 20 26 75 6e 75 73 65 64 2c 20 26 6c 61 72  E, &unused, &lar
0560: 67 65 73 74 4d 65 6d 41 6c 6c 6f 63 2c 20 30 29  gestMemAlloc, 0)
0570: 3b 0a 20 20 20 20 73 71 6c 69 74 65 33 5f 73 74  ;.    sqlite3_st
0580: 61 74 75 73 28 53 51 4c 49 54 45 5f 53 54 41 54  atus(SQLITE_STAT
0590: 55 53 5f 50 41 47 45 43 41 43 48 45 5f 4f 56 45  US_PAGECACHE_OVE
05a0: 52 46 4c 4f 57 2c 20 26 70 61 67 65 43 61 63 68  RFLOW, &pageCach
05b0: 65 4f 76 65 72 66 6c 6f 77 2c 20 26 75 6e 75 73  eOverflow, &unus
05c0: 65 64 2c 20 30 29 3b 0a 20 20 20 20 65 6e 76 2d  ed, 0);.    env-
05d0: 3e 53 65 74 49 6e 74 46 69 65 6c 64 28 73 74 61  >SetIntField(sta
05e0: 74 73 4f 62 6a 2c 20 67 53 51 4c 69 74 65 44 65  tsObj, gSQLiteDe
05f0: 62 75 67 50 61 67 65 72 53 74 61 74 73 43 6c 61  bugPagerStatsCla
0600: 73 73 49 6e 66 6f 2e 6d 65 6d 6f 72 79 55 73 65  ssInfo.memoryUse
0610: 64 2c 20 6d 65 6d 6f 72 79 55 73 65 64 29 3b 0a  d, memoryUsed);.
0620: 20 20 20 20 65 6e 76 2d 3e 53 65 74 49 6e 74 46      env->SetIntF
0630: 69 65 6c 64 28 73 74 61 74 73 4f 62 6a 2c 20 67  ield(statsObj, g
0640: 53 51 4c 69 74 65 44 65 62 75 67 50 61 67 65 72  SQLiteDebugPager
0650: 53 74 61 74 73 43 6c 61 73 73 49 6e 66 6f 2e 70  StatsClassInfo.p
0660: 61 67 65 43 61 63 68 65 4f 76 65 72 66 6c 6f 77  ageCacheOverflow
0670: 2c 0a 20 20 20 20 20 20 20 20 20 20 20 20 70 61  ,.            pa
0680: 67 65 43 61 63 68 65 4f 76 65 72 66 6c 6f 77 29  geCacheOverflow)
0690: 3b 0a 20 20 20 20 65 6e 76 2d 3e 53 65 74 49 6e  ;.    env->SetIn
06a0: 74 46 69 65 6c 64 28 73 74 61 74 73 4f 62 6a 2c  tField(statsObj,
06b0: 20 67 53 51 4c 69 74 65 44 65 62 75 67 50 61 67   gSQLiteDebugPag
06c0: 65 72 53 74 61 74 73 43 6c 61 73 73 49 6e 66 6f  erStatsClassInfo
06d0: 2e 6c 61 72 67 65 73 74 4d 65 6d 41 6c 6c 6f 63  .largestMemAlloc
06e0: 2c 20 6c 61 72 67 65 73 74 4d 65 6d 41 6c 6c 6f  , largestMemAllo
06f0: 63 29 3b 0a 7d 0a 0a 2f 2a 0a 20 2a 20 4a 4e 49  c);.}../*. * JNI
0700: 20 72 65 67 69 73 74 72 61 74 69 6f 6e 2e 0a 20   registration.. 
0710: 2a 2f 0a 0a 73 74 61 74 69 63 20 4a 4e 49 4e 61  */..static JNINa
0720: 74 69 76 65 4d 65 74 68 6f 64 20 67 4d 65 74 68  tiveMethod gMeth
0730: 6f 64 73 5b 5d 20 3d 0a 7b 0a 20 20 20 20 7b 20  ods[] =.{.    { 
0740: 22 6e 61 74 69 76 65 47 65 74 50 61 67 65 72 53  "nativeGetPagerS
0750: 74 61 74 73 22 2c 20 22 28 4c 6f 72 67 2f 73 71  tats", "(Lorg/sq
0760: 6c 69 74 65 2f 64 61 74 61 62 61 73 65 2f 73 71  lite/database/sq
0770: 6c 69 74 65 2f 53 51 4c 69 74 65 44 65 62 75 67  lite/SQLiteDebug
0780: 24 50 61 67 65 72 53 74 61 74 73 3b 29 56 22 2c  $PagerStats;)V",
0790: 0a 20 20 20 20 20 20 20 20 20 20 20 20 28 76 6f  .            (vo
07a0: 69 64 2a 29 20 6e 61 74 69 76 65 47 65 74 50 61  id*) nativeGetPa
07b0: 67 65 72 53 74 61 74 73 20 7d 2c 0a 7d 3b 0a 0a  gerStats },.};..
07c0: 23 64 65 66 69 6e 65 20 46 49 4e 44 5f 43 4c 41  #define FIND_CLA
07d0: 53 53 28 76 61 72 2c 20 63 6c 61 73 73 4e 61 6d  SS(var, classNam
07e0: 65 29 20 5c 0a 20 20 20 20 20 20 20 20 76 61 72  e) \.        var
07f0: 20 3d 20 65 6e 76 2d 3e 46 69 6e 64 43 6c 61 73   = env->FindClas
0800: 73 28 63 6c 61 73 73 4e 61 6d 65 29 3b 20 5c 0a  s(className); \.
0810: 20 20 20 20 20 20 20 20 4c 4f 47 5f 46 41 54 41          LOG_FATA
0820: 4c 5f 49 46 28 21 20 76 61 72 2c 20 22 55 6e 61  L_IF(! var, "Una
0830: 62 6c 65 20 74 6f 20 66 69 6e 64 20 63 6c 61 73  ble to find clas
0840: 73 20 22 20 63 6c 61 73 73 4e 61 6d 65 29 3b 0a  s " className);.
0850: 0a 23 64 65 66 69 6e 65 20 47 45 54 5f 46 49 45  .#define GET_FIE
0860: 4c 44 5f 49 44 28 76 61 72 2c 20 63 6c 61 7a 7a  LD_ID(var, clazz
0870: 2c 20 66 69 65 6c 64 4e 61 6d 65 2c 20 66 69 65  , fieldName, fie
0880: 6c 64 44 65 73 63 72 69 70 74 6f 72 29 20 5c 0a  ldDescriptor) \.
0890: 20 20 20 20 20 20 20 20 76 61 72 20 3d 20 65 6e          var = en
08a0: 76 2d 3e 47 65 74 46 69 65 6c 64 49 44 28 63 6c  v->GetFieldID(cl
08b0: 61 7a 7a 2c 20 66 69 65 6c 64 4e 61 6d 65 2c 20  azz, fieldName, 
08c0: 66 69 65 6c 64 44 65 73 63 72 69 70 74 6f 72 29  fieldDescriptor)
08d0: 3b 20 5c 0a 20 20 20 20 20 20 20 20 4c 4f 47 5f  ; \.        LOG_
08e0: 46 41 54 41 4c 5f 49 46 28 21 20 76 61 72 2c 20  FATAL_IF(! var, 
08f0: 22 55 6e 61 62 6c 65 20 74 6f 20 66 69 6e 64 20  "Unable to find 
0900: 66 69 65 6c 64 20 22 20 66 69 65 6c 64 4e 61 6d  field " fieldNam
0910: 65 29 3b 0a 0a 69 6e 74 20 72 65 67 69 73 74 65  e);..int registe
0920: 72 5f 61 6e 64 72 6f 69 64 5f 64 61 74 61 62 61  r_android_databa
0930: 73 65 5f 53 51 4c 69 74 65 44 65 62 75 67 28 4a  se_SQLiteDebug(J
0940: 4e 49 45 6e 76 20 2a 65 6e 76 29 0a 7b 0a 20 20  NIEnv *env).{.  
0950: 20 20 6a 63 6c 61 73 73 20 63 6c 61 7a 7a 3b 0a    jclass clazz;.
0960: 20 20 20 20 46 49 4e 44 5f 43 4c 41 53 53 28 63      FIND_CLASS(c
0970: 6c 61 7a 7a 2c 20 22 6f 72 67 2f 73 71 6c 69 74  lazz, "org/sqlit
0980: 65 2f 64 61 74 61 62 61 73 65 2f 73 71 6c 69 74  e/database/sqlit
0990: 65 2f 53 51 4c 69 74 65 44 65 62 75 67 24 50 61  e/SQLiteDebug$Pa
09a0: 67 65 72 53 74 61 74 73 22 29 3b 0a 0a 20 20 20  gerStats");..   
09b0: 20 47 45 54 5f 46 49 45 4c 44 5f 49 44 28 67 53   GET_FIELD_ID(gS
09c0: 51 4c 69 74 65 44 65 62 75 67 50 61 67 65 72 53  QLiteDebugPagerS
09d0: 74 61 74 73 43 6c 61 73 73 49 6e 66 6f 2e 6d 65  tatsClassInfo.me
09e0: 6d 6f 72 79 55 73 65 64 2c 20 63 6c 61 7a 7a 2c  moryUsed, clazz,
09f0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 22 6d 65  .            "me
0a00: 6d 6f 72 79 55 73 65 64 22 2c 20 22 49 22 29 3b  moryUsed", "I");
0a10: 0a 20 20 20 20 47 45 54 5f 46 49 45 4c 44 5f 49  .    GET_FIELD_I
0a20: 44 28 67 53 51 4c 69 74 65 44 65 62 75 67 50 61  D(gSQLiteDebugPa
0a30: 67 65 72 53 74 61 74 73 43 6c 61 73 73 49 6e 66  gerStatsClassInf
0a40: 6f 2e 6c 61 72 67 65 73 74 4d 65 6d 41 6c 6c 6f  o.largestMemAllo
0a50: 63 2c 20 63 6c 61 7a 7a 2c 0a 20 20 20 20 20 20  c, clazz,.      
0a60: 20 20 20 20 20 20 22 6c 61 72 67 65 73 74 4d 65        "largestMe
0a70: 6d 41 6c 6c 6f 63 22 2c 20 22 49 22 29 3b 0a 20  mAlloc", "I");. 
0a80: 20 20 20 47 45 54 5f 46 49 45 4c 44 5f 49 44 28     GET_FIELD_ID(
0a90: 67 53 51 4c 69 74 65 44 65 62 75 67 50 61 67 65  gSQLiteDebugPage
0aa0: 72 53 74 61 74 73 43 6c 61 73 73 49 6e 66 6f 2e  rStatsClassInfo.
0ab0: 70 61 67 65 43 61 63 68 65 4f 76 65 72 66 6c 6f  pageCacheOverflo
0ac0: 77 2c 20 63 6c 61 7a 7a 2c 0a 20 20 20 20 20 20  w, clazz,.      
0ad0: 20 20 20 20 20 20 22 70 61 67 65 43 61 63 68 65        "pageCache
0ae0: 4f 76 65 72 66 6c 6f 77 22 2c 20 22 49 22 29 3b  Overflow", "I");
0af0: 0a 0a 20 20 20 20 72 65 74 75 72 6e 20 6a 6e 69  ..    return jni
0b00: 52 65 67 69 73 74 65 72 4e 61 74 69 76 65 4d 65  RegisterNativeMe
0b10: 74 68 6f 64 73 28 65 6e 76 2c 20 22 6f 72 67 2f  thods(env, "org/
0b20: 73 71 6c 69 74 65 2f 64 61 74 61 62 61 73 65 2f  sqlite/database/
0b30: 73 71 6c 69 74 65 2f 53 51 4c 69 74 65 44 65 62  sqlite/SQLiteDeb
0b40: 75 67 22 2c 0a 20 20 20 20 20 20 20 20 20 20 20  ug",.           
0b50: 20 67 4d 65 74 68 6f 64 73 2c 20 4e 45 4c 45 4d   gMethods, NELEM
0b60: 28 67 4d 65 74 68 6f 64 73 29 29 3b 0a 7d 0a 0a  (gMethods));.}..
0b70: 7d 20 2f 2f 20 6e 61 6d 65 73 70 61 63 65 20 61  } // namespace a
0b80: 6e 64 72 6f 69 64 0a                             ndroid.