/ Hex Artifact Content
Login

Artifact e42d3ae79511ee86545bed07e9e5e7321f8139b55cdf73f60849352070bf12ad:


0000: 2f 2a 0a 2a 2a 20 32 30 31 37 2d 31 32 2d 32 36  /*.** 2017-12-26
0010: 0a 2a 2a 0a 2a 2a 20 54 68 65 20 61 75 74 68 6f  .**.** The autho
0020: 72 20 64 69 73 63 6c 61 69 6d 73 20 63 6f 70 79  r disclaims copy
0030: 72 69 67 68 74 20 74 6f 20 74 68 69 73 20 73 6f  right to this so
0040: 75 72 63 65 20 63 6f 64 65 2e 20 20 49 6e 20 70  urce code.  In p
0050: 6c 61 63 65 20 6f 66 0a 2a 2a 20 61 20 6c 65 67  lace of.** a leg
0060: 61 6c 20 6e 6f 74 69 63 65 2c 20 68 65 72 65 20  al notice, here 
0070: 69 73 20 61 20 62 6c 65 73 73 69 6e 67 3a 0a 2a  is a blessing:.*
0080: 2a 0a 2a 2a 20 20 20 20 4d 61 79 20 79 6f 75 20  *.**    May you 
0090: 64 6f 20 67 6f 6f 64 20 61 6e 64 20 6e 6f 74 20  do good and not 
00a0: 65 76 69 6c 2e 0a 2a 2a 20 20 20 20 4d 61 79 20  evil..**    May 
00b0: 79 6f 75 20 66 69 6e 64 20 66 6f 72 67 69 76 65  you find forgive
00c0: 6e 65 73 73 20 66 6f 72 20 79 6f 75 72 73 65 6c  ness for yoursel
00d0: 66 20 61 6e 64 20 66 6f 72 67 69 76 65 20 6f 74  f and forgive ot
00e0: 68 65 72 73 2e 0a 2a 2a 20 20 20 20 4d 61 79 20  hers..**    May 
00f0: 79 6f 75 20 73 68 61 72 65 20 66 72 65 65 6c 79  you share freely
0100: 2c 20 6e 65 76 65 72 20 74 61 6b 69 6e 67 20 6d  , never taking m
0110: 6f 72 65 20 74 68 61 6e 20 79 6f 75 20 67 69 76  ore than you giv
0120: 65 2e 0a 2a 2a 0a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  e..**.**********
0130: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0140: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0150: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0160: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0170: 2a 2a 2a 2a 0a 2a 2a 0a 2a 2a 20 54 68 69 73 20  ****.**.** This 
0180: 66 69 6c 65 20 69 6d 70 6c 65 6d 65 6e 74 73 20  file implements 
0190: 61 20 76 69 72 74 75 61 6c 20 74 61 62 6c 65 20  a virtual table 
01a0: 66 6f 72 20 72 65 61 64 69 6e 67 20 61 6e 64 20  for reading and 
01b0: 77 72 69 74 69 6e 67 20 5a 49 50 20 61 72 63 68  writing ZIP arch
01c0: 69 76 65 0a 2a 2a 20 66 69 6c 65 73 2e 0a 2a 2a  ive.** files..**
01d0: 0a 2a 2a 20 55 73 61 67 65 20 65 78 61 6d 70 6c  .** Usage exampl
01e0: 65 3a 0a 2a 2a 0a 2a 2a 20 20 20 20 20 53 45 4c  e:.**.**     SEL
01f0: 45 43 54 20 6e 61 6d 65 2c 20 73 7a 2c 20 64 61  ECT name, sz, da
0200: 74 65 74 69 6d 65 28 6d 74 69 6d 65 2c 27 75 6e  tetime(mtime,'un
0210: 69 78 65 70 6f 63 68 27 29 20 46 52 4f 4d 20 7a  ixepoch') FROM z
0220: 69 70 66 69 6c 65 28 24 66 69 6c 65 6e 61 6d 65  ipfile($filename
0230: 29 3b 0a 2a 2a 0a 2a 2a 20 43 75 72 72 65 6e 74  );.**.** Current
0240: 20 6c 69 6d 69 74 61 74 69 6f 6e 73 3a 0a 2a 2a   limitations:.**
0250: 0a 2a 2a 20 20 20 20 2a 20 20 4e 6f 20 73 75 70  .**    *  No sup
0260: 70 6f 72 74 20 66 6f 72 20 65 6e 63 72 79 70 74  port for encrypt
0270: 69 6f 6e 0a 2a 2a 20 20 20 20 2a 20 20 4e 6f 20  ion.**    *  No 
0280: 73 75 70 70 6f 72 74 20 66 6f 72 20 5a 49 50 20  support for ZIP 
0290: 61 72 63 68 69 76 65 73 20 73 70 61 6e 6e 69 6e  archives spannin
02a0: 67 20 6d 75 6c 74 69 70 6c 65 20 66 69 6c 65 73  g multiple files
02b0: 0a 2a 2a 20 20 20 20 2a 20 20 4e 6f 20 73 75 70  .**    *  No sup
02c0: 70 6f 72 74 20 66 6f 72 20 7a 69 70 36 34 20 65  port for zip64 e
02d0: 78 74 65 6e 73 69 6f 6e 73 0a 2a 2a 20 20 20 20  xtensions.**    
02e0: 2a 20 20 4f 6e 6c 79 20 74 68 65 20 22 69 6e 66  *  Only the "inf
02f0: 6c 61 74 65 2f 64 65 66 6c 61 74 65 22 20 28 7a  late/deflate" (z
0300: 6c 69 62 29 20 63 6f 6d 70 72 65 73 73 69 6f 6e  lib) compression
0310: 20 6d 65 74 68 6f 64 20 69 73 20 73 75 70 70 6f   method is suppo
0320: 72 74 65 64 0a 2a 2f 0a 23 69 6e 63 6c 75 64 65  rted.*/.#include
0330: 20 22 73 71 6c 69 74 65 33 65 78 74 2e 68 22 0a   "sqlite3ext.h".
0340: 53 51 4c 49 54 45 5f 45 58 54 45 4e 53 49 4f 4e  SQLITE_EXTENSION
0350: 5f 49 4e 49 54 31 0a 23 69 6e 63 6c 75 64 65 20  _INIT1.#include 
0360: 3c 73 74 64 69 6f 2e 68 3e 0a 23 69 6e 63 6c 75  <stdio.h>.#inclu
0370: 64 65 20 3c 73 74 72 69 6e 67 2e 68 3e 0a 23 69  de <string.h>.#i
0380: 6e 63 6c 75 64 65 20 3c 61 73 73 65 72 74 2e 68  nclude <assert.h
0390: 3e 0a 0a 23 69 6e 63 6c 75 64 65 20 3c 73 79 73  >..#include <sys
03a0: 2f 74 79 70 65 73 2e 68 3e 0a 23 69 6e 63 6c 75  /types.h>.#inclu
03b0: 64 65 20 3c 73 79 73 2f 73 74 61 74 2e 68 3e 0a  de <sys/stat.h>.
03c0: 23 69 6e 63 6c 75 64 65 20 3c 66 63 6e 74 6c 2e  #include <fcntl.
03d0: 68 3e 0a 23 69 66 20 21 64 65 66 69 6e 65 64 28  h>.#if !defined(
03e0: 5f 57 49 4e 33 32 29 20 26 26 20 21 64 65 66 69  _WIN32) && !defi
03f0: 6e 65 64 28 57 49 4e 33 32 29 0a 23 20 20 69 6e  ned(WIN32).#  in
0400: 63 6c 75 64 65 20 3c 75 6e 69 73 74 64 2e 68 3e  clude <unistd.h>
0410: 0a 23 20 20 69 6e 63 6c 75 64 65 20 3c 64 69 72  .#  include <dir
0420: 65 6e 74 2e 68 3e 0a 23 20 20 69 6e 63 6c 75 64  ent.h>.#  includ
0430: 65 20 3c 75 74 69 6d 65 2e 68 3e 0a 23 65 6c 73  e <utime.h>.#els
0440: 65 0a 23 20 20 69 6e 63 6c 75 64 65 20 3c 69 6f  e.#  include <io
0450: 2e 68 3e 0a 23 65 6e 64 69 66 0a 23 69 6e 63 6c  .h>.#endif.#incl
0460: 75 64 65 20 3c 74 69 6d 65 2e 68 3e 0a 23 69 6e  ude <time.h>.#in
0470: 63 6c 75 64 65 20 3c 65 72 72 6e 6f 2e 68 3e 0a  clude <errno.h>.
0480: 0a 23 69 6e 63 6c 75 64 65 20 3c 7a 6c 69 62 2e  .#include <zlib.
0490: 68 3e 0a 0a 23 69 66 6e 64 65 66 20 53 51 4c 49  h>..#ifndef SQLI
04a0: 54 45 5f 4f 4d 49 54 5f 56 49 52 54 55 41 4c 54  TE_OMIT_VIRTUALT
04b0: 41 42 4c 45 0a 0a 23 69 66 6e 64 65 66 20 53 51  ABLE..#ifndef SQ
04c0: 4c 49 54 45 5f 41 4d 41 4c 47 41 4d 41 54 49 4f  LITE_AMALGAMATIO
04d0: 4e 0a 74 79 70 65 64 65 66 20 73 71 6c 69 74 65  N.typedef sqlite
04e0: 33 5f 69 6e 74 36 34 20 69 36 34 3b 0a 74 79 70  3_int64 i64;.typ
04f0: 65 64 65 66 20 75 6e 73 69 67 6e 65 64 20 63 68  edef unsigned ch
0500: 61 72 20 75 38 3b 0a 74 79 70 65 64 65 66 20 75  ar u8;.typedef u
0510: 6e 73 69 67 6e 65 64 20 73 68 6f 72 74 20 75 31  nsigned short u1
0520: 36 3b 0a 74 79 70 65 64 65 66 20 75 6e 73 69 67  6;.typedef unsig
0530: 6e 65 64 20 6c 6f 6e 67 20 75 33 32 3b 0a 23 64  ned long u32;.#d
0540: 65 66 69 6e 65 20 4d 49 4e 28 61 2c 62 29 20 28  efine MIN(a,b) (
0550: 28 61 29 3c 28 62 29 20 3f 20 28 61 29 20 3a 20  (a)<(b) ? (a) : 
0560: 28 62 29 29 0a 23 65 6e 64 69 66 0a 0a 73 74 61  (b)).#endif..sta
0570: 74 69 63 20 63 6f 6e 73 74 20 63 68 61 72 20 5a  tic const char Z
0580: 49 50 46 49 4c 45 5f 53 43 48 45 4d 41 5b 5d 20  IPFILE_SCHEMA[] 
0590: 3d 20 0a 20 20 22 43 52 45 41 54 45 20 54 41 42  = .  "CREATE TAB
05a0: 4c 45 20 79 28 22 0a 20 20 20 20 22 6e 61 6d 65  LE y(".    "name
05b0: 20 50 52 49 4d 41 52 59 20 4b 45 59 2c 22 20 20   PRIMARY KEY,"  
05c0: 2f 2a 20 30 3a 20 4e 61 6d 65 20 6f 66 20 66 69  /* 0: Name of fi
05d0: 6c 65 20 69 6e 20 7a 69 70 20 61 72 63 68 69 76  le in zip archiv
05e0: 65 20 2a 2f 0a 20 20 20 20 22 6d 6f 64 65 2c 22  e */.    "mode,"
05f0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a                /*
0600: 20 31 3a 20 50 4f 53 49 58 20 6d 6f 64 65 20 66   1: POSIX mode f
0610: 6f 72 20 66 69 6c 65 20 2a 2f 0a 20 20 20 20 22  or file */.    "
0620: 6d 74 69 6d 65 2c 22 20 20 20 20 20 20 20 20 20  mtime,"         
0630: 20 20 20 20 2f 2a 20 32 3a 20 4c 61 73 74 20 6d      /* 2: Last m
0640: 6f 64 69 66 69 63 61 74 69 6f 6e 20 74 69 6d 65  odification time
0650: 20 28 73 65 63 73 20 73 69 6e 63 65 20 31 39 37   (secs since 197
0660: 30 29 2a 2f 0a 20 20 20 20 22 73 7a 2c 22 20 20  0)*/.    "sz,"  
0670: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a                /*
0680: 20 33 3a 20 53 69 7a 65 20 6f 66 20 6f 62 6a 65   3: Size of obje
0690: 63 74 20 2a 2f 0a 20 20 20 20 22 72 61 77 64 61  ct */.    "rawda
06a0: 74 61 2c 22 20 20 20 20 20 20 20 20 20 20 20 2f  ta,"           /
06b0: 2a 20 34 3a 20 52 61 77 20 64 61 74 61 20 2a 2f  * 4: Raw data */
06c0: 0a 20 20 20 20 22 64 61 74 61 2c 22 20 20 20 20  .    "data,"    
06d0: 20 20 20 20 20 20 20 20 20 20 2f 2a 20 35 3a 20            /* 5: 
06e0: 55 6e 63 6f 6d 70 72 65 73 73 65 64 20 64 61 74  Uncompressed dat
06f0: 61 20 2a 2f 0a 20 20 20 20 22 6d 65 74 68 6f 64  a */.    "method
0700: 2c 22 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a  ,"            /*
0710: 20 36 3a 20 43 6f 6d 70 72 65 73 73 69 6f 6e 20   6: Compression 
0720: 6d 65 74 68 6f 64 20 28 69 6e 74 65 67 65 72 29  method (integer)
0730: 20 2a 2f 0a 20 20 20 20 22 66 69 6c 65 20 48 49   */.    "file HI
0740: 44 44 45 4e 22 20 20 20 20 20 20 20 20 2f 2a 20  DDEN"        /* 
0750: 37 3a 20 4e 61 6d 65 20 6f 66 20 7a 69 70 20 66  7: Name of zip f
0760: 69 6c 65 20 2a 2f 0a 20 20 22 29 20 57 49 54 48  ile */.  ") WITH
0770: 4f 55 54 20 52 4f 57 49 44 3b 22 3b 0a 0a 23 64  OUT ROWID;";..#d
0780: 65 66 69 6e 65 20 5a 49 50 46 49 4c 45 5f 46 5f  efine ZIPFILE_F_
0790: 43 4f 4c 55 4d 4e 5f 49 44 58 20 37 20 20 20 20  COLUMN_IDX 7    
07a0: 2f 2a 20 49 6e 64 65 78 20 6f 66 20 63 6f 6c 75  /* Index of colu
07b0: 6d 6e 20 22 66 69 6c 65 22 20 69 6e 20 74 68 65  mn "file" in the
07c0: 20 61 62 6f 76 65 20 2a 2f 0a 23 64 65 66 69 6e   above */.#defin
07d0: 65 20 5a 49 50 46 49 4c 45 5f 42 55 46 46 45 52  e ZIPFILE_BUFFER
07e0: 5f 53 49 5a 45 20 28 36 34 2a 31 30 32 34 29 0a  _SIZE (64*1024).
07f0: 0a 0a 2f 2a 0a 2a 2a 20 4d 61 67 69 63 20 6e 75  ../*.** Magic nu
0800: 6d 62 65 72 73 20 75 73 65 64 20 74 6f 20 72 65  mbers used to re
0810: 61 64 20 61 6e 64 20 77 72 69 74 65 20 7a 69 70  ad and write zip
0820: 20 66 69 6c 65 73 2e 0a 2a 2a 0a 2a 2a 20 5a 49   files..**.** ZI
0830: 50 46 49 4c 45 5f 4e 45 57 45 4e 54 52 59 5f 4d  PFILE_NEWENTRY_M
0840: 41 44 45 42 59 3a 0a 2a 2a 20 20 20 55 73 65 20  ADEBY:.**   Use 
0850: 74 68 69 73 20 76 61 6c 75 65 20 66 6f 72 20 74  this value for t
0860: 68 65 20 22 76 65 72 73 69 6f 6e 2d 6d 61 64 65  he "version-made
0870: 2d 62 79 22 20 66 69 65 6c 64 20 69 6e 20 6e 65  -by" field in ne
0880: 77 20 7a 69 70 20 66 69 6c 65 0a 2a 2a 20 20 20  w zip file.**   
0890: 65 6e 74 72 69 65 73 2e 20 54 68 65 20 75 70 70  entries. The upp
08a0: 65 72 20 62 79 74 65 20 69 6e 64 69 63 61 74 65  er byte indicate
08b0: 73 20 22 75 6e 69 78 22 2c 20 61 6e 64 20 74 68  s "unix", and th
08c0: 65 20 6c 6f 77 65 72 20 62 79 74 65 20 0a 2a 2a  e lower byte .**
08d0: 20 20 20 69 6e 64 69 63 61 74 65 73 20 74 68 61     indicates tha
08e0: 74 20 74 68 65 20 7a 69 70 20 66 69 6c 65 20 6d  t the zip file m
08f0: 61 74 63 68 65 73 20 70 6b 7a 69 70 20 73 70 65  atches pkzip spe
0900: 63 69 66 69 63 61 74 69 6f 6e 20 33 2e 30 2e 20  cification 3.0. 
0910: 0a 2a 2a 20 20 20 54 68 69 73 20 69 73 20 77 68  .**   This is wh
0920: 61 74 20 69 6e 66 6f 2d 7a 69 70 20 73 65 65 6d  at info-zip seem
0930: 73 20 74 6f 20 64 6f 2e 0a 2a 2a 0a 2a 2a 20 5a  s to do..**.** Z
0940: 49 50 46 49 4c 45 5f 4e 45 57 45 4e 54 52 59 5f  IPFILE_NEWENTRY_
0950: 52 45 51 55 49 52 45 44 3a 0a 2a 2a 20 20 20 56  REQUIRED:.**   V
0960: 61 6c 75 65 20 66 6f 72 20 22 76 65 72 73 69 6f  alue for "versio
0970: 6e 2d 72 65 71 75 69 72 65 64 2d 74 6f 2d 65 78  n-required-to-ex
0980: 74 72 61 63 74 22 20 66 69 65 6c 64 20 6f 66 20  tract" field of 
0990: 6e 65 77 20 65 6e 74 72 69 65 73 2e 0a 2a 2a 20  new entries..** 
09a0: 20 20 56 65 72 73 69 6f 6e 20 32 2e 30 20 69 73    Version 2.0 is
09b0: 20 72 65 71 75 69 72 65 64 20 74 6f 20 73 75 70   required to sup
09c0: 70 6f 72 74 20 66 6f 6c 64 65 72 73 20 61 6e 64  port folders and
09d0: 20 64 65 66 6c 61 74 65 20 63 6f 6d 70 72 65 73   deflate compres
09e0: 73 69 6f 6e 2e 0a 2a 2a 0a 2a 2a 20 5a 49 50 46  sion..**.** ZIPF
09f0: 49 4c 45 5f 4e 45 57 45 4e 54 52 59 5f 46 4c 41  ILE_NEWENTRY_FLA
0a00: 47 53 3a 0a 2a 2a 20 20 20 56 61 6c 75 65 20 66  GS:.**   Value f
0a10: 6f 72 20 22 67 65 6e 65 72 61 6c 2d 70 75 72 70  or "general-purp
0a20: 6f 73 65 2d 62 69 74 2d 66 6c 61 67 73 22 20 66  ose-bit-flags" f
0a30: 69 65 6c 64 20 6f 66 20 6e 65 77 20 65 6e 74 72  ield of new entr
0a40: 69 65 73 2e 20 42 69 74 0a 2a 2a 20 20 20 31 31  ies. Bit.**   11
0a50: 20 6d 65 61 6e 73 20 22 75 74 66 2d 38 20 66 69   means "utf-8 fi
0a60: 6c 65 6e 61 6d 65 20 61 6e 64 20 63 6f 6d 6d 65  lename and comme
0a70: 6e 74 22 2e 0a 2a 2a 0a 2a 2a 20 5a 49 50 46 49  nt"..**.** ZIPFI
0a80: 4c 45 5f 53 49 47 4e 41 54 55 52 45 5f 43 44 53  LE_SIGNATURE_CDS
0a90: 3a 0a 2a 2a 20 20 20 46 69 72 73 74 20 34 20 62  :.**   First 4 b
0aa0: 79 74 65 73 20 6f 66 20 61 20 76 61 6c 69 64 20  ytes of a valid 
0ab0: 43 44 53 20 72 65 63 6f 72 64 2e 0a 2a 2a 0a 2a  CDS record..**.*
0ac0: 2a 20 5a 49 50 46 49 4c 45 5f 53 49 47 4e 41 54  * ZIPFILE_SIGNAT
0ad0: 55 52 45 5f 4c 46 48 3a 0a 2a 2a 20 20 20 46 69  URE_LFH:.**   Fi
0ae0: 72 73 74 20 34 20 62 79 74 65 73 20 6f 66 20 61  rst 4 bytes of a
0af0: 20 76 61 6c 69 64 20 4c 46 48 20 72 65 63 6f 72   valid LFH recor
0b00: 64 2e 0a 2a 2f 0a 23 64 65 66 69 6e 65 20 5a 49  d..*/.#define ZI
0b10: 50 46 49 4c 45 5f 45 58 54 52 41 5f 54 49 4d 45  PFILE_EXTRA_TIME
0b20: 53 54 41 4d 50 20 20 20 30 78 35 34 35 35 0a 23  STAMP   0x5455.#
0b30: 64 65 66 69 6e 65 20 5a 49 50 46 49 4c 45 5f 4e  define ZIPFILE_N
0b40: 45 57 45 4e 54 52 59 5f 4d 41 44 45 42 59 20 20  EWENTRY_MADEBY  
0b50: 20 28 28 33 3c 3c 38 29 20 2b 20 33 30 29 0a 23   ((3<<8) + 30).#
0b60: 64 65 66 69 6e 65 20 5a 49 50 46 49 4c 45 5f 4e  define ZIPFILE_N
0b70: 45 57 45 4e 54 52 59 5f 52 45 51 55 49 52 45 44  EWENTRY_REQUIRED
0b80: 20 32 30 0a 23 64 65 66 69 6e 65 20 5a 49 50 46   20.#define ZIPF
0b90: 49 4c 45 5f 4e 45 57 45 4e 54 52 59 5f 46 4c 41  ILE_NEWENTRY_FLA
0ba0: 47 53 20 20 20 20 30 78 38 30 30 0a 23 64 65 66  GS    0x800.#def
0bb0: 69 6e 65 20 5a 49 50 46 49 4c 45 5f 53 49 47 4e  ine ZIPFILE_SIGN
0bc0: 41 54 55 52 45 5f 43 44 53 20 20 20 20 20 30 78  ATURE_CDS     0x
0bd0: 30 32 30 31 34 62 35 30 0a 23 64 65 66 69 6e 65  02014b50.#define
0be0: 20 5a 49 50 46 49 4c 45 5f 53 49 47 4e 41 54 55   ZIPFILE_SIGNATU
0bf0: 52 45 5f 4c 46 48 20 20 20 20 20 30 78 30 34 30  RE_LFH     0x040
0c00: 33 34 62 35 30 0a 23 64 65 66 69 6e 65 20 5a 49  34b50.#define ZI
0c10: 50 46 49 4c 45 5f 53 49 47 4e 41 54 55 52 45 5f  PFILE_SIGNATURE_
0c20: 45 4f 43 44 20 20 20 20 30 78 30 36 30 35 34 62  EOCD    0x06054b
0c30: 35 30 0a 23 64 65 66 69 6e 65 20 5a 49 50 46 49  50.#define ZIPFI
0c40: 4c 45 5f 4c 46 48 5f 46 49 58 45 44 5f 53 5a 20  LE_LFH_FIXED_SZ 
0c50: 20 20 20 20 20 33 30 0a 0a 2f 2a 0a 2a 2a 20 53       30../*.** S
0c60: 65 74 20 74 68 65 20 65 72 72 6f 72 20 6d 65 73  et the error mes
0c70: 73 61 67 65 20 63 6f 6e 74 61 69 6e 65 64 20 69  sage contained i
0c80: 6e 20 63 6f 6e 74 65 78 74 20 63 74 78 20 74 6f  n context ctx to
0c90: 20 74 68 65 20 72 65 73 75 6c 74 73 20 6f 66 0a   the results of.
0ca0: 2a 2a 20 76 70 72 69 6e 74 66 28 7a 46 6d 74 2c  ** vprintf(zFmt,
0cb0: 20 2e 2e 2e 29 2e 0a 2a 2f 0a 73 74 61 74 69 63   ...)..*/.static
0cc0: 20 76 6f 69 64 20 7a 69 70 66 69 6c 65 43 74 78   void zipfileCtx
0cd0: 45 72 72 6f 72 4d 73 67 28 73 71 6c 69 74 65 33  ErrorMsg(sqlite3
0ce0: 5f 63 6f 6e 74 65 78 74 20 2a 63 74 78 2c 20 63  _context *ctx, c
0cf0: 6f 6e 73 74 20 63 68 61 72 20 2a 7a 46 6d 74 2c  onst char *zFmt,
0d00: 20 2e 2e 2e 29 7b 0a 20 20 63 68 61 72 20 2a 7a   ...){.  char *z
0d10: 4d 73 67 20 3d 20 30 3b 0a 20 20 76 61 5f 6c 69  Msg = 0;.  va_li
0d20: 73 74 20 61 70 3b 0a 20 20 76 61 5f 73 74 61 72  st ap;.  va_star
0d30: 74 28 61 70 2c 20 7a 46 6d 74 29 3b 0a 20 20 7a  t(ap, zFmt);.  z
0d40: 4d 73 67 20 3d 20 73 71 6c 69 74 65 33 5f 76 6d  Msg = sqlite3_vm
0d50: 70 72 69 6e 74 66 28 7a 46 6d 74 2c 20 61 70 29  printf(zFmt, ap)
0d60: 3b 0a 20 20 73 71 6c 69 74 65 33 5f 72 65 73 75  ;.  sqlite3_resu
0d70: 6c 74 5f 65 72 72 6f 72 28 63 74 78 2c 20 7a 4d  lt_error(ctx, zM
0d80: 73 67 2c 20 2d 31 29 3b 0a 20 20 73 71 6c 69 74  sg, -1);.  sqlit
0d90: 65 33 5f 66 72 65 65 28 7a 4d 73 67 29 3b 0a 20  e3_free(zMsg);. 
0da0: 20 76 61 5f 65 6e 64 28 61 70 29 3b 0a 7d 0a 0a   va_end(ap);.}..
0db0: 0a 2f 2a 0a 2a 2a 2a 20 34 2e 33 2e 31 36 20 20  ./*.*** 4.3.16  
0dc0: 45 6e 64 20 6f 66 20 63 65 6e 74 72 61 6c 20 64  End of central d
0dd0: 69 72 65 63 74 6f 72 79 20 72 65 63 6f 72 64 3a  irectory record:
0de0: 0a 2a 2a 2a 0a 2a 2a 2a 20 20 20 65 6e 64 20 6f  .***.***   end o
0df0: 66 20 63 65 6e 74 72 61 6c 20 64 69 72 20 73 69  f central dir si
0e00: 67 6e 61 74 75 72 65 20 20 20 20 34 20 62 79 74  gnature    4 byt
0e10: 65 73 20 20 28 30 78 30 36 30 35 34 62 35 30 29  es  (0x06054b50)
0e20: 0a 2a 2a 2a 20 20 20 6e 75 6d 62 65 72 20 6f 66  .***   number of
0e30: 20 74 68 69 73 20 64 69 73 6b 20 20 20 20 20 20   this disk      
0e40: 20 20 20 20 20 20 20 32 20 62 79 74 65 73 0a 2a         2 bytes.*
0e50: 2a 2a 20 20 20 6e 75 6d 62 65 72 20 6f 66 20 74  **   number of t
0e60: 68 65 20 64 69 73 6b 20 77 69 74 68 20 74 68 65  he disk with the
0e70: 0a 2a 2a 2a 20 20 20 73 74 61 72 74 20 6f 66 20  .***   start of 
0e80: 74 68 65 20 63 65 6e 74 72 61 6c 20 64 69 72 65  the central dire
0e90: 63 74 6f 72 79 20 20 32 20 62 79 74 65 73 0a 2a  ctory  2 bytes.*
0ea0: 2a 2a 20 20 20 74 6f 74 61 6c 20 6e 75 6d 62 65  **   total numbe
0eb0: 72 20 6f 66 20 65 6e 74 72 69 65 73 20 69 6e 20  r of entries in 
0ec0: 74 68 65 0a 2a 2a 2a 20 20 20 63 65 6e 74 72 61  the.***   centra
0ed0: 6c 20 64 69 72 65 63 74 6f 72 79 20 6f 6e 20 74  l directory on t
0ee0: 68 69 73 20 64 69 73 6b 20 20 32 20 62 79 74 65  his disk  2 byte
0ef0: 73 0a 2a 2a 2a 20 20 20 74 6f 74 61 6c 20 6e 75  s.***   total nu
0f00: 6d 62 65 72 20 6f 66 20 65 6e 74 72 69 65 73 20  mber of entries 
0f10: 69 6e 0a 2a 2a 2a 20 20 20 74 68 65 20 63 65 6e  in.***   the cen
0f20: 74 72 61 6c 20 64 69 72 65 63 74 6f 72 79 20 20  tral directory  
0f30: 20 20 20 20 20 20 20 20 20 32 20 62 79 74 65 73           2 bytes
0f40: 0a 2a 2a 2a 20 20 20 73 69 7a 65 20 6f 66 20 74  .***   size of t
0f50: 68 65 20 63 65 6e 74 72 61 6c 20 64 69 72 65 63  he central direc
0f60: 74 6f 72 79 20 20 20 34 20 62 79 74 65 73 0a 2a  tory   4 bytes.*
0f70: 2a 2a 20 20 20 6f 66 66 73 65 74 20 6f 66 20 73  **   offset of s
0f80: 74 61 72 74 20 6f 66 20 63 65 6e 74 72 61 6c 0a  tart of central.
0f90: 2a 2a 2a 20 20 20 64 69 72 65 63 74 6f 72 79 20  ***   directory 
0fa0: 77 69 74 68 20 72 65 73 70 65 63 74 20 74 6f 0a  with respect to.
0fb0: 2a 2a 2a 20 20 20 74 68 65 20 73 74 61 72 74 69  ***   the starti
0fc0: 6e 67 20 64 69 73 6b 20 6e 75 6d 62 65 72 20 20  ng disk number  
0fd0: 20 20 20 20 20 20 34 20 62 79 74 65 73 0a 2a 2a        4 bytes.**
0fe0: 2a 20 20 20 2e 5a 49 50 20 66 69 6c 65 20 63 6f  *   .ZIP file co
0ff0: 6d 6d 65 6e 74 20 6c 65 6e 67 74 68 20 20 20 20  mment length    
1000: 20 20 20 20 32 20 62 79 74 65 73 0a 2a 2a 2a 20      2 bytes.*** 
1010: 20 20 2e 5a 49 50 20 66 69 6c 65 20 63 6f 6d 6d    .ZIP file comm
1020: 65 6e 74 20 20 20 20 20 20 20 28 76 61 72 69 61  ent       (varia
1030: 62 6c 65 20 73 69 7a 65 29 0a 2a 2f 0a 74 79 70  ble size).*/.typ
1040: 65 64 65 66 20 73 74 72 75 63 74 20 5a 69 70 66  edef struct Zipf
1050: 69 6c 65 45 4f 43 44 20 5a 69 70 66 69 6c 65 45  ileEOCD ZipfileE
1060: 4f 43 44 3b 0a 73 74 72 75 63 74 20 5a 69 70 66  OCD;.struct Zipf
1070: 69 6c 65 45 4f 43 44 20 7b 0a 20 20 75 31 36 20  ileEOCD {.  u16 
1080: 69 44 69 73 6b 3b 0a 20 20 75 31 36 20 69 46 69  iDisk;.  u16 iFi
1090: 72 73 74 44 69 73 6b 3b 0a 20 20 75 31 36 20 6e  rstDisk;.  u16 n
10a0: 45 6e 74 72 79 3b 0a 20 20 75 31 36 20 6e 45 6e  Entry;.  u16 nEn
10b0: 74 72 79 54 6f 74 61 6c 3b 0a 20 20 75 33 32 20  tryTotal;.  u32 
10c0: 6e 53 69 7a 65 3b 0a 20 20 75 33 32 20 69 4f 66  nSize;.  u32 iOf
10d0: 66 73 65 74 3b 0a 7d 3b 0a 0a 2f 2a 0a 2a 2a 2a  fset;.};../*.***
10e0: 20 34 2e 33 2e 31 32 20 20 43 65 6e 74 72 61 6c   4.3.12  Central
10f0: 20 64 69 72 65 63 74 6f 72 79 20 73 74 72 75 63   directory struc
1100: 74 75 72 65 3a 0a 2a 2a 2a 0a 2a 2a 2a 20 2e 2e  ture:.***.*** ..
1110: 2e 0a 2a 2a 2a 0a 2a 2a 2a 20 20 20 63 65 6e 74  ..***.***   cent
1120: 72 61 6c 20 66 69 6c 65 20 68 65 61 64 65 72 20  ral file header 
1130: 73 69 67 6e 61 74 75 72 65 20 20 20 34 20 62 79  signature   4 by
1140: 74 65 73 20 20 28 30 78 30 32 30 31 34 62 35 30  tes  (0x02014b50
1150: 29 0a 2a 2a 2a 20 20 20 76 65 72 73 69 6f 6e 20  ).***   version 
1160: 6d 61 64 65 20 62 79 20 20 20 20 20 20 20 20 20  made by         
1170: 20 20 20 20 20 20 20 20 32 20 62 79 74 65 73 0a          2 bytes.
1180: 2a 2a 2a 20 20 20 76 65 72 73 69 6f 6e 20 6e 65  ***   version ne
1190: 65 64 65 64 20 74 6f 20 65 78 74 72 61 63 74 20  eded to extract 
11a0: 20 20 20 20 20 20 32 20 62 79 74 65 73 0a 2a 2a        2 bytes.**
11b0: 2a 20 20 20 67 65 6e 65 72 61 6c 20 70 75 72 70  *   general purp
11c0: 6f 73 65 20 62 69 74 20 66 6c 61 67 20 20 20 20  ose bit flag    
11d0: 20 20 20 20 32 20 62 79 74 65 73 0a 2a 2a 2a 20      2 bytes.*** 
11e0: 20 20 63 6f 6d 70 72 65 73 73 69 6f 6e 20 6d 65    compression me
11f0: 74 68 6f 64 20 20 20 20 20 20 20 20 20 20 20 20  thod            
1200: 20 20 32 20 62 79 74 65 73 0a 2a 2a 2a 20 20 20    2 bytes.***   
1210: 6c 61 73 74 20 6d 6f 64 20 66 69 6c 65 20 74 69  last mod file ti
1220: 6d 65 20 20 20 20 20 20 20 20 20 20 20 20 20 20  me              
1230: 32 20 62 79 74 65 73 0a 2a 2a 2a 20 20 20 6c 61  2 bytes.***   la
1240: 73 74 20 6d 6f 64 20 66 69 6c 65 20 64 61 74 65  st mod file date
1250: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 32 20                2 
1260: 62 79 74 65 73 0a 2a 2a 2a 20 20 20 63 72 63 2d  bytes.***   crc-
1270: 33 32 20 20 20 20 20 20 20 20 20 20 20 20 20 20  32              
1280: 20 20 20 20 20 20 20 20 20 20 20 20 34 20 62 79              4 by
1290: 74 65 73 0a 2a 2a 2a 20 20 20 63 6f 6d 70 72 65  tes.***   compre
12a0: 73 73 65 64 20 73 69 7a 65 20 20 20 20 20 20 20  ssed size       
12b0: 20 20 20 20 20 20 20 20 20 20 34 20 62 79 74 65            4 byte
12c0: 73 0a 2a 2a 2a 20 20 20 75 6e 63 6f 6d 70 72 65  s.***   uncompre
12d0: 73 73 65 64 20 73 69 7a 65 20 20 20 20 20 20 20  ssed size       
12e0: 20 20 20 20 20 20 20 20 34 20 62 79 74 65 73 0a          4 bytes.
12f0: 2a 2a 2a 20 20 20 66 69 6c 65 20 6e 61 6d 65 20  ***   file name 
1300: 6c 65 6e 67 74 68 20 20 20 20 20 20 20 20 20 20  length          
1310: 20 20 20 20 20 20 32 20 62 79 74 65 73 0a 2a 2a        2 bytes.**
1320: 2a 20 20 20 65 78 74 72 61 20 66 69 65 6c 64 20  *   extra field 
1330: 6c 65 6e 67 74 68 20 20 20 20 20 20 20 20 20 20  length          
1340: 20 20 20 20 32 20 62 79 74 65 73 0a 2a 2a 2a 20      2 bytes.*** 
1350: 20 20 66 69 6c 65 20 63 6f 6d 6d 65 6e 74 20 6c    file comment l
1360: 65 6e 67 74 68 20 20 20 20 20 20 20 20 20 20 20  ength           
1370: 20 20 32 20 62 79 74 65 73 0a 2a 2a 2a 20 20 20    2 bytes.***   
1380: 64 69 73 6b 20 6e 75 6d 62 65 72 20 73 74 61 72  disk number star
1390: 74 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  t               
13a0: 32 20 62 79 74 65 73 0a 2a 2a 2a 20 20 20 69 6e  2 bytes.***   in
13b0: 74 65 72 6e 61 6c 20 66 69 6c 65 20 61 74 74 72  ternal file attr
13c0: 69 62 75 74 65 73 20 20 20 20 20 20 20 20 32 20  ibutes        2 
13d0: 62 79 74 65 73 0a 2a 2a 2a 20 20 20 65 78 74 65  bytes.***   exte
13e0: 72 6e 61 6c 20 66 69 6c 65 20 61 74 74 72 69 62  rnal file attrib
13f0: 75 74 65 73 20 20 20 20 20 20 20 20 34 20 62 79  utes        4 by
1400: 74 65 73 0a 2a 2a 2a 20 20 20 72 65 6c 61 74 69  tes.***   relati
1410: 76 65 20 6f 66 66 73 65 74 20 6f 66 20 6c 6f 63  ve offset of loc
1420: 61 6c 20 68 65 61 64 65 72 20 34 20 62 79 74 65  al header 4 byte
1430: 73 0a 2a 2f 0a 74 79 70 65 64 65 66 20 73 74 72  s.*/.typedef str
1440: 75 63 74 20 5a 69 70 66 69 6c 65 43 44 53 20 5a  uct ZipfileCDS Z
1450: 69 70 66 69 6c 65 43 44 53 3b 0a 73 74 72 75 63  ipfileCDS;.struc
1460: 74 20 5a 69 70 66 69 6c 65 43 44 53 20 7b 0a 20  t ZipfileCDS {. 
1470: 20 75 31 36 20 69 56 65 72 73 69 6f 6e 4d 61 64   u16 iVersionMad
1480: 65 42 79 3b 0a 20 20 75 31 36 20 69 56 65 72 73  eBy;.  u16 iVers
1490: 69 6f 6e 45 78 74 72 61 63 74 3b 0a 20 20 75 31  ionExtract;.  u1
14a0: 36 20 66 6c 61 67 73 3b 0a 20 20 75 31 36 20 69  6 flags;.  u16 i
14b0: 43 6f 6d 70 72 65 73 73 69 6f 6e 3b 0a 20 20 75  Compression;.  u
14c0: 31 36 20 6d 54 69 6d 65 3b 0a 20 20 75 31 36 20  16 mTime;.  u16 
14d0: 6d 44 61 74 65 3b 0a 20 20 75 33 32 20 63 72 63  mDate;.  u32 crc
14e0: 33 32 3b 0a 20 20 75 33 32 20 73 7a 43 6f 6d 70  32;.  u32 szComp
14f0: 72 65 73 73 65 64 3b 0a 20 20 75 33 32 20 73 7a  ressed;.  u32 sz
1500: 55 6e 63 6f 6d 70 72 65 73 73 65 64 3b 0a 20 20  Uncompressed;.  
1510: 75 31 36 20 6e 46 69 6c 65 3b 0a 20 20 75 31 36  u16 nFile;.  u16
1520: 20 6e 45 78 74 72 61 3b 0a 20 20 75 31 36 20 6e   nExtra;.  u16 n
1530: 43 6f 6d 6d 65 6e 74 3b 0a 20 20 75 31 36 20 69  Comment;.  u16 i
1540: 44 69 73 6b 53 74 61 72 74 3b 0a 20 20 75 31 36  DiskStart;.  u16
1550: 20 69 49 6e 74 65 72 6e 61 6c 41 74 74 72 3b 0a   iInternalAttr;.
1560: 20 20 75 33 32 20 69 45 78 74 65 72 6e 61 6c 41    u32 iExternalA
1570: 74 74 72 3b 0a 20 20 75 33 32 20 69 4f 66 66 73  ttr;.  u32 iOffs
1580: 65 74 3b 0a 20 20 63 68 61 72 20 2a 7a 46 69 6c  et;.  char *zFil
1590: 65 3b 20 20 20 20 20 20 20 20 20 20 20 20 20 20  e;              
15a0: 20 20 20 20 20 20 2f 2a 20 46 69 6c 65 6e 61 6d        /* Filenam
15b0: 65 20 28 73 71 6c 69 74 65 33 5f 6d 61 6c 6c 6f  e (sqlite3_mallo
15c0: 63 28 29 29 20 2a 2f 0a 7d 3b 0a 0a 2f 2a 0a 2a  c()) */.};../*.*
15d0: 2a 2a 20 34 2e 33 2e 37 20 20 4c 6f 63 61 6c 20  ** 4.3.7  Local 
15e0: 66 69 6c 65 20 68 65 61 64 65 72 3a 0a 2a 2a 2a  file header:.***
15f0: 0a 2a 2a 2a 20 20 20 6c 6f 63 61 6c 20 66 69 6c  .***   local fil
1600: 65 20 68 65 61 64 65 72 20 73 69 67 6e 61 74 75  e header signatu
1610: 72 65 20 20 20 20 20 34 20 62 79 74 65 73 20 20  re     4 bytes  
1620: 28 30 78 30 34 30 33 34 62 35 30 29 0a 2a 2a 2a  (0x04034b50).***
1630: 20 20 20 76 65 72 73 69 6f 6e 20 6e 65 65 64 65     version neede
1640: 64 20 74 6f 20 65 78 74 72 61 63 74 20 20 20 20  d to extract    
1650: 20 20 20 32 20 62 79 74 65 73 0a 2a 2a 2a 20 20     2 bytes.***  
1660: 20 67 65 6e 65 72 61 6c 20 70 75 72 70 6f 73 65   general purpose
1670: 20 62 69 74 20 66 6c 61 67 20 20 20 20 20 20 20   bit flag       
1680: 20 32 20 62 79 74 65 73 0a 2a 2a 2a 20 20 20 63   2 bytes.***   c
1690: 6f 6d 70 72 65 73 73 69 6f 6e 20 6d 65 74 68 6f  ompression metho
16a0: 64 20 20 20 20 20 20 20 20 20 20 20 20 20 20 32  d              2
16b0: 20 62 79 74 65 73 0a 2a 2a 2a 20 20 20 6c 61 73   bytes.***   las
16c0: 74 20 6d 6f 64 20 66 69 6c 65 20 74 69 6d 65 20  t mod file time 
16d0: 20 20 20 20 20 20 20 20 20 20 20 20 20 32 20 62               2 b
16e0: 79 74 65 73 0a 2a 2a 2a 20 20 20 6c 61 73 74 20  ytes.***   last 
16f0: 6d 6f 64 20 66 69 6c 65 20 64 61 74 65 20 20 20  mod file date   
1700: 20 20 20 20 20 20 20 20 20 20 20 32 20 62 79 74             2 byt
1710: 65 73 0a 2a 2a 2a 20 20 20 63 72 63 2d 33 32 20  es.***   crc-32 
1720: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1730: 20 20 20 20 20 20 20 20 20 34 20 62 79 74 65 73           4 bytes
1740: 0a 2a 2a 2a 20 20 20 63 6f 6d 70 72 65 73 73 65  .***   compresse
1750: 64 20 73 69 7a 65 20 20 20 20 20 20 20 20 20 20  d size          
1760: 20 20 20 20 20 20 20 34 20 62 79 74 65 73 0a 2a         4 bytes.*
1770: 2a 2a 20 20 20 75 6e 63 6f 6d 70 72 65 73 73 65  **   uncompresse
1780: 64 20 73 69 7a 65 20 20 20 20 20 20 20 20 20 20  d size          
1790: 20 20 20 20 20 34 20 62 79 74 65 73 0a 2a 2a 2a       4 bytes.***
17a0: 20 20 20 66 69 6c 65 20 6e 61 6d 65 20 6c 65 6e     file name len
17b0: 67 74 68 20 20 20 20 20 20 20 20 20 20 20 20 20  gth             
17c0: 20 20 20 32 20 62 79 74 65 73 0a 2a 2a 2a 20 20     2 bytes.***  
17d0: 20 65 78 74 72 61 20 66 69 65 6c 64 20 6c 65 6e   extra field len
17e0: 67 74 68 20 20 20 20 20 20 20 20 20 20 20 20 20  gth             
17f0: 20 32 20 62 79 74 65 73 0a 2a 2a 2a 20 20 20 0a   2 bytes.***   .
1800: 2a 2f 0a 74 79 70 65 64 65 66 20 73 74 72 75 63  */.typedef struc
1810: 74 20 5a 69 70 66 69 6c 65 4c 46 48 20 5a 69 70  t ZipfileLFH Zip
1820: 66 69 6c 65 4c 46 48 3b 0a 73 74 72 75 63 74 20  fileLFH;.struct 
1830: 5a 69 70 66 69 6c 65 4c 46 48 20 7b 0a 20 20 75  ZipfileLFH {.  u
1840: 31 36 20 69 56 65 72 73 69 6f 6e 45 78 74 72 61  16 iVersionExtra
1850: 63 74 3b 0a 20 20 75 31 36 20 66 6c 61 67 73 3b  ct;.  u16 flags;
1860: 0a 20 20 75 31 36 20 69 43 6f 6d 70 72 65 73 73  .  u16 iCompress
1870: 69 6f 6e 3b 0a 20 20 75 31 36 20 6d 54 69 6d 65  ion;.  u16 mTime
1880: 3b 0a 20 20 75 31 36 20 6d 44 61 74 65 3b 0a 20  ;.  u16 mDate;. 
1890: 20 75 33 32 20 63 72 63 33 32 3b 0a 20 20 75 33   u32 crc32;.  u3
18a0: 32 20 73 7a 43 6f 6d 70 72 65 73 73 65 64 3b 0a  2 szCompressed;.
18b0: 20 20 75 33 32 20 73 7a 55 6e 63 6f 6d 70 72 65    u32 szUncompre
18c0: 73 73 65 64 3b 0a 20 20 75 31 36 20 6e 46 69 6c  ssed;.  u16 nFil
18d0: 65 3b 0a 20 20 75 31 36 20 6e 45 78 74 72 61 3b  e;.  u16 nExtra;
18e0: 0a 7d 3b 0a 0a 74 79 70 65 64 65 66 20 73 74 72  .};..typedef str
18f0: 75 63 74 20 5a 69 70 66 69 6c 65 45 6e 74 72 79  uct ZipfileEntry
1900: 20 5a 69 70 66 69 6c 65 45 6e 74 72 79 3b 0a 73   ZipfileEntry;.s
1910: 74 72 75 63 74 20 5a 69 70 66 69 6c 65 45 6e 74  truct ZipfileEnt
1920: 72 79 20 7b 0a 20 20 63 68 61 72 20 2a 7a 50 61  ry {.  char *zPa
1930: 74 68 3b 20 20 20 20 20 20 20 20 20 20 20 20 20  th;             
1940: 20 20 2f 2a 20 50 61 74 68 20 6f 66 20 7a 69 70    /* Path of zip
1950: 66 69 6c 65 20 65 6e 74 72 79 20 2a 2f 0a 20 20  file entry */.  
1960: 75 38 20 2a 61 43 64 73 45 6e 74 72 79 3b 20 20  u8 *aCdsEntry;  
1970: 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 42 75             /* Bu
1980: 66 66 65 72 20 63 6f 6e 74 61 69 6e 69 6e 67 20  ffer containing 
1990: 65 6e 74 69 72 65 20 43 44 53 20 65 6e 74 72 79  entire CDS entry
19a0: 20 2a 2f 0a 20 20 69 6e 74 20 6e 43 64 73 45 6e   */.  int nCdsEn
19b0: 74 72 79 3b 20 20 20 20 20 20 20 20 20 20 20 20  try;            
19c0: 20 2f 2a 20 53 69 7a 65 20 6f 66 20 62 75 66 66   /* Size of buff
19d0: 65 72 20 61 43 64 73 45 6e 74 72 79 5b 5d 20 69  er aCdsEntry[] i
19e0: 6e 20 62 79 74 65 73 20 2a 2f 0a 20 20 69 6e 74  n bytes */.  int
19f0: 20 62 44 65 6c 65 74 65 64 3b 20 20 20 20 20 20   bDeleted;      
1a00: 20 20 20 20 20 20 20 20 2f 2a 20 54 72 75 65 20          /* True 
1a10: 69 66 20 65 6e 74 72 79 20 68 61 73 20 62 65 65  if entry has bee
1a20: 6e 20 64 65 6c 65 74 65 64 20 2a 2f 0a 20 20 5a  n deleted */.  Z
1a30: 69 70 66 69 6c 65 45 6e 74 72 79 20 2a 70 4e 65  ipfileEntry *pNe
1a40: 78 74 3b 20 20 20 20 20 20 20 2f 2a 20 4e 65 78  xt;       /* Nex
1a50: 74 20 65 6c 65 6d 65 6e 74 20 69 6e 20 69 6e 2d  t element in in-
1a60: 6d 65 6d 6f 72 79 20 43 44 53 20 2a 2f 0a 7d 3b  memory CDS */.};
1a70: 0a 0a 2f 2a 20 0a 2a 2a 20 43 75 72 73 6f 72 20  ../* .** Cursor 
1a80: 74 79 70 65 20 66 6f 72 20 72 65 63 75 72 73 69  type for recursi
1a90: 76 65 6c 79 20 69 74 65 72 61 74 69 6e 67 20 74  vely iterating t
1aa0: 68 72 6f 75 67 68 20 61 20 64 69 72 65 63 74 6f  hrough a directo
1ab0: 72 79 20 73 74 72 75 63 74 75 72 65 2e 0a 2a 2f  ry structure..*/
1ac0: 0a 74 79 70 65 64 65 66 20 73 74 72 75 63 74 20  .typedef struct 
1ad0: 5a 69 70 66 69 6c 65 43 73 72 20 5a 69 70 66 69  ZipfileCsr Zipfi
1ae0: 6c 65 43 73 72 3b 0a 73 74 72 75 63 74 20 5a 69  leCsr;.struct Zi
1af0: 70 66 69 6c 65 43 73 72 20 7b 0a 20 20 73 71 6c  pfileCsr {.  sql
1b00: 69 74 65 33 5f 76 74 61 62 5f 63 75 72 73 6f 72  ite3_vtab_cursor
1b10: 20 62 61 73 65 3b 20 20 2f 2a 20 42 61 73 65 20   base;  /* Base 
1b20: 63 6c 61 73 73 20 2d 20 6d 75 73 74 20 62 65 20  class - must be 
1b30: 66 69 72 73 74 20 2a 2f 0a 20 20 69 6e 74 20 62  first */.  int b
1b40: 45 6f 66 3b 20 20 20 20 20 20 20 20 20 20 20 20  Eof;            
1b50: 20 20 20 20 20 20 2f 2a 20 54 72 75 65 20 77 68        /* True wh
1b60: 65 6e 20 61 74 20 45 4f 46 20 2a 2f 0a 0a 20 20  en at EOF */..  
1b70: 2f 2a 20 55 73 65 64 20 6f 75 74 73 69 64 65 20  /* Used outside 
1b80: 6f 66 20 77 72 69 74 65 20 74 72 61 6e 73 61 63  of write transac
1b90: 74 69 6f 6e 73 20 2a 2f 0a 20 20 46 49 4c 45 20  tions */.  FILE 
1ba0: 2a 70 46 69 6c 65 3b 20 20 20 20 20 20 20 20 20  *pFile;         
1bb0: 20 20 20 20 20 20 2f 2a 20 5a 69 70 20 66 69 6c        /* Zip fil
1bc0: 65 20 2a 2f 0a 20 20 69 36 34 20 69 4e 65 78 74  e */.  i64 iNext
1bd0: 4f 66 66 3b 20 20 20 20 20 20 20 20 20 20 20 20  Off;            
1be0: 20 20 2f 2a 20 4f 66 66 73 65 74 20 6f 66 20 6e    /* Offset of n
1bf0: 65 78 74 20 72 65 63 6f 72 64 20 69 6e 20 63 65  ext record in ce
1c00: 6e 74 72 61 6c 20 64 69 72 65 63 74 6f 72 79 20  ntral directory 
1c10: 2a 2f 0a 20 20 5a 69 70 66 69 6c 65 45 4f 43 44  */.  ZipfileEOCD
1c20: 20 65 6f 63 64 3b 20 20 20 20 20 20 20 20 20 20   eocd;          
1c30: 2f 2a 20 50 61 72 73 65 20 6f 66 20 63 65 6e 74  /* Parse of cent
1c40: 72 61 6c 20 64 69 72 65 63 74 6f 72 79 20 72 65  ral directory re
1c50: 63 6f 72 64 20 2a 2f 0a 0a 20 20 2f 2a 20 55 73  cord */..  /* Us
1c60: 65 64 20 69 6e 73 69 64 65 20 77 72 69 74 65 20  ed inside write 
1c70: 74 72 61 6e 73 61 63 74 69 6f 6e 73 20 2a 2f 0a  transactions */.
1c80: 20 20 5a 69 70 66 69 6c 65 45 6e 74 72 79 20 2a    ZipfileEntry *
1c90: 70 43 75 72 72 65 6e 74 3b 0a 0a 20 20 5a 69 70  pCurrent;..  Zip
1ca0: 66 69 6c 65 43 44 53 20 63 64 73 3b 20 20 20 20  fileCDS cds;    
1cb0: 20 20 20 20 20 20 20 20 2f 2a 20 43 65 6e 74 72          /* Centr
1cc0: 61 6c 20 44 69 72 65 63 74 6f 72 79 20 53 74 72  al Directory Str
1cd0: 75 63 74 75 72 65 20 2a 2f 0a 20 20 5a 69 70 66  ucture */.  Zipf
1ce0: 69 6c 65 4c 46 48 20 6c 66 68 3b 20 20 20 20 20  ileLFH lfh;     
1cf0: 20 20 20 20 20 20 20 2f 2a 20 4c 6f 63 61 6c 20         /* Local 
1d00: 46 69 6c 65 20 48 65 61 64 65 72 20 66 6f 72 20  File Header for 
1d10: 63 75 72 72 65 6e 74 20 65 6e 74 72 79 20 2a 2f  current entry */
1d20: 0a 20 20 69 36 34 20 69 44 61 74 61 4f 66 66 3b  .  i64 iDataOff;
1d30: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a                /*
1d40: 20 4f 66 66 73 65 74 20 69 6e 20 7a 69 70 66 69   Offset in zipfi
1d50: 6c 65 20 74 6f 20 64 61 74 61 20 2a 2f 0a 20 20  le to data */.  
1d60: 75 33 32 20 6d 54 69 6d 65 3b 20 20 20 20 20 20  u32 mTime;      
1d70: 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 45 78             /* Ex
1d80: 74 65 6e 64 65 64 20 6d 74 69 6d 65 20 76 61 6c  tended mtime val
1d90: 75 65 20 2a 2f 0a 20 20 69 6e 74 20 66 6c 61 67  ue */.  int flag
1da0: 73 3b 20 20 20 20 20 20 20 20 20 20 20 20 20 20  s;              
1db0: 20 20 20 2f 2a 20 46 6c 61 67 73 20 62 79 74 65     /* Flags byte
1dc0: 20 28 73 65 65 20 62 65 6c 6f 77 20 66 6f 72 20   (see below for 
1dd0: 62 69 74 73 29 20 2a 2f 0a 20 20 5a 69 70 66 69  bits) */.  Zipfi
1de0: 6c 65 43 73 72 20 2a 70 43 73 72 4e 65 78 74 3b  leCsr *pCsrNext;
1df0: 20 20 20 20 20 20 2f 2a 20 4e 65 78 74 20 63 75        /* Next cu
1e00: 72 73 6f 72 20 6f 6e 20 73 61 6d 65 20 76 69 72  rsor on same vir
1e10: 74 75 61 6c 20 74 61 62 6c 65 20 2a 2f 0a 7d 3b  tual table */.};
1e20: 0a 0a 2f 2a 0a 2a 2a 20 56 61 6c 75 65 73 20 66  ../*.** Values f
1e30: 6f 72 20 5a 69 70 66 69 6c 65 43 73 72 2e 66 6c  or ZipfileCsr.fl
1e40: 61 67 73 2e 0a 2a 2f 0a 23 64 65 66 69 6e 65 20  ags..*/.#define 
1e50: 5a 49 50 46 49 4c 45 5f 4d 54 49 4d 45 5f 56 41  ZIPFILE_MTIME_VA
1e60: 4c 49 44 20 30 78 30 30 30 31 0a 0a 74 79 70 65  LID 0x0001..type
1e70: 64 65 66 20 73 74 72 75 63 74 20 5a 69 70 66 69  def struct Zipfi
1e80: 6c 65 54 61 62 20 5a 69 70 66 69 6c 65 54 61 62  leTab ZipfileTab
1e90: 3b 0a 73 74 72 75 63 74 20 5a 69 70 66 69 6c 65  ;.struct Zipfile
1ea0: 54 61 62 20 7b 0a 20 20 73 71 6c 69 74 65 33 5f  Tab {.  sqlite3_
1eb0: 76 74 61 62 20 62 61 73 65 3b 20 20 20 20 20 20  vtab base;      
1ec0: 20 20 20 2f 2a 20 42 61 73 65 20 63 6c 61 73 73     /* Base class
1ed0: 20 2d 20 6d 75 73 74 20 62 65 20 66 69 72 73 74   - must be first
1ee0: 20 2a 2f 0a 20 20 63 68 61 72 20 2a 7a 46 69 6c   */.  char *zFil
1ef0: 65 3b 20 20 20 20 20 20 20 20 20 20 20 20 20 20  e;              
1f00: 20 2f 2a 20 5a 69 70 20 66 69 6c 65 20 74 68 69   /* Zip file thi
1f10: 73 20 74 61 62 6c 65 20 61 63 63 65 73 73 65 73  s table accesses
1f20: 20 28 6d 61 79 20 62 65 20 4e 55 4c 4c 29 20 2a   (may be NULL) *
1f30: 2f 0a 20 20 75 38 20 2a 61 42 75 66 66 65 72 3b  /.  u8 *aBuffer;
1f40: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f                 /
1f50: 2a 20 54 65 6d 70 6f 72 61 72 79 20 62 75 66 66  * Temporary buff
1f60: 65 72 20 75 73 65 64 20 66 6f 72 20 76 61 72 69  er used for vari
1f70: 6f 75 73 20 74 61 73 6b 73 20 2a 2f 0a 0a 20 20  ous tasks */..  
1f80: 2f 2a 20 54 68 65 20 66 6f 6c 6c 6f 77 69 6e 67  /* The following
1f90: 20 61 72 65 20 75 73 65 64 20 62 79 20 77 72 69   are used by wri
1fa0: 74 65 20 74 72 61 6e 73 61 63 74 69 6f 6e 73 20  te transactions 
1fb0: 6f 6e 6c 79 20 2a 2f 0a 20 20 5a 69 70 66 69 6c  only */.  Zipfil
1fc0: 65 43 73 72 20 2a 70 43 73 72 4c 69 73 74 3b 20  eCsr *pCsrList; 
1fd0: 20 20 20 20 20 2f 2a 20 4c 69 73 74 20 6f 66 20       /* List of 
1fe0: 63 75 72 73 6f 72 73 20 2a 2f 0a 20 20 5a 69 70  cursors */.  Zip
1ff0: 66 69 6c 65 45 6e 74 72 79 20 2a 70 46 69 72 73  fileEntry *pFirs
2000: 74 45 6e 74 72 79 3b 20 2f 2a 20 4c 69 6e 6b 65  tEntry; /* Linke
2010: 64 20 6c 69 73 74 20 6f 66 20 61 6c 6c 20 66 69  d list of all fi
2020: 6c 65 73 20 28 69 66 20 70 57 72 69 74 65 46 64  les (if pWriteFd
2030: 21 3d 30 29 20 2a 2f 0a 20 20 5a 69 70 66 69 6c  !=0) */.  Zipfil
2040: 65 45 6e 74 72 79 20 2a 70 4c 61 73 74 45 6e 74  eEntry *pLastEnt
2050: 72 79 3b 20 20 2f 2a 20 4c 61 73 74 20 65 6c 65  ry;  /* Last ele
2060: 6d 65 6e 74 20 69 6e 20 70 46 69 72 73 74 45 6e  ment in pFirstEn
2070: 74 72 79 20 6c 69 73 74 20 2a 2f 0a 20 20 46 49  try list */.  FI
2080: 4c 45 20 2a 70 57 72 69 74 65 46 64 3b 20 20 20  LE *pWriteFd;   
2090: 20 20 20 20 20 20 20 20 20 2f 2a 20 46 69 6c 65           /* File
20a0: 20 68 61 6e 64 6c 65 20 6f 70 65 6e 20 6f 6e 20   handle open on 
20b0: 7a 69 70 20 61 72 63 68 69 76 65 20 2a 2f 0a 20  zip archive */. 
20c0: 20 69 36 34 20 73 7a 43 75 72 72 65 6e 74 3b 20   i64 szCurrent; 
20d0: 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 43              /* C
20e0: 75 72 72 65 6e 74 20 73 69 7a 65 20 6f 66 20 7a  urrent size of z
20f0: 69 70 20 61 72 63 68 69 76 65 20 2a 2f 0a 20 20  ip archive */.  
2100: 69 36 34 20 73 7a 4f 72 69 67 3b 20 20 20 20 20  i64 szOrig;     
2110: 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 53 69             /* Si
2120: 7a 65 20 6f 66 20 61 72 63 68 69 76 65 20 61 74  ze of archive at
2130: 20 73 74 61 72 74 20 6f 66 20 74 72 61 6e 73 61   start of transa
2140: 63 74 69 6f 6e 20 2a 2f 0a 7d 3b 0a 0a 73 74 61  ction */.};..sta
2150: 74 69 63 20 76 6f 69 64 20 7a 69 70 66 69 6c 65  tic void zipfile
2160: 44 65 71 75 6f 74 65 28 63 68 61 72 20 2a 7a 49  Dequote(char *zI
2170: 6e 29 7b 0a 20 20 63 68 61 72 20 71 20 3d 20 7a  n){.  char q = z
2180: 49 6e 5b 30 5d 3b 0a 20 20 69 66 28 20 71 3d 3d  In[0];.  if( q==
2190: 27 22 27 20 7c 7c 20 71 3d 3d 27 5c 27 27 20 7c  '"' || q=='\'' |
21a0: 7c 20 71 3d 3d 27 60 27 20 7c 7c 20 71 3d 3d 27  | q=='`' || q=='
21b0: 5b 27 20 29 7b 0a 20 20 20 20 63 68 61 72 20 63  [' ){.    char c
21c0: 3b 0a 20 20 20 20 69 6e 74 20 69 49 6e 20 3d 20  ;.    int iIn = 
21d0: 31 3b 0a 20 20 20 20 69 6e 74 20 69 4f 75 74 20  1;.    int iOut 
21e0: 3d 20 30 3b 0a 20 20 20 20 69 66 28 20 71 3d 3d  = 0;.    if( q==
21f0: 27 5b 27 20 29 20 71 20 3d 20 27 5d 27 3b 0a 20  '[' ) q = ']';. 
2200: 20 20 20 77 68 69 6c 65 28 20 28 63 20 3d 20 7a     while( (c = z
2210: 49 6e 5b 69 49 6e 2b 2b 5d 29 20 29 7b 0a 20 20  In[iIn++]) ){.  
2220: 20 20 20 20 69 66 28 20 63 3d 3d 71 20 29 7b 0a      if( c==q ){.
2230: 20 20 20 20 20 20 20 20 69 66 28 20 7a 49 6e 5b          if( zIn[
2240: 69 49 6e 2b 2b 5d 21 3d 71 20 29 20 62 72 65 61  iIn++]!=q ) brea
2250: 6b 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 20  k;.      }.     
2260: 20 7a 49 6e 5b 69 4f 75 74 2b 2b 5d 20 3d 20 63   zIn[iOut++] = c
2270: 3b 0a 20 20 20 20 7d 0a 20 20 20 20 7a 49 6e 5b  ;.    }.    zIn[
2280: 69 4f 75 74 5d 20 3d 20 27 5c 30 27 3b 0a 20 20  iOut] = '\0';.  
2290: 7d 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 43 6f 6e 73 74  }.}../*.** Const
22a0: 72 75 63 74 20 61 20 6e 65 77 20 5a 69 70 66 69  ruct a new Zipfi
22b0: 6c 65 54 61 62 20 76 69 72 74 75 61 6c 20 74 61  leTab virtual ta
22c0: 62 6c 65 20 6f 62 6a 65 63 74 2e 0a 2a 2a 20 0a  ble object..** .
22d0: 2a 2a 20 20 20 61 72 67 76 5b 30 5d 20 20 20 2d  **   argv[0]   -
22e0: 3e 20 6d 6f 64 75 6c 65 20 6e 61 6d 65 20 20 28  > module name  (
22f0: 22 7a 69 70 66 69 6c 65 22 29 0a 2a 2a 20 20 20  "zipfile").**   
2300: 61 72 67 76 5b 31 5d 20 20 20 2d 3e 20 64 61 74  argv[1]   -> dat
2310: 61 62 61 73 65 20 6e 61 6d 65 0a 2a 2a 20 20 20  abase name.**   
2320: 61 72 67 76 5b 32 5d 20 20 20 2d 3e 20 74 61 62  argv[2]   -> tab
2330: 6c 65 20 6e 61 6d 65 0a 2a 2a 20 20 20 61 72 67  le name.**   arg
2340: 76 5b 2e 2e 2e 5d 20 2d 3e 20 22 63 6f 6c 75 6d  v[...] -> "colum
2350: 6e 20 6e 61 6d 65 22 20 61 6e 64 20 6f 74 68 65  n name" and othe
2360: 72 20 6d 6f 64 75 6c 65 20 61 72 67 75 6d 65 6e  r module argumen
2370: 74 20 66 69 65 6c 64 73 2e 0a 2a 2f 0a 73 74 61  t fields..*/.sta
2380: 74 69 63 20 69 6e 74 20 7a 69 70 66 69 6c 65 43  tic int zipfileC
2390: 6f 6e 6e 65 63 74 28 0a 20 20 73 71 6c 69 74 65  onnect(.  sqlite
23a0: 33 20 2a 64 62 2c 0a 20 20 76 6f 69 64 20 2a 70  3 *db,.  void *p
23b0: 41 75 78 2c 0a 20 20 69 6e 74 20 61 72 67 63 2c  Aux,.  int argc,
23c0: 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 63 6f 6e   const char *con
23d0: 73 74 2a 61 72 67 76 2c 0a 20 20 73 71 6c 69 74  st*argv,.  sqlit
23e0: 65 33 5f 76 74 61 62 20 2a 2a 70 70 56 74 61 62  e3_vtab **ppVtab
23f0: 2c 0a 20 20 63 68 61 72 20 2a 2a 70 7a 45 72 72  ,.  char **pzErr
2400: 0a 29 7b 0a 20 20 69 6e 74 20 6e 42 79 74 65 20  .){.  int nByte 
2410: 3d 20 73 69 7a 65 6f 66 28 5a 69 70 66 69 6c 65  = sizeof(Zipfile
2420: 54 61 62 29 20 2b 20 5a 49 50 46 49 4c 45 5f 42  Tab) + ZIPFILE_B
2430: 55 46 46 45 52 5f 53 49 5a 45 3b 0a 20 20 69 6e  UFFER_SIZE;.  in
2440: 74 20 6e 46 69 6c 65 20 3d 20 30 3b 0a 20 20 63  t nFile = 0;.  c
2450: 6f 6e 73 74 20 63 68 61 72 20 2a 7a 46 69 6c 65  onst char *zFile
2460: 20 3d 20 30 3b 0a 20 20 5a 69 70 66 69 6c 65 54   = 0;.  ZipfileT
2470: 61 62 20 2a 70 4e 65 77 20 3d 20 30 3b 0a 20 20  ab *pNew = 0;.  
2480: 69 6e 74 20 72 63 3b 0a 0a 20 20 69 66 28 20 61  int rc;..  if( a
2490: 72 67 63 3e 33 20 29 7b 0a 20 20 20 20 7a 46 69  rgc>3 ){.    zFi
24a0: 6c 65 20 3d 20 61 72 67 76 5b 33 5d 3b 0a 20 20  le = argv[3];.  
24b0: 20 20 6e 46 69 6c 65 20 3d 20 28 69 6e 74 29 73    nFile = (int)s
24c0: 74 72 6c 65 6e 28 7a 46 69 6c 65 29 2b 31 3b 0a  trlen(zFile)+1;.
24d0: 20 20 7d 0a 0a 20 20 72 63 20 3d 20 73 71 6c 69    }..  rc = sqli
24e0: 74 65 33 5f 64 65 63 6c 61 72 65 5f 76 74 61 62  te3_declare_vtab
24f0: 28 64 62 2c 20 5a 49 50 46 49 4c 45 5f 53 43 48  (db, ZIPFILE_SCH
2500: 45 4d 41 29 3b 0a 20 20 69 66 28 20 72 63 3d 3d  EMA);.  if( rc==
2510: 53 51 4c 49 54 45 5f 4f 4b 20 29 7b 0a 20 20 20  SQLITE_OK ){.   
2520: 20 70 4e 65 77 20 3d 20 28 5a 69 70 66 69 6c 65   pNew = (Zipfile
2530: 54 61 62 2a 29 73 71 6c 69 74 65 33 5f 6d 61 6c  Tab*)sqlite3_mal
2540: 6c 6f 63 28 6e 42 79 74 65 2b 6e 46 69 6c 65 29  loc(nByte+nFile)
2550: 3b 0a 20 20 20 20 69 66 28 20 70 4e 65 77 3d 3d  ;.    if( pNew==
2560: 30 20 29 20 72 65 74 75 72 6e 20 53 51 4c 49 54  0 ) return SQLIT
2570: 45 5f 4e 4f 4d 45 4d 3b 0a 20 20 20 20 6d 65 6d  E_NOMEM;.    mem
2580: 73 65 74 28 70 4e 65 77 2c 20 30 2c 20 6e 42 79  set(pNew, 0, nBy
2590: 74 65 2b 6e 46 69 6c 65 29 3b 0a 20 20 20 20 70  te+nFile);.    p
25a0: 4e 65 77 2d 3e 61 42 75 66 66 65 72 20 3d 20 28  New->aBuffer = (
25b0: 75 38 2a 29 26 70 4e 65 77 5b 31 5d 3b 0a 20 20  u8*)&pNew[1];.  
25c0: 20 20 69 66 28 20 7a 46 69 6c 65 20 29 7b 0a 20    if( zFile ){. 
25d0: 20 20 20 20 20 70 4e 65 77 2d 3e 7a 46 69 6c 65       pNew->zFile
25e0: 20 3d 20 28 63 68 61 72 2a 29 26 70 4e 65 77 2d   = (char*)&pNew-
25f0: 3e 61 42 75 66 66 65 72 5b 5a 49 50 46 49 4c 45  >aBuffer[ZIPFILE
2600: 5f 42 55 46 46 45 52 5f 53 49 5a 45 5d 3b 0a 20  _BUFFER_SIZE];. 
2610: 20 20 20 20 20 6d 65 6d 63 70 79 28 70 4e 65 77       memcpy(pNew
2620: 2d 3e 7a 46 69 6c 65 2c 20 7a 46 69 6c 65 2c 20  ->zFile, zFile, 
2630: 6e 46 69 6c 65 29 3b 0a 20 20 20 20 20 20 7a 69  nFile);.      zi
2640: 70 66 69 6c 65 44 65 71 75 6f 74 65 28 70 4e 65  pfileDequote(pNe
2650: 77 2d 3e 7a 46 69 6c 65 29 3b 0a 20 20 20 20 7d  w->zFile);.    }
2660: 0a 20 20 7d 0a 20 20 2a 70 70 56 74 61 62 20 3d  .  }.  *ppVtab =
2670: 20 28 73 71 6c 69 74 65 33 5f 76 74 61 62 2a 29   (sqlite3_vtab*)
2680: 70 4e 65 77 3b 0a 20 20 72 65 74 75 72 6e 20 72  pNew;.  return r
2690: 63 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 54 68 69 73  c;.}../*.** This
26a0: 20 6d 65 74 68 6f 64 20 69 73 20 74 68 65 20 64   method is the d
26b0: 65 73 74 72 75 63 74 6f 72 20 66 6f 72 20 7a 69  estructor for zi
26c0: 70 66 69 6c 65 20 76 74 61 62 20 6f 62 6a 65 63  pfile vtab objec
26d0: 74 73 2e 0a 2a 2f 0a 73 74 61 74 69 63 20 69 6e  ts..*/.static in
26e0: 74 20 7a 69 70 66 69 6c 65 44 69 73 63 6f 6e 6e  t zipfileDisconn
26f0: 65 63 74 28 73 71 6c 69 74 65 33 5f 76 74 61 62  ect(sqlite3_vtab
2700: 20 2a 70 56 74 61 62 29 7b 0a 20 20 73 71 6c 69   *pVtab){.  sqli
2710: 74 65 33 5f 66 72 65 65 28 70 56 74 61 62 29 3b  te3_free(pVtab);
2720: 0a 20 20 72 65 74 75 72 6e 20 53 51 4c 49 54 45  .  return SQLITE
2730: 5f 4f 4b 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 43 6f  _OK;.}../*.** Co
2740: 6e 73 74 72 75 63 74 6f 72 20 66 6f 72 20 61 20  nstructor for a 
2750: 6e 65 77 20 5a 69 70 66 69 6c 65 43 73 72 20 6f  new ZipfileCsr o
2760: 62 6a 65 63 74 2e 0a 2a 2f 0a 73 74 61 74 69 63  bject..*/.static
2770: 20 69 6e 74 20 7a 69 70 66 69 6c 65 4f 70 65 6e   int zipfileOpen
2780: 28 73 71 6c 69 74 65 33 5f 76 74 61 62 20 2a 70  (sqlite3_vtab *p
2790: 2c 20 73 71 6c 69 74 65 33 5f 76 74 61 62 5f 63  , sqlite3_vtab_c
27a0: 75 72 73 6f 72 20 2a 2a 70 70 43 73 72 29 7b 0a  ursor **ppCsr){.
27b0: 20 20 5a 69 70 66 69 6c 65 43 73 72 20 2a 70 43    ZipfileCsr *pC
27c0: 73 72 3b 0a 20 20 70 43 73 72 20 3d 20 73 71 6c  sr;.  pCsr = sql
27d0: 69 74 65 33 5f 6d 61 6c 6c 6f 63 28 73 69 7a 65  ite3_malloc(size
27e0: 6f 66 28 2a 70 43 73 72 29 29 3b 0a 20 20 2a 70  of(*pCsr));.  *p
27f0: 70 43 73 72 20 3d 20 28 73 71 6c 69 74 65 33 5f  pCsr = (sqlite3_
2800: 76 74 61 62 5f 63 75 72 73 6f 72 2a 29 70 43 73  vtab_cursor*)pCs
2810: 72 3b 0a 20 20 69 66 28 20 70 43 73 72 3d 3d 30  r;.  if( pCsr==0
2820: 20 29 7b 0a 20 20 20 20 72 65 74 75 72 6e 20 53   ){.    return S
2830: 51 4c 49 54 45 5f 4e 4f 4d 45 4d 3b 0a 20 20 7d  QLITE_NOMEM;.  }
2840: 0a 20 20 6d 65 6d 73 65 74 28 70 43 73 72 2c 20  .  memset(pCsr, 
2850: 30 2c 20 73 69 7a 65 6f 66 28 2a 70 43 73 72 29  0, sizeof(*pCsr)
2860: 29 3b 0a 20 20 72 65 74 75 72 6e 20 53 51 4c 49  );.  return SQLI
2870: 54 45 5f 4f 4b 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20  TE_OK;.}../*.** 
2880: 52 65 73 65 74 20 61 20 63 75 72 73 6f 72 20 62  Reset a cursor b
2890: 61 63 6b 20 74 6f 20 74 68 65 20 73 74 61 74 65  ack to the state
28a0: 20 69 74 20 77 61 73 20 69 6e 20 77 68 65 6e 20   it was in when 
28b0: 66 69 72 73 74 20 72 65 74 75 72 6e 65 64 0a 2a  first returned.*
28c0: 2a 20 62 79 20 7a 69 70 66 69 6c 65 4f 70 65 6e  * by zipfileOpen
28d0: 28 29 2e 0a 2a 2f 0a 73 74 61 74 69 63 20 76 6f  ()..*/.static vo
28e0: 69 64 20 7a 69 70 66 69 6c 65 52 65 73 65 74 43  id zipfileResetC
28f0: 75 72 73 6f 72 28 5a 69 70 66 69 6c 65 43 73 72  ursor(ZipfileCsr
2900: 20 2a 70 43 73 72 29 7b 0a 20 20 5a 69 70 66 69   *pCsr){.  Zipfi
2910: 6c 65 54 61 62 20 2a 70 54 61 62 20 3d 20 28 5a  leTab *pTab = (Z
2920: 69 70 66 69 6c 65 54 61 62 2a 29 28 70 43 73 72  ipfileTab*)(pCsr
2930: 2d 3e 62 61 73 65 2e 70 56 74 61 62 29 3b 0a 20  ->base.pVtab);. 
2940: 20 5a 69 70 66 69 6c 65 43 73 72 20 2a 2a 70 70   ZipfileCsr **pp
2950: 3b 0a 0a 20 20 2f 2a 20 52 65 6d 6f 76 65 20 74  ;..  /* Remove t
2960: 68 69 73 20 63 75 72 73 6f 72 20 66 72 6f 6d 20  his cursor from 
2970: 74 68 65 20 5a 69 70 66 69 6c 65 54 61 62 2e 70  the ZipfileTab.p
2980: 43 73 72 4c 69 73 74 20 6c 69 73 74 2e 20 2a 2f  CsrList list. */
2990: 0a 20 20 66 6f 72 28 70 70 3d 26 70 54 61 62 2d  .  for(pp=&pTab-
29a0: 3e 70 43 73 72 4c 69 73 74 3b 20 2a 70 70 3b 20  >pCsrList; *pp; 
29b0: 70 70 3d 26 28 28 2a 70 70 29 2d 3e 70 43 73 72  pp=&((*pp)->pCsr
29c0: 4e 65 78 74 29 29 7b 0a 20 20 20 20 69 66 28 20  Next)){.    if( 
29d0: 2a 70 70 3d 3d 70 43 73 72 20 29 20 2a 70 70 20  *pp==pCsr ) *pp 
29e0: 3d 20 70 43 73 72 2d 3e 70 43 73 72 4e 65 78 74  = pCsr->pCsrNext
29f0: 3b 0a 20 20 7d 0a 0a 20 20 73 71 6c 69 74 65 33  ;.  }..  sqlite3
2a00: 5f 66 72 65 65 28 70 43 73 72 2d 3e 63 64 73 2e  _free(pCsr->cds.
2a10: 7a 46 69 6c 65 29 3b 0a 20 20 70 43 73 72 2d 3e  zFile);.  pCsr->
2a20: 63 64 73 2e 7a 46 69 6c 65 20 3d 20 30 3b 0a 20  cds.zFile = 0;. 
2a30: 20 70 43 73 72 2d 3e 62 45 6f 66 20 3d 20 30 3b   pCsr->bEof = 0;
2a40: 0a 20 20 69 66 28 20 70 43 73 72 2d 3e 70 46 69  .  if( pCsr->pFi
2a50: 6c 65 20 29 7b 0a 20 20 20 20 66 63 6c 6f 73 65  le ){.    fclose
2a60: 28 70 43 73 72 2d 3e 70 46 69 6c 65 29 3b 0a 20  (pCsr->pFile);. 
2a70: 20 20 20 70 43 73 72 2d 3e 70 46 69 6c 65 20 3d     pCsr->pFile =
2a80: 20 30 3b 0a 20 20 7d 0a 7d 0a 0a 2f 2a 0a 2a 2a   0;.  }.}../*.**
2a90: 20 44 65 73 74 72 75 63 74 6f 72 20 66 6f 72 20   Destructor for 
2aa0: 61 6e 20 5a 69 70 66 69 6c 65 43 73 72 2e 0a 2a  an ZipfileCsr..*
2ab0: 2f 0a 73 74 61 74 69 63 20 69 6e 74 20 7a 69 70  /.static int zip
2ac0: 66 69 6c 65 43 6c 6f 73 65 28 73 71 6c 69 74 65  fileClose(sqlite
2ad0: 33 5f 76 74 61 62 5f 63 75 72 73 6f 72 20 2a 63  3_vtab_cursor *c
2ae0: 75 72 29 7b 0a 20 20 5a 69 70 66 69 6c 65 43 73  ur){.  ZipfileCs
2af0: 72 20 2a 70 43 73 72 20 3d 20 28 5a 69 70 66 69  r *pCsr = (Zipfi
2b00: 6c 65 43 73 72 2a 29 63 75 72 3b 0a 20 20 7a 69  leCsr*)cur;.  zi
2b10: 70 66 69 6c 65 52 65 73 65 74 43 75 72 73 6f 72  pfileResetCursor
2b20: 28 70 43 73 72 29 3b 0a 20 20 73 71 6c 69 74 65  (pCsr);.  sqlite
2b30: 33 5f 66 72 65 65 28 70 43 73 72 29 3b 0a 20 20  3_free(pCsr);.  
2b40: 72 65 74 75 72 6e 20 53 51 4c 49 54 45 5f 4f 4b  return SQLITE_OK
2b50: 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 53 65 74 20 74  ;.}../*.** Set t
2b60: 68 65 20 65 72 72 6f 72 20 6d 65 73 73 61 67 65  he error message
2b70: 20 66 6f 72 20 74 68 65 20 76 69 72 74 75 61 6c   for the virtual
2b80: 20 74 61 62 6c 65 20 61 73 73 6f 63 69 61 74 65   table associate
2b90: 64 20 77 69 74 68 20 63 75 72 73 6f 72 0a 2a 2a  d with cursor.**
2ba0: 20 70 43 73 72 20 74 6f 20 74 68 65 20 72 65 73   pCsr to the res
2bb0: 75 6c 74 73 20 6f 66 20 76 70 72 69 6e 74 66 28  ults of vprintf(
2bc0: 7a 46 6d 74 2c 20 2e 2e 2e 29 2e 0a 2a 2f 0a 73  zFmt, ...)..*/.s
2bd0: 74 61 74 69 63 20 76 6f 69 64 20 7a 69 70 66 69  tatic void zipfi
2be0: 6c 65 53 65 74 45 72 72 6d 73 67 28 5a 69 70 66  leSetErrmsg(Zipf
2bf0: 69 6c 65 43 73 72 20 2a 70 43 73 72 2c 20 63 6f  ileCsr *pCsr, co
2c00: 6e 73 74 20 63 68 61 72 20 2a 7a 46 6d 74 2c 20  nst char *zFmt, 
2c10: 2e 2e 2e 29 7b 0a 20 20 76 61 5f 6c 69 73 74 20  ...){.  va_list 
2c20: 61 70 3b 0a 20 20 76 61 5f 73 74 61 72 74 28 61  ap;.  va_start(a
2c30: 70 2c 20 7a 46 6d 74 29 3b 0a 20 20 70 43 73 72  p, zFmt);.  pCsr
2c40: 2d 3e 62 61 73 65 2e 70 56 74 61 62 2d 3e 7a 45  ->base.pVtab->zE
2c50: 72 72 4d 73 67 20 3d 20 73 71 6c 69 74 65 33 5f  rrMsg = sqlite3_
2c60: 76 6d 70 72 69 6e 74 66 28 7a 46 6d 74 2c 20 61  vmprintf(zFmt, a
2c70: 70 29 3b 0a 20 20 76 61 5f 65 6e 64 28 61 70 29  p);.  va_end(ap)
2c80: 3b 0a 7d 0a 0a 73 74 61 74 69 63 20 69 6e 74 20  ;.}..static int 
2c90: 7a 69 70 66 69 6c 65 52 65 61 64 44 61 74 61 28  zipfileReadData(
2ca0: 0a 20 20 46 49 4c 45 20 2a 70 46 69 6c 65 2c 20  .  FILE *pFile, 
2cb0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2cc0: 20 20 20 2f 2a 20 52 65 61 64 20 66 72 6f 6d 20     /* Read from 
2cd0: 74 68 69 73 20 66 69 6c 65 20 2a 2f 0a 20 20 75  this file */.  u
2ce0: 38 20 2a 61 52 65 61 64 2c 20 20 20 20 20 20 20  8 *aRead,       
2cf0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f                 /
2d00: 2a 20 52 65 61 64 20 69 6e 74 6f 20 74 68 69 73  * Read into this
2d10: 20 62 75 66 66 65 72 20 2a 2f 0a 20 20 69 6e 74   buffer */.  int
2d20: 20 6e 52 65 61 64 2c 20 20 20 20 20 20 20 20 20   nRead,         
2d30: 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20               /* 
2d40: 4e 75 6d 62 65 72 20 6f 66 20 62 79 74 65 73 20  Number of bytes 
2d50: 74 6f 20 72 65 61 64 20 2a 2f 0a 20 20 69 36 34  to read */.  i64
2d60: 20 69 4f 66 66 2c 20 20 20 20 20 20 20 20 20 20   iOff,          
2d70: 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20               /* 
2d80: 4f 66 66 73 65 74 20 74 6f 20 72 65 61 64 20 66  Offset to read f
2d90: 72 6f 6d 20 2a 2f 0a 20 20 63 68 61 72 20 2a 2a  rom */.  char **
2da0: 70 7a 45 72 72 6d 73 67 20 20 20 20 20 20 20 20  pzErrmsg        
2db0: 20 20 20 20 20 20 20 20 20 2f 2a 20 4f 55 54 3a           /* OUT:
2dc0: 20 45 72 72 6f 72 20 6d 65 73 73 61 67 65 20 28   Error message (
2dd0: 66 72 6f 6d 20 73 71 6c 69 74 65 33 5f 6d 61 6c  from sqlite3_mal
2de0: 6c 6f 63 29 20 2a 2f 0a 29 7b 0a 20 20 73 69 7a  loc) */.){.  siz
2df0: 65 5f 74 20 6e 3b 0a 20 20 66 73 65 65 6b 28 70  e_t n;.  fseek(p
2e00: 46 69 6c 65 2c 20 28 6c 6f 6e 67 29 69 4f 66 66  File, (long)iOff
2e10: 2c 20 53 45 45 4b 5f 53 45 54 29 3b 0a 20 20 6e  , SEEK_SET);.  n
2e20: 20 3d 20 66 72 65 61 64 28 61 52 65 61 64 2c 20   = fread(aRead, 
2e30: 31 2c 20 6e 52 65 61 64 2c 20 70 46 69 6c 65 29  1, nRead, pFile)
2e40: 3b 0a 20 20 69 66 28 20 28 69 6e 74 29 6e 21 3d  ;.  if( (int)n!=
2e50: 6e 52 65 61 64 20 29 7b 0a 20 20 20 20 2a 70 7a  nRead ){.    *pz
2e60: 45 72 72 6d 73 67 20 3d 20 73 71 6c 69 74 65 33  Errmsg = sqlite3
2e70: 5f 6d 70 72 69 6e 74 66 28 22 65 72 72 6f 72 20  _mprintf("error 
2e80: 69 6e 20 66 72 65 61 64 28 29 22 29 3b 0a 20 20  in fread()");.  
2e90: 20 20 72 65 74 75 72 6e 20 53 51 4c 49 54 45 5f    return SQLITE_
2ea0: 45 52 52 4f 52 3b 0a 20 20 7d 0a 20 20 72 65 74  ERROR;.  }.  ret
2eb0: 75 72 6e 20 53 51 4c 49 54 45 5f 4f 4b 3b 0a 7d  urn SQLITE_OK;.}
2ec0: 0a 0a 73 74 61 74 69 63 20 69 6e 74 20 7a 69 70  ..static int zip
2ed0: 66 69 6c 65 41 70 70 65 6e 64 44 61 74 61 28 0a  fileAppendData(.
2ee0: 20 20 5a 69 70 66 69 6c 65 54 61 62 20 2a 70 54    ZipfileTab *pT
2ef0: 61 62 2c 0a 20 20 63 6f 6e 73 74 20 75 38 20 2a  ab,.  const u8 *
2f00: 61 57 72 69 74 65 2c 0a 20 20 69 6e 74 20 6e 57  aWrite,.  int nW
2f10: 72 69 74 65 0a 29 7b 0a 20 20 73 69 7a 65 5f 74  rite.){.  size_t
2f20: 20 6e 3b 0a 20 20 66 73 65 65 6b 28 70 54 61 62   n;.  fseek(pTab
2f30: 2d 3e 70 57 72 69 74 65 46 64 2c 20 28 6c 6f 6e  ->pWriteFd, (lon
2f40: 67 29 70 54 61 62 2d 3e 73 7a 43 75 72 72 65 6e  g)pTab->szCurren
2f50: 74 2c 20 53 45 45 4b 5f 53 45 54 29 3b 0a 20 20  t, SEEK_SET);.  
2f60: 6e 20 3d 20 66 77 72 69 74 65 28 61 57 72 69 74  n = fwrite(aWrit
2f70: 65 2c 20 31 2c 20 6e 57 72 69 74 65 2c 20 70 54  e, 1, nWrite, pT
2f80: 61 62 2d 3e 70 57 72 69 74 65 46 64 29 3b 0a 20  ab->pWriteFd);. 
2f90: 20 69 66 28 20 28 69 6e 74 29 6e 21 3d 6e 57 72   if( (int)n!=nWr
2fa0: 69 74 65 20 29 7b 0a 20 20 20 20 70 54 61 62 2d  ite ){.    pTab-
2fb0: 3e 62 61 73 65 2e 7a 45 72 72 4d 73 67 20 3d 20  >base.zErrMsg = 
2fc0: 73 71 6c 69 74 65 33 5f 6d 70 72 69 6e 74 66 28  sqlite3_mprintf(
2fd0: 22 65 72 72 6f 72 20 69 6e 20 66 77 72 69 74 65  "error in fwrite
2fe0: 28 29 22 29 3b 0a 20 20 20 20 72 65 74 75 72 6e  ()");.    return
2ff0: 20 53 51 4c 49 54 45 5f 45 52 52 4f 52 3b 0a 20   SQLITE_ERROR;. 
3000: 20 7d 0a 20 20 70 54 61 62 2d 3e 73 7a 43 75 72   }.  pTab->szCur
3010: 72 65 6e 74 20 2b 3d 20 6e 57 72 69 74 65 3b 0a  rent += nWrite;.
3020: 20 20 72 65 74 75 72 6e 20 53 51 4c 49 54 45 5f    return SQLITE_
3030: 4f 4b 3b 0a 7d 0a 0a 73 74 61 74 69 63 20 75 31  OK;.}..static u1
3040: 36 20 7a 69 70 66 69 6c 65 47 65 74 55 31 36 28  6 zipfileGetU16(
3050: 63 6f 6e 73 74 20 75 38 20 2a 61 42 75 66 29 7b  const u8 *aBuf){
3060: 0a 20 20 72 65 74 75 72 6e 20 28 61 42 75 66 5b  .  return (aBuf[
3070: 31 5d 20 3c 3c 20 38 29 20 2b 20 61 42 75 66 5b  1] << 8) + aBuf[
3080: 30 5d 3b 0a 7d 0a 73 74 61 74 69 63 20 75 33 32  0];.}.static u32
3090: 20 7a 69 70 66 69 6c 65 47 65 74 55 33 32 28 63   zipfileGetU32(c
30a0: 6f 6e 73 74 20 75 38 20 2a 61 42 75 66 29 7b 0a  onst u8 *aBuf){.
30b0: 20 20 72 65 74 75 72 6e 20 28 28 75 33 32 29 28    return ((u32)(
30c0: 61 42 75 66 5b 33 5d 29 20 3c 3c 20 32 34 29 0a  aBuf[3]) << 24).
30d0: 20 20 20 20 20 20 20 2b 20 28 28 75 33 32 29 28         + ((u32)(
30e0: 61 42 75 66 5b 32 5d 29 20 3c 3c 20 31 36 29 0a  aBuf[2]) << 16).
30f0: 20 20 20 20 20 20 20 2b 20 28 28 75 33 32 29 28         + ((u32)(
3100: 61 42 75 66 5b 31 5d 29 20 3c 3c 20 20 38 29 0a  aBuf[1]) <<  8).
3110: 20 20 20 20 20 20 20 2b 20 28 28 75 33 32 29 28         + ((u32)(
3120: 61 42 75 66 5b 30 5d 29 20 3c 3c 20 20 30 29 3b  aBuf[0]) <<  0);
3130: 0a 7d 0a 0a 73 74 61 74 69 63 20 76 6f 69 64 20  .}..static void 
3140: 7a 69 70 66 69 6c 65 50 75 74 55 31 36 28 75 38  zipfilePutU16(u8
3150: 20 2a 61 42 75 66 2c 20 75 31 36 20 76 61 6c 29   *aBuf, u16 val)
3160: 7b 0a 20 20 61 42 75 66 5b 30 5d 20 3d 20 76 61  {.  aBuf[0] = va
3170: 6c 20 26 20 30 78 46 46 3b 0a 20 20 61 42 75 66  l & 0xFF;.  aBuf
3180: 5b 31 5d 20 3d 20 28 76 61 6c 3e 3e 38 29 20 26  [1] = (val>>8) &
3190: 20 30 78 46 46 3b 0a 7d 0a 73 74 61 74 69 63 20   0xFF;.}.static 
31a0: 76 6f 69 64 20 7a 69 70 66 69 6c 65 50 75 74 55  void zipfilePutU
31b0: 33 32 28 75 38 20 2a 61 42 75 66 2c 20 75 33 32  32(u8 *aBuf, u32
31c0: 20 76 61 6c 29 7b 0a 20 20 61 42 75 66 5b 30 5d   val){.  aBuf[0]
31d0: 20 3d 20 76 61 6c 20 26 20 30 78 46 46 3b 0a 20   = val & 0xFF;. 
31e0: 20 61 42 75 66 5b 31 5d 20 3d 20 28 76 61 6c 3e   aBuf[1] = (val>
31f0: 3e 38 29 20 26 20 30 78 46 46 3b 0a 20 20 61 42  >8) & 0xFF;.  aB
3200: 75 66 5b 32 5d 20 3d 20 28 76 61 6c 3e 3e 31 36  uf[2] = (val>>16
3210: 29 20 26 20 30 78 46 46 3b 0a 20 20 61 42 75 66  ) & 0xFF;.  aBuf
3220: 5b 33 5d 20 3d 20 28 76 61 6c 3e 3e 32 34 29 20  [3] = (val>>24) 
3230: 26 20 30 78 46 46 3b 0a 7d 0a 0a 23 64 65 66 69  & 0xFF;.}..#defi
3240: 6e 65 20 7a 69 70 66 69 6c 65 52 65 61 64 33 32  ne zipfileRead32
3250: 28 61 42 75 66 29 20 28 20 61 42 75 66 2b 3d 34  (aBuf) ( aBuf+=4
3260: 2c 20 7a 69 70 66 69 6c 65 47 65 74 55 33 32 28  , zipfileGetU32(
3270: 61 42 75 66 2d 34 29 20 29 0a 23 64 65 66 69 6e  aBuf-4) ).#defin
3280: 65 20 7a 69 70 66 69 6c 65 52 65 61 64 31 36 28  e zipfileRead16(
3290: 61 42 75 66 29 20 28 20 61 42 75 66 2b 3d 32 2c  aBuf) ( aBuf+=2,
32a0: 20 7a 69 70 66 69 6c 65 47 65 74 55 31 36 28 61   zipfileGetU16(a
32b0: 42 75 66 2d 32 29 20 29 0a 0a 23 64 65 66 69 6e  Buf-2) )..#defin
32c0: 65 20 7a 69 70 66 69 6c 65 57 72 69 74 65 33 32  e zipfileWrite32
32d0: 28 61 42 75 66 2c 76 61 6c 29 20 7b 20 7a 69 70  (aBuf,val) { zip
32e0: 66 69 6c 65 50 75 74 55 33 32 28 61 42 75 66 2c  filePutU32(aBuf,
32f0: 76 61 6c 29 3b 20 61 42 75 66 2b 3d 34 3b 20 7d  val); aBuf+=4; }
3300: 0a 23 64 65 66 69 6e 65 20 7a 69 70 66 69 6c 65  .#define zipfile
3310: 57 72 69 74 65 31 36 28 61 42 75 66 2c 76 61 6c  Write16(aBuf,val
3320: 29 20 7b 20 7a 69 70 66 69 6c 65 50 75 74 55 31  ) { zipfilePutU1
3330: 36 28 61 42 75 66 2c 76 61 6c 29 3b 20 61 42 75  6(aBuf,val); aBu
3340: 66 2b 3d 32 3b 20 7d 0a 0a 73 74 61 74 69 63 20  f+=2; }..static 
3350: 75 38 2a 20 7a 69 70 66 69 6c 65 43 73 72 42 75  u8* zipfileCsrBu
3360: 66 66 65 72 28 5a 69 70 66 69 6c 65 43 73 72 20  ffer(ZipfileCsr 
3370: 2a 70 43 73 72 29 7b 0a 20 20 72 65 74 75 72 6e  *pCsr){.  return
3380: 20 28 28 5a 69 70 66 69 6c 65 54 61 62 2a 29 28   ((ZipfileTab*)(
3390: 70 43 73 72 2d 3e 62 61 73 65 2e 70 56 74 61 62  pCsr->base.pVtab
33a0: 29 29 2d 3e 61 42 75 66 66 65 72 3b 0a 7d 0a 0a  ))->aBuffer;.}..
33b0: 2f 2a 0a 2a 2a 20 4d 61 67 69 63 20 6e 75 6d 62  /*.** Magic numb
33c0: 65 72 73 20 75 73 65 64 20 74 6f 20 72 65 61 64  ers used to read
33d0: 20 43 44 53 20 72 65 63 6f 72 64 73 2e 0a 2a 2f   CDS records..*/
33e0: 0a 23 64 65 66 69 6e 65 20 5a 49 50 46 49 4c 45  .#define ZIPFILE
33f0: 5f 43 44 53 5f 46 49 58 45 44 5f 53 5a 20 20 34  _CDS_FIXED_SZ  4
3400: 36 0a 23 64 65 66 69 6e 65 20 5a 49 50 46 49 4c  6.#define ZIPFIL
3410: 45 5f 43 44 53 5f 4e 46 49 4c 45 5f 4f 46 46 20  E_CDS_NFILE_OFF 
3420: 32 38 0a 0a 73 74 61 74 69 63 20 69 6e 74 20 7a  28..static int z
3430: 69 70 66 69 6c 65 52 65 61 64 43 44 53 28 5a 69  ipfileReadCDS(Zi
3440: 70 66 69 6c 65 43 73 72 20 2a 70 43 73 72 29 7b  pfileCsr *pCsr){
3450: 0a 20 20 63 68 61 72 20 2a 2a 70 7a 45 72 72 20  .  char **pzErr 
3460: 3d 20 26 70 43 73 72 2d 3e 62 61 73 65 2e 70 56  = &pCsr->base.pV
3470: 74 61 62 2d 3e 7a 45 72 72 4d 73 67 3b 0a 20 20  tab->zErrMsg;.  
3480: 75 38 20 2a 61 52 65 61 64 3b 0a 20 20 69 6e 74  u8 *aRead;.  int
3490: 20 72 63 20 3d 20 53 51 4c 49 54 45 5f 4f 4b 3b   rc = SQLITE_OK;
34a0: 0a 0a 20 20 73 71 6c 69 74 65 33 5f 66 72 65 65  ..  sqlite3_free
34b0: 28 70 43 73 72 2d 3e 63 64 73 2e 7a 46 69 6c 65  (pCsr->cds.zFile
34c0: 29 3b 0a 20 20 70 43 73 72 2d 3e 63 64 73 2e 7a  );.  pCsr->cds.z
34d0: 46 69 6c 65 20 3d 20 30 3b 0a 0a 20 20 69 66 28  File = 0;..  if(
34e0: 20 70 43 73 72 2d 3e 70 43 75 72 72 65 6e 74 3d   pCsr->pCurrent=
34f0: 3d 30 20 29 7b 0a 20 20 20 20 61 52 65 61 64 20  =0 ){.    aRead 
3500: 3d 20 7a 69 70 66 69 6c 65 43 73 72 42 75 66 66  = zipfileCsrBuff
3510: 65 72 28 70 43 73 72 29 3b 0a 20 20 20 20 72 63  er(pCsr);.    rc
3520: 20 3d 20 7a 69 70 66 69 6c 65 52 65 61 64 44 61   = zipfileReadDa
3530: 74 61 28 0a 20 20 20 20 20 20 20 20 70 43 73 72  ta(.        pCsr
3540: 2d 3e 70 46 69 6c 65 2c 20 61 52 65 61 64 2c 20  ->pFile, aRead, 
3550: 5a 49 50 46 49 4c 45 5f 43 44 53 5f 46 49 58 45  ZIPFILE_CDS_FIXE
3560: 44 5f 53 5a 2c 20 70 43 73 72 2d 3e 69 4e 65 78  D_SZ, pCsr->iNex
3570: 74 4f 66 66 2c 20 70 7a 45 72 72 0a 20 20 20 20  tOff, pzErr.    
3580: 29 3b 0a 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20  );.  }else{.    
3590: 61 52 65 61 64 20 3d 20 70 43 73 72 2d 3e 70 43  aRead = pCsr->pC
35a0: 75 72 72 65 6e 74 2d 3e 61 43 64 73 45 6e 74 72  urrent->aCdsEntr
35b0: 79 3b 0a 20 20 7d 0a 0a 20 20 69 66 28 20 72 63  y;.  }..  if( rc
35c0: 3d 3d 53 51 4c 49 54 45 5f 4f 4b 20 29 7b 0a 20  ==SQLITE_OK ){. 
35d0: 20 20 20 75 33 32 20 73 69 67 20 3d 20 7a 69 70     u32 sig = zip
35e0: 66 69 6c 65 52 65 61 64 33 32 28 61 52 65 61 64  fileRead32(aRead
35f0: 29 3b 0a 20 20 20 20 69 66 28 20 73 69 67 21 3d  );.    if( sig!=
3600: 5a 49 50 46 49 4c 45 5f 53 49 47 4e 41 54 55 52  ZIPFILE_SIGNATUR
3610: 45 5f 43 44 53 20 29 7b 0a 20 20 20 20 20 20 61  E_CDS ){.      a
3620: 73 73 65 72 74 28 20 70 43 73 72 2d 3e 70 43 75  ssert( pCsr->pCu
3630: 72 72 65 6e 74 3d 3d 30 20 29 3b 0a 20 20 20 20  rrent==0 );.    
3640: 20 20 7a 69 70 66 69 6c 65 53 65 74 45 72 72 6d    zipfileSetErrm
3650: 73 67 28 70 43 73 72 2c 22 66 61 69 6c 65 64 20  sg(pCsr,"failed 
3660: 74 6f 20 72 65 61 64 20 43 44 53 20 61 74 20 6f  to read CDS at o
3670: 66 66 73 65 74 20 25 6c 6c 64 22 2c 70 43 73 72  ffset %lld",pCsr
3680: 2d 3e 69 4e 65 78 74 4f 66 66 29 3b 0a 20 20 20  ->iNextOff);.   
3690: 20 20 20 72 63 20 3d 20 53 51 4c 49 54 45 5f 45     rc = SQLITE_E
36a0: 52 52 4f 52 3b 0a 20 20 20 20 7d 65 6c 73 65 7b  RROR;.    }else{
36b0: 0a 20 20 20 20 20 20 69 6e 74 20 6e 52 65 61 64  .      int nRead
36c0: 3b 0a 20 20 20 20 20 20 70 43 73 72 2d 3e 63 64  ;.      pCsr->cd
36d0: 73 2e 69 56 65 72 73 69 6f 6e 4d 61 64 65 42 79  s.iVersionMadeBy
36e0: 20 3d 20 7a 69 70 66 69 6c 65 52 65 61 64 31 36   = zipfileRead16
36f0: 28 61 52 65 61 64 29 3b 0a 20 20 20 20 20 20 70  (aRead);.      p
3700: 43 73 72 2d 3e 63 64 73 2e 69 56 65 72 73 69 6f  Csr->cds.iVersio
3710: 6e 45 78 74 72 61 63 74 20 3d 20 7a 69 70 66 69  nExtract = zipfi
3720: 6c 65 52 65 61 64 31 36 28 61 52 65 61 64 29 3b  leRead16(aRead);
3730: 0a 20 20 20 20 20 20 70 43 73 72 2d 3e 63 64 73  .      pCsr->cds
3740: 2e 66 6c 61 67 73 20 3d 20 7a 69 70 66 69 6c 65  .flags = zipfile
3750: 52 65 61 64 31 36 28 61 52 65 61 64 29 3b 0a 20  Read16(aRead);. 
3760: 20 20 20 20 20 70 43 73 72 2d 3e 63 64 73 2e 69       pCsr->cds.i
3770: 43 6f 6d 70 72 65 73 73 69 6f 6e 20 3d 20 7a 69  Compression = zi
3780: 70 66 69 6c 65 52 65 61 64 31 36 28 61 52 65 61  pfileRead16(aRea
3790: 64 29 3b 0a 20 20 20 20 20 20 70 43 73 72 2d 3e  d);.      pCsr->
37a0: 63 64 73 2e 6d 54 69 6d 65 20 3d 20 7a 69 70 66  cds.mTime = zipf
37b0: 69 6c 65 52 65 61 64 31 36 28 61 52 65 61 64 29  ileRead16(aRead)
37c0: 3b 0a 20 20 20 20 20 20 70 43 73 72 2d 3e 63 64  ;.      pCsr->cd
37d0: 73 2e 6d 44 61 74 65 20 3d 20 7a 69 70 66 69 6c  s.mDate = zipfil
37e0: 65 52 65 61 64 31 36 28 61 52 65 61 64 29 3b 0a  eRead16(aRead);.
37f0: 20 20 20 20 20 20 70 43 73 72 2d 3e 63 64 73 2e        pCsr->cds.
3800: 63 72 63 33 32 20 3d 20 7a 69 70 66 69 6c 65 52  crc32 = zipfileR
3810: 65 61 64 33 32 28 61 52 65 61 64 29 3b 0a 20 20  ead32(aRead);.  
3820: 20 20 20 20 70 43 73 72 2d 3e 63 64 73 2e 73 7a      pCsr->cds.sz
3830: 43 6f 6d 70 72 65 73 73 65 64 20 3d 20 7a 69 70  Compressed = zip
3840: 66 69 6c 65 52 65 61 64 33 32 28 61 52 65 61 64  fileRead32(aRead
3850: 29 3b 0a 20 20 20 20 20 20 70 43 73 72 2d 3e 63  );.      pCsr->c
3860: 64 73 2e 73 7a 55 6e 63 6f 6d 70 72 65 73 73 65  ds.szUncompresse
3870: 64 20 3d 20 7a 69 70 66 69 6c 65 52 65 61 64 33  d = zipfileRead3
3880: 32 28 61 52 65 61 64 29 3b 0a 20 20 20 20 20 20  2(aRead);.      
3890: 61 73 73 65 72 74 28 20 70 43 73 72 2d 3e 70 43  assert( pCsr->pC
38a0: 75 72 72 65 6e 74 20 0a 20 20 20 20 20 20 20 20  urrent .        
38b0: 20 20 20 7c 7c 20 61 52 65 61 64 3d 3d 7a 69 70     || aRead==zip
38c0: 66 69 6c 65 43 73 72 42 75 66 66 65 72 28 70 43  fileCsrBuffer(pC
38d0: 73 72 29 2b 5a 49 50 46 49 4c 45 5f 43 44 53 5f  sr)+ZIPFILE_CDS_
38e0: 4e 46 49 4c 45 5f 4f 46 46 20 0a 20 20 20 20 20  NFILE_OFF .     
38f0: 20 29 3b 0a 20 20 20 20 20 20 70 43 73 72 2d 3e   );.      pCsr->
3900: 63 64 73 2e 6e 46 69 6c 65 20 3d 20 7a 69 70 66  cds.nFile = zipf
3910: 69 6c 65 52 65 61 64 31 36 28 61 52 65 61 64 29  ileRead16(aRead)
3920: 3b 0a 20 20 20 20 20 20 70 43 73 72 2d 3e 63 64  ;.      pCsr->cd
3930: 73 2e 6e 45 78 74 72 61 20 3d 20 7a 69 70 66 69  s.nExtra = zipfi
3940: 6c 65 52 65 61 64 31 36 28 61 52 65 61 64 29 3b  leRead16(aRead);
3950: 0a 20 20 20 20 20 20 70 43 73 72 2d 3e 63 64 73  .      pCsr->cds
3960: 2e 6e 43 6f 6d 6d 65 6e 74 20 3d 20 7a 69 70 66  .nComment = zipf
3970: 69 6c 65 52 65 61 64 31 36 28 61 52 65 61 64 29  ileRead16(aRead)
3980: 3b 0a 20 20 20 20 20 20 70 43 73 72 2d 3e 63 64  ;.      pCsr->cd
3990: 73 2e 69 44 69 73 6b 53 74 61 72 74 20 3d 20 7a  s.iDiskStart = z
39a0: 69 70 66 69 6c 65 52 65 61 64 31 36 28 61 52 65  ipfileRead16(aRe
39b0: 61 64 29 3b 0a 20 20 20 20 20 20 70 43 73 72 2d  ad);.      pCsr-
39c0: 3e 63 64 73 2e 69 49 6e 74 65 72 6e 61 6c 41 74  >cds.iInternalAt
39d0: 74 72 20 3d 20 7a 69 70 66 69 6c 65 52 65 61 64  tr = zipfileRead
39e0: 31 36 28 61 52 65 61 64 29 3b 0a 20 20 20 20 20  16(aRead);.     
39f0: 20 70 43 73 72 2d 3e 63 64 73 2e 69 45 78 74 65   pCsr->cds.iExte
3a00: 72 6e 61 6c 41 74 74 72 20 3d 20 7a 69 70 66 69  rnalAttr = zipfi
3a10: 6c 65 52 65 61 64 33 32 28 61 52 65 61 64 29 3b  leRead32(aRead);
3a20: 0a 20 20 20 20 20 20 70 43 73 72 2d 3e 63 64 73  .      pCsr->cds
3a30: 2e 69 4f 66 66 73 65 74 20 3d 20 7a 69 70 66 69  .iOffset = zipfi
3a40: 6c 65 52 65 61 64 33 32 28 61 52 65 61 64 29 3b  leRead32(aRead);
3a50: 0a 20 20 20 20 20 20 61 73 73 65 72 74 28 20 70  .      assert( p
3a60: 43 73 72 2d 3e 70 43 75 72 72 65 6e 74 20 0a 20  Csr->pCurrent . 
3a70: 20 20 20 20 20 20 20 20 20 20 7c 7c 20 61 52 65            || aRe
3a80: 61 64 3d 3d 7a 69 70 66 69 6c 65 43 73 72 42 75  ad==zipfileCsrBu
3a90: 66 66 65 72 28 70 43 73 72 29 2b 5a 49 50 46 49  ffer(pCsr)+ZIPFI
3aa0: 4c 45 5f 43 44 53 5f 46 49 58 45 44 5f 53 5a 0a  LE_CDS_FIXED_SZ.
3ab0: 20 20 20 20 20 20 29 3b 0a 0a 20 20 20 20 20 20        );..      
3ac0: 69 66 28 20 70 43 73 72 2d 3e 70 43 75 72 72 65  if( pCsr->pCurre
3ad0: 6e 74 3d 3d 30 20 29 7b 0a 20 20 20 20 20 20 20  nt==0 ){.       
3ae0: 20 6e 52 65 61 64 20 3d 20 70 43 73 72 2d 3e 63   nRead = pCsr->c
3af0: 64 73 2e 6e 46 69 6c 65 20 2b 20 70 43 73 72 2d  ds.nFile + pCsr-
3b00: 3e 63 64 73 2e 6e 45 78 74 72 61 3b 0a 20 20 20  >cds.nExtra;.   
3b10: 20 20 20 20 20 61 52 65 61 64 20 3d 20 7a 69 70       aRead = zip
3b20: 66 69 6c 65 43 73 72 42 75 66 66 65 72 28 70 43  fileCsrBuffer(pC
3b30: 73 72 29 3b 0a 20 20 20 20 20 20 20 20 70 43 73  sr);.        pCs
3b40: 72 2d 3e 69 4e 65 78 74 4f 66 66 20 2b 3d 20 5a  r->iNextOff += Z
3b50: 49 50 46 49 4c 45 5f 43 44 53 5f 46 49 58 45 44  IPFILE_CDS_FIXED
3b60: 5f 53 5a 3b 0a 20 20 20 20 20 20 20 20 72 63 20  _SZ;.        rc 
3b70: 3d 20 7a 69 70 66 69 6c 65 52 65 61 64 44 61 74  = zipfileReadDat
3b80: 61 28 70 43 73 72 2d 3e 70 46 69 6c 65 2c 20 61  a(pCsr->pFile, a
3b90: 52 65 61 64 2c 20 6e 52 65 61 64 2c 20 70 43 73  Read, nRead, pCs
3ba0: 72 2d 3e 69 4e 65 78 74 4f 66 66 2c 20 70 7a 45  r->iNextOff, pzE
3bb0: 72 72 29 3b 0a 20 20 20 20 20 20 7d 0a 0a 20 20  rr);.      }..  
3bc0: 20 20 20 20 69 66 28 20 72 63 3d 3d 53 51 4c 49      if( rc==SQLI
3bd0: 54 45 5f 4f 4b 20 29 7b 0a 20 20 20 20 20 20 20  TE_OK ){.       
3be0: 20 70 43 73 72 2d 3e 63 64 73 2e 7a 46 69 6c 65   pCsr->cds.zFile
3bf0: 20 3d 20 73 71 6c 69 74 65 33 5f 6d 70 72 69 6e   = sqlite3_mprin
3c00: 74 66 28 22 25 2e 2a 73 22 2c 20 28 69 6e 74 29  tf("%.*s", (int)
3c10: 70 43 73 72 2d 3e 63 64 73 2e 6e 46 69 6c 65 2c  pCsr->cds.nFile,
3c20: 20 61 52 65 61 64 29 3b 0a 20 20 20 20 20 20 20   aRead);.       
3c30: 20 70 43 73 72 2d 3e 69 4e 65 78 74 4f 66 66 20   pCsr->iNextOff 
3c40: 2b 3d 20 70 43 73 72 2d 3e 63 64 73 2e 6e 46 69  += pCsr->cds.nFi
3c50: 6c 65 3b 0a 20 20 20 20 20 20 20 20 70 43 73 72  le;.        pCsr
3c60: 2d 3e 69 4e 65 78 74 4f 66 66 20 2b 3d 20 70 43  ->iNextOff += pC
3c70: 73 72 2d 3e 63 64 73 2e 6e 45 78 74 72 61 3b 0a  sr->cds.nExtra;.
3c80: 20 20 20 20 20 20 20 20 70 43 73 72 2d 3e 69 4e          pCsr->iN
3c90: 65 78 74 4f 66 66 20 2b 3d 20 70 43 73 72 2d 3e  extOff += pCsr->
3ca0: 63 64 73 2e 6e 43 6f 6d 6d 65 6e 74 3b 0a 20 20  cds.nComment;.  
3cb0: 20 20 20 20 7d 0a 0a 20 20 20 20 20 20 2f 2a 20      }..      /* 
3cc0: 53 63 61 6e 20 74 68 65 20 63 64 73 2e 6e 45 78  Scan the cds.nEx
3cd0: 74 72 61 20 62 79 74 65 73 20 6f 66 20 22 65 78  tra bytes of "ex
3ce0: 74 72 61 22 20 66 69 65 6c 64 73 20 66 6f 72 20  tra" fields for 
3cf0: 61 6e 79 20 74 68 61 74 20 63 61 6e 0a 20 20 20  any that can.   
3d00: 20 20 20 2a 2a 20 62 65 20 69 6e 74 65 72 70 72     ** be interpr
3d10: 65 74 65 64 2e 20 54 68 65 20 67 65 6e 65 72 61  eted. The genera
3d20: 6c 20 66 6f 72 6d 61 74 20 6f 66 20 61 6e 20 65  l format of an e
3d30: 78 74 72 61 20 66 69 65 6c 64 20 69 73 3a 0a 20  xtra field is:. 
3d40: 20 20 20 20 20 2a 2a 0a 20 20 20 20 20 20 2a 2a       **.      **
3d50: 20 20 20 48 65 61 64 65 72 20 49 44 20 20 20 20     Header ID    
3d60: 32 20 62 79 74 65 73 0a 20 20 20 20 20 20 2a 2a  2 bytes.      **
3d70: 20 20 20 44 61 74 61 20 53 69 7a 65 20 20 20 20     Data Size    
3d80: 32 20 62 79 74 65 73 0a 20 20 20 20 20 20 2a 2a  2 bytes.      **
3d90: 20 20 20 44 61 74 61 20 20 20 20 20 20 20 20 20     Data         
3da0: 4e 20 62 79 74 65 73 0a 20 20 20 20 20 20 2a 2a  N bytes.      **
3db0: 0a 20 20 20 20 20 20 2a 2f 0a 20 20 20 20 20 20  .      */.      
3dc0: 69 66 28 20 72 63 3d 3d 53 51 4c 49 54 45 5f 4f  if( rc==SQLITE_O
3dd0: 4b 20 29 7b 0a 20 20 20 20 20 20 20 20 75 38 20  K ){.        u8 
3de0: 2a 70 20 3d 20 26 61 52 65 61 64 5b 70 43 73 72  *p = &aRead[pCsr
3df0: 2d 3e 63 64 73 2e 6e 46 69 6c 65 5d 3b 0a 20 20  ->cds.nFile];.  
3e00: 20 20 20 20 20 20 75 38 20 2a 70 45 6e 64 20 3d        u8 *pEnd =
3e10: 20 26 70 5b 70 43 73 72 2d 3e 63 64 73 2e 6e 45   &p[pCsr->cds.nE
3e20: 78 74 72 61 5d 3b 0a 0a 20 20 20 20 20 20 20 20  xtra];..        
3e30: 77 68 69 6c 65 28 20 70 3c 70 45 6e 64 20 29 7b  while( p<pEnd ){
3e40: 0a 20 20 20 20 20 20 20 20 20 20 75 31 36 20 69  .          u16 i
3e50: 64 20 3d 20 7a 69 70 66 69 6c 65 52 65 61 64 31  d = zipfileRead1
3e60: 36 28 70 29 3b 0a 20 20 20 20 20 20 20 20 20 20  6(p);.          
3e70: 75 31 36 20 6e 42 79 74 65 20 3d 20 7a 69 70 66  u16 nByte = zipf
3e80: 69 6c 65 52 65 61 64 31 36 28 70 29 3b 0a 0a 20  ileRead16(p);.. 
3e90: 20 20 20 20 20 20 20 20 20 73 77 69 74 63 68 28           switch(
3ea0: 20 69 64 20 29 7b 0a 20 20 20 20 20 20 20 20 20   id ){.         
3eb0: 20 20 20 63 61 73 65 20 5a 49 50 46 49 4c 45 5f     case ZIPFILE_
3ec0: 45 58 54 52 41 5f 54 49 4d 45 53 54 41 4d 50 3a  EXTRA_TIMESTAMP:
3ed0: 20 7b 0a 20 20 20 20 20 20 20 20 20 20 20 20 20   {.             
3ee0: 20 75 38 20 62 20 3d 20 70 5b 30 5d 3b 0a 20 20   u8 b = p[0];.  
3ef0: 20 20 20 20 20 20 20 20 20 20 20 20 69 66 28 20              if( 
3f00: 62 20 26 20 30 78 30 31 20 29 7b 20 20 20 20 20  b & 0x01 ){     
3f10: 2f 2a 20 30 78 30 31 20 2d 3e 20 6d 6f 64 74 69  /* 0x01 -> modti
3f20: 6d 65 20 69 73 20 70 72 65 73 65 6e 74 20 2a 2f  me is present */
3f30: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
3f40: 20 70 43 73 72 2d 3e 6d 54 69 6d 65 20 3d 20 7a   pCsr->mTime = z
3f50: 69 70 66 69 6c 65 47 65 74 55 33 32 28 26 70 5b  ipfileGetU32(&p[
3f60: 31 5d 29 3b 0a 20 20 20 20 20 20 20 20 20 20 20  1]);.           
3f70: 20 20 20 20 20 70 43 73 72 2d 3e 66 6c 61 67 73       pCsr->flags
3f80: 20 7c 3d 20 5a 49 50 46 49 4c 45 5f 4d 54 49 4d   |= ZIPFILE_MTIM
3f90: 45 5f 56 41 4c 49 44 3b 0a 20 20 20 20 20 20 20  E_VALID;.       
3fa0: 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20         }.       
3fb0: 20 20 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20         break;.  
3fc0: 20 20 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20            }.    
3fd0: 20 20 20 20 20 20 7d 0a 0a 20 20 20 20 20 20 20        }..       
3fe0: 20 20 20 70 20 2b 3d 20 6e 42 79 74 65 3b 0a 20     p += nByte;. 
3ff0: 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 7d         }.      }
4000: 0a 20 20 20 20 7d 0a 20 20 7d 0a 0a 20 20 72 65  .    }.  }..  re
4010: 74 75 72 6e 20 72 63 3b 0a 7d 0a 0a 73 74 61 74  turn rc;.}..stat
4020: 69 63 20 46 49 4c 45 20 2a 7a 69 70 66 69 6c 65  ic FILE *zipfile
4030: 47 65 74 46 64 28 5a 69 70 66 69 6c 65 43 73 72  GetFd(ZipfileCsr
4040: 20 2a 70 43 73 72 29 7b 0a 20 20 69 66 28 20 70   *pCsr){.  if( p
4050: 43 73 72 2d 3e 70 46 69 6c 65 20 29 20 72 65 74  Csr->pFile ) ret
4060: 75 72 6e 20 70 43 73 72 2d 3e 70 46 69 6c 65 3b  urn pCsr->pFile;
4070: 0a 20 20 72 65 74 75 72 6e 20 28 28 5a 69 70 66  .  return ((Zipf
4080: 69 6c 65 54 61 62 2a 29 28 70 43 73 72 2d 3e 62  ileTab*)(pCsr->b
4090: 61 73 65 2e 70 56 74 61 62 29 29 2d 3e 70 57 72  ase.pVtab))->pWr
40a0: 69 74 65 46 64 3b 0a 7d 0a 0a 73 74 61 74 69 63  iteFd;.}..static
40b0: 20 69 6e 74 20 7a 69 70 66 69 6c 65 52 65 61 64   int zipfileRead
40c0: 4c 46 48 28 5a 69 70 66 69 6c 65 43 73 72 20 2a  LFH(ZipfileCsr *
40d0: 70 43 73 72 29 7b 0a 20 20 46 49 4c 45 20 2a 70  pCsr){.  FILE *p
40e0: 46 69 6c 65 20 3d 20 7a 69 70 66 69 6c 65 47 65  File = zipfileGe
40f0: 74 46 64 28 70 43 73 72 29 3b 0a 20 20 63 68 61  tFd(pCsr);.  cha
4100: 72 20 2a 2a 70 7a 45 72 72 20 3d 20 26 70 43 73  r **pzErr = &pCs
4110: 72 2d 3e 62 61 73 65 2e 70 56 74 61 62 2d 3e 7a  r->base.pVtab->z
4120: 45 72 72 4d 73 67 3b 0a 20 20 73 74 61 74 69 63  ErrMsg;.  static
4130: 20 63 6f 6e 73 74 20 69 6e 74 20 73 7a 46 69 78   const int szFix
4140: 20 3d 20 5a 49 50 46 49 4c 45 5f 4c 46 48 5f 46   = ZIPFILE_LFH_F
4150: 49 58 45 44 5f 53 5a 3b 0a 20 20 75 38 20 2a 61  IXED_SZ;.  u8 *a
4160: 52 65 61 64 20 3d 20 7a 69 70 66 69 6c 65 43 73  Read = zipfileCs
4170: 72 42 75 66 66 65 72 28 70 43 73 72 29 3b 0a 20  rBuffer(pCsr);. 
4180: 20 69 6e 74 20 72 63 3b 0a 0a 20 20 72 63 20 3d   int rc;..  rc =
4190: 20 7a 69 70 66 69 6c 65 52 65 61 64 44 61 74 61   zipfileReadData
41a0: 28 70 46 69 6c 65 2c 20 61 52 65 61 64 2c 20 73  (pFile, aRead, s
41b0: 7a 46 69 78 2c 20 70 43 73 72 2d 3e 63 64 73 2e  zFix, pCsr->cds.
41c0: 69 4f 66 66 73 65 74 2c 20 70 7a 45 72 72 29 3b  iOffset, pzErr);
41d0: 0a 20 20 69 66 28 20 72 63 3d 3d 53 51 4c 49 54  .  if( rc==SQLIT
41e0: 45 5f 4f 4b 20 29 7b 0a 20 20 20 20 75 33 32 20  E_OK ){.    u32 
41f0: 73 69 67 20 3d 20 7a 69 70 66 69 6c 65 52 65 61  sig = zipfileRea
4200: 64 33 32 28 61 52 65 61 64 29 3b 0a 20 20 20 20  d32(aRead);.    
4210: 69 66 28 20 73 69 67 21 3d 5a 49 50 46 49 4c 45  if( sig!=ZIPFILE
4220: 5f 53 49 47 4e 41 54 55 52 45 5f 4c 46 48 20 29  _SIGNATURE_LFH )
4230: 7b 0a 20 20 20 20 20 20 7a 69 70 66 69 6c 65 53  {.      zipfileS
4240: 65 74 45 72 72 6d 73 67 28 70 43 73 72 2c 20 22  etErrmsg(pCsr, "
4250: 66 61 69 6c 65 64 20 74 6f 20 72 65 61 64 20 4c  failed to read L
4260: 46 48 20 61 74 20 6f 66 66 73 65 74 20 25 64 22  FH at offset %d"
4270: 2c 20 0a 20 20 20 20 20 20 20 20 20 20 28 69 6e  , .          (in
4280: 74 29 70 43 73 72 2d 3e 63 64 73 2e 69 4f 66 66  t)pCsr->cds.iOff
4290: 73 65 74 0a 20 20 20 20 20 20 29 3b 0a 20 20 20  set.      );.   
42a0: 20 20 20 72 63 20 3d 20 53 51 4c 49 54 45 5f 45     rc = SQLITE_E
42b0: 52 52 4f 52 3b 0a 20 20 20 20 7d 65 6c 73 65 7b  RROR;.    }else{
42c0: 0a 20 20 20 20 20 20 70 43 73 72 2d 3e 6c 66 68  .      pCsr->lfh
42d0: 2e 69 56 65 72 73 69 6f 6e 45 78 74 72 61 63 74  .iVersionExtract
42e0: 20 3d 20 7a 69 70 66 69 6c 65 52 65 61 64 31 36   = zipfileRead16
42f0: 28 61 52 65 61 64 29 3b 0a 20 20 20 20 20 20 70  (aRead);.      p
4300: 43 73 72 2d 3e 6c 66 68 2e 66 6c 61 67 73 20 3d  Csr->lfh.flags =
4310: 20 7a 69 70 66 69 6c 65 52 65 61 64 31 36 28 61   zipfileRead16(a
4320: 52 65 61 64 29 3b 0a 20 20 20 20 20 20 70 43 73  Read);.      pCs
4330: 72 2d 3e 6c 66 68 2e 69 43 6f 6d 70 72 65 73 73  r->lfh.iCompress
4340: 69 6f 6e 20 3d 20 7a 69 70 66 69 6c 65 52 65 61  ion = zipfileRea
4350: 64 31 36 28 61 52 65 61 64 29 3b 0a 20 20 20 20  d16(aRead);.    
4360: 20 20 70 43 73 72 2d 3e 6c 66 68 2e 6d 54 69 6d    pCsr->lfh.mTim
4370: 65 20 3d 20 7a 69 70 66 69 6c 65 52 65 61 64 31  e = zipfileRead1
4380: 36 28 61 52 65 61 64 29 3b 0a 20 20 20 20 20 20  6(aRead);.      
4390: 70 43 73 72 2d 3e 6c 66 68 2e 6d 44 61 74 65 20  pCsr->lfh.mDate 
43a0: 3d 20 7a 69 70 66 69 6c 65 52 65 61 64 31 36 28  = zipfileRead16(
43b0: 61 52 65 61 64 29 3b 0a 20 20 20 20 20 20 70 43  aRead);.      pC
43c0: 73 72 2d 3e 6c 66 68 2e 63 72 63 33 32 20 3d 20  sr->lfh.crc32 = 
43d0: 7a 69 70 66 69 6c 65 52 65 61 64 33 32 28 61 52  zipfileRead32(aR
43e0: 65 61 64 29 3b 0a 20 20 20 20 20 20 70 43 73 72  ead);.      pCsr
43f0: 2d 3e 6c 66 68 2e 73 7a 43 6f 6d 70 72 65 73 73  ->lfh.szCompress
4400: 65 64 20 3d 20 7a 69 70 66 69 6c 65 52 65 61 64  ed = zipfileRead
4410: 33 32 28 61 52 65 61 64 29 3b 0a 20 20 20 20 20  32(aRead);.     
4420: 20 70 43 73 72 2d 3e 6c 66 68 2e 73 7a 55 6e 63   pCsr->lfh.szUnc
4430: 6f 6d 70 72 65 73 73 65 64 20 3d 20 7a 69 70 66  ompressed = zipf
4440: 69 6c 65 52 65 61 64 33 32 28 61 52 65 61 64 29  ileRead32(aRead)
4450: 3b 0a 20 20 20 20 20 20 70 43 73 72 2d 3e 6c 66  ;.      pCsr->lf
4460: 68 2e 6e 46 69 6c 65 20 3d 20 7a 69 70 66 69 6c  h.nFile = zipfil
4470: 65 52 65 61 64 31 36 28 61 52 65 61 64 29 3b 0a  eRead16(aRead);.
4480: 20 20 20 20 20 20 70 43 73 72 2d 3e 6c 66 68 2e        pCsr->lfh.
4490: 6e 45 78 74 72 61 20 3d 20 7a 69 70 66 69 6c 65  nExtra = zipfile
44a0: 52 65 61 64 31 36 28 61 52 65 61 64 29 3b 0a 20  Read16(aRead);. 
44b0: 20 20 20 20 20 61 73 73 65 72 74 28 20 61 52 65       assert( aRe
44c0: 61 64 3d 3d 7a 69 70 66 69 6c 65 43 73 72 42 75  ad==zipfileCsrBu
44d0: 66 66 65 72 28 70 43 73 72 29 2b 73 7a 46 69 78  ffer(pCsr)+szFix
44e0: 20 29 3b 0a 20 20 20 20 20 20 70 43 73 72 2d 3e   );.      pCsr->
44f0: 69 44 61 74 61 4f 66 66 20 3d 20 70 43 73 72 2d  iDataOff = pCsr-
4500: 3e 63 64 73 2e 69 4f 66 66 73 65 74 2b 73 7a 46  >cds.iOffset+szF
4510: 69 78 2b 70 43 73 72 2d 3e 6c 66 68 2e 6e 46 69  ix+pCsr->lfh.nFi
4520: 6c 65 2b 70 43 73 72 2d 3e 6c 66 68 2e 6e 45 78  le+pCsr->lfh.nEx
4530: 74 72 61 3b 0a 20 20 20 20 7d 0a 20 20 7d 0a 0a  tra;.    }.  }..
4540: 20 20 72 65 74 75 72 6e 20 72 63 3b 0a 7d 0a 0a    return rc;.}..
4550: 0a 2f 2a 0a 2a 2a 20 41 64 76 61 6e 63 65 20 61  ./*.** Advance a
4560: 6e 20 5a 69 70 66 69 6c 65 43 73 72 20 74 6f 20  n ZipfileCsr to 
4570: 69 74 73 20 6e 65 78 74 20 72 6f 77 20 6f 66 20  its next row of 
4580: 6f 75 74 70 75 74 2e 0a 2a 2f 0a 73 74 61 74 69  output..*/.stati
4590: 63 20 69 6e 74 20 7a 69 70 66 69 6c 65 4e 65 78  c int zipfileNex
45a0: 74 28 73 71 6c 69 74 65 33 5f 76 74 61 62 5f 63  t(sqlite3_vtab_c
45b0: 75 72 73 6f 72 20 2a 63 75 72 29 7b 0a 20 20 5a  ursor *cur){.  Z
45c0: 69 70 66 69 6c 65 43 73 72 20 2a 70 43 73 72 20  ipfileCsr *pCsr 
45d0: 3d 20 28 5a 69 70 66 69 6c 65 43 73 72 2a 29 63  = (ZipfileCsr*)c
45e0: 75 72 3b 0a 20 20 69 6e 74 20 72 63 20 3d 20 53  ur;.  int rc = S
45f0: 51 4c 49 54 45 5f 4f 4b 3b 0a 20 20 70 43 73 72  QLITE_OK;.  pCsr
4600: 2d 3e 66 6c 61 67 73 20 3d 20 30 3b 0a 0a 20 20  ->flags = 0;..  
4610: 69 66 28 20 70 43 73 72 2d 3e 70 43 75 72 72 65  if( pCsr->pCurre
4620: 6e 74 3d 3d 30 20 29 7b 0a 20 20 20 20 69 36 34  nt==0 ){.    i64
4630: 20 69 45 6f 66 20 3d 20 70 43 73 72 2d 3e 65 6f   iEof = pCsr->eo
4640: 63 64 2e 69 4f 66 66 73 65 74 20 2b 20 70 43 73  cd.iOffset + pCs
4650: 72 2d 3e 65 6f 63 64 2e 6e 53 69 7a 65 3b 0a 20  r->eocd.nSize;. 
4660: 20 20 20 69 66 28 20 70 43 73 72 2d 3e 69 4e 65     if( pCsr->iNe
4670: 78 74 4f 66 66 3e 3d 69 45 6f 66 20 29 7b 0a 20  xtOff>=iEof ){. 
4680: 20 20 20 20 20 70 43 73 72 2d 3e 62 45 6f 66 20       pCsr->bEof 
4690: 3d 20 31 3b 0a 20 20 20 20 7d 0a 20 20 7d 65 6c  = 1;.    }.  }el
46a0: 73 65 7b 0a 20 20 20 20 61 73 73 65 72 74 28 20  se{.    assert( 
46b0: 70 43 73 72 2d 3e 70 46 69 6c 65 3d 3d 30 20 29  pCsr->pFile==0 )
46c0: 3b 0a 20 20 20 20 64 6f 20 7b 0a 20 20 20 20 20  ;.    do {.     
46d0: 20 70 43 73 72 2d 3e 70 43 75 72 72 65 6e 74 20   pCsr->pCurrent 
46e0: 3d 20 70 43 73 72 2d 3e 70 43 75 72 72 65 6e 74  = pCsr->pCurrent
46f0: 2d 3e 70 4e 65 78 74 3b 0a 20 20 20 20 7d 77 68  ->pNext;.    }wh
4700: 69 6c 65 28 20 70 43 73 72 2d 3e 70 43 75 72 72  ile( pCsr->pCurr
4710: 65 6e 74 20 26 26 20 70 43 73 72 2d 3e 70 43 75  ent && pCsr->pCu
4720: 72 72 65 6e 74 2d 3e 62 44 65 6c 65 74 65 64 20  rrent->bDeleted 
4730: 29 3b 0a 20 20 20 20 69 66 28 20 70 43 73 72 2d  );.    if( pCsr-
4740: 3e 70 43 75 72 72 65 6e 74 3d 3d 30 20 29 7b 0a  >pCurrent==0 ){.
4750: 20 20 20 20 20 20 70 43 73 72 2d 3e 62 45 6f 66        pCsr->bEof
4760: 20 3d 20 31 3b 0a 20 20 20 20 7d 0a 20 20 7d 0a   = 1;.    }.  }.
4770: 0a 20 20 69 66 28 20 70 43 73 72 2d 3e 62 45 6f  .  if( pCsr->bEo
4780: 66 3d 3d 30 20 29 7b 0a 20 20 20 20 72 63 20 3d  f==0 ){.    rc =
4790: 20 7a 69 70 66 69 6c 65 52 65 61 64 43 44 53 28   zipfileReadCDS(
47a0: 70 43 73 72 29 3b 0a 20 20 20 20 69 66 28 20 72  pCsr);.    if( r
47b0: 63 3d 3d 53 51 4c 49 54 45 5f 4f 4b 20 29 7b 0a  c==SQLITE_OK ){.
47c0: 20 20 20 20 20 20 72 63 20 3d 20 7a 69 70 66 69        rc = zipfi
47d0: 6c 65 52 65 61 64 4c 46 48 28 70 43 73 72 29 3b  leReadLFH(pCsr);
47e0: 0a 20 20 20 20 7d 0a 20 20 7d 0a 0a 20 20 72 65  .    }.  }..  re
47f0: 74 75 72 6e 20 72 63 3b 0a 7d 0a 0a 2f 2a 0a 2a  turn rc;.}../*.*
4800: 2a 20 22 53 74 61 6e 64 61 72 64 22 20 4d 53 2d  * "Standard" MS-
4810: 44 4f 53 20 74 69 6d 65 20 66 6f 72 6d 61 74 3a  DOS time format:
4820: 0a 2a 2a 0a 2a 2a 20 20 20 46 69 6c 65 20 6d 6f  .**.**   File mo
4830: 64 69 66 69 63 61 74 69 6f 6e 20 74 69 6d 65 3a  dification time:
4840: 0a 2a 2a 20 20 20 20 20 42 69 74 73 20 30 30 2d  .**     Bits 00-
4850: 30 34 3a 20 73 65 63 6f 6e 64 73 20 64 69 76 69  04: seconds divi
4860: 64 65 64 20 62 79 20 32 0a 2a 2a 20 20 20 20 20  ded by 2.**     
4870: 42 69 74 73 20 30 35 2d 31 30 3a 20 6d 69 6e 75  Bits 05-10: minu
4880: 74 65 0a 2a 2a 20 20 20 20 20 42 69 74 73 20 31  te.**     Bits 1
4890: 31 2d 31 35 3a 20 68 6f 75 72 0a 2a 2a 20 20 20  1-15: hour.**   
48a0: 46 69 6c 65 20 6d 6f 64 69 66 69 63 61 74 69 6f  File modificatio
48b0: 6e 20 64 61 74 65 3a 0a 2a 2a 20 20 20 20 20 42  n date:.**     B
48c0: 69 74 73 20 30 30 2d 30 34 3a 20 64 61 79 0a 2a  its 00-04: day.*
48d0: 2a 20 20 20 20 20 42 69 74 73 20 30 35 2d 30 38  *     Bits 05-08
48e0: 3a 20 6d 6f 6e 74 68 20 28 31 2d 31 32 29 0a 2a  : month (1-12).*
48f0: 2a 20 20 20 20 20 42 69 74 73 20 30 39 2d 31 35  *     Bits 09-15
4900: 3a 20 79 65 61 72 73 20 66 72 6f 6d 20 31 39 38  : years from 198
4910: 30 20 0a 2a 2f 0a 73 74 61 74 69 63 20 74 69 6d  0 .*/.static tim
4920: 65 5f 74 20 7a 69 70 66 69 6c 65 4d 74 69 6d 65  e_t zipfileMtime
4930: 28 5a 69 70 66 69 6c 65 43 73 72 20 2a 70 43 73  (ZipfileCsr *pCs
4940: 72 29 7b 0a 20 20 73 74 72 75 63 74 20 74 6d 20  r){.  struct tm 
4950: 74 3b 0a 20 20 6d 65 6d 73 65 74 28 26 74 2c 20  t;.  memset(&t, 
4960: 30 2c 20 73 69 7a 65 6f 66 28 74 29 29 3b 0a 20  0, sizeof(t));. 
4970: 20 74 2e 74 6d 5f 73 65 63 20 3d 20 28 70 43 73   t.tm_sec = (pCs
4980: 72 2d 3e 63 64 73 2e 6d 54 69 6d 65 20 26 20 30  r->cds.mTime & 0
4990: 78 31 46 29 2a 32 3b 0a 20 20 74 2e 74 6d 5f 6d  x1F)*2;.  t.tm_m
49a0: 69 6e 20 3d 20 28 70 43 73 72 2d 3e 63 64 73 2e  in = (pCsr->cds.
49b0: 6d 54 69 6d 65 20 3e 3e 20 35 29 20 26 20 30 78  mTime >> 5) & 0x
49c0: 32 46 3b 0a 20 20 74 2e 74 6d 5f 68 6f 75 72 20  2F;.  t.tm_hour 
49d0: 3d 20 28 70 43 73 72 2d 3e 63 64 73 2e 6d 54 69  = (pCsr->cds.mTi
49e0: 6d 65 20 3e 3e 20 31 31 29 20 26 20 30 78 31 46  me >> 11) & 0x1F
49f0: 3b 0a 0a 20 20 74 2e 74 6d 5f 6d 64 61 79 20 3d  ;..  t.tm_mday =
4a00: 20 28 70 43 73 72 2d 3e 63 64 73 2e 6d 44 61 74   (pCsr->cds.mDat
4a10: 65 20 26 20 30 78 31 46 29 3b 0a 20 20 74 2e 74  e & 0x1F);.  t.t
4a20: 6d 5f 6d 6f 6e 20 3d 20 28 28 70 43 73 72 2d 3e  m_mon = ((pCsr->
4a30: 63 64 73 2e 6d 44 61 74 65 20 3e 3e 20 35 29 20  cds.mDate >> 5) 
4a40: 26 20 30 78 30 46 29 20 2d 20 31 3b 0a 20 20 74  & 0x0F) - 1;.  t
4a50: 2e 74 6d 5f 79 65 61 72 20 3d 20 38 30 20 2b 20  .tm_year = 80 + 
4a60: 28 28 70 43 73 72 2d 3e 63 64 73 2e 6d 44 61 74  ((pCsr->cds.mDat
4a70: 65 20 3e 3e 20 39 29 20 26 20 30 78 37 46 29 3b  e >> 9) & 0x7F);
4a80: 0a 0a 20 20 72 65 74 75 72 6e 20 6d 6b 74 69 6d  ..  return mktim
4a90: 65 28 26 74 29 3b 0a 7d 0a 0a 73 74 61 74 69 63  e(&t);.}..static
4aa0: 20 76 6f 69 64 20 7a 69 70 66 69 6c 65 4d 74 69   void zipfileMti
4ab0: 6d 65 54 6f 44 6f 73 28 5a 69 70 66 69 6c 65 43  meToDos(ZipfileC
4ac0: 44 53 20 2a 70 43 64 73 2c 20 75 33 32 20 6d 54  DS *pCds, u32 mT
4ad0: 69 6d 65 29 7b 0a 20 20 74 69 6d 65 5f 74 20 74  ime){.  time_t t
4ae0: 20 3d 20 28 74 69 6d 65 5f 74 29 6d 54 69 6d 65   = (time_t)mTime
4af0: 3b 0a 20 20 73 74 72 75 63 74 20 74 6d 20 72 65  ;.  struct tm re
4b00: 73 3b 0a 0a 23 69 66 20 21 64 65 66 69 6e 65 64  s;..#if !defined
4b10: 28 5f 57 49 4e 33 32 29 20 26 26 20 21 64 65 66  (_WIN32) && !def
4b20: 69 6e 65 64 28 57 49 4e 33 32 29 0a 20 20 6c 6f  ined(WIN32).  lo
4b30: 63 61 6c 74 69 6d 65 5f 72 28 26 74 2c 20 26 72  caltime_r(&t, &r
4b40: 65 73 29 3b 0a 23 65 6c 73 65 0a 20 20 6d 65 6d  es);.#else.  mem
4b50: 63 70 79 28 26 72 65 73 2c 20 6c 6f 63 61 6c 74  cpy(&res, localt
4b60: 69 6d 65 28 26 74 29 2c 20 73 69 7a 65 6f 66 28  ime(&t), sizeof(
4b70: 73 74 72 75 63 74 20 74 6d 29 29 3b 0a 23 65 6e  struct tm));.#en
4b80: 64 69 66 0a 0a 20 20 70 43 64 73 2d 3e 6d 54 69  dif..  pCds->mTi
4b90: 6d 65 20 3d 20 28 75 31 36 29 28 0a 20 20 20 20  me = (u16)(.    
4ba0: 28 72 65 73 2e 74 6d 5f 73 65 63 20 2f 20 32 29  (res.tm_sec / 2)
4bb0: 20 2b 20 0a 20 20 20 20 28 72 65 73 2e 74 6d 5f   + .    (res.tm_
4bc0: 6d 69 6e 20 3c 3c 20 35 29 20 2b 0a 20 20 20 20  min << 5) +.    
4bd0: 28 72 65 73 2e 74 6d 5f 68 6f 75 72 20 3c 3c 20  (res.tm_hour << 
4be0: 31 31 29 29 3b 0a 0a 20 20 70 43 64 73 2d 3e 6d  11));..  pCds->m
4bf0: 44 61 74 65 20 3d 20 28 75 31 36 29 28 0a 20 20  Date = (u16)(.  
4c00: 20 20 28 72 65 73 2e 74 6d 5f 6d 64 61 79 2d 31    (res.tm_mday-1
4c10: 29 20 2b 0a 20 20 20 20 28 28 72 65 73 2e 74 6d  ) +.    ((res.tm
4c20: 5f 6d 6f 6e 2b 31 29 20 3c 3c 20 35 29 20 2b 0a  _mon+1) << 5) +.
4c30: 20 20 20 20 28 28 72 65 73 2e 74 6d 5f 79 65 61      ((res.tm_yea
4c40: 72 2d 38 30 29 20 3c 3c 20 39 29 29 3b 0a 7d 0a  r-80) << 9));.}.
4c50: 0a 73 74 61 74 69 63 20 76 6f 69 64 20 7a 69 70  .static void zip
4c60: 66 69 6c 65 49 6e 66 6c 61 74 65 28 0a 20 20 73  fileInflate(.  s
4c70: 71 6c 69 74 65 33 5f 63 6f 6e 74 65 78 74 20 2a  qlite3_context *
4c80: 70 43 74 78 2c 20 20 20 20 20 20 20 20 20 20 2f  pCtx,          /
4c90: 2a 20 53 74 6f 72 65 20 65 72 72 6f 72 20 68 65  * Store error he
4ca0: 72 65 2c 20 69 66 20 61 6e 79 20 2a 2f 0a 20 20  re, if any */.  
4cb0: 63 6f 6e 73 74 20 75 38 20 2a 61 49 6e 2c 20 20  const u8 *aIn,  
4cc0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
4cd0: 2f 2a 20 43 6f 6d 70 72 65 73 73 65 64 20 64 61  /* Compressed da
4ce0: 74 61 20 2a 2f 0a 20 20 69 6e 74 20 6e 49 6e 2c  ta */.  int nIn,
4cf0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
4d00: 20 20 20 20 20 20 20 20 2f 2a 20 53 69 7a 65 20          /* Size 
4d10: 6f 66 20 62 75 66 66 65 72 20 61 49 6e 5b 5d 20  of buffer aIn[] 
4d20: 69 6e 20 62 79 74 65 73 20 2a 2f 0a 20 20 69 6e  in bytes */.  in
4d30: 74 20 6e 4f 75 74 20 20 20 20 20 20 20 20 20 20  t nOut          
4d40: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a                /*
4d50: 20 45 78 70 65 63 74 65 64 20 6f 75 74 70 75 74   Expected output
4d60: 20 73 69 7a 65 20 2a 2f 0a 29 7b 0a 20 20 75 38   size */.){.  u8
4d70: 20 2a 61 52 65 73 20 3d 20 73 71 6c 69 74 65 33   *aRes = sqlite3
4d80: 5f 6d 61 6c 6c 6f 63 28 6e 4f 75 74 29 3b 0a 20  _malloc(nOut);. 
4d90: 20 69 66 28 20 61 52 65 73 3d 3d 30 20 29 7b 0a   if( aRes==0 ){.
4da0: 20 20 20 20 73 71 6c 69 74 65 33 5f 72 65 73 75      sqlite3_resu
4db0: 6c 74 5f 65 72 72 6f 72 5f 6e 6f 6d 65 6d 28 70  lt_error_nomem(p
4dc0: 43 74 78 29 3b 0a 20 20 7d 65 6c 73 65 7b 0a 20  Ctx);.  }else{. 
4dd0: 20 20 20 69 6e 74 20 65 72 72 3b 0a 20 20 20 20     int err;.    
4de0: 7a 5f 73 74 72 65 61 6d 20 73 74 72 3b 0a 20 20  z_stream str;.  
4df0: 20 20 6d 65 6d 73 65 74 28 26 73 74 72 2c 20 30    memset(&str, 0
4e00: 2c 20 73 69 7a 65 6f 66 28 73 74 72 29 29 3b 0a  , sizeof(str));.
4e10: 0a 20 20 20 20 73 74 72 2e 6e 65 78 74 5f 69 6e  .    str.next_in
4e20: 20 3d 20 28 42 79 74 65 2a 29 61 49 6e 3b 0a 20   = (Byte*)aIn;. 
4e30: 20 20 20 73 74 72 2e 61 76 61 69 6c 5f 69 6e 20     str.avail_in 
4e40: 3d 20 6e 49 6e 3b 0a 20 20 20 20 73 74 72 2e 6e  = nIn;.    str.n
4e50: 65 78 74 5f 6f 75 74 20 3d 20 28 42 79 74 65 2a  ext_out = (Byte*
4e60: 29 61 52 65 73 3b 0a 20 20 20 20 73 74 72 2e 61  )aRes;.    str.a
4e70: 76 61 69 6c 5f 6f 75 74 20 3d 20 6e 4f 75 74 3b  vail_out = nOut;
4e80: 0a 0a 20 20 20 20 65 72 72 20 3d 20 69 6e 66 6c  ..    err = infl
4e90: 61 74 65 49 6e 69 74 32 28 26 73 74 72 2c 20 2d  ateInit2(&str, -
4ea0: 31 35 29 3b 0a 20 20 20 20 69 66 28 20 65 72 72  15);.    if( err
4eb0: 21 3d 5a 5f 4f 4b 20 29 7b 0a 20 20 20 20 20 20  !=Z_OK ){.      
4ec0: 7a 69 70 66 69 6c 65 43 74 78 45 72 72 6f 72 4d  zipfileCtxErrorM
4ed0: 73 67 28 70 43 74 78 2c 20 22 69 6e 66 6c 61 74  sg(pCtx, "inflat
4ee0: 65 49 6e 69 74 32 28 29 20 66 61 69 6c 65 64 20  eInit2() failed 
4ef0: 28 25 64 29 22 2c 20 65 72 72 29 3b 0a 20 20 20  (%d)", err);.   
4f00: 20 7d 65 6c 73 65 7b 0a 20 20 20 20 20 20 65 72   }else{.      er
4f10: 72 20 3d 20 69 6e 66 6c 61 74 65 28 26 73 74 72  r = inflate(&str
4f20: 2c 20 5a 5f 4e 4f 5f 46 4c 55 53 48 29 3b 0a 20  , Z_NO_FLUSH);. 
4f30: 20 20 20 20 20 69 66 28 20 65 72 72 21 3d 5a 5f       if( err!=Z_
4f40: 53 54 52 45 41 4d 5f 45 4e 44 20 29 7b 0a 20 20  STREAM_END ){.  
4f50: 20 20 20 20 20 20 7a 69 70 66 69 6c 65 43 74 78        zipfileCtx
4f60: 45 72 72 6f 72 4d 73 67 28 70 43 74 78 2c 20 22  ErrorMsg(pCtx, "
4f70: 69 6e 66 6c 61 74 65 28 29 20 66 61 69 6c 65 64  inflate() failed
4f80: 20 28 25 64 29 22 2c 20 65 72 72 29 3b 0a 20 20   (%d)", err);.  
4f90: 20 20 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20 20      }else{.     
4fa0: 20 20 20 73 71 6c 69 74 65 33 5f 72 65 73 75 6c     sqlite3_resul
4fb0: 74 5f 62 6c 6f 62 28 70 43 74 78 2c 20 61 52 65  t_blob(pCtx, aRe
4fc0: 73 2c 20 6e 4f 75 74 2c 20 53 51 4c 49 54 45 5f  s, nOut, SQLITE_
4fd0: 54 52 41 4e 53 49 45 4e 54 29 3b 0a 20 20 20 20  TRANSIENT);.    
4fe0: 20 20 7d 0a 20 20 20 20 7d 0a 20 20 20 20 73 71    }.    }.    sq
4ff0: 6c 69 74 65 33 5f 66 72 65 65 28 61 52 65 73 29  lite3_free(aRes)
5000: 3b 0a 20 20 20 20 69 6e 66 6c 61 74 65 45 6e 64  ;.    inflateEnd
5010: 28 26 73 74 72 29 3b 0a 20 20 7d 0a 7d 0a 0a 73  (&str);.  }.}..s
5020: 74 61 74 69 63 20 69 6e 74 20 7a 69 70 66 69 6c  tatic int zipfil
5030: 65 44 65 66 6c 61 74 65 28 0a 20 20 5a 69 70 66  eDeflate(.  Zipf
5040: 69 6c 65 54 61 62 20 2a 70 54 61 62 2c 20 20 20  ileTab *pTab,   
5050: 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 53              /* S
5060: 65 74 20 65 72 72 6f 72 20 6d 65 73 73 61 67 65  et error message
5070: 20 68 65 72 65 20 2a 2f 0a 20 20 63 6f 6e 73 74   here */.  const
5080: 20 75 38 20 2a 61 49 6e 2c 20 69 6e 74 20 6e 49   u8 *aIn, int nI
5090: 6e 2c 20 20 20 20 20 20 20 20 20 2f 2a 20 49 6e  n,         /* In
50a0: 70 75 74 20 2a 2f 0a 20 20 75 38 20 2a 2a 70 70  put */.  u8 **pp
50b0: 4f 75 74 2c 20 69 6e 74 20 2a 70 6e 4f 75 74 20  Out, int *pnOut 
50c0: 20 20 20 20 20 20 20 20 20 2f 2a 20 4f 75 74 70           /* Outp
50d0: 75 74 20 2a 2f 0a 29 7b 0a 20 20 69 6e 74 20 6e  ut */.){.  int n
50e0: 41 6c 6c 6f 63 20 3d 20 28 69 6e 74 29 63 6f 6d  Alloc = (int)com
50f0: 70 72 65 73 73 42 6f 75 6e 64 28 6e 49 6e 29 3b  pressBound(nIn);
5100: 0a 20 20 75 38 20 2a 61 4f 75 74 3b 0a 20 20 69  .  u8 *aOut;.  i
5110: 6e 74 20 72 63 20 3d 20 53 51 4c 49 54 45 5f 4f  nt rc = SQLITE_O
5120: 4b 3b 0a 0a 20 20 61 4f 75 74 20 3d 20 28 75 38  K;..  aOut = (u8
5130: 2a 29 73 71 6c 69 74 65 33 5f 6d 61 6c 6c 6f 63  *)sqlite3_malloc
5140: 28 6e 41 6c 6c 6f 63 29 3b 0a 20 20 69 66 28 20  (nAlloc);.  if( 
5150: 61 4f 75 74 3d 3d 30 20 29 7b 0a 20 20 20 20 72  aOut==0 ){.    r
5160: 63 20 3d 20 53 51 4c 49 54 45 5f 4e 4f 4d 45 4d  c = SQLITE_NOMEM
5170: 3b 0a 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20 69  ;.  }else{.    i
5180: 6e 74 20 72 65 73 3b 0a 20 20 20 20 7a 5f 73 74  nt res;.    z_st
5190: 72 65 61 6d 20 73 74 72 3b 0a 20 20 20 20 6d 65  ream str;.    me
51a0: 6d 73 65 74 28 26 73 74 72 2c 20 30 2c 20 73 69  mset(&str, 0, si
51b0: 7a 65 6f 66 28 73 74 72 29 29 3b 0a 20 20 20 20  zeof(str));.    
51c0: 73 74 72 2e 6e 65 78 74 5f 69 6e 20 3d 20 28 7a  str.next_in = (z
51d0: 5f 63 6f 6e 73 74 20 42 79 74 65 66 2a 29 61 49  _const Bytef*)aI
51e0: 6e 3b 0a 20 20 20 20 73 74 72 2e 61 76 61 69 6c  n;.    str.avail
51f0: 5f 69 6e 20 3d 20 6e 49 6e 3b 0a 20 20 20 20 73  _in = nIn;.    s
5200: 74 72 2e 6e 65 78 74 5f 6f 75 74 20 3d 20 61 4f  tr.next_out = aO
5210: 75 74 3b 0a 20 20 20 20 73 74 72 2e 61 76 61 69  ut;.    str.avai
5220: 6c 5f 6f 75 74 20 3d 20 6e 41 6c 6c 6f 63 3b 0a  l_out = nAlloc;.
5230: 0a 20 20 20 20 64 65 66 6c 61 74 65 49 6e 69 74  .    deflateInit
5240: 32 28 26 73 74 72 2c 20 39 2c 20 5a 5f 44 45 46  2(&str, 9, Z_DEF
5250: 4c 41 54 45 44 2c 20 2d 31 35 2c 20 38 2c 20 5a  LATED, -15, 8, Z
5260: 5f 44 45 46 41 55 4c 54 5f 53 54 52 41 54 45 47  _DEFAULT_STRATEG
5270: 59 29 3b 0a 20 20 20 20 72 65 73 20 3d 20 64 65  Y);.    res = de
5280: 66 6c 61 74 65 28 26 73 74 72 2c 20 5a 5f 46 49  flate(&str, Z_FI
5290: 4e 49 53 48 29 3b 0a 0a 20 20 20 20 69 66 28 20  NISH);..    if( 
52a0: 72 65 73 3d 3d 5a 5f 53 54 52 45 41 4d 5f 45 4e  res==Z_STREAM_EN
52b0: 44 20 29 7b 0a 20 20 20 20 20 20 2a 70 70 4f 75  D ){.      *ppOu
52c0: 74 20 3d 20 61 4f 75 74 3b 0a 20 20 20 20 20 20  t = aOut;.      
52d0: 2a 70 6e 4f 75 74 20 3d 20 28 69 6e 74 29 73 74  *pnOut = (int)st
52e0: 72 2e 74 6f 74 61 6c 5f 6f 75 74 3b 0a 20 20 20  r.total_out;.   
52f0: 20 7d 65 6c 73 65 7b 0a 20 20 20 20 20 20 73 71   }else{.      sq
5300: 6c 69 74 65 33 5f 66 72 65 65 28 61 4f 75 74 29  lite3_free(aOut)
5310: 3b 0a 20 20 20 20 20 20 70 54 61 62 2d 3e 62 61  ;.      pTab->ba
5320: 73 65 2e 7a 45 72 72 4d 73 67 20 3d 20 73 71 6c  se.zErrMsg = sql
5330: 69 74 65 33 5f 6d 70 72 69 6e 74 66 28 22 7a 69  ite3_mprintf("zi
5340: 70 66 69 6c 65 3a 20 64 65 66 6c 61 74 65 28 29  pfile: deflate()
5350: 20 65 72 72 6f 72 22 29 3b 0a 20 20 20 20 20 20   error");.      
5360: 72 63 20 3d 20 53 51 4c 49 54 45 5f 45 52 52 4f  rc = SQLITE_ERRO
5370: 52 3b 0a 20 20 20 20 7d 0a 20 20 20 20 64 65 66  R;.    }.    def
5380: 6c 61 74 65 45 6e 64 28 26 73 74 72 29 3b 0a 20  lateEnd(&str);. 
5390: 20 7d 0a 0a 20 20 72 65 74 75 72 6e 20 72 63 3b   }..  return rc;
53a0: 0a 7d 0a 0a 0a 2f 2a 0a 2a 2a 20 52 65 74 75 72  .}.../*.** Retur
53b0: 6e 20 76 61 6c 75 65 73 20 6f 66 20 63 6f 6c 75  n values of colu
53c0: 6d 6e 73 20 66 6f 72 20 74 68 65 20 72 6f 77 20  mns for the row 
53d0: 61 74 20 77 68 69 63 68 20 74 68 65 20 73 65 72  at which the ser
53e0: 69 65 73 5f 63 75 72 73 6f 72 0a 2a 2a 20 69 73  ies_cursor.** is
53f0: 20 63 75 72 72 65 6e 74 6c 79 20 70 6f 69 6e 74   currently point
5400: 69 6e 67 2e 0a 2a 2f 0a 73 74 61 74 69 63 20 69  ing..*/.static i
5410: 6e 74 20 7a 69 70 66 69 6c 65 43 6f 6c 75 6d 6e  nt zipfileColumn
5420: 28 0a 20 20 73 71 6c 69 74 65 33 5f 76 74 61 62  (.  sqlite3_vtab
5430: 5f 63 75 72 73 6f 72 20 2a 63 75 72 2c 20 20 20  _cursor *cur,   
5440: 2f 2a 20 54 68 65 20 63 75 72 73 6f 72 20 2a 2f  /* The cursor */
5450: 0a 20 20 73 71 6c 69 74 65 33 5f 63 6f 6e 74 65  .  sqlite3_conte
5460: 78 74 20 2a 63 74 78 2c 20 20 20 20 20 20 20 2f  xt *ctx,       /
5470: 2a 20 46 69 72 73 74 20 61 72 67 75 6d 65 6e 74  * First argument
5480: 20 74 6f 20 73 71 6c 69 74 65 33 5f 72 65 73 75   to sqlite3_resu
5490: 6c 74 5f 2e 2e 2e 28 29 20 2a 2f 0a 20 20 69 6e  lt_...() */.  in
54a0: 74 20 69 20 20 20 20 20 20 20 20 20 20 20 20 20  t i             
54b0: 20 20 20 20 20 20 20 20 20 20 2f 2a 20 57 68 69            /* Whi
54c0: 63 68 20 63 6f 6c 75 6d 6e 20 74 6f 20 72 65 74  ch column to ret
54d0: 75 72 6e 20 2a 2f 0a 29 7b 0a 20 20 5a 69 70 66  urn */.){.  Zipf
54e0: 69 6c 65 43 73 72 20 2a 70 43 73 72 20 3d 20 28  ileCsr *pCsr = (
54f0: 5a 69 70 66 69 6c 65 43 73 72 2a 29 63 75 72 3b  ZipfileCsr*)cur;
5500: 0a 20 20 69 6e 74 20 72 63 20 3d 20 53 51 4c 49  .  int rc = SQLI
5510: 54 45 5f 4f 4b 3b 0a 20 20 73 77 69 74 63 68 28  TE_OK;.  switch(
5520: 20 69 20 29 7b 0a 20 20 20 20 63 61 73 65 20 30   i ){.    case 0
5530: 3a 20 20 20 2f 2a 20 6e 61 6d 65 20 2a 2f 0a 20  :   /* name */. 
5540: 20 20 20 20 20 73 71 6c 69 74 65 33 5f 72 65 73       sqlite3_res
5550: 75 6c 74 5f 74 65 78 74 28 63 74 78 2c 20 70 43  ult_text(ctx, pC
5560: 73 72 2d 3e 63 64 73 2e 7a 46 69 6c 65 2c 20 2d  sr->cds.zFile, -
5570: 31 2c 20 53 51 4c 49 54 45 5f 54 52 41 4e 53 49  1, SQLITE_TRANSI
5580: 45 4e 54 29 3b 0a 20 20 20 20 20 20 62 72 65 61  ENT);.      brea
5590: 6b 3b 0a 20 20 20 20 63 61 73 65 20 31 3a 20 20  k;.    case 1:  
55a0: 20 2f 2a 20 6d 6f 64 65 20 2a 2f 0a 20 20 20 20   /* mode */.    
55b0: 20 20 2f 2a 20 54 4f 44 4f 3a 20 57 68 65 74 68    /* TODO: Wheth
55c0: 65 72 20 6f 72 20 6e 6f 74 20 74 68 65 20 66 6f  er or not the fo
55d0: 6c 6c 6f 77 69 6e 67 20 69 73 20 63 6f 72 72 65  llowing is corre
55e0: 63 74 20 73 75 72 65 6c 79 20 64 65 70 65 6e 64  ct surely depend
55f0: 73 20 6f 6e 0a 20 20 20 20 20 20 2a 2a 20 74 68  s on.      ** th
5600: 65 20 70 6c 61 74 66 6f 72 6d 20 6f 6e 20 77 68  e platform on wh
5610: 69 63 68 20 74 68 65 20 61 72 63 68 69 76 65 20  ich the archive 
5620: 77 61 73 20 63 72 65 61 74 65 64 2e 20 20 2a 2f  was created.  */
5630: 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33 5f 72  .      sqlite3_r
5640: 65 73 75 6c 74 5f 69 6e 74 28 63 74 78 2c 20 70  esult_int(ctx, p
5650: 43 73 72 2d 3e 63 64 73 2e 69 45 78 74 65 72 6e  Csr->cds.iExtern
5660: 61 6c 41 74 74 72 20 3e 3e 20 31 36 29 3b 0a 20  alAttr >> 16);. 
5670: 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20       break;.    
5680: 63 61 73 65 20 32 3a 20 7b 20 2f 2a 20 6d 74 69  case 2: { /* mti
5690: 6d 65 20 2a 2f 0a 20 20 20 20 20 20 69 66 28 20  me */.      if( 
56a0: 70 43 73 72 2d 3e 66 6c 61 67 73 20 26 20 5a 49  pCsr->flags & ZI
56b0: 50 46 49 4c 45 5f 4d 54 49 4d 45 5f 56 41 4c 49  PFILE_MTIME_VALI
56c0: 44 20 29 7b 0a 20 20 20 20 20 20 20 20 73 71 6c  D ){.        sql
56d0: 69 74 65 33 5f 72 65 73 75 6c 74 5f 69 6e 74 36  ite3_result_int6
56e0: 34 28 63 74 78 2c 20 70 43 73 72 2d 3e 6d 54 69  4(ctx, pCsr->mTi
56f0: 6d 65 29 3b 0a 20 20 20 20 20 20 7d 65 6c 73 65  me);.      }else
5700: 7b 0a 20 20 20 20 20 20 20 20 73 71 6c 69 74 65  {.        sqlite
5710: 33 5f 72 65 73 75 6c 74 5f 69 6e 74 36 34 28 63  3_result_int64(c
5720: 74 78 2c 20 7a 69 70 66 69 6c 65 4d 74 69 6d 65  tx, zipfileMtime
5730: 28 70 43 73 72 29 29 3b 0a 20 20 20 20 20 20 7d  (pCsr));.      }
5740: 0a 20 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20  .      break;.  
5750: 20 20 7d 0a 20 20 20 20 63 61 73 65 20 33 3a 20    }.    case 3: 
5760: 7b 20 2f 2a 20 73 7a 20 2a 2f 0a 20 20 20 20 20  { /* sz */.     
5770: 20 73 71 6c 69 74 65 33 5f 72 65 73 75 6c 74 5f   sqlite3_result_
5780: 69 6e 74 36 34 28 63 74 78 2c 20 70 43 73 72 2d  int64(ctx, pCsr-
5790: 3e 63 64 73 2e 73 7a 55 6e 63 6f 6d 70 72 65 73  >cds.szUncompres
57a0: 73 65 64 29 3b 0a 20 20 20 20 20 20 62 72 65 61  sed);.      brea
57b0: 6b 3b 0a 20 20 20 20 7d 0a 20 20 20 20 63 61 73  k;.    }.    cas
57c0: 65 20 34 3a 20 20 20 2f 2a 20 72 61 77 64 61 74  e 4:   /* rawdat
57d0: 61 20 2a 2f 0a 20 20 20 20 63 61 73 65 20 35 3a  a */.    case 5:
57e0: 20 7b 20 2f 2a 20 64 61 74 61 20 2a 2f 0a 20 20   { /* data */.  
57f0: 20 20 20 20 69 66 28 20 69 3d 3d 34 20 7c 7c 20      if( i==4 || 
5800: 70 43 73 72 2d 3e 63 64 73 2e 69 43 6f 6d 70 72  pCsr->cds.iCompr
5810: 65 73 73 69 6f 6e 3d 3d 30 20 7c 7c 20 70 43 73  ession==0 || pCs
5820: 72 2d 3e 63 64 73 2e 69 43 6f 6d 70 72 65 73 73  r->cds.iCompress
5830: 69 6f 6e 3d 3d 38 20 29 7b 0a 20 20 20 20 20 20  ion==8 ){.      
5840: 20 20 69 6e 74 20 73 7a 20 3d 20 70 43 73 72 2d    int sz = pCsr-
5850: 3e 63 64 73 2e 73 7a 43 6f 6d 70 72 65 73 73 65  >cds.szCompresse
5860: 64 3b 0a 20 20 20 20 20 20 20 20 69 66 28 20 73  d;.        if( s
5870: 7a 3e 30 20 29 7b 0a 20 20 20 20 20 20 20 20 20  z>0 ){.         
5880: 20 75 38 20 2a 61 42 75 66 20 3d 20 73 71 6c 69   u8 *aBuf = sqli
5890: 74 65 33 5f 6d 61 6c 6c 6f 63 28 73 7a 29 3b 0a  te3_malloc(sz);.
58a0: 20 20 20 20 20 20 20 20 20 20 69 66 28 20 61 42            if( aB
58b0: 75 66 3d 3d 30 20 29 7b 0a 20 20 20 20 20 20 20  uf==0 ){.       
58c0: 20 20 20 20 20 72 63 20 3d 20 53 51 4c 49 54 45       rc = SQLITE
58d0: 5f 4e 4f 4d 45 4d 3b 0a 20 20 20 20 20 20 20 20  _NOMEM;.        
58e0: 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20 20 20 20    }else{.       
58f0: 20 20 20 20 20 46 49 4c 45 20 2a 70 46 69 6c 65       FILE *pFile
5900: 20 3d 20 7a 69 70 66 69 6c 65 47 65 74 46 64 28   = zipfileGetFd(
5910: 70 43 73 72 29 3b 0a 20 20 20 20 20 20 20 20 20  pCsr);.         
5920: 20 20 20 72 63 20 3d 20 7a 69 70 66 69 6c 65 52     rc = zipfileR
5930: 65 61 64 44 61 74 61 28 70 46 69 6c 65 2c 20 61  eadData(pFile, a
5940: 42 75 66 2c 20 73 7a 2c 20 70 43 73 72 2d 3e 69  Buf, sz, pCsr->i
5950: 44 61 74 61 4f 66 66 2c 0a 20 20 20 20 20 20 20  DataOff,.       
5960: 20 20 20 20 20 20 20 20 20 26 70 43 73 72 2d 3e           &pCsr->
5970: 62 61 73 65 2e 70 56 74 61 62 2d 3e 7a 45 72 72  base.pVtab->zErr
5980: 4d 73 67 0a 20 20 20 20 20 20 20 20 20 20 20 20  Msg.            
5990: 29 3b 0a 20 20 20 20 20 20 20 20 20 20 7d 0a 20  );.          }. 
59a0: 20 20 20 20 20 20 20 20 20 69 66 28 20 72 63 3d           if( rc=
59b0: 3d 53 51 4c 49 54 45 5f 4f 4b 20 29 7b 0a 20 20  =SQLITE_OK ){.  
59c0: 20 20 20 20 20 20 20 20 20 20 69 66 28 20 69 3d            if( i=
59d0: 3d 35 20 26 26 20 70 43 73 72 2d 3e 63 64 73 2e  =5 && pCsr->cds.
59e0: 69 43 6f 6d 70 72 65 73 73 69 6f 6e 20 29 7b 0a  iCompression ){.
59f0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7a 69                zi
5a00: 70 66 69 6c 65 49 6e 66 6c 61 74 65 28 63 74 78  pfileInflate(ctx
5a10: 2c 20 61 42 75 66 2c 20 73 7a 2c 20 70 43 73 72  , aBuf, sz, pCsr
5a20: 2d 3e 63 64 73 2e 73 7a 55 6e 63 6f 6d 70 72 65  ->cds.szUncompre
5a30: 73 73 65 64 29 3b 0a 20 20 20 20 20 20 20 20 20  ssed);.         
5a40: 20 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20 20 20     }else{.      
5a50: 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 33 5f          sqlite3_
5a60: 72 65 73 75 6c 74 5f 62 6c 6f 62 28 63 74 78 2c  result_blob(ctx,
5a70: 20 61 42 75 66 2c 20 73 7a 2c 20 53 51 4c 49 54   aBuf, sz, SQLIT
5a80: 45 5f 54 52 41 4e 53 49 45 4e 54 29 3b 0a 20 20  E_TRANSIENT);.  
5a90: 20 20 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20            }.    
5aa0: 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 33 5f          sqlite3_
5ab0: 66 72 65 65 28 61 42 75 66 29 3b 0a 20 20 20 20  free(aBuf);.    
5ac0: 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20        }.        
5ad0: 7d 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20  }.      }.      
5ae0: 62 72 65 61 6b 3b 0a 20 20 20 20 7d 0a 20 20 20  break;.    }.   
5af0: 20 63 61 73 65 20 36 3a 20 20 20 2f 2a 20 6d 65   case 6:   /* me
5b00: 74 68 6f 64 20 2a 2f 0a 20 20 20 20 20 20 73 71  thod */.      sq
5b10: 6c 69 74 65 33 5f 72 65 73 75 6c 74 5f 69 6e 74  lite3_result_int
5b20: 28 63 74 78 2c 20 70 43 73 72 2d 3e 63 64 73 2e  (ctx, pCsr->cds.
5b30: 69 43 6f 6d 70 72 65 73 73 69 6f 6e 29 3b 0a 20  iCompression);. 
5b40: 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 7d 0a       break;.  }.
5b50: 0a 20 20 72 65 74 75 72 6e 20 53 51 4c 49 54 45  .  return SQLITE
5b60: 5f 4f 4b 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 52 65  _OK;.}../*.** Re
5b70: 74 75 72 6e 20 74 68 65 20 72 6f 77 69 64 20 66  turn the rowid f
5b80: 6f 72 20 74 68 65 20 63 75 72 72 65 6e 74 20 72  or the current r
5b90: 6f 77 2e 0a 2a 2f 0a 73 74 61 74 69 63 20 69 6e  ow..*/.static in
5ba0: 74 20 7a 69 70 66 69 6c 65 52 6f 77 69 64 28 73  t zipfileRowid(s
5bb0: 71 6c 69 74 65 33 5f 76 74 61 62 5f 63 75 72 73  qlite3_vtab_curs
5bc0: 6f 72 20 2a 63 75 72 2c 20 73 71 6c 69 74 65 5f  or *cur, sqlite_
5bd0: 69 6e 74 36 34 20 2a 70 52 6f 77 69 64 29 7b 0a  int64 *pRowid){.
5be0: 20 20 61 73 73 65 72 74 28 20 30 20 29 3b 0a 20    assert( 0 );. 
5bf0: 20 72 65 74 75 72 6e 20 53 51 4c 49 54 45 5f 4f   return SQLITE_O
5c00: 4b 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 52 65 74 75  K;.}../*.** Retu
5c10: 72 6e 20 54 52 55 45 20 69 66 20 74 68 65 20 63  rn TRUE if the c
5c20: 75 72 73 6f 72 20 68 61 73 20 62 65 65 6e 20 6d  ursor has been m
5c30: 6f 76 65 64 20 6f 66 66 20 6f 66 20 74 68 65 20  oved off of the 
5c40: 6c 61 73 74 0a 2a 2a 20 72 6f 77 20 6f 66 20 6f  last.** row of o
5c50: 75 74 70 75 74 2e 0a 2a 2f 0a 73 74 61 74 69 63  utput..*/.static
5c60: 20 69 6e 74 20 7a 69 70 66 69 6c 65 45 6f 66 28   int zipfileEof(
5c70: 73 71 6c 69 74 65 33 5f 76 74 61 62 5f 63 75 72  sqlite3_vtab_cur
5c80: 73 6f 72 20 2a 63 75 72 29 7b 0a 20 20 5a 69 70  sor *cur){.  Zip
5c90: 66 69 6c 65 43 73 72 20 2a 70 43 73 72 20 3d 20  fileCsr *pCsr = 
5ca0: 28 5a 69 70 66 69 6c 65 43 73 72 2a 29 63 75 72  (ZipfileCsr*)cur
5cb0: 3b 0a 20 20 72 65 74 75 72 6e 20 70 43 73 72 2d  ;.  return pCsr-
5cc0: 3e 62 45 6f 66 3b 0a 7d 0a 0a 2f 2a 0a 2a 2f 0a  >bEof;.}../*.*/.
5cd0: 73 74 61 74 69 63 20 69 6e 74 20 7a 69 70 66 69  static int zipfi
5ce0: 6c 65 52 65 61 64 45 4f 43 44 28 0a 20 20 5a 69  leReadEOCD(.  Zi
5cf0: 70 66 69 6c 65 54 61 62 20 2a 70 54 61 62 2c 20  pfileTab *pTab, 
5d00: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a                /*
5d10: 20 52 65 74 75 72 6e 20 65 72 72 6f 72 73 20 68   Return errors h
5d20: 65 72 65 20 2a 2f 0a 20 20 46 49 4c 45 20 2a 70  ere */.  FILE *p
5d30: 46 69 6c 65 2c 20 20 20 20 20 20 20 20 20 20 20  File,           
5d40: 20 20 20 20 20 20 20 20 20 2f 2a 20 52 65 61 64           /* Read
5d50: 20 66 72 6f 6d 20 74 68 69 73 20 66 69 6c 65 20   from this file 
5d60: 2a 2f 0a 20 20 5a 69 70 66 69 6c 65 45 4f 43 44  */.  ZipfileEOCD
5d70: 20 2a 70 45 4f 43 44 20 20 20 20 20 20 20 20 20   *pEOCD         
5d80: 20 20 20 20 20 2f 2a 20 4f 62 6a 65 63 74 20 74       /* Object t
5d90: 6f 20 70 6f 70 75 6c 61 74 65 20 2a 2f 0a 29 7b  o populate */.){
5da0: 0a 20 20 75 38 20 2a 61 52 65 61 64 20 3d 20 70  .  u8 *aRead = p
5db0: 54 61 62 2d 3e 61 42 75 66 66 65 72 3b 20 20 20  Tab->aBuffer;   
5dc0: 20 20 20 2f 2a 20 54 65 6d 70 6f 72 61 72 79 20     /* Temporary 
5dd0: 62 75 66 66 65 72 20 2a 2f 0a 20 20 69 36 34 20  buffer */.  i64 
5de0: 73 7a 46 69 6c 65 3b 20 20 20 20 20 20 20 20 20  szFile;         
5df0: 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 54              /* T
5e00: 6f 74 61 6c 20 73 69 7a 65 20 6f 66 20 66 69 6c  otal size of fil
5e10: 65 20 69 6e 20 62 79 74 65 73 20 2a 2f 0a 20 20  e in bytes */.  
5e20: 69 6e 74 20 6e 52 65 61 64 3b 20 20 20 20 20 20  int nRead;      
5e30: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
5e40: 2f 2a 20 42 79 74 65 73 20 74 6f 20 72 65 61 64  /* Bytes to read
5e50: 20 66 72 6f 6d 20 66 69 6c 65 20 2a 2f 0a 20 20   from file */.  
5e60: 69 36 34 20 69 4f 66 66 3b 20 20 20 20 20 20 20  i64 iOff;       
5e70: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
5e80: 2f 2a 20 4f 66 66 73 65 74 20 74 6f 20 72 65 61  /* Offset to rea
5e90: 64 20 66 72 6f 6d 20 2a 2f 0a 20 20 69 6e 74 20  d from */.  int 
5ea0: 72 63 3b 0a 0a 20 20 66 73 65 65 6b 28 70 46 69  rc;..  fseek(pFi
5eb0: 6c 65 2c 20 30 2c 20 53 45 45 4b 5f 45 4e 44 29  le, 0, SEEK_END)
5ec0: 3b 0a 20 20 73 7a 46 69 6c 65 20 3d 20 28 69 36  ;.  szFile = (i6
5ed0: 34 29 66 74 65 6c 6c 28 70 46 69 6c 65 29 3b 0a  4)ftell(pFile);.
5ee0: 20 20 69 66 28 20 73 7a 46 69 6c 65 3d 3d 30 20    if( szFile==0 
5ef0: 29 7b 0a 20 20 20 20 72 65 74 75 72 6e 20 53 51  ){.    return SQ
5f00: 4c 49 54 45 5f 45 4d 50 54 59 3b 0a 20 20 7d 0a  LITE_EMPTY;.  }.
5f10: 20 20 6e 52 65 61 64 20 3d 20 28 69 6e 74 29 28    nRead = (int)(
5f20: 4d 49 4e 28 73 7a 46 69 6c 65 2c 20 5a 49 50 46  MIN(szFile, ZIPF
5f30: 49 4c 45 5f 42 55 46 46 45 52 5f 53 49 5a 45 29  ILE_BUFFER_SIZE)
5f40: 29 3b 0a 20 20 69 4f 66 66 20 3d 20 73 7a 46 69  );.  iOff = szFi
5f50: 6c 65 20 2d 20 6e 52 65 61 64 3b 0a 0a 20 20 72  le - nRead;..  r
5f60: 63 20 3d 20 7a 69 70 66 69 6c 65 52 65 61 64 44  c = zipfileReadD
5f70: 61 74 61 28 70 46 69 6c 65 2c 20 61 52 65 61 64  ata(pFile, aRead
5f80: 2c 20 6e 52 65 61 64 2c 20 69 4f 66 66 2c 20 26  , nRead, iOff, &
5f90: 70 54 61 62 2d 3e 62 61 73 65 2e 7a 45 72 72 4d  pTab->base.zErrM
5fa0: 73 67 29 3b 0a 20 20 69 66 28 20 72 63 3d 3d 53  sg);.  if( rc==S
5fb0: 51 4c 49 54 45 5f 4f 4b 20 29 7b 0a 20 20 20 20  QLITE_OK ){.    
5fc0: 69 6e 74 20 69 3b 0a 0a 20 20 20 20 2f 2a 20 53  int i;..    /* S
5fd0: 63 61 6e 20 62 61 63 6b 77 61 72 64 73 20 6c 6f  can backwards lo
5fe0: 6f 6b 69 6e 67 20 66 6f 72 20 74 68 65 20 73 69  oking for the si
5ff0: 67 6e 61 74 75 72 65 20 62 79 74 65 73 20 2a 2f  gnature bytes */
6000: 0a 20 20 20 20 66 6f 72 28 69 3d 6e 52 65 61 64  .    for(i=nRead
6010: 2d 32 30 3b 20 69 3e 3d 30 3b 20 69 2d 2d 29 7b  -20; i>=0; i--){
6020: 0a 20 20 20 20 20 20 69 66 28 20 61 52 65 61 64  .      if( aRead
6030: 5b 69 5d 3d 3d 30 78 35 30 20 26 26 20 61 52 65  [i]==0x50 && aRe
6040: 61 64 5b 69 2b 31 5d 3d 3d 30 78 34 62 20 0a 20  ad[i+1]==0x4b . 
6050: 20 20 20 20 20 20 26 26 20 61 52 65 61 64 5b 69        && aRead[i
6060: 2b 32 5d 3d 3d 30 78 30 35 20 26 26 20 61 52 65  +2]==0x05 && aRe
6070: 61 64 5b 69 2b 33 5d 3d 3d 30 78 30 36 20 0a 20  ad[i+3]==0x06 . 
6080: 20 20 20 20 20 29 7b 0a 20 20 20 20 20 20 20 20       ){.        
6090: 62 72 65 61 6b 3b 0a 20 20 20 20 20 20 7d 0a 20  break;.      }. 
60a0: 20 20 20 7d 0a 20 20 20 20 69 66 28 20 69 3c 30     }.    if( i<0
60b0: 20 29 7b 0a 20 20 20 20 20 20 70 54 61 62 2d 3e   ){.      pTab->
60c0: 62 61 73 65 2e 7a 45 72 72 4d 73 67 20 3d 20 73  base.zErrMsg = s
60d0: 71 6c 69 74 65 33 5f 6d 70 72 69 6e 74 66 28 0a  qlite3_mprintf(.
60e0: 20 20 20 20 20 20 20 20 20 20 22 63 61 6e 6e 6f            "canno
60f0: 74 20 66 69 6e 64 20 65 6e 64 20 6f 66 20 63 65  t find end of ce
6100: 6e 74 72 61 6c 20 64 69 72 65 63 74 6f 72 79 20  ntral directory 
6110: 72 65 63 6f 72 64 22 0a 20 20 20 20 20 20 29 3b  record".      );
6120: 0a 20 20 20 20 20 20 72 65 74 75 72 6e 20 53 51  .      return SQ
6130: 4c 49 54 45 5f 45 52 52 4f 52 3b 0a 20 20 20 20  LITE_ERROR;.    
6140: 7d 0a 0a 20 20 20 20 61 52 65 61 64 20 2b 3d 20  }..    aRead += 
6150: 69 2b 34 3b 0a 20 20 20 20 70 45 4f 43 44 2d 3e  i+4;.    pEOCD->
6160: 69 44 69 73 6b 20 3d 20 7a 69 70 66 69 6c 65 52  iDisk = zipfileR
6170: 65 61 64 31 36 28 61 52 65 61 64 29 3b 0a 20 20  ead16(aRead);.  
6180: 20 20 70 45 4f 43 44 2d 3e 69 46 69 72 73 74 44    pEOCD->iFirstD
6190: 69 73 6b 20 3d 20 7a 69 70 66 69 6c 65 52 65 61  isk = zipfileRea
61a0: 64 31 36 28 61 52 65 61 64 29 3b 0a 20 20 20 20  d16(aRead);.    
61b0: 70 45 4f 43 44 2d 3e 6e 45 6e 74 72 79 20 3d 20  pEOCD->nEntry = 
61c0: 7a 69 70 66 69 6c 65 52 65 61 64 31 36 28 61 52  zipfileRead16(aR
61d0: 65 61 64 29 3b 0a 20 20 20 20 70 45 4f 43 44 2d  ead);.    pEOCD-
61e0: 3e 6e 45 6e 74 72 79 54 6f 74 61 6c 20 3d 20 7a  >nEntryTotal = z
61f0: 69 70 66 69 6c 65 52 65 61 64 31 36 28 61 52 65  ipfileRead16(aRe
6200: 61 64 29 3b 0a 20 20 20 20 70 45 4f 43 44 2d 3e  ad);.    pEOCD->
6210: 6e 53 69 7a 65 20 3d 20 7a 69 70 66 69 6c 65 52  nSize = zipfileR
6220: 65 61 64 33 32 28 61 52 65 61 64 29 3b 0a 20 20  ead32(aRead);.  
6230: 20 20 70 45 4f 43 44 2d 3e 69 4f 66 66 73 65 74    pEOCD->iOffset
6240: 20 3d 20 7a 69 70 66 69 6c 65 52 65 61 64 33 32   = zipfileRead32
6250: 28 61 52 65 61 64 29 3b 0a 0a 23 69 66 20 30 0a  (aRead);..#if 0.
6260: 20 20 20 20 70 72 69 6e 74 66 28 22 69 44 69 73      printf("iDis
6270: 6b 3d 25 64 20 20 69 46 69 72 73 74 44 69 73 6b  k=%d  iFirstDisk
6280: 3d 25 64 20 20 6e 45 6e 74 72 79 3d 25 64 20 20  =%d  nEntry=%d  
6290: 22 0a 20 20 20 20 20 20 20 20 20 20 20 22 6e 45  ".           "nE
62a0: 6e 74 72 79 54 6f 74 61 6c 3d 25 64 20 20 6e 53  ntryTotal=%d  nS
62b0: 69 7a 65 3d 25 64 20 20 69 4f 66 66 73 65 74 3d  ize=%d  iOffset=
62c0: 25 64 22 2c 20 0a 20 20 20 20 20 20 20 20 20 20  %d", .          
62d0: 20 28 69 6e 74 29 70 45 4f 43 44 2d 3e 69 44 69   (int)pEOCD->iDi
62e0: 73 6b 2c 20 28 69 6e 74 29 70 45 4f 43 44 2d 3e  sk, (int)pEOCD->
62f0: 69 46 69 72 73 74 44 69 73 6b 2c 20 28 69 6e 74  iFirstDisk, (int
6300: 29 70 45 4f 43 44 2d 3e 6e 45 6e 74 72 79 2c 0a  )pEOCD->nEntry,.
6310: 20 20 20 20 20 20 20 20 20 20 20 28 69 6e 74 29             (int)
6320: 70 45 4f 43 44 2d 3e 6e 45 6e 74 72 79 54 6f 74  pEOCD->nEntryTot
6330: 61 6c 2c 20 28 69 6e 74 29 70 45 4f 43 44 2d 3e  al, (int)pEOCD->
6340: 6e 53 69 7a 65 2c 20 28 69 6e 74 29 70 45 4f 43  nSize, (int)pEOC
6350: 44 2d 3e 69 4f 66 66 73 65 74 0a 20 20 20 20 29  D->iOffset.    )
6360: 3b 0a 23 65 6e 64 69 66 0a 20 20 7d 0a 0a 20 20  ;.#endif.  }..  
6370: 72 65 74 75 72 6e 20 53 51 4c 49 54 45 5f 4f 4b  return SQLITE_OK
6380: 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 78 46 69 6c 74  ;.}../*.** xFilt
6390: 65 72 20 63 61 6c 6c 62 61 63 6b 2e 0a 2a 2f 0a  er callback..*/.
63a0: 73 74 61 74 69 63 20 69 6e 74 20 7a 69 70 66 69  static int zipfi
63b0: 6c 65 46 69 6c 74 65 72 28 0a 20 20 73 71 6c 69  leFilter(.  sqli
63c0: 74 65 33 5f 76 74 61 62 5f 63 75 72 73 6f 72 20  te3_vtab_cursor 
63d0: 2a 63 75 72 2c 20 0a 20 20 69 6e 74 20 69 64 78  *cur, .  int idx
63e0: 4e 75 6d 2c 20 63 6f 6e 73 74 20 63 68 61 72 20  Num, const char 
63f0: 2a 69 64 78 53 74 72 2c 0a 20 20 69 6e 74 20 61  *idxStr,.  int a
6400: 72 67 63 2c 20 73 71 6c 69 74 65 33 5f 76 61 6c  rgc, sqlite3_val
6410: 75 65 20 2a 2a 61 72 67 76 0a 29 7b 0a 20 20 5a  ue **argv.){.  Z
6420: 69 70 66 69 6c 65 54 61 62 20 2a 70 54 61 62 20  ipfileTab *pTab 
6430: 3d 20 28 5a 69 70 66 69 6c 65 54 61 62 2a 29 63  = (ZipfileTab*)c
6440: 75 72 2d 3e 70 56 74 61 62 3b 0a 20 20 5a 69 70  ur->pVtab;.  Zip
6450: 66 69 6c 65 43 73 72 20 2a 70 43 73 72 20 3d 20  fileCsr *pCsr = 
6460: 28 5a 69 70 66 69 6c 65 43 73 72 2a 29 63 75 72  (ZipfileCsr*)cur
6470: 3b 0a 20 20 63 6f 6e 73 74 20 63 68 61 72 20 2a  ;.  const char *
6480: 7a 46 69 6c 65 3b 20 20 20 20 20 20 20 20 20 20  zFile;          
6490: 20 20 20 20 2f 2a 20 5a 69 70 20 66 69 6c 65 20      /* Zip file 
64a0: 74 6f 20 73 63 61 6e 20 2a 2f 0a 20 20 69 6e 74  to scan */.  int
64b0: 20 72 63 20 3d 20 53 51 4c 49 54 45 5f 4f 4b 3b   rc = SQLITE_OK;
64c0: 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20               /* 
64d0: 52 65 74 75 72 6e 20 43 6f 64 65 20 2a 2f 0a 0a  Return Code */..
64e0: 20 20 7a 69 70 66 69 6c 65 52 65 73 65 74 43 75    zipfileResetCu
64f0: 72 73 6f 72 28 70 43 73 72 29 3b 0a 0a 20 20 69  rsor(pCsr);..  i
6500: 66 28 20 70 54 61 62 2d 3e 7a 46 69 6c 65 20 29  f( pTab->zFile )
6510: 7b 0a 20 20 20 20 7a 46 69 6c 65 20 3d 20 70 54  {.    zFile = pT
6520: 61 62 2d 3e 7a 46 69 6c 65 3b 0a 20 20 7d 65 6c  ab->zFile;.  }el
6530: 73 65 20 69 66 28 20 69 64 78 4e 75 6d 3d 3d 30  se if( idxNum==0
6540: 20 29 7b 0a 20 20 20 20 2f 2a 20 45 72 72 6f 72   ){.    /* Error
6550: 2e 20 54 68 69 73 20 69 73 20 61 6e 20 65 70 6f  . This is an epo
6560: 6e 79 6d 6f 75 73 20 76 69 72 74 75 61 6c 20 74  nymous virtual t
6570: 61 62 6c 65 20 61 6e 64 20 74 68 65 20 75 73 65  able and the use
6580: 72 20 68 61 73 20 6e 6f 74 20 0a 20 20 20 20 2a  r has not .    *
6590: 2a 20 73 75 70 70 6c 69 65 64 20 61 20 66 69 6c  * supplied a fil
65a0: 65 20 6e 61 6d 65 2e 20 2a 2f 0a 20 20 20 20 7a  e name. */.    z
65b0: 69 70 66 69 6c 65 53 65 74 45 72 72 6d 73 67 28  ipfileSetErrmsg(
65c0: 70 43 73 72 2c 20 22 74 61 62 6c 65 20 66 75 6e  pCsr, "table fun
65d0: 63 74 69 6f 6e 20 7a 69 70 66 69 6c 65 28 29 20  ction zipfile() 
65e0: 72 65 71 75 69 72 65 73 20 61 6e 20 61 72 67 75  requires an argu
65f0: 6d 65 6e 74 22 29 3b 0a 20 20 20 20 72 65 74 75  ment");.    retu
6600: 72 6e 20 53 51 4c 49 54 45 5f 45 52 52 4f 52 3b  rn SQLITE_ERROR;
6610: 0a 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20 7a 46  .  }else{.    zF
6620: 69 6c 65 20 3d 20 28 63 6f 6e 73 74 20 63 68 61  ile = (const cha
6630: 72 2a 29 73 71 6c 69 74 65 33 5f 76 61 6c 75 65  r*)sqlite3_value
6640: 5f 74 65 78 74 28 61 72 67 76 5b 30 5d 29 3b 0a  _text(argv[0]);.
6650: 20 20 7d 0a 0a 20 20 69 66 28 20 70 54 61 62 2d    }..  if( pTab-
6660: 3e 70 57 72 69 74 65 46 64 3d 3d 30 20 29 7b 0a  >pWriteFd==0 ){.
6670: 20 20 20 20 70 43 73 72 2d 3e 70 46 69 6c 65 20      pCsr->pFile 
6680: 3d 20 66 6f 70 65 6e 28 7a 46 69 6c 65 2c 20 22  = fopen(zFile, "
6690: 72 62 22 29 3b 0a 20 20 20 20 69 66 28 20 70 43  rb");.    if( pC
66a0: 73 72 2d 3e 70 46 69 6c 65 3d 3d 30 20 29 7b 0a  sr->pFile==0 ){.
66b0: 20 20 20 20 20 20 7a 69 70 66 69 6c 65 53 65 74        zipfileSet
66c0: 45 72 72 6d 73 67 28 70 43 73 72 2c 20 22 63 61  Errmsg(pCsr, "ca
66d0: 6e 6e 6f 74 20 6f 70 65 6e 20 66 69 6c 65 3a 20  nnot open file: 
66e0: 25 73 22 2c 20 7a 46 69 6c 65 29 3b 0a 20 20 20  %s", zFile);.   
66f0: 20 20 20 72 63 20 3d 20 53 51 4c 49 54 45 5f 45     rc = SQLITE_E
6700: 52 52 4f 52 3b 0a 20 20 20 20 7d 65 6c 73 65 7b  RROR;.    }else{
6710: 0a 20 20 20 20 20 20 72 63 20 3d 20 7a 69 70 66  .      rc = zipf
6720: 69 6c 65 52 65 61 64 45 4f 43 44 28 70 54 61 62  ileReadEOCD(pTab
6730: 2c 20 70 43 73 72 2d 3e 70 46 69 6c 65 2c 20 26  , pCsr->pFile, &
6740: 70 43 73 72 2d 3e 65 6f 63 64 29 3b 0a 20 20 20  pCsr->eocd);.   
6750: 20 20 20 69 66 28 20 72 63 3d 3d 53 51 4c 49 54     if( rc==SQLIT
6760: 45 5f 4f 4b 20 29 7b 0a 20 20 20 20 20 20 20 20  E_OK ){.        
6770: 70 43 73 72 2d 3e 69 4e 65 78 74 4f 66 66 20 3d  pCsr->iNextOff =
6780: 20 70 43 73 72 2d 3e 65 6f 63 64 2e 69 4f 66 66   pCsr->eocd.iOff
6790: 73 65 74 3b 0a 20 20 20 20 20 20 20 20 72 63 20  set;.        rc 
67a0: 3d 20 7a 69 70 66 69 6c 65 4e 65 78 74 28 63 75  = zipfileNext(cu
67b0: 72 29 3b 0a 20 20 20 20 20 20 7d 65 6c 73 65 20  r);.      }else 
67c0: 69 66 28 20 72 63 3d 3d 53 51 4c 49 54 45 5f 45  if( rc==SQLITE_E
67d0: 4d 50 54 59 20 29 7b 0a 20 20 20 20 20 20 20 20  MPTY ){.        
67e0: 72 63 20 3d 20 53 51 4c 49 54 45 5f 4f 4b 3b 0a  rc = SQLITE_OK;.
67f0: 20 20 20 20 20 20 20 20 70 43 73 72 2d 3e 62 45          pCsr->bE
6800: 6f 66 20 3d 20 31 3b 0a 20 20 20 20 20 20 7d 0a  of = 1;.      }.
6810: 20 20 20 20 7d 0a 20 20 7d 65 6c 73 65 7b 0a 20      }.  }else{. 
6820: 20 20 20 5a 69 70 66 69 6c 65 45 6e 74 72 79 20     ZipfileEntry 
6830: 65 3b 0a 20 20 20 20 6d 65 6d 73 65 74 28 26 65  e;.    memset(&e
6840: 2c 20 30 2c 20 73 69 7a 65 6f 66 28 65 29 29 3b  , 0, sizeof(e));
6850: 0a 20 20 20 20 65 2e 70 4e 65 78 74 20 3d 20 70  .    e.pNext = p
6860: 54 61 62 2d 3e 70 46 69 72 73 74 45 6e 74 72 79  Tab->pFirstEntry
6870: 3b 0a 20 20 20 20 70 43 73 72 2d 3e 70 43 75 72  ;.    pCsr->pCur
6880: 72 65 6e 74 20 3d 20 26 65 3b 0a 20 20 20 20 72  rent = &e;.    r
6890: 63 20 3d 20 7a 69 70 66 69 6c 65 4e 65 78 74 28  c = zipfileNext(
68a0: 63 75 72 29 3b 0a 20 20 20 20 61 73 73 65 72 74  cur);.    assert
68b0: 28 20 70 43 73 72 2d 3e 70 43 75 72 72 65 6e 74  ( pCsr->pCurrent
68c0: 21 3d 26 65 20 29 3b 0a 20 20 7d 0a 0a 20 20 72  !=&e );.  }..  r
68d0: 65 74 75 72 6e 20 72 63 3b 0a 7d 0a 0a 2f 2a 0a  eturn rc;.}../*.
68e0: 2a 2a 20 78 42 65 73 74 49 6e 64 65 78 20 63 61  ** xBestIndex ca
68f0: 6c 6c 62 61 63 6b 2e 0a 2a 2f 0a 73 74 61 74 69  llback..*/.stati
6900: 63 20 69 6e 74 20 7a 69 70 66 69 6c 65 42 65 73  c int zipfileBes
6910: 74 49 6e 64 65 78 28 0a 20 20 73 71 6c 69 74 65  tIndex(.  sqlite
6920: 33 5f 76 74 61 62 20 2a 74 61 62 2c 0a 20 20 73  3_vtab *tab,.  s
6930: 71 6c 69 74 65 33 5f 69 6e 64 65 78 5f 69 6e 66  qlite3_index_inf
6940: 6f 20 2a 70 49 64 78 49 6e 66 6f 0a 29 7b 0a 20  o *pIdxInfo.){. 
6950: 20 69 6e 74 20 69 3b 0a 0a 20 20 66 6f 72 28 69   int i;..  for(i
6960: 3d 30 3b 20 69 3c 70 49 64 78 49 6e 66 6f 2d 3e  =0; i<pIdxInfo->
6970: 6e 43 6f 6e 73 74 72 61 69 6e 74 3b 20 69 2b 2b  nConstraint; i++
6980: 29 7b 0a 20 20 20 20 63 6f 6e 73 74 20 73 74 72  ){.    const str
6990: 75 63 74 20 73 71 6c 69 74 65 33 5f 69 6e 64 65  uct sqlite3_inde
69a0: 78 5f 63 6f 6e 73 74 72 61 69 6e 74 20 2a 70 43  x_constraint *pC
69b0: 6f 6e 73 20 3d 20 26 70 49 64 78 49 6e 66 6f 2d  ons = &pIdxInfo-
69c0: 3e 61 43 6f 6e 73 74 72 61 69 6e 74 5b 69 5d 3b  >aConstraint[i];
69d0: 0a 20 20 20 20 69 66 28 20 70 43 6f 6e 73 2d 3e  .    if( pCons->
69e0: 75 73 61 62 6c 65 3d 3d 30 20 29 20 63 6f 6e 74  usable==0 ) cont
69f0: 69 6e 75 65 3b 0a 20 20 20 20 69 66 28 20 70 43  inue;.    if( pC
6a00: 6f 6e 73 2d 3e 6f 70 21 3d 53 51 4c 49 54 45 5f  ons->op!=SQLITE_
6a10: 49 4e 44 45 58 5f 43 4f 4e 53 54 52 41 49 4e 54  INDEX_CONSTRAINT
6a20: 5f 45 51 20 29 20 63 6f 6e 74 69 6e 75 65 3b 0a  _EQ ) continue;.
6a30: 20 20 20 20 69 66 28 20 70 43 6f 6e 73 2d 3e 69      if( pCons->i
6a40: 43 6f 6c 75 6d 6e 21 3d 5a 49 50 46 49 4c 45 5f  Column!=ZIPFILE_
6a50: 46 5f 43 4f 4c 55 4d 4e 5f 49 44 58 20 29 20 63  F_COLUMN_IDX ) c
6a60: 6f 6e 74 69 6e 75 65 3b 0a 20 20 20 20 62 72 65  ontinue;.    bre
6a70: 61 6b 3b 0a 20 20 7d 0a 0a 20 20 69 66 28 20 69  ak;.  }..  if( i
6a80: 3c 70 49 64 78 49 6e 66 6f 2d 3e 6e 43 6f 6e 73  <pIdxInfo->nCons
6a90: 74 72 61 69 6e 74 20 29 7b 0a 20 20 20 20 70 49  traint ){.    pI
6aa0: 64 78 49 6e 66 6f 2d 3e 61 43 6f 6e 73 74 72 61  dxInfo->aConstra
6ab0: 69 6e 74 55 73 61 67 65 5b 69 5d 2e 61 72 67 76  intUsage[i].argv
6ac0: 49 6e 64 65 78 20 3d 20 31 3b 0a 20 20 20 20 70  Index = 1;.    p
6ad0: 49 64 78 49 6e 66 6f 2d 3e 61 43 6f 6e 73 74 72  IdxInfo->aConstr
6ae0: 61 69 6e 74 55 73 61 67 65 5b 69 5d 2e 6f 6d 69  aintUsage[i].omi
6af0: 74 20 3d 20 31 3b 0a 20 20 20 20 70 49 64 78 49  t = 1;.    pIdxI
6b00: 6e 66 6f 2d 3e 65 73 74 69 6d 61 74 65 64 43 6f  nfo->estimatedCo
6b10: 73 74 20 3d 20 31 30 30 30 2e 30 3b 0a 20 20 20  st = 1000.0;.   
6b20: 20 70 49 64 78 49 6e 66 6f 2d 3e 69 64 78 4e 75   pIdxInfo->idxNu
6b30: 6d 20 3d 20 31 3b 0a 20 20 7d 65 6c 73 65 7b 0a  m = 1;.  }else{.
6b40: 20 20 20 20 70 49 64 78 49 6e 66 6f 2d 3e 65 73      pIdxInfo->es
6b50: 74 69 6d 61 74 65 64 43 6f 73 74 20 3d 20 28 64  timatedCost = (d
6b60: 6f 75 62 6c 65 29 28 28 28 73 71 6c 69 74 65 33  ouble)(((sqlite3
6b70: 5f 69 6e 74 36 34 29 31 29 20 3c 3c 20 35 30 29  _int64)1) << 50)
6b80: 3b 0a 20 20 20 20 70 49 64 78 49 6e 66 6f 2d 3e  ;.    pIdxInfo->
6b90: 69 64 78 4e 75 6d 20 3d 20 30 3b 0a 20 20 7d 0a  idxNum = 0;.  }.
6ba0: 0a 20 20 72 65 74 75 72 6e 20 53 51 4c 49 54 45  .  return SQLITE
6bb0: 5f 4f 4b 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 41 64  _OK;.}../*.** Ad
6bc0: 64 20 6f 62 6a 65 63 74 20 70 4e 65 77 20 74 6f  d object pNew to
6bd0: 20 74 68 65 20 65 6e 64 20 6f 66 20 74 68 65 20   the end of the 
6be0: 6c 69 6e 6b 65 64 20 6c 69 73 74 20 74 68 61 74  linked list that
6bf0: 20 62 65 67 69 6e 73 20 61 74 0a 2a 2a 20 5a 69   begins at.** Zi
6c00: 70 66 69 6c 65 54 61 62 2e 70 46 69 72 73 74 45  pfileTab.pFirstE
6c10: 6e 74 72 79 20 61 6e 64 20 65 6e 64 73 20 77 69  ntry and ends wi
6c20: 74 68 20 70 4c 61 73 74 45 6e 74 72 79 2e 0a 2a  th pLastEntry..*
6c30: 2f 0a 73 74 61 74 69 63 20 76 6f 69 64 20 7a 69  /.static void zi
6c40: 70 66 69 6c 65 41 64 64 45 6e 74 72 79 28 5a 69  pfileAddEntry(Zi
6c50: 70 66 69 6c 65 54 61 62 20 2a 70 54 61 62 2c 20  pfileTab *pTab, 
6c60: 5a 69 70 66 69 6c 65 45 6e 74 72 79 20 2a 70 4e  ZipfileEntry *pN
6c70: 65 77 29 7b 0a 20 20 61 73 73 65 72 74 28 20 28  ew){.  assert( (
6c80: 70 54 61 62 2d 3e 70 46 69 72 73 74 45 6e 74 72  pTab->pFirstEntr
6c90: 79 3d 3d 30 29 3d 3d 28 70 54 61 62 2d 3e 70 4c  y==0)==(pTab->pL
6ca0: 61 73 74 45 6e 74 72 79 3d 3d 30 29 20 29 3b 0a  astEntry==0) );.
6cb0: 20 20 61 73 73 65 72 74 28 20 70 4e 65 77 2d 3e    assert( pNew->
6cc0: 70 4e 65 78 74 3d 3d 30 20 29 3b 0a 20 20 69 66  pNext==0 );.  if
6cd0: 28 20 70 54 61 62 2d 3e 70 46 69 72 73 74 45 6e  ( pTab->pFirstEn
6ce0: 74 72 79 3d 3d 30 20 29 7b 0a 20 20 20 20 70 54  try==0 ){.    pT
6cf0: 61 62 2d 3e 70 46 69 72 73 74 45 6e 74 72 79 20  ab->pFirstEntry 
6d00: 3d 20 70 54 61 62 2d 3e 70 4c 61 73 74 45 6e 74  = pTab->pLastEnt
6d10: 72 79 20 3d 20 70 4e 65 77 3b 0a 20 20 7d 65 6c  ry = pNew;.  }el
6d20: 73 65 7b 0a 20 20 20 20 61 73 73 65 72 74 28 20  se{.    assert( 
6d30: 70 54 61 62 2d 3e 70 4c 61 73 74 45 6e 74 72 79  pTab->pLastEntry
6d40: 2d 3e 70 4e 65 78 74 3d 3d 30 20 29 3b 0a 20 20  ->pNext==0 );.  
6d50: 20 20 70 54 61 62 2d 3e 70 4c 61 73 74 45 6e 74    pTab->pLastEnt
6d60: 72 79 2d 3e 70 4e 65 78 74 20 3d 20 70 4e 65 77  ry->pNext = pNew
6d70: 3b 0a 20 20 20 20 70 54 61 62 2d 3e 70 4c 61 73  ;.    pTab->pLas
6d80: 74 45 6e 74 72 79 20 3d 20 70 4e 65 77 3b 0a 20  tEntry = pNew;. 
6d90: 20 7d 0a 7d 0a 0a 73 74 61 74 69 63 20 69 6e 74   }.}..static int
6da0: 20 7a 69 70 66 69 6c 65 4c 6f 61 64 44 69 72 65   zipfileLoadDire
6db0: 63 74 6f 72 79 28 5a 69 70 66 69 6c 65 54 61 62  ctory(ZipfileTab
6dc0: 20 2a 70 54 61 62 29 7b 0a 20 20 5a 69 70 66 69   *pTab){.  Zipfi
6dd0: 6c 65 45 4f 43 44 20 65 6f 63 64 3b 0a 20 20 69  leEOCD eocd;.  i
6de0: 6e 74 20 72 63 3b 0a 0a 20 20 72 63 20 3d 20 7a  nt rc;..  rc = z
6df0: 69 70 66 69 6c 65 52 65 61 64 45 4f 43 44 28 70  ipfileReadEOCD(p
6e00: 54 61 62 2c 20 70 54 61 62 2d 3e 70 57 72 69 74  Tab, pTab->pWrit
6e10: 65 46 64 2c 20 26 65 6f 63 64 29 3b 0a 20 20 69  eFd, &eocd);.  i
6e20: 66 28 20 72 63 3d 3d 53 51 4c 49 54 45 5f 4f 4b  f( rc==SQLITE_OK
6e30: 20 29 7b 0a 20 20 20 20 69 6e 74 20 69 3b 0a 20   ){.    int i;. 
6e40: 20 20 20 69 6e 74 20 69 4f 66 66 20 3d 20 30 3b     int iOff = 0;
6e50: 0a 20 20 20 20 75 38 20 2a 61 42 75 66 20 3d 20  .    u8 *aBuf = 
6e60: 73 71 6c 69 74 65 33 5f 6d 61 6c 6c 6f 63 28 65  sqlite3_malloc(e
6e70: 6f 63 64 2e 6e 53 69 7a 65 29 3b 0a 20 20 20 20  ocd.nSize);.    
6e80: 69 66 28 20 61 42 75 66 3d 3d 30 20 29 7b 0a 20  if( aBuf==0 ){. 
6e90: 20 20 20 20 20 72 63 20 3d 20 53 51 4c 49 54 45       rc = SQLITE
6ea0: 5f 4e 4f 4d 45 4d 3b 0a 20 20 20 20 7d 65 6c 73  _NOMEM;.    }els
6eb0: 65 7b 0a 20 20 20 20 20 20 72 63 20 3d 20 7a 69  e{.      rc = zi
6ec0: 70 66 69 6c 65 52 65 61 64 44 61 74 61 28 0a 20  pfileReadData(. 
6ed0: 20 20 20 20 20 20 20 20 20 70 54 61 62 2d 3e 70           pTab->p
6ee0: 57 72 69 74 65 46 64 2c 20 61 42 75 66 2c 20 65  WriteFd, aBuf, e
6ef0: 6f 63 64 2e 6e 53 69 7a 65 2c 20 65 6f 63 64 2e  ocd.nSize, eocd.
6f00: 69 4f 66 66 73 65 74 2c 20 26 70 54 61 62 2d 3e  iOffset, &pTab->
6f10: 62 61 73 65 2e 7a 45 72 72 4d 73 67 0a 20 20 20  base.zErrMsg.   
6f20: 20 20 20 29 3b 0a 20 20 20 20 7d 0a 0a 20 20 20     );.    }..   
6f30: 20 66 6f 72 28 69 3d 30 3b 20 72 63 3d 3d 53 51   for(i=0; rc==SQ
6f40: 4c 49 54 45 5f 4f 4b 20 26 26 20 69 3c 65 6f 63  LITE_OK && i<eoc
6f50: 64 2e 6e 45 6e 74 72 79 3b 20 69 2b 2b 29 7b 0a  d.nEntry; i++){.
6f60: 20 20 20 20 20 20 75 31 36 20 6e 46 69 6c 65 3b        u16 nFile;
6f70: 0a 20 20 20 20 20 20 75 31 36 20 6e 45 78 74 72  .      u16 nExtr
6f80: 61 3b 0a 20 20 20 20 20 20 75 31 36 20 6e 43 6f  a;.      u16 nCo
6f90: 6d 6d 65 6e 74 3b 0a 20 20 20 20 20 20 5a 69 70  mment;.      Zip
6fa0: 66 69 6c 65 45 6e 74 72 79 20 2a 70 4e 65 77 3b  fileEntry *pNew;
6fb0: 0a 20 20 20 20 20 20 75 38 20 2a 61 52 65 63 20  .      u8 *aRec 
6fc0: 3d 20 26 61 42 75 66 5b 69 4f 66 66 5d 3b 0a 0a  = &aBuf[iOff];..
6fd0: 20 20 20 20 20 20 6e 46 69 6c 65 20 3d 20 7a 69        nFile = zi
6fe0: 70 66 69 6c 65 47 65 74 55 31 36 28 26 61 52 65  pfileGetU16(&aRe
6ff0: 63 5b 5a 49 50 46 49 4c 45 5f 43 44 53 5f 4e 46  c[ZIPFILE_CDS_NF
7000: 49 4c 45 5f 4f 46 46 5d 29 3b 0a 20 20 20 20 20  ILE_OFF]);.     
7010: 20 6e 45 78 74 72 61 20 3d 20 7a 69 70 66 69 6c   nExtra = zipfil
7020: 65 47 65 74 55 31 36 28 26 61 52 65 63 5b 5a 49  eGetU16(&aRec[ZI
7030: 50 46 49 4c 45 5f 43 44 53 5f 4e 46 49 4c 45 5f  PFILE_CDS_NFILE_
7040: 4f 46 46 2b 32 5d 29 3b 0a 20 20 20 20 20 20 6e  OFF+2]);.      n
7050: 43 6f 6d 6d 65 6e 74 20 3d 20 7a 69 70 66 69 6c  Comment = zipfil
7060: 65 47 65 74 55 31 36 28 26 61 52 65 63 5b 5a 49  eGetU16(&aRec[ZI
7070: 50 46 49 4c 45 5f 43 44 53 5f 4e 46 49 4c 45 5f  PFILE_CDS_NFILE_
7080: 4f 46 46 2b 34 5d 29 3b 0a 0a 20 20 20 20 20 20  OFF+4]);..      
7090: 70 4e 65 77 20 3d 20 73 71 6c 69 74 65 33 5f 6d  pNew = sqlite3_m
70a0: 61 6c 6c 6f 63 28 0a 20 20 20 20 20 20 20 20 20  alloc(.         
70b0: 20 73 69 7a 65 6f 66 28 5a 69 70 66 69 6c 65 45   sizeof(ZipfileE
70c0: 6e 74 72 79 29 20 0a 20 20 20 20 20 20 20 20 2b  ntry) .        +
70d0: 20 6e 46 69 6c 65 2b 31 20 0a 20 20 20 20 20 20   nFile+1 .      
70e0: 20 20 2b 20 5a 49 50 46 49 4c 45 5f 43 44 53 5f    + ZIPFILE_CDS_
70f0: 46 49 58 45 44 5f 53 5a 2b 6e 46 69 6c 65 2b 6e  FIXED_SZ+nFile+n
7100: 45 78 74 72 61 2b 6e 43 6f 6d 6d 65 6e 74 0a 20  Extra+nComment. 
7110: 20 20 20 20 20 29 3b 0a 20 20 20 20 20 20 69 66       );.      if
7120: 28 20 70 4e 65 77 3d 3d 30 20 29 7b 0a 20 20 20  ( pNew==0 ){.   
7130: 20 20 20 20 20 72 63 20 3d 20 53 51 4c 49 54 45       rc = SQLITE
7140: 5f 4e 4f 4d 45 4d 3b 0a 20 20 20 20 20 20 7d 65  _NOMEM;.      }e
7150: 6c 73 65 7b 0a 20 20 20 20 20 20 20 20 6d 65 6d  lse{.        mem
7160: 73 65 74 28 70 4e 65 77 2c 20 30 2c 20 73 69 7a  set(pNew, 0, siz
7170: 65 6f 66 28 5a 69 70 66 69 6c 65 45 6e 74 72 79  eof(ZipfileEntry
7180: 29 29 3b 0a 20 20 20 20 20 20 20 20 70 4e 65 77  ));.        pNew
7190: 2d 3e 7a 50 61 74 68 20 3d 20 28 63 68 61 72 2a  ->zPath = (char*
71a0: 29 26 70 4e 65 77 5b 31 5d 3b 0a 20 20 20 20 20  )&pNew[1];.     
71b0: 20 20 20 6d 65 6d 63 70 79 28 70 4e 65 77 2d 3e     memcpy(pNew->
71c0: 7a 50 61 74 68 2c 20 26 61 52 65 63 5b 5a 49 50  zPath, &aRec[ZIP
71d0: 46 49 4c 45 5f 43 44 53 5f 46 49 58 45 44 5f 53  FILE_CDS_FIXED_S
71e0: 5a 5d 2c 20 6e 46 69 6c 65 29 3b 0a 20 20 20 20  Z], nFile);.    
71f0: 20 20 20 20 70 4e 65 77 2d 3e 7a 50 61 74 68 5b      pNew->zPath[
7200: 6e 46 69 6c 65 5d 20 3d 20 27 5c 30 27 3b 0a 20  nFile] = '\0';. 
7210: 20 20 20 20 20 20 20 70 4e 65 77 2d 3e 61 43 64         pNew->aCd
7220: 73 45 6e 74 72 79 20 3d 20 28 75 38 2a 29 26 70  sEntry = (u8*)&p
7230: 4e 65 77 2d 3e 7a 50 61 74 68 5b 6e 46 69 6c 65  New->zPath[nFile
7240: 2b 31 5d 3b 0a 20 20 20 20 20 20 20 20 70 4e 65  +1];.        pNe
7250: 77 2d 3e 6e 43 64 73 45 6e 74 72 79 20 3d 20 5a  w->nCdsEntry = Z
7260: 49 50 46 49 4c 45 5f 43 44 53 5f 46 49 58 45 44  IPFILE_CDS_FIXED
7270: 5f 53 5a 2b 6e 46 69 6c 65 2b 6e 45 78 74 72 61  _SZ+nFile+nExtra
7280: 2b 6e 43 6f 6d 6d 65 6e 74 3b 0a 20 20 20 20 20  +nComment;.     
7290: 20 20 20 6d 65 6d 63 70 79 28 70 4e 65 77 2d 3e     memcpy(pNew->
72a0: 61 43 64 73 45 6e 74 72 79 2c 20 61 52 65 63 2c  aCdsEntry, aRec,
72b0: 20 70 4e 65 77 2d 3e 6e 43 64 73 45 6e 74 72 79   pNew->nCdsEntry
72c0: 29 3b 0a 20 20 20 20 20 20 20 20 7a 69 70 66 69  );.        zipfi
72d0: 6c 65 41 64 64 45 6e 74 72 79 28 70 54 61 62 2c  leAddEntry(pTab,
72e0: 20 70 4e 65 77 29 3b 0a 20 20 20 20 20 20 7d 0a   pNew);.      }.
72f0: 0a 20 20 20 20 20 20 69 4f 66 66 20 2b 3d 20 5a  .      iOff += Z
7300: 49 50 46 49 4c 45 5f 43 44 53 5f 46 49 58 45 44  IPFILE_CDS_FIXED
7310: 5f 53 5a 2b 6e 46 69 6c 65 2b 6e 45 78 74 72 61  _SZ+nFile+nExtra
7320: 2b 6e 43 6f 6d 6d 65 6e 74 3b 0a 20 20 20 20 7d  +nComment;.    }
7330: 0a 0a 20 20 20 20 73 71 6c 69 74 65 33 5f 66 72  ..    sqlite3_fr
7340: 65 65 28 61 42 75 66 29 3b 0a 20 20 7d 65 6c 73  ee(aBuf);.  }els
7350: 65 20 69 66 28 20 72 63 3d 3d 53 51 4c 49 54 45  e if( rc==SQLITE
7360: 5f 45 4d 50 54 59 20 29 7b 0a 20 20 20 20 72 63  _EMPTY ){.    rc
7370: 20 3d 20 53 51 4c 49 54 45 5f 4f 4b 3b 0a 20 20   = SQLITE_OK;.  
7380: 7d 0a 0a 20 20 72 65 74 75 72 6e 20 72 63 3b 0a  }..  return rc;.
7390: 7d 0a 0a 73 74 61 74 69 63 20 5a 69 70 66 69 6c  }..static Zipfil
73a0: 65 45 6e 74 72 79 20 2a 7a 69 70 66 69 6c 65 4e  eEntry *zipfileN
73b0: 65 77 45 6e 74 72 79 28 0a 20 20 5a 69 70 66 69  ewEntry(.  Zipfi
73c0: 6c 65 43 44 53 20 2a 70 43 64 73 2c 20 20 20 20  leCDS *pCds,    
73d0: 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 56 61             /* Va
73e0: 6c 75 65 73 20 66 6f 72 20 66 69 78 65 64 20 73  lues for fixed s
73f0: 69 7a 65 20 70 61 72 74 20 6f 66 20 43 44 53 20  ize part of CDS 
7400: 2a 2f 0a 20 20 63 6f 6e 73 74 20 63 68 61 72 20  */.  const char 
7410: 2a 7a 50 61 74 68 2c 20 20 20 20 20 20 20 20 20  *zPath,         
7420: 20 20 20 20 20 2f 2a 20 50 61 74 68 20 66 6f 72       /* Path for
7430: 20 6e 65 77 20 65 6e 74 72 79 20 2a 2f 0a 20 20   new entry */.  
7440: 69 6e 74 20 6e 50 61 74 68 2c 20 20 20 20 20 20  int nPath,      
7450: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
7460: 2f 2a 20 73 74 72 6c 65 6e 28 7a 50 61 74 68 29  /* strlen(zPath)
7470: 20 2a 2f 0a 20 20 75 33 32 20 6d 54 69 6d 65 20   */.  u32 mTime 
7480: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
7490: 20 20 20 20 20 20 2f 2a 20 4d 6f 64 69 66 69 63        /* Modific
74a0: 61 74 69 6f 6e 20 74 69 6d 65 20 28 6f 72 20 30  ation time (or 0
74b0: 29 20 2a 2f 0a 29 7b 0a 20 20 75 38 20 2a 61 57  ) */.){.  u8 *aW
74c0: 72 69 74 65 3b 0a 20 20 5a 69 70 66 69 6c 65 45  rite;.  ZipfileE
74d0: 6e 74 72 79 20 2a 70 4e 65 77 3b 0a 20 20 70 43  ntry *pNew;.  pC
74e0: 64 73 2d 3e 6e 46 69 6c 65 20 3d 20 28 75 31 36  ds->nFile = (u16
74f0: 29 6e 50 61 74 68 3b 0a 20 20 70 43 64 73 2d 3e  )nPath;.  pCds->
7500: 6e 45 78 74 72 61 20 3d 20 6d 54 69 6d 65 20 3f  nExtra = mTime ?
7510: 20 39 20 3a 20 30 3b 0a 20 20 70 4e 65 77 20 3d   9 : 0;.  pNew =
7520: 20 28 5a 69 70 66 69 6c 65 45 6e 74 72 79 2a 29   (ZipfileEntry*)
7530: 73 71 6c 69 74 65 33 5f 6d 61 6c 6c 6f 63 28 0a  sqlite3_malloc(.
7540: 20 20 20 20 73 69 7a 65 6f 66 28 5a 69 70 66 69      sizeof(Zipfi
7550: 6c 65 45 6e 74 72 79 29 20 2b 20 0a 20 20 20 20  leEntry) + .    
7560: 6e 50 61 74 68 2b 31 20 2b 20 0a 20 20 20 20 5a  nPath+1 + .    Z
7570: 49 50 46 49 4c 45 5f 43 44 53 5f 46 49 58 45 44  IPFILE_CDS_FIXED
7580: 5f 53 5a 20 2b 20 6e 50 61 74 68 20 2b 20 70 43  _SZ + nPath + pC
7590: 64 73 2d 3e 6e 45 78 74 72 61 0a 20 20 29 3b 0a  ds->nExtra.  );.
75a0: 0a 20 20 69 66 28 20 70 4e 65 77 20 29 7b 0a 20  .  if( pNew ){. 
75b0: 20 20 20 6d 65 6d 73 65 74 28 70 4e 65 77 2c 20     memset(pNew, 
75c0: 30 2c 20 73 69 7a 65 6f 66 28 5a 69 70 66 69 6c  0, sizeof(Zipfil
75d0: 65 45 6e 74 72 79 29 29 3b 0a 20 20 20 20 70 4e  eEntry));.    pN
75e0: 65 77 2d 3e 7a 50 61 74 68 20 3d 20 28 63 68 61  ew->zPath = (cha
75f0: 72 2a 29 26 70 4e 65 77 5b 31 5d 3b 0a 20 20 20  r*)&pNew[1];.   
7600: 20 70 4e 65 77 2d 3e 61 43 64 73 45 6e 74 72 79   pNew->aCdsEntry
7610: 20 3d 20 28 75 38 2a 29 26 70 4e 65 77 2d 3e 7a   = (u8*)&pNew->z
7620: 50 61 74 68 5b 6e 50 61 74 68 2b 31 5d 3b 0a 20  Path[nPath+1];. 
7630: 20 20 20 70 4e 65 77 2d 3e 6e 43 64 73 45 6e 74     pNew->nCdsEnt
7640: 72 79 20 3d 20 5a 49 50 46 49 4c 45 5f 43 44 53  ry = ZIPFILE_CDS
7650: 5f 46 49 58 45 44 5f 53 5a 20 2b 20 6e 50 61 74  _FIXED_SZ + nPat
7660: 68 20 2b 20 70 43 64 73 2d 3e 6e 45 78 74 72 61  h + pCds->nExtra
7670: 3b 0a 20 20 20 20 6d 65 6d 63 70 79 28 70 4e 65  ;.    memcpy(pNe
7680: 77 2d 3e 7a 50 61 74 68 2c 20 7a 50 61 74 68 2c  w->zPath, zPath,
7690: 20 6e 50 61 74 68 2b 31 29 3b 0a 0a 20 20 20 20   nPath+1);..    
76a0: 61 57 72 69 74 65 20 3d 20 70 4e 65 77 2d 3e 61  aWrite = pNew->a
76b0: 43 64 73 45 6e 74 72 79 3b 0a 20 20 20 20 7a 69  CdsEntry;.    zi
76c0: 70 66 69 6c 65 57 72 69 74 65 33 32 28 61 57 72  pfileWrite32(aWr
76d0: 69 74 65 2c 20 5a 49 50 46 49 4c 45 5f 53 49 47  ite, ZIPFILE_SIG
76e0: 4e 41 54 55 52 45 5f 43 44 53 29 3b 0a 20 20 20  NATURE_CDS);.   
76f0: 20 7a 69 70 66 69 6c 65 57 72 69 74 65 31 36 28   zipfileWrite16(
7700: 61 57 72 69 74 65 2c 20 70 43 64 73 2d 3e 69 56  aWrite, pCds->iV
7710: 65 72 73 69 6f 6e 4d 61 64 65 42 79 29 3b 0a 20  ersionMadeBy);. 
7720: 20 20 20 7a 69 70 66 69 6c 65 57 72 69 74 65 31     zipfileWrite1
7730: 36 28 61 57 72 69 74 65 2c 20 70 43 64 73 2d 3e  6(aWrite, pCds->
7740: 69 56 65 72 73 69 6f 6e 45 78 74 72 61 63 74 29  iVersionExtract)
7750: 3b 0a 20 20 20 20 7a 69 70 66 69 6c 65 57 72 69  ;.    zipfileWri
7760: 74 65 31 36 28 61 57 72 69 74 65 2c 20 70 43 64  te16(aWrite, pCd
7770: 73 2d 3e 66 6c 61 67 73 29 3b 0a 20 20 20 20 7a  s->flags);.    z
7780: 69 70 66 69 6c 65 57 72 69 74 65 31 36 28 61 57  ipfileWrite16(aW
7790: 72 69 74 65 2c 20 70 43 64 73 2d 3e 69 43 6f 6d  rite, pCds->iCom
77a0: 70 72 65 73 73 69 6f 6e 29 3b 0a 20 20 20 20 7a  pression);.    z
77b0: 69 70 66 69 6c 65 57 72 69 74 65 31 36 28 61 57  ipfileWrite16(aW
77c0: 72 69 74 65 2c 20 70 43 64 73 2d 3e 6d 54 69 6d  rite, pCds->mTim
77d0: 65 29 3b 0a 20 20 20 20 7a 69 70 66 69 6c 65 57  e);.    zipfileW
77e0: 72 69 74 65 31 36 28 61 57 72 69 74 65 2c 20 70  rite16(aWrite, p
77f0: 43 64 73 2d 3e 6d 44 61 74 65 29 3b 0a 20 20 20  Cds->mDate);.   
7800: 20 7a 69 70 66 69 6c 65 57 72 69 74 65 33 32 28   zipfileWrite32(
7810: 61 57 72 69 74 65 2c 20 70 43 64 73 2d 3e 63 72  aWrite, pCds->cr
7820: 63 33 32 29 3b 0a 20 20 20 20 7a 69 70 66 69 6c  c32);.    zipfil
7830: 65 57 72 69 74 65 33 32 28 61 57 72 69 74 65 2c  eWrite32(aWrite,
7840: 20 70 43 64 73 2d 3e 73 7a 43 6f 6d 70 72 65 73   pCds->szCompres
7850: 73 65 64 29 3b 0a 20 20 20 20 7a 69 70 66 69 6c  sed);.    zipfil
7860: 65 57 72 69 74 65 33 32 28 61 57 72 69 74 65 2c  eWrite32(aWrite,
7870: 20 70 43 64 73 2d 3e 73 7a 55 6e 63 6f 6d 70 72   pCds->szUncompr
7880: 65 73 73 65 64 29 3b 0a 20 20 20 20 7a 69 70 66  essed);.    zipf
7890: 69 6c 65 57 72 69 74 65 31 36 28 61 57 72 69 74  ileWrite16(aWrit
78a0: 65 2c 20 70 43 64 73 2d 3e 6e 46 69 6c 65 29 3b  e, pCds->nFile);
78b0: 0a 20 20 20 20 7a 69 70 66 69 6c 65 57 72 69 74  .    zipfileWrit
78c0: 65 31 36 28 61 57 72 69 74 65 2c 20 70 43 64 73  e16(aWrite, pCds
78d0: 2d 3e 6e 45 78 74 72 61 29 3b 0a 20 20 20 20 7a  ->nExtra);.    z
78e0: 69 70 66 69 6c 65 57 72 69 74 65 31 36 28 61 57  ipfileWrite16(aW
78f0: 72 69 74 65 2c 20 70 43 64 73 2d 3e 6e 43 6f 6d  rite, pCds->nCom
7900: 6d 65 6e 74 29 3b 20 20 20 20 20 20 61 73 73 65  ment);      asse
7910: 72 74 28 20 70 43 64 73 2d 3e 6e 43 6f 6d 6d 65  rt( pCds->nComme
7920: 6e 74 3d 3d 30 20 29 3b 0a 20 20 20 20 7a 69 70  nt==0 );.    zip
7930: 66 69 6c 65 57 72 69 74 65 31 36 28 61 57 72 69  fileWrite16(aWri
7940: 74 65 2c 20 70 43 64 73 2d 3e 69 44 69 73 6b 53  te, pCds->iDiskS
7950: 74 61 72 74 29 3b 0a 20 20 20 20 7a 69 70 66 69  tart);.    zipfi
7960: 6c 65 57 72 69 74 65 31 36 28 61 57 72 69 74 65  leWrite16(aWrite
7970: 2c 20 70 43 64 73 2d 3e 69 49 6e 74 65 72 6e 61  , pCds->iInterna
7980: 6c 41 74 74 72 29 3b 0a 20 20 20 20 7a 69 70 66  lAttr);.    zipf
7990: 69 6c 65 57 72 69 74 65 33 32 28 61 57 72 69 74  ileWrite32(aWrit
79a0: 65 2c 20 70 43 64 73 2d 3e 69 45 78 74 65 72 6e  e, pCds->iExtern
79b0: 61 6c 41 74 74 72 29 3b 0a 20 20 20 20 7a 69 70  alAttr);.    zip
79c0: 66 69 6c 65 57 72 69 74 65 33 32 28 61 57 72 69  fileWrite32(aWri
79d0: 74 65 2c 20 70 43 64 73 2d 3e 69 4f 66 66 73 65  te, pCds->iOffse
79e0: 74 29 3b 0a 20 20 20 20 61 73 73 65 72 74 28 20  t);.    assert( 
79f0: 61 57 72 69 74 65 3d 3d 26 70 4e 65 77 2d 3e 61  aWrite==&pNew->a
7a00: 43 64 73 45 6e 74 72 79 5b 5a 49 50 46 49 4c 45  CdsEntry[ZIPFILE
7a10: 5f 43 44 53 5f 46 49 58 45 44 5f 53 5a 5d 20 29  _CDS_FIXED_SZ] )
7a20: 3b 0a 20 20 20 20 6d 65 6d 63 70 79 28 61 57 72  ;.    memcpy(aWr
7a30: 69 74 65 2c 20 7a 50 61 74 68 2c 20 6e 50 61 74  ite, zPath, nPat
7a40: 68 29 3b 0a 20 20 20 20 69 66 28 20 70 43 64 73  h);.    if( pCds
7a50: 2d 3e 6e 45 78 74 72 61 20 29 7b 0a 20 20 20 20  ->nExtra ){.    
7a60: 20 20 61 57 72 69 74 65 20 2b 3d 20 6e 50 61 74    aWrite += nPat
7a70: 68 3b 0a 20 20 20 20 20 20 7a 69 70 66 69 6c 65  h;.      zipfile
7a80: 57 72 69 74 65 31 36 28 61 57 72 69 74 65 2c 20  Write16(aWrite, 
7a90: 5a 49 50 46 49 4c 45 5f 45 58 54 52 41 5f 54 49  ZIPFILE_EXTRA_TI
7aa0: 4d 45 53 54 41 4d 50 29 3b 0a 20 20 20 20 20 20  MESTAMP);.      
7ab0: 7a 69 70 66 69 6c 65 57 72 69 74 65 31 36 28 61  zipfileWrite16(a
7ac0: 57 72 69 74 65 2c 20 35 29 3b 0a 20 20 20 20 20  Write, 5);.     
7ad0: 20 2a 61 57 72 69 74 65 2b 2b 20 3d 20 30 78 30   *aWrite++ = 0x0
7ae0: 31 3b 0a 20 20 20 20 20 20 7a 69 70 66 69 6c 65  1;.      zipfile
7af0: 57 72 69 74 65 33 32 28 61 57 72 69 74 65 2c 20  Write32(aWrite, 
7b00: 6d 54 69 6d 65 29 3b 0a 20 20 20 20 7d 0a 20 20  mTime);.    }.  
7b10: 7d 0a 0a 20 20 72 65 74 75 72 6e 20 70 4e 65 77  }..  return pNew
7b20: 3b 0a 7d 0a 0a 73 74 61 74 69 63 20 69 6e 74 20  ;.}..static int 
7b30: 7a 69 70 66 69 6c 65 41 70 70 65 6e 64 45 6e 74  zipfileAppendEnt
7b40: 72 79 28 0a 20 20 5a 69 70 66 69 6c 65 54 61 62  ry(.  ZipfileTab
7b50: 20 2a 70 54 61 62 2c 0a 20 20 5a 69 70 66 69 6c   *pTab,.  Zipfil
7b60: 65 43 44 53 20 2a 70 43 64 73 2c 0a 20 20 63 6f  eCDS *pCds,.  co
7b70: 6e 73 74 20 63 68 61 72 20 2a 7a 50 61 74 68 2c  nst char *zPath,
7b80: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a                /*
7b90: 20 50 61 74 68 20 66 6f 72 20 6e 65 77 20 65 6e   Path for new en
7ba0: 74 72 79 20 2a 2f 0a 20 20 69 6e 74 20 6e 50 61  try */.  int nPa
7bb0: 74 68 2c 20 20 20 20 20 20 20 20 20 20 20 20 20  th,             
7bc0: 20 20 20 20 20 20 20 20 20 2f 2a 20 73 74 72 6c           /* strl
7bd0: 65 6e 28 7a 50 61 74 68 29 20 2a 2f 0a 20 20 63  en(zPath) */.  c
7be0: 6f 6e 73 74 20 75 38 20 2a 70 44 61 74 61 2c 0a  onst u8 *pData,.
7bf0: 20 20 69 6e 74 20 6e 44 61 74 61 2c 0a 20 20 75    int nData,.  u
7c00: 33 32 20 6d 54 69 6d 65 0a 29 7b 0a 20 20 75 38  32 mTime.){.  u8
7c10: 20 2a 61 42 75 66 20 3d 20 70 54 61 62 2d 3e 61   *aBuf = pTab->a
7c20: 42 75 66 66 65 72 3b 0a 20 20 69 6e 74 20 72 63  Buffer;.  int rc
7c30: 3b 0a 0a 20 20 7a 69 70 66 69 6c 65 57 72 69 74  ;..  zipfileWrit
7c40: 65 33 32 28 61 42 75 66 2c 20 5a 49 50 46 49 4c  e32(aBuf, ZIPFIL
7c50: 45 5f 53 49 47 4e 41 54 55 52 45 5f 4c 46 48 29  E_SIGNATURE_LFH)
7c60: 3b 0a 20 20 7a 69 70 66 69 6c 65 57 72 69 74 65  ;.  zipfileWrite
7c70: 31 36 28 61 42 75 66 2c 20 70 43 64 73 2d 3e 69  16(aBuf, pCds->i
7c80: 56 65 72 73 69 6f 6e 45 78 74 72 61 63 74 29 3b  VersionExtract);
7c90: 0a 20 20 7a 69 70 66 69 6c 65 57 72 69 74 65 31  .  zipfileWrite1
7ca0: 36 28 61 42 75 66 2c 20 70 43 64 73 2d 3e 66 6c  6(aBuf, pCds->fl
7cb0: 61 67 73 29 3b 0a 20 20 7a 69 70 66 69 6c 65 57  ags);.  zipfileW
7cc0: 72 69 74 65 31 36 28 61 42 75 66 2c 20 70 43 64  rite16(aBuf, pCd
7cd0: 73 2d 3e 69 43 6f 6d 70 72 65 73 73 69 6f 6e 29  s->iCompression)
7ce0: 3b 0a 20 20 7a 69 70 66 69 6c 65 57 72 69 74 65  ;.  zipfileWrite
7cf0: 31 36 28 61 42 75 66 2c 20 70 43 64 73 2d 3e 6d  16(aBuf, pCds->m
7d00: 54 69 6d 65 29 3b 0a 20 20 7a 69 70 66 69 6c 65  Time);.  zipfile
7d10: 57 72 69 74 65 31 36 28 61 42 75 66 2c 20 70 43  Write16(aBuf, pC
7d20: 64 73 2d 3e 6d 44 61 74 65 29 3b 0a 20 20 7a 69  ds->mDate);.  zi
7d30: 70 66 69 6c 65 57 72 69 74 65 33 32 28 61 42 75  pfileWrite32(aBu
7d40: 66 2c 20 70 43 64 73 2d 3e 63 72 63 33 32 29 3b  f, pCds->crc32);
7d50: 0a 20 20 7a 69 70 66 69 6c 65 57 72 69 74 65 33  .  zipfileWrite3
7d60: 32 28 61 42 75 66 2c 20 70 43 64 73 2d 3e 73 7a  2(aBuf, pCds->sz
7d70: 43 6f 6d 70 72 65 73 73 65 64 29 3b 0a 20 20 7a  Compressed);.  z
7d80: 69 70 66 69 6c 65 57 72 69 74 65 33 32 28 61 42  ipfileWrite32(aB
7d90: 75 66 2c 20 70 43 64 73 2d 3e 73 7a 55 6e 63 6f  uf, pCds->szUnco
7da0: 6d 70 72 65 73 73 65 64 29 3b 0a 20 20 7a 69 70  mpressed);.  zip
7db0: 66 69 6c 65 57 72 69 74 65 31 36 28 61 42 75 66  fileWrite16(aBuf
7dc0: 2c 20 28 75 31 36 29 6e 50 61 74 68 29 3b 0a 20  , (u16)nPath);. 
7dd0: 20 7a 69 70 66 69 6c 65 57 72 69 74 65 31 36 28   zipfileWrite16(
7de0: 61 42 75 66 2c 20 70 43 64 73 2d 3e 6e 45 78 74  aBuf, pCds->nExt
7df0: 72 61 29 3b 0a 20 20 61 73 73 65 72 74 28 20 61  ra);.  assert( a
7e00: 42 75 66 3d 3d 26 70 54 61 62 2d 3e 61 42 75 66  Buf==&pTab->aBuf
7e10: 66 65 72 5b 5a 49 50 46 49 4c 45 5f 4c 46 48 5f  fer[ZIPFILE_LFH_
7e20: 46 49 58 45 44 5f 53 5a 5d 20 29 3b 0a 20 20 72  FIXED_SZ] );.  r
7e30: 63 20 3d 20 7a 69 70 66 69 6c 65 41 70 70 65 6e  c = zipfileAppen
7e40: 64 44 61 74 61 28 70 54 61 62 2c 20 70 54 61 62  dData(pTab, pTab
7e50: 2d 3e 61 42 75 66 66 65 72 2c 20 28 69 6e 74 29  ->aBuffer, (int)
7e60: 28 61 42 75 66 20 2d 20 70 54 61 62 2d 3e 61 42  (aBuf - pTab->aB
7e70: 75 66 66 65 72 29 29 3b 0a 20 20 69 66 28 20 72  uffer));.  if( r
7e80: 63 3d 3d 53 51 4c 49 54 45 5f 4f 4b 20 29 7b 0a  c==SQLITE_OK ){.
7e90: 20 20 20 20 72 63 20 3d 20 7a 69 70 66 69 6c 65      rc = zipfile
7ea0: 41 70 70 65 6e 64 44 61 74 61 28 70 54 61 62 2c  AppendData(pTab,
7eb0: 20 28 63 6f 6e 73 74 20 75 38 2a 29 7a 50 61 74   (const u8*)zPat
7ec0: 68 2c 20 6e 50 61 74 68 29 3b 0a 20 20 7d 0a 0a  h, nPath);.  }..
7ed0: 20 20 69 66 28 20 72 63 3d 3d 53 51 4c 49 54 45    if( rc==SQLITE
7ee0: 5f 4f 4b 20 26 26 20 70 43 64 73 2d 3e 6e 45 78  _OK && pCds->nEx
7ef0: 74 72 61 20 29 7b 0a 20 20 20 20 61 42 75 66 20  tra ){.    aBuf 
7f00: 3d 20 70 54 61 62 2d 3e 61 42 75 66 66 65 72 3b  = pTab->aBuffer;
7f10: 0a 20 20 20 20 7a 69 70 66 69 6c 65 57 72 69 74  .    zipfileWrit
7f20: 65 31 36 28 61 42 75 66 2c 20 5a 49 50 46 49 4c  e16(aBuf, ZIPFIL
7f30: 45 5f 45 58 54 52 41 5f 54 49 4d 45 53 54 41 4d  E_EXTRA_TIMESTAM
7f40: 50 29 3b 0a 20 20 20 20 7a 69 70 66 69 6c 65 57  P);.    zipfileW
7f50: 72 69 74 65 31 36 28 61 42 75 66 2c 20 35 29 3b  rite16(aBuf, 5);
7f60: 0a 20 20 20 20 2a 61 42 75 66 2b 2b 20 3d 20 30  .    *aBuf++ = 0
7f70: 78 30 31 3b 0a 20 20 20 20 7a 69 70 66 69 6c 65  x01;.    zipfile
7f80: 57 72 69 74 65 33 32 28 61 42 75 66 2c 20 6d 54  Write32(aBuf, mT
7f90: 69 6d 65 29 3b 0a 20 20 20 20 72 63 20 3d 20 7a  ime);.    rc = z
7fa0: 69 70 66 69 6c 65 41 70 70 65 6e 64 44 61 74 61  ipfileAppendData
7fb0: 28 70 54 61 62 2c 20 70 54 61 62 2d 3e 61 42 75  (pTab, pTab->aBu
7fc0: 66 66 65 72 2c 20 39 29 3b 0a 20 20 7d 0a 0a 20  ffer, 9);.  }.. 
7fd0: 20 69 66 28 20 72 63 3d 3d 53 51 4c 49 54 45 5f   if( rc==SQLITE_
7fe0: 4f 4b 20 29 7b 0a 20 20 20 20 72 63 20 3d 20 7a  OK ){.    rc = z
7ff0: 69 70 66 69 6c 65 41 70 70 65 6e 64 44 61 74 61  ipfileAppendData
8000: 28 70 54 61 62 2c 20 70 44 61 74 61 2c 20 6e 44  (pTab, pData, nD
8010: 61 74 61 29 3b 0a 20 20 7d 0a 0a 20 20 72 65 74  ata);.  }..  ret
8020: 75 72 6e 20 72 63 3b 0a 7d 0a 0a 73 74 61 74 69  urn rc;.}..stati
8030: 63 20 69 6e 74 20 7a 69 70 66 69 6c 65 47 65 74  c int zipfileGet
8040: 4d 6f 64 65 28 0a 20 20 5a 69 70 66 69 6c 65 54  Mode(.  ZipfileT
8050: 61 62 20 2a 70 54 61 62 2c 20 0a 20 20 73 71 6c  ab *pTab, .  sql
8060: 69 74 65 33 5f 76 61 6c 75 65 20 2a 70 56 61 6c  ite3_value *pVal
8070: 2c 20 0a 20 20 75 33 32 20 64 65 66 61 75 6c 74  , .  u32 default
8080: 4d 6f 64 65 2c 20 20 20 20 20 20 20 20 20 20 20  Mode,           
8090: 20 20 20 20 20 2f 2a 20 56 61 6c 75 65 20 74 6f       /* Value to
80a0: 20 75 73 65 20 69 66 20 70 56 61 6c 20 49 53 20   use if pVal IS 
80b0: 4e 55 4c 4c 20 2a 2f 0a 20 20 75 33 32 20 2a 70  NULL */.  u32 *p
80c0: 4d 6f 64 65 0a 29 7b 0a 20 20 63 6f 6e 73 74 20  Mode.){.  const 
80d0: 63 68 61 72 20 2a 7a 20 3d 20 28 63 6f 6e 73 74  char *z = (const
80e0: 20 63 68 61 72 2a 29 73 71 6c 69 74 65 33 5f 76   char*)sqlite3_v
80f0: 61 6c 75 65 5f 74 65 78 74 28 70 56 61 6c 29 3b  alue_text(pVal);
8100: 0a 20 20 75 33 32 20 6d 6f 64 65 20 3d 20 30 3b  .  u32 mode = 0;
8110: 0a 20 20 69 66 28 20 7a 3d 3d 30 20 29 7b 0a 20  .  if( z==0 ){. 
8120: 20 20 20 6d 6f 64 65 20 3d 20 64 65 66 61 75 6c     mode = defaul
8130: 74 4d 6f 64 65 3b 0a 20 20 7d 65 6c 73 65 20 69  tMode;.  }else i
8140: 66 28 20 7a 5b 30 5d 3e 3d 30 20 26 26 20 7a 5b  f( z[0]>=0 && z[
8150: 30 5d 3c 3d 39 20 29 7b 0a 20 20 20 20 6d 6f 64  0]<=9 ){.    mod
8160: 65 20 3d 20 28 75 6e 73 69 67 6e 65 64 20 69 6e  e = (unsigned in
8170: 74 29 73 71 6c 69 74 65 33 5f 76 61 6c 75 65 5f  t)sqlite3_value_
8180: 69 6e 74 28 70 56 61 6c 29 3b 0a 20 20 7d 65 6c  int(pVal);.  }el
8190: 73 65 7b 0a 20 20 20 20 63 6f 6e 73 74 20 63 68  se{.    const ch
81a0: 61 72 20 7a 54 65 6d 70 6c 61 74 65 5b 31 31 5d  ar zTemplate[11]
81b0: 20 3d 20 22 2d 72 77 78 72 77 78 72 77 78 22 3b   = "-rwxrwxrwx";
81c0: 0a 20 20 20 20 69 6e 74 20 69 3b 0a 20 20 20 20  .    int i;.    
81d0: 69 66 28 20 73 74 72 6c 65 6e 28 7a 29 21 3d 31  if( strlen(z)!=1
81e0: 30 20 29 20 67 6f 74 6f 20 70 61 72 73 65 5f 65  0 ) goto parse_e
81f0: 72 72 6f 72 3b 0a 20 20 20 20 73 77 69 74 63 68  rror;.    switch
8200: 28 20 7a 5b 30 5d 20 29 7b 0a 20 20 20 20 20 20  ( z[0] ){.      
8210: 63 61 73 65 20 27 2d 27 3a 20 6d 6f 64 65 20 7c  case '-': mode |
8220: 3d 20 53 5f 49 46 52 45 47 3b 20 62 72 65 61 6b  = S_IFREG; break
8230: 3b 0a 20 20 20 20 20 20 63 61 73 65 20 27 64 27  ;.      case 'd'
8240: 3a 20 6d 6f 64 65 20 7c 3d 20 53 5f 49 46 44 49  : mode |= S_IFDI
8250: 52 3b 20 62 72 65 61 6b 3b 0a 23 69 66 20 21 64  R; break;.#if !d
8260: 65 66 69 6e 65 64 28 5f 57 49 4e 33 32 29 20 26  efined(_WIN32) &
8270: 26 20 21 64 65 66 69 6e 65 64 28 57 49 4e 33 32  & !defined(WIN32
8280: 29 0a 20 20 20 20 20 20 63 61 73 65 20 27 6c 27  ).      case 'l'
8290: 3a 20 6d 6f 64 65 20 7c 3d 20 53 5f 49 46 4c 4e  : mode |= S_IFLN
82a0: 4b 3b 20 62 72 65 61 6b 3b 0a 23 65 6e 64 69 66  K; break;.#endif
82b0: 0a 20 20 20 20 20 20 64 65 66 61 75 6c 74 3a 20  .      default: 
82c0: 67 6f 74 6f 20 70 61 72 73 65 5f 65 72 72 6f 72  goto parse_error
82d0: 3b 0a 20 20 20 20 7d 0a 20 20 20 20 66 6f 72 28  ;.    }.    for(
82e0: 69 3d 31 3b 20 69 3c 31 30 3b 20 69 2b 2b 29 7b  i=1; i<10; i++){
82f0: 0a 20 20 20 20 20 20 69 66 28 20 7a 5b 69 5d 3d  .      if( z[i]=
8300: 3d 7a 54 65 6d 70 6c 61 74 65 5b 69 5d 20 29 20  =zTemplate[i] ) 
8310: 6d 6f 64 65 20 7c 3d 20 31 20 3c 3c 20 28 39 2d  mode |= 1 << (9-
8320: 69 29 3b 0a 20 20 20 20 20 20 65 6c 73 65 20 69  i);.      else i
8330: 66 28 20 7a 5b 69 5d 21 3d 27 2d 27 20 29 20 67  f( z[i]!='-' ) g
8340: 6f 74 6f 20 70 61 72 73 65 5f 65 72 72 6f 72 3b  oto parse_error;
8350: 0a 20 20 20 20 7d 0a 20 20 7d 0a 20 20 2a 70 4d  .    }.  }.  *pM
8360: 6f 64 65 20 3d 20 6d 6f 64 65 3b 0a 20 20 72 65  ode = mode;.  re
8370: 74 75 72 6e 20 53 51 4c 49 54 45 5f 4f 4b 3b 0a  turn SQLITE_OK;.
8380: 0a 20 70 61 72 73 65 5f 65 72 72 6f 72 3a 0a 20  . parse_error:. 
8390: 20 70 54 61 62 2d 3e 62 61 73 65 2e 7a 45 72 72   pTab->base.zErr
83a0: 4d 73 67 20 3d 20 73 71 6c 69 74 65 33 5f 6d 70  Msg = sqlite3_mp
83b0: 72 69 6e 74 66 28 22 7a 69 70 66 69 6c 65 3a 20  rintf("zipfile: 
83c0: 70 61 72 73 65 20 65 72 72 6f 72 20 69 6e 20 6d  parse error in m
83d0: 6f 64 65 3a 20 25 73 22 2c 20 7a 29 3b 0a 20 20  ode: %s", z);.  
83e0: 72 65 74 75 72 6e 20 53 51 4c 49 54 45 5f 45 52  return SQLITE_ER
83f0: 52 4f 52 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 42 6f  ROR;.}../*.** Bo
8400: 74 68 20 28 63 6f 6e 73 74 20 63 68 61 72 2a 29  th (const char*)
8410: 20 61 72 67 75 6d 65 6e 74 73 20 70 6f 69 6e 74   arguments point
8420: 20 74 6f 20 6e 75 6c 2d 74 65 72 6d 69 6e 61 74   to nul-terminat
8430: 65 64 20 73 74 72 69 6e 67 73 2e 20 41 72 67 75  ed strings. Argu
8440: 6d 65 6e 74 0a 2a 2a 20 6e 42 20 69 73 20 74 68  ment.** nB is th
8450: 65 20 76 61 6c 75 65 20 6f 66 20 73 74 72 6c 65  e value of strle
8460: 6e 28 7a 42 29 2e 20 54 68 69 73 20 66 75 6e 63  n(zB). This func
8470: 74 69 6f 6e 20 72 65 74 75 72 6e 73 20 30 20 69  tion returns 0 i
8480: 66 20 74 68 65 20 73 74 72 69 6e 67 73 20 61 72  f the strings ar
8490: 65 0a 2a 2a 20 69 64 65 6e 74 69 63 61 6c 2c 20  e.** identical, 
84a0: 69 67 6e 6f 72 69 6e 67 20 61 6e 79 20 74 72 61  ignoring any tra
84b0: 69 6c 69 6e 67 20 27 2f 27 20 63 68 61 72 61 63  iling '/' charac
84c0: 74 65 72 20 69 6e 20 65 69 74 68 65 72 20 70 61  ter in either pa
84d0: 74 68 2e 20 20 2a 2f 0a 73 74 61 74 69 63 20 69  th.  */.static i
84e0: 6e 74 20 7a 69 70 66 69 6c 65 43 6f 6d 70 61 72  nt zipfileCompar
84f0: 65 50 61 74 68 28 63 6f 6e 73 74 20 63 68 61 72  ePath(const char
8500: 20 2a 7a 41 2c 20 63 6f 6e 73 74 20 63 68 61 72   *zA, const char
8510: 20 2a 7a 42 2c 20 69 6e 74 20 6e 42 29 7b 0a 20   *zB, int nB){. 
8520: 20 69 6e 74 20 6e 41 20 3d 20 28 69 6e 74 29 73   int nA = (int)s
8530: 74 72 6c 65 6e 28 7a 41 29 3b 0a 20 20 69 66 28  trlen(zA);.  if(
8540: 20 7a 41 5b 6e 41 2d 31 5d 3d 3d 27 2f 27 20 29   zA[nA-1]=='/' )
8550: 20 6e 41 2d 2d 3b 0a 20 20 69 66 28 20 7a 42 5b   nA--;.  if( zB[
8560: 6e 42 2d 31 5d 3d 3d 27 2f 27 20 29 20 6e 42 2d  nB-1]=='/' ) nB-
8570: 2d 3b 0a 20 20 69 66 28 20 6e 41 3d 3d 6e 42 20  -;.  if( nA==nB 
8580: 26 26 20 6d 65 6d 63 6d 70 28 7a 41 2c 20 7a 42  && memcmp(zA, zB
8590: 2c 20 6e 41 29 3d 3d 30 20 29 20 72 65 74 75 72  , nA)==0 ) retur
85a0: 6e 20 30 3b 0a 20 20 72 65 74 75 72 6e 20 31 3b  n 0;.  return 1;
85b0: 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 78 55 70 64 61 74  .}../*.** xUpdat
85c0: 65 20 6d 65 74 68 6f 64 2e 0a 2a 2f 0a 73 74 61  e method..*/.sta
85d0: 74 69 63 20 69 6e 74 20 7a 69 70 66 69 6c 65 55  tic int zipfileU
85e0: 70 64 61 74 65 28 0a 20 20 73 71 6c 69 74 65 33  pdate(.  sqlite3
85f0: 5f 76 74 61 62 20 2a 70 56 74 61 62 2c 20 0a 20  _vtab *pVtab, . 
8600: 20 69 6e 74 20 6e 56 61 6c 2c 20 0a 20 20 73 71   int nVal, .  sq
8610: 6c 69 74 65 33 5f 76 61 6c 75 65 20 2a 2a 61 70  lite3_value **ap
8620: 56 61 6c 2c 20 0a 20 20 73 71 6c 69 74 65 5f 69  Val, .  sqlite_i
8630: 6e 74 36 34 20 2a 70 52 6f 77 69 64 0a 29 7b 0a  nt64 *pRowid.){.
8640: 20 20 5a 69 70 66 69 6c 65 54 61 62 20 2a 70 54    ZipfileTab *pT
8650: 61 62 20 3d 20 28 5a 69 70 66 69 6c 65 54 61 62  ab = (ZipfileTab
8660: 2a 29 70 56 74 61 62 3b 0a 20 20 69 6e 74 20 72  *)pVtab;.  int r
8670: 63 20 3d 20 53 51 4c 49 54 45 5f 4f 4b 3b 20 20  c = SQLITE_OK;  
8680: 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 52 65             /* Re
8690: 74 75 72 6e 20 43 6f 64 65 20 2a 2f 0a 20 20 5a  turn Code */.  Z
86a0: 69 70 66 69 6c 65 45 6e 74 72 79 20 2a 70 4e 65  ipfileEntry *pNe
86b0: 77 20 3d 20 30 3b 20 20 20 20 20 20 20 20 20 2f  w = 0;         /
86c0: 2a 20 4e 65 77 20 69 6e 2d 6d 65 6d 6f 72 79 20  * New in-memory 
86d0: 43 44 53 20 65 6e 74 72 79 20 2a 2f 0a 0a 20 20  CDS entry */..  
86e0: 75 33 32 20 6d 6f 64 65 20 3d 20 30 3b 20 20 20  u32 mode = 0;   
86f0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
8700: 2f 2a 20 4d 6f 64 65 20 66 6f 72 20 6e 65 77 20  /* Mode for new 
8710: 65 6e 74 72 79 20 2a 2f 0a 20 20 69 36 34 20 6d  entry */.  i64 m
8720: 54 69 6d 65 20 3d 20 30 3b 20 20 20 20 20 20 20  Time = 0;       
8730: 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 4d 6f             /* Mo
8740: 64 69 66 69 63 61 74 69 6f 6e 20 74 69 6d 65 20  dification time 
8750: 66 6f 72 20 6e 65 77 20 65 6e 74 72 79 20 2a 2f  for new entry */
8760: 0a 20 20 69 36 34 20 73 7a 20 3d 20 30 3b 20 20  .  i64 sz = 0;  
8770: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
8780: 20 20 20 2f 2a 20 55 6e 63 6f 6d 70 72 65 73 73     /* Uncompress
8790: 65 64 20 73 69 7a 65 20 2a 2f 0a 20 20 63 6f 6e  ed size */.  con
87a0: 73 74 20 63 68 61 72 20 2a 7a 50 61 74 68 20 3d  st char *zPath =
87b0: 20 30 3b 20 20 20 20 20 20 20 20 20 20 2f 2a 20   0;          /* 
87c0: 50 61 74 68 20 66 6f 72 20 6e 65 77 20 65 6e 74  Path for new ent
87d0: 72 79 20 2a 2f 0a 20 20 69 6e 74 20 6e 50 61 74  ry */.  int nPat
87e0: 68 20 3d 20 30 3b 20 20 20 20 20 20 20 20 20 20  h = 0;          
87f0: 20 20 20 20 20 20 20 20 2f 2a 20 73 74 72 6c 65          /* strle
8800: 6e 28 7a 50 61 74 68 29 20 2a 2f 0a 20 20 63 6f  n(zPath) */.  co
8810: 6e 73 74 20 75 38 20 2a 70 44 61 74 61 20 3d 20  nst u8 *pData = 
8820: 30 3b 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a  0;            /*
8830: 20 50 6f 69 6e 74 65 72 20 74 6f 20 62 75 66 66   Pointer to buff
8840: 65 72 20 63 6f 6e 74 61 69 6e 69 6e 67 20 63 6f  er containing co
8850: 6e 74 65 6e 74 20 2a 2f 0a 20 20 69 6e 74 20 6e  ntent */.  int n
8860: 44 61 74 61 20 3d 20 30 3b 20 20 20 20 20 20 20  Data = 0;       
8870: 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 53 69             /* Si
8880: 7a 65 20 6f 66 20 70 44 61 74 61 20 62 75 66 66  ze of pData buff
8890: 65 72 20 69 6e 20 62 79 74 65 73 20 2a 2f 0a 20  er in bytes */. 
88a0: 20 69 6e 74 20 69 4d 65 74 68 6f 64 20 3d 20 30   int iMethod = 0
88b0: 3b 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ;               
88c0: 20 2f 2a 20 43 6f 6d 70 72 65 73 73 69 6f 6e 20   /* Compression 
88d0: 6d 65 74 68 6f 64 20 66 6f 72 20 6e 65 77 20 65  method for new e
88e0: 6e 74 72 79 20 2a 2f 0a 20 20 75 38 20 2a 70 46  ntry */.  u8 *pF
88f0: 72 65 65 20 3d 20 30 3b 20 20 20 20 20 20 20 20  ree = 0;        
8900: 20 20 20 20 20 20 20 20 20 20 2f 2a 20 46 72 65            /* Fre
8910: 65 20 74 68 69 73 20 2a 2f 0a 20 20 63 68 61 72  e this */.  char
8920: 20 2a 7a 46 72 65 65 20 3d 20 30 3b 20 20 20 20   *zFree = 0;    
8930: 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 41              /* A
8940: 6c 73 6f 20 66 72 65 65 20 74 68 69 73 20 2a 2f  lso free this */
8950: 0a 20 20 5a 69 70 66 69 6c 65 43 44 53 20 63 64  .  ZipfileCDS cd
8960: 73 3b 20 20 20 20 20 20 20 20 20 20 20 20 20 20  s;              
8970: 20 20 20 2f 2a 20 4e 65 77 20 43 65 6e 74 72 61     /* New Centra
8980: 6c 20 44 69 72 65 63 74 6f 72 79 20 53 74 72 75  l Directory Stru
8990: 63 74 75 72 65 20 65 6e 74 72 79 20 2a 2f 0a 0a  cture entry */..
89a0: 20 20 69 6e 74 20 62 49 73 44 69 72 20 3d 20 30    int bIsDir = 0
89b0: 3b 0a 0a 20 20 69 6e 74 20 6d 4e 75 6c 6c 3b 0a  ;..  int mNull;.
89c0: 0a 20 20 61 73 73 65 72 74 28 20 70 54 61 62 2d  .  assert( pTab-
89d0: 3e 7a 46 69 6c 65 20 29 3b 0a 20 20 61 73 73 65  >zFile );.  asse
89e0: 72 74 28 20 70 54 61 62 2d 3e 70 57 72 69 74 65  rt( pTab->pWrite
89f0: 46 64 20 29 3b 0a 0a 20 20 69 66 28 20 73 71 6c  Fd );..  if( sql
8a00: 69 74 65 33 5f 76 61 6c 75 65 5f 74 79 70 65 28  ite3_value_type(
8a10: 61 70 56 61 6c 5b 30 5d 29 21 3d 53 51 4c 49 54  apVal[0])!=SQLIT
8a20: 45 5f 4e 55 4c 4c 20 29 7b 0a 20 20 20 20 69 66  E_NULL ){.    if
8a30: 28 20 6e 56 61 6c 3e 31 20 29 7b 0a 20 20 20 20  ( nVal>1 ){.    
8a40: 20 20 72 65 74 75 72 6e 20 53 51 4c 49 54 45 5f    return SQLITE_
8a50: 43 4f 4e 53 54 52 41 49 4e 54 3b 0a 20 20 20 20  CONSTRAINT;.    
8a60: 7d 65 6c 73 65 7b 0a 20 20 20 20 20 20 63 6f 6e  }else{.      con
8a70: 73 74 20 63 68 61 72 20 2a 7a 44 65 6c 65 74 65  st char *zDelete
8a80: 20 3d 20 28 63 6f 6e 73 74 20 63 68 61 72 2a 29   = (const char*)
8a90: 73 71 6c 69 74 65 33 5f 76 61 6c 75 65 5f 74 65  sqlite3_value_te
8aa0: 78 74 28 61 70 56 61 6c 5b 30 5d 29 3b 0a 20 20  xt(apVal[0]);.  
8ab0: 20 20 20 20 69 6e 74 20 6e 44 65 6c 65 74 65 20      int nDelete 
8ac0: 3d 20 73 74 72 6c 65 6e 28 7a 44 65 6c 65 74 65  = strlen(zDelete
8ad0: 29 3b 0a 20 20 20 20 20 20 5a 69 70 66 69 6c 65  );.      Zipfile
8ae0: 45 6e 74 72 79 20 2a 70 3b 0a 20 20 20 20 20 20  Entry *p;.      
8af0: 66 6f 72 28 70 3d 70 54 61 62 2d 3e 70 46 69 72  for(p=pTab->pFir
8b00: 73 74 45 6e 74 72 79 3b 20 70 3b 20 70 3d 70 2d  stEntry; p; p=p-
8b10: 3e 70 4e 65 78 74 29 7b 0a 20 20 20 20 20 20 20  >pNext){.       
8b20: 20 69 66 28 20 7a 69 70 66 69 6c 65 43 6f 6d 70   if( zipfileComp
8b30: 61 72 65 50 61 74 68 28 70 2d 3e 7a 50 61 74 68  arePath(p->zPath
8b40: 2c 20 7a 44 65 6c 65 74 65 2c 20 6e 44 65 6c 65  , zDelete, nDele
8b50: 74 65 29 3d 3d 30 20 29 7b 0a 20 20 20 20 20 20  te)==0 ){.      
8b60: 20 20 20 20 70 2d 3e 62 44 65 6c 65 74 65 64 20      p->bDeleted 
8b70: 3d 20 31 3b 0a 20 20 20 20 20 20 20 20 20 20 62  = 1;.          b
8b80: 72 65 61 6b 3b 0a 20 20 20 20 20 20 20 20 7d 0a  reak;.        }.
8b90: 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 72 65        }.      re
8ba0: 74 75 72 6e 20 53 51 4c 49 54 45 5f 4f 4b 3b 0a  turn SQLITE_OK;.
8bb0: 20 20 20 20 7d 0a 20 20 7d 0a 0a 20 20 6d 4e 75      }.  }..  mNu
8bc0: 6c 6c 20 3d 20 28 73 71 6c 69 74 65 33 5f 76 61  ll = (sqlite3_va
8bd0: 6c 75 65 5f 74 79 70 65 28 61 70 56 61 6c 5b 35  lue_type(apVal[5
8be0: 5d 29 3d 3d 53 51 4c 49 54 45 5f 4e 55 4c 4c 20  ])==SQLITE_NULL 
8bf0: 3f 20 30 78 30 20 3a 20 30 78 38 29 20 20 2f 2a  ? 0x0 : 0x8)  /*
8c00: 20 73 7a 20 2a 2f 0a 20 20 20 20 20 20 20 20 2b   sz */.        +
8c10: 20 28 73 71 6c 69 74 65 33 5f 76 61 6c 75 65 5f   (sqlite3_value_
8c20: 74 79 70 65 28 61 70 56 61 6c 5b 36 5d 29 3d 3d  type(apVal[6])==
8c30: 53 51 4c 49 54 45 5f 4e 55 4c 4c 20 3f 20 30 78  SQLITE_NULL ? 0x
8c40: 30 20 3a 20 30 78 34 29 20 20 2f 2a 20 72 61 77  0 : 0x4)  /* raw
8c50: 64 61 74 61 20 2a 2f 0a 20 20 20 20 20 20 20 20  data */.        
8c60: 2b 20 28 73 71 6c 69 74 65 33 5f 76 61 6c 75 65  + (sqlite3_value
8c70: 5f 74 79 70 65 28 61 70 56 61 6c 5b 37 5d 29 3d  _type(apVal[7])=
8c80: 3d 53 51 4c 49 54 45 5f 4e 55 4c 4c 20 3f 20 30  =SQLITE_NULL ? 0
8c90: 78 30 20 3a 20 30 78 32 29 20 20 2f 2a 20 64 61  x0 : 0x2)  /* da
8ca0: 74 61 20 2a 2f 0a 20 20 20 20 20 20 20 20 2b 20  ta */.        + 
8cb0: 28 73 71 6c 69 74 65 33 5f 76 61 6c 75 65 5f 74  (sqlite3_value_t
8cc0: 79 70 65 28 61 70 56 61 6c 5b 38 5d 29 3d 3d 53  ype(apVal[8])==S
8cd0: 51 4c 49 54 45 5f 4e 55 4c 4c 20 3f 20 30 78 30  QLITE_NULL ? 0x0
8ce0: 20 3a 20 30 78 31 29 3b 20 2f 2a 20 6d 65 74 68   : 0x1); /* meth
8cf0: 6f 64 20 2a 2f 0a 20 20 69 66 28 20 6d 4e 75 6c  od */.  if( mNul
8d00: 6c 3d 3d 30 78 30 30 20 29 7b 20 20 20 20 20 0a  l==0x00 ){     .
8d10: 20 20 20 20 2f 2a 20 41 6c 6c 20 66 6f 75 72 20      /* All four 
8d20: 61 72 65 20 4e 55 4c 4c 20 2d 20 74 68 69 73 20  are NULL - this 
8d30: 6d 75 73 74 20 62 65 20 61 20 64 69 72 65 63 74  must be a direct
8d40: 6f 72 79 20 2a 2f 0a 20 20 20 20 62 49 73 44 69  ory */.    bIsDi
8d50: 72 20 3d 20 31 3b 0a 20 20 7d 0a 20 20 65 6c 73  r = 1;.  }.  els
8d60: 65 20 69 66 28 20 6d 4e 75 6c 6c 3d 3d 30 78 32  e if( mNull==0x2
8d70: 20 7c 7c 20 6d 4e 75 6c 6c 3d 3d 30 78 33 20 29   || mNull==0x3 )
8d80: 7b 0a 20 20 20 20 2f 2a 20 56 61 6c 75 65 20 73  {.    /* Value s
8d90: 70 65 63 69 66 69 65 64 20 66 6f 72 20 22 64 61  pecified for "da
8da0: 74 61 22 2c 20 61 6e 64 20 70 6f 73 73 69 62 6c  ta", and possibl
8db0: 79 20 22 6d 65 74 68 6f 64 22 2e 20 54 68 69 73  y "method". This
8dc0: 20 6d 75 73 74 20 62 65 0a 20 20 20 20 2a 2a 20   must be.    ** 
8dd0: 61 20 72 65 67 75 6c 61 72 20 66 69 6c 65 20 6f  a regular file o
8de0: 72 20 61 20 73 79 6d 6c 69 6e 6b 2e 20 2a 2f 0a  r a symlink. */.
8df0: 20 20 20 20 63 6f 6e 73 74 20 75 38 20 2a 61 49      const u8 *aI
8e00: 6e 20 3d 20 73 71 6c 69 74 65 33 5f 76 61 6c 75  n = sqlite3_valu
8e10: 65 5f 62 6c 6f 62 28 61 70 56 61 6c 5b 37 5d 29  e_blob(apVal[7])
8e20: 3b 0a 20 20 20 20 69 6e 74 20 6e 49 6e 20 3d 20  ;.    int nIn = 
8e30: 73 71 6c 69 74 65 33 5f 76 61 6c 75 65 5f 62 79  sqlite3_value_by
8e40: 74 65 73 28 61 70 56 61 6c 5b 37 5d 29 3b 0a 20  tes(apVal[7]);. 
8e50: 20 20 20 69 6e 74 20 62 41 75 74 6f 20 3d 20 73     int bAuto = s
8e60: 71 6c 69 74 65 33 5f 76 61 6c 75 65 5f 74 79 70  qlite3_value_typ
8e70: 65 28 61 70 56 61 6c 5b 38 5d 29 3d 3d 53 51 4c  e(apVal[8])==SQL
8e80: 49 54 45 5f 4e 55 4c 4c 3b 0a 20 20 20 20 0a 20  ITE_NULL;.    . 
8e90: 20 20 20 69 4d 65 74 68 6f 64 20 3d 20 73 71 6c     iMethod = sql
8ea0: 69 74 65 33 5f 76 61 6c 75 65 5f 69 6e 74 28 61  ite3_value_int(a
8eb0: 70 56 61 6c 5b 38 5d 29 3b 0a 20 20 20 20 73 7a  pVal[8]);.    sz
8ec0: 20 3d 20 6e 49 6e 3b 0a 20 20 20 20 69 66 28 20   = nIn;.    if( 
8ed0: 69 4d 65 74 68 6f 64 21 3d 30 20 26 26 20 69 4d  iMethod!=0 && iM
8ee0: 65 74 68 6f 64 21 3d 38 20 29 7b 0a 20 20 20 20  ethod!=8 ){.    
8ef0: 20 20 72 63 20 3d 20 53 51 4c 49 54 45 5f 43 4f    rc = SQLITE_CO
8f00: 4e 53 54 52 41 49 4e 54 3b 0a 20 20 20 20 7d 65  NSTRAINT;.    }e
8f10: 6c 73 65 20 69 66 28 20 62 41 75 74 6f 20 7c 7c  lse if( bAuto ||
8f20: 20 69 4d 65 74 68 6f 64 20 29 7b 0a 20 20 20 20   iMethod ){.    
8f30: 20 20 72 63 20 3d 20 7a 69 70 66 69 6c 65 44 65    rc = zipfileDe
8f40: 66 6c 61 74 65 28 70 54 61 62 2c 20 61 49 6e 2c  flate(pTab, aIn,
8f50: 20 6e 49 6e 2c 20 26 70 46 72 65 65 2c 20 26 6e   nIn, &pFree, &n
8f60: 44 61 74 61 29 3b 0a 20 20 20 20 20 20 69 66 28  Data);.      if(
8f70: 20 72 63 3d 3d 53 51 4c 49 54 45 5f 4f 4b 20 29   rc==SQLITE_OK )
8f80: 7b 0a 20 20 20 20 20 20 20 20 69 66 28 20 69 4d  {.        if( iM
8f90: 65 74 68 6f 64 20 7c 7c 20 6e 44 61 74 61 3c 6e  ethod || nData<n
8fa0: 49 6e 20 29 7b 0a 20 20 20 20 20 20 20 20 20 20  In ){.          
8fb0: 69 4d 65 74 68 6f 64 20 3d 20 38 3b 0a 20 20 20  iMethod = 8;.   
8fc0: 20 20 20 20 20 20 20 70 44 61 74 61 20 3d 20 70         pData = p
8fd0: 46 72 65 65 3b 0a 20 20 20 20 20 20 20 20 7d 65  Free;.        }e
8fe0: 6c 73 65 7b 0a 20 20 20 20 20 20 20 20 20 20 70  lse{.          p
8ff0: 44 61 74 61 20 3d 20 61 49 6e 3b 0a 20 20 20 20  Data = aIn;.    
9000: 20 20 20 20 20 20 6e 44 61 74 61 20 3d 20 6e 49        nData = nI
9010: 6e 3b 0a 20 20 20 20 20 20 20 20 7d 0a 20 20 20  n;.        }.   
9020: 20 20 20 7d 0a 20 20 20 20 7d 0a 20 20 7d 0a 20     }.    }.  }. 
9030: 20 65 6c 73 65 20 69 66 28 20 6d 4e 75 6c 6c 3d   else if( mNull=
9040: 3d 30 78 30 44 20 29 7b 0a 20 20 20 20 2f 2a 20  =0x0D ){.    /* 
9050: 56 61 6c 75 65 73 20 73 70 65 63 69 66 69 65 64  Values specified
9060: 20 66 6f 72 20 22 73 7a 22 2c 20 22 72 61 77 64   for "sz", "rawd
9070: 61 74 61 22 20 61 6e 64 20 22 6d 65 74 68 6f 64  ata" and "method
9080: 22 2e 20 49 6e 20 6f 74 68 65 72 20 77 6f 72 64  ". In other word
9090: 73 2c 0a 20 20 20 20 2a 2a 20 70 72 65 2d 63 6f  s,.    ** pre-co
90a0: 6d 70 72 65 73 73 65 64 20 64 61 74 61 20 69 73  mpressed data is
90b0: 20 62 65 69 6e 67 20 69 6e 73 65 72 74 65 64 2e   being inserted.
90c0: 20 20 2a 2f 0a 20 20 20 20 70 44 61 74 61 20 3d    */.    pData =
90d0: 20 73 71 6c 69 74 65 33 5f 76 61 6c 75 65 5f 62   sqlite3_value_b
90e0: 6c 6f 62 28 61 70 56 61 6c 5b 36 5d 29 3b 0a 20  lob(apVal[6]);. 
90f0: 20 20 20 6e 44 61 74 61 20 3d 20 73 71 6c 69 74     nData = sqlit
9100: 65 33 5f 76 61 6c 75 65 5f 62 79 74 65 73 28 61  e3_value_bytes(a
9110: 70 56 61 6c 5b 36 5d 29 3b 0a 20 20 20 20 73 7a  pVal[6]);.    sz
9120: 20 3d 20 73 71 6c 69 74 65 33 5f 76 61 6c 75 65   = sqlite3_value
9130: 5f 69 6e 74 28 61 70 56 61 6c 5b 35 5d 29 3b 0a  _int(apVal[5]);.
9140: 20 20 20 20 69 4d 65 74 68 6f 64 20 3d 20 73 71      iMethod = sq
9150: 6c 69 74 65 33 5f 76 61 6c 75 65 5f 69 6e 74 28  lite3_value_int(
9160: 61 70 56 61 6c 5b 38 5d 29 3b 0a 20 20 20 20 69  apVal[8]);.    i
9170: 66 28 20 69 4d 65 74 68 6f 64 3c 30 20 7c 7c 20  f( iMethod<0 || 
9180: 69 4d 65 74 68 6f 64 3e 36 35 35 33 35 20 29 7b  iMethod>65535 ){
9190: 0a 20 20 20 20 20 20 70 54 61 62 2d 3e 62 61 73  .      pTab->bas
91a0: 65 2e 7a 45 72 72 4d 73 67 20 3d 20 73 71 6c 69  e.zErrMsg = sqli
91b0: 74 65 33 5f 6d 70 72 69 6e 74 66 28 0a 20 20 20  te3_mprintf(.   
91c0: 20 20 20 20 20 20 20 22 7a 69 70 66 69 6c 65 3a         "zipfile:
91d0: 20 69 6e 76 61 6c 69 64 20 63 6f 6d 70 72 65 73   invalid compres
91e0: 73 69 6f 6e 20 6d 65 74 68 6f 64 3a 20 25 64 22  sion method: %d"
91f0: 2c 20 69 4d 65 74 68 6f 64 0a 20 20 20 20 20 20  , iMethod.      
9200: 29 3b 0a 20 20 20 20 20 20 72 63 20 3d 20 53 51  );.      rc = SQ
9210: 4c 49 54 45 5f 45 52 52 4f 52 3b 0a 20 20 20 20  LITE_ERROR;.    
9220: 7d 0a 20 20 7d 0a 20 20 65 6c 73 65 7b 0a 20 20  }.  }.  else{.  
9230: 20 20 72 63 20 3d 20 53 51 4c 49 54 45 5f 43 4f    rc = SQLITE_CO
9240: 4e 53 54 52 41 49 4e 54 3b 0a 20 20 7d 0a 0a 20  NSTRAINT;.  }.. 
9250: 20 69 66 28 20 72 63 3d 3d 53 51 4c 49 54 45 5f   if( rc==SQLITE_
9260: 4f 4b 20 29 7b 0a 20 20 20 20 72 63 20 3d 20 7a  OK ){.    rc = z
9270: 69 70 66 69 6c 65 47 65 74 4d 6f 64 65 28 70 54  ipfileGetMode(pT
9280: 61 62 2c 20 61 70 56 61 6c 5b 33 5d 2c 20 0a 20  ab, apVal[3], . 
9290: 20 20 20 20 20 20 20 28 62 49 73 44 69 72 20 3f         (bIsDir ?
92a0: 20 28 53 5f 49 46 44 49 52 20 2b 20 30 37 35 35   (S_IFDIR + 0755
92b0: 29 20 3a 20 28 53 5f 49 46 52 45 47 20 2b 20 30  ) : (S_IFREG + 0
92c0: 36 34 34 29 29 2c 20 26 6d 6f 64 65 0a 20 20 20  644)), &mode.   
92d0: 20 29 3b 0a 20 20 20 20 69 66 28 20 72 63 3d 3d   );.    if( rc==
92e0: 53 51 4c 49 54 45 5f 4f 4b 20 26 26 20 28 62 49  SQLITE_OK && (bI
92f0: 73 44 69 72 20 3d 3d 20 28 28 6d 6f 64 65 20 26  sDir == ((mode &
9300: 20 53 5f 49 46 44 49 52 29 3d 3d 30 29 29 20 29   S_IFDIR)==0)) )
9310: 7b 0a 20 20 20 20 20 20 2f 2a 20 54 68 65 20 22  {.      /* The "
9320: 6d 6f 64 65 22 20 61 74 74 72 69 62 75 74 65 20  mode" attribute 
9330: 69 73 20 61 20 64 69 72 65 63 74 6f 72 79 2c 20  is a directory, 
9340: 62 75 74 20 64 61 74 61 20 68 61 73 20 62 65 65  but data has bee
9350: 6e 20 73 70 65 63 69 66 69 65 64 2e 0a 20 20 20  n specified..   
9360: 20 20 20 2a 2a 20 4f 72 20 76 69 63 65 2d 76 65     ** Or vice-ve
9370: 72 73 61 20 2d 20 6e 6f 20 64 61 74 61 20 62 75  rsa - no data bu
9380: 74 20 22 6d 6f 64 65 22 20 69 73 20 61 20 66 69  t "mode" is a fi
9390: 6c 65 20 6f 72 20 73 79 6d 6c 69 6e 6b 2e 20 20  le or symlink.  
93a0: 2a 2f 0a 20 20 20 20 20 20 72 63 20 3d 20 53 51  */.      rc = SQ
93b0: 4c 49 54 45 5f 43 4f 4e 53 54 52 41 49 4e 54 3b  LITE_CONSTRAINT;
93c0: 0a 20 20 20 20 7d 0a 20 20 7d 0a 0a 20 20 69 66  .    }.  }..  if
93d0: 28 20 72 63 3d 3d 53 51 4c 49 54 45 5f 4f 4b 20  ( rc==SQLITE_OK 
93e0: 29 7b 0a 20 20 20 20 7a 50 61 74 68 20 3d 20 28  ){.    zPath = (
93f0: 63 6f 6e 73 74 20 63 68 61 72 2a 29 73 71 6c 69  const char*)sqli
9400: 74 65 33 5f 76 61 6c 75 65 5f 74 65 78 74 28 61  te3_value_text(a
9410: 70 56 61 6c 5b 32 5d 29 3b 0a 20 20 20 20 6e 50  pVal[2]);.    nP
9420: 61 74 68 20 3d 20 28 69 6e 74 29 73 74 72 6c 65  ath = (int)strle
9430: 6e 28 7a 50 61 74 68 29 3b 0a 20 20 20 20 69 66  n(zPath);.    if
9440: 28 20 73 71 6c 69 74 65 33 5f 76 61 6c 75 65 5f  ( sqlite3_value_
9450: 74 79 70 65 28 61 70 56 61 6c 5b 34 5d 29 3d 3d  type(apVal[4])==
9460: 53 51 4c 49 54 45 5f 4e 55 4c 4c 20 29 7b 0a 20  SQLITE_NULL ){. 
9470: 20 20 20 20 20 6d 54 69 6d 65 20 3d 20 28 73 71       mTime = (sq
9480: 6c 69 74 65 33 5f 69 6e 74 36 34 29 74 69 6d 65  lite3_int64)time
9490: 28 30 29 3b 0a 20 20 20 20 7d 65 6c 73 65 7b 0a  (0);.    }else{.
94a0: 20 20 20 20 20 20 6d 54 69 6d 65 20 3d 20 73 71        mTime = sq
94b0: 6c 69 74 65 33 5f 76 61 6c 75 65 5f 69 6e 74 36  lite3_value_int6
94c0: 34 28 61 70 56 61 6c 5b 34 5d 29 3b 0a 20 20 20  4(apVal[4]);.   
94d0: 20 7d 0a 20 20 7d 0a 0a 20 20 69 66 28 20 72 63   }.  }..  if( rc
94e0: 3d 3d 53 51 4c 49 54 45 5f 4f 4b 20 26 26 20 62  ==SQLITE_OK && b
94f0: 49 73 44 69 72 20 29 7b 0a 20 20 20 20 2f 2a 20  IsDir ){.    /* 
9500: 46 6f 72 20 61 20 64 69 72 65 63 74 6f 72 79 2c  For a directory,
9510: 20 63 68 65 63 6b 20 74 68 61 74 20 74 68 65 20   check that the 
9520: 6c 61 73 74 20 63 68 61 72 61 63 74 65 72 20 69  last character i
9530: 6e 20 74 68 65 20 70 61 74 68 20 69 73 20 61 0a  n the path is a.
9540: 20 20 20 20 2a 2a 20 27 2f 27 2e 20 54 68 69 73      ** '/'. This
9550: 20 61 70 70 65 61 72 73 20 74 6f 20 62 65 20 72   appears to be r
9560: 65 71 75 69 72 65 64 20 66 6f 72 20 63 6f 6d 70  equired for comp
9570: 61 74 69 62 69 6c 69 74 79 20 77 69 74 68 20 69  atibility with i
9580: 6e 66 6f 2d 7a 69 70 0a 20 20 20 20 2a 2a 20 28  nfo-zip.    ** (
9590: 74 68 65 20 75 6e 7a 69 70 20 63 6f 6d 6d 61 6e  the unzip comman
95a0: 64 20 6f 6e 20 75 6e 69 78 29 2e 20 49 74 20 64  d on unix). It d
95b0: 6f 65 73 20 6e 6f 74 20 63 72 65 61 74 65 20 64  oes not create d
95c0: 69 72 65 63 74 6f 72 69 65 73 0a 20 20 20 20 2a  irectories.    *
95d0: 2a 20 6f 74 68 65 72 77 69 73 65 2e 20 20 2a 2f  * otherwise.  */
95e0: 0a 20 20 20 20 69 66 28 20 7a 50 61 74 68 5b 6e  .    if( zPath[n
95f0: 50 61 74 68 2d 31 5d 21 3d 27 2f 27 20 29 7b 0a  Path-1]!='/' ){.
9600: 20 20 20 20 20 20 7a 46 72 65 65 20 3d 20 73 71        zFree = sq
9610: 6c 69 74 65 33 5f 6d 70 72 69 6e 74 66 28 22 25  lite3_mprintf("%
9620: 73 2f 22 2c 20 7a 50 61 74 68 29 3b 0a 20 20 20  s/", zPath);.   
9630: 20 20 20 69 66 28 20 7a 46 72 65 65 3d 3d 30 20     if( zFree==0 
9640: 29 7b 20 72 63 20 3d 20 53 51 4c 49 54 45 5f 4e  ){ rc = SQLITE_N
9650: 4f 4d 45 4d 3b 20 7d 0a 20 20 20 20 20 20 7a 50  OMEM; }.      zP
9660: 61 74 68 20 3d 20 28 63 6f 6e 73 74 20 63 68 61  ath = (const cha
9670: 72 2a 29 7a 46 72 65 65 3b 0a 20 20 20 20 20 20  r*)zFree;.      
9680: 6e 50 61 74 68 2b 2b 3b 0a 20 20 20 20 7d 0a 20  nPath++;.    }. 
9690: 20 7d 0a 0a 20 20 2f 2a 20 43 68 65 63 6b 20 74   }..  /* Check t
96a0: 68 61 74 20 77 65 27 72 65 20 6e 6f 74 20 69 6e  hat we're not in
96b0: 73 65 72 74 69 6e 67 20 61 20 64 75 70 6c 69 63  serting a duplic
96c0: 61 74 65 20 65 6e 74 72 79 20 2a 2f 0a 20 20 69  ate entry */.  i
96d0: 66 28 20 72 63 3d 3d 53 51 4c 49 54 45 5f 4f 4b  f( rc==SQLITE_OK
96e0: 20 29 7b 0a 20 20 20 20 5a 69 70 66 69 6c 65 45   ){.    ZipfileE
96f0: 6e 74 72 79 20 2a 70 3b 0a 20 20 20 20 66 6f 72  ntry *p;.    for
9700: 28 70 3d 70 54 61 62 2d 3e 70 46 69 72 73 74 45  (p=pTab->pFirstE
9710: 6e 74 72 79 3b 20 70 3b 20 70 3d 70 2d 3e 70 4e  ntry; p; p=p->pN
9720: 65 78 74 29 7b 0a 20 20 20 20 20 20 69 66 28 20  ext){.      if( 
9730: 7a 69 70 66 69 6c 65 43 6f 6d 70 61 72 65 50 61  zipfileComparePa
9740: 74 68 28 70 2d 3e 7a 50 61 74 68 2c 20 7a 50 61  th(p->zPath, zPa
9750: 74 68 2c 20 6e 50 61 74 68 29 3d 3d 30 20 29 7b  th, nPath)==0 ){
9760: 0a 20 20 20 20 20 20 20 20 72 63 20 3d 20 53 51  .        rc = SQ
9770: 4c 49 54 45 5f 43 4f 4e 53 54 52 41 49 4e 54 3b  LITE_CONSTRAINT;
9780: 0a 20 20 20 20 20 20 20 20 62 72 65 61 6b 3b 0a  .        break;.
9790: 20 20 20 20 20 20 7d 0a 20 20 20 20 7d 0a 20 20        }.    }.  
97a0: 7d 0a 0a 20 20 69 66 28 20 72 63 3d 3d 53 51 4c  }..  if( rc==SQL
97b0: 49 54 45 5f 4f 4b 20 29 7b 0a 20 20 20 20 2f 2a  ITE_OK ){.    /*
97c0: 20 43 72 65 61 74 65 20 74 68 65 20 6e 65 77 20   Create the new 
97d0: 43 44 53 20 72 65 63 6f 72 64 2e 20 2a 2f 0a 20  CDS record. */. 
97e0: 20 20 20 6d 65 6d 73 65 74 28 26 63 64 73 2c 20     memset(&cds, 
97f0: 30 2c 20 73 69 7a 65 6f 66 28 63 64 73 29 29 3b  0, sizeof(cds));
9800: 0a 20 20 20 20 63 64 73 2e 69 56 65 72 73 69 6f  .    cds.iVersio
9810: 6e 4d 61 64 65 42 79 20 3d 20 5a 49 50 46 49 4c  nMadeBy = ZIPFIL
9820: 45 5f 4e 45 57 45 4e 54 52 59 5f 4d 41 44 45 42  E_NEWENTRY_MADEB
9830: 59 3b 0a 20 20 20 20 63 64 73 2e 69 56 65 72 73  Y;.    cds.iVers
9840: 69 6f 6e 45 78 74 72 61 63 74 20 3d 20 5a 49 50  ionExtract = ZIP
9850: 46 49 4c 45 5f 4e 45 57 45 4e 54 52 59 5f 52 45  FILE_NEWENTRY_RE
9860: 51 55 49 52 45 44 3b 0a 20 20 20 20 63 64 73 2e  QUIRED;.    cds.
9870: 66 6c 61 67 73 20 3d 20 5a 49 50 46 49 4c 45 5f  flags = ZIPFILE_
9880: 4e 45 57 45 4e 54 52 59 5f 46 4c 41 47 53 3b 0a  NEWENTRY_FLAGS;.
9890: 20 20 20 20 63 64 73 2e 69 43 6f 6d 70 72 65 73      cds.iCompres
98a0: 73 69 6f 6e 20 3d 20 28 75 31 36 29 69 4d 65 74  sion = (u16)iMet
98b0: 68 6f 64 3b 0a 20 20 20 20 7a 69 70 66 69 6c 65  hod;.    zipfile
98c0: 4d 74 69 6d 65 54 6f 44 6f 73 28 26 63 64 73 2c  MtimeToDos(&cds,
98d0: 20 28 75 33 32 29 6d 54 69 6d 65 29 3b 0a 20 20   (u32)mTime);.  
98e0: 20 20 63 64 73 2e 63 72 63 33 32 20 3d 20 63 72    cds.crc32 = cr
98f0: 63 33 32 28 30 2c 20 70 44 61 74 61 2c 20 6e 44  c32(0, pData, nD
9900: 61 74 61 29 3b 0a 20 20 20 20 63 64 73 2e 73 7a  ata);.    cds.sz
9910: 43 6f 6d 70 72 65 73 73 65 64 20 3d 20 6e 44 61  Compressed = nDa
9920: 74 61 3b 0a 20 20 20 20 63 64 73 2e 73 7a 55 6e  ta;.    cds.szUn
9930: 63 6f 6d 70 72 65 73 73 65 64 20 3d 20 28 75 33  compressed = (u3
9940: 32 29 73 7a 3b 0a 20 20 20 20 63 64 73 2e 69 45  2)sz;.    cds.iE
9950: 78 74 65 72 6e 61 6c 41 74 74 72 20 3d 20 28 6d  xternalAttr = (m
9960: 6f 64 65 3c 3c 31 36 29 3b 0a 20 20 20 20 63 64  ode<<16);.    cd
9970: 73 2e 69 4f 66 66 73 65 74 20 3d 20 28 75 33 32  s.iOffset = (u32
9980: 29 70 54 61 62 2d 3e 73 7a 43 75 72 72 65 6e 74  )pTab->szCurrent
9990: 3b 0a 20 20 20 20 70 4e 65 77 20 3d 20 7a 69 70  ;.    pNew = zip
99a0: 66 69 6c 65 4e 65 77 45 6e 74 72 79 28 26 63 64  fileNewEntry(&cd
99b0: 73 2c 20 7a 50 61 74 68 2c 20 6e 50 61 74 68 2c  s, zPath, nPath,
99c0: 20 28 75 33 32 29 6d 54 69 6d 65 29 3b 0a 20 20   (u32)mTime);.  
99d0: 20 20 69 66 28 20 70 4e 65 77 3d 3d 30 20 29 7b    if( pNew==0 ){
99e0: 0a 20 20 20 20 20 20 72 63 20 3d 20 53 51 4c 49  .      rc = SQLI
99f0: 54 45 5f 4e 4f 4d 45 4d 3b 0a 20 20 20 20 7d 65  TE_NOMEM;.    }e
9a00: 6c 73 65 7b 0a 20 20 20 20 20 20 7a 69 70 66 69  lse{.      zipfi
9a10: 6c 65 41 64 64 45 6e 74 72 79 28 70 54 61 62 2c  leAddEntry(pTab,
9a20: 20 70 4e 65 77 29 3b 0a 20 20 20 20 7d 0a 20 20   pNew);.    }.  
9a30: 7d 0a 0a 20 20 2f 2a 20 41 70 70 65 6e 64 20 74  }..  /* Append t
9a40: 68 65 20 6e 65 77 20 68 65 61 64 65 72 2b 66 69  he new header+fi
9a50: 6c 65 20 74 6f 20 74 68 65 20 61 72 63 68 69 76  le to the archiv
9a60: 65 20 2a 2f 0a 20 20 69 66 28 20 72 63 3d 3d 53  e */.  if( rc==S
9a70: 51 4c 49 54 45 5f 4f 4b 20 29 7b 0a 20 20 20 20  QLITE_OK ){.    
9a80: 72 63 20 3d 20 7a 69 70 66 69 6c 65 41 70 70 65  rc = zipfileAppe
9a90: 6e 64 45 6e 74 72 79 28 70 54 61 62 2c 20 26 63  ndEntry(pTab, &c
9aa0: 64 73 2c 20 7a 50 61 74 68 2c 20 6e 50 61 74 68  ds, zPath, nPath
9ab0: 2c 20 70 44 61 74 61 2c 20 6e 44 61 74 61 2c 20  , pData, nData, 
9ac0: 28 75 33 32 29 6d 54 69 6d 65 29 3b 0a 20 20 7d  (u32)mTime);.  }
9ad0: 0a 0a 20 20 73 71 6c 69 74 65 33 5f 66 72 65 65  ..  sqlite3_free
9ae0: 28 70 46 72 65 65 29 3b 0a 20 20 73 71 6c 69 74  (pFree);.  sqlit
9af0: 65 33 5f 66 72 65 65 28 7a 46 72 65 65 29 3b 0a  e3_free(zFree);.
9b00: 20 20 72 65 74 75 72 6e 20 72 63 3b 0a 7d 0a 0a    return rc;.}..
9b10: 73 74 61 74 69 63 20 69 6e 74 20 7a 69 70 66 69  static int zipfi
9b20: 6c 65 41 70 70 65 6e 64 45 4f 43 44 28 5a 69 70  leAppendEOCD(Zip
9b30: 66 69 6c 65 54 61 62 20 2a 70 54 61 62 2c 20 5a  fileTab *pTab, Z
9b40: 69 70 66 69 6c 65 45 4f 43 44 20 2a 70 29 7b 0a  ipfileEOCD *p){.
9b50: 20 20 75 38 20 2a 61 42 75 66 20 3d 20 70 54 61    u8 *aBuf = pTa
9b60: 62 2d 3e 61 42 75 66 66 65 72 3b 0a 0a 20 20 7a  b->aBuffer;..  z
9b70: 69 70 66 69 6c 65 57 72 69 74 65 33 32 28 61 42  ipfileWrite32(aB
9b80: 75 66 2c 20 5a 49 50 46 49 4c 45 5f 53 49 47 4e  uf, ZIPFILE_SIGN
9b90: 41 54 55 52 45 5f 45 4f 43 44 29 3b 0a 20 20 7a  ATURE_EOCD);.  z
9ba0: 69 70 66 69 6c 65 57 72 69 74 65 31 36 28 61 42  ipfileWrite16(aB
9bb0: 75 66 2c 20 70 2d 3e 69 44 69 73 6b 29 3b 0a 20  uf, p->iDisk);. 
9bc0: 20 7a 69 70 66 69 6c 65 57 72 69 74 65 31 36 28   zipfileWrite16(
9bd0: 61 42 75 66 2c 20 70 2d 3e 69 46 69 72 73 74 44  aBuf, p->iFirstD
9be0: 69 73 6b 29 3b 0a 20 20 7a 69 70 66 69 6c 65 57  isk);.  zipfileW
9bf0: 72 69 74 65 31 36 28 61 42 75 66 2c 20 70 2d 3e  rite16(aBuf, p->
9c00: 6e 45 6e 74 72 79 29 3b 0a 20 20 7a 69 70 66 69  nEntry);.  zipfi
9c10: 6c 65 57 72 69 74 65 31 36 28 61 42 75 66 2c 20  leWrite16(aBuf, 
9c20: 70 2d 3e 6e 45 6e 74 72 79 54 6f 74 61 6c 29 3b  p->nEntryTotal);
9c30: 0a 20 20 7a 69 70 66 69 6c 65 57 72 69 74 65 33  .  zipfileWrite3
9c40: 32 28 61 42 75 66 2c 20 70 2d 3e 6e 53 69 7a 65  2(aBuf, p->nSize
9c50: 29 3b 0a 20 20 7a 69 70 66 69 6c 65 57 72 69 74  );.  zipfileWrit
9c60: 65 33 32 28 61 42 75 66 2c 20 70 2d 3e 69 4f 66  e32(aBuf, p->iOf
9c70: 66 73 65 74 29 3b 0a 20 20 7a 69 70 66 69 6c 65  fset);.  zipfile
9c80: 57 72 69 74 65 31 36 28 61 42 75 66 2c 20 30 29  Write16(aBuf, 0)
9c90: 3b 20 20 20 20 20 20 20 20 2f 2a 20 53 69 7a 65  ;        /* Size
9ca0: 20 6f 66 20 74 72 61 69 6c 69 6e 67 20 63 6f 6d   of trailing com
9cb0: 6d 65 6e 74 20 69 6e 20 62 79 74 65 73 2a 2f 0a  ment in bytes*/.
9cc0: 0a 20 20 61 73 73 65 72 74 28 20 28 61 42 75 66  .  assert( (aBuf
9cd0: 2d 70 54 61 62 2d 3e 61 42 75 66 66 65 72 29 3d  -pTab->aBuffer)=
9ce0: 3d 32 32 20 29 3b 0a 20 20 72 65 74 75 72 6e 20  =22 );.  return 
9cf0: 7a 69 70 66 69 6c 65 41 70 70 65 6e 64 44 61 74  zipfileAppendDat
9d00: 61 28 70 54 61 62 2c 20 70 54 61 62 2d 3e 61 42  a(pTab, pTab->aB
9d10: 75 66 66 65 72 2c 20 28 69 6e 74 29 28 61 42 75  uffer, (int)(aBu
9d20: 66 20 2d 20 70 54 61 62 2d 3e 61 42 75 66 66 65  f - pTab->aBuffe
9d30: 72 29 29 3b 0a 7d 0a 0a 73 74 61 74 69 63 20 76  r));.}..static v
9d40: 6f 69 64 20 7a 69 70 66 69 6c 65 43 6c 65 61 6e  oid zipfileClean
9d50: 75 70 54 72 61 6e 73 61 63 74 69 6f 6e 28 5a 69  upTransaction(Zi
9d60: 70 66 69 6c 65 54 61 62 20 2a 70 54 61 62 29 7b  pfileTab *pTab){
9d70: 0a 20 20 5a 69 70 66 69 6c 65 45 6e 74 72 79 20  .  ZipfileEntry 
9d80: 2a 70 45 6e 74 72 79 3b 0a 20 20 5a 69 70 66 69  *pEntry;.  Zipfi
9d90: 6c 65 45 6e 74 72 79 20 2a 70 4e 65 78 74 3b 0a  leEntry *pNext;.
9da0: 0a 20 20 66 6f 72 28 70 45 6e 74 72 79 3d 70 54  .  for(pEntry=pT
9db0: 61 62 2d 3e 70 46 69 72 73 74 45 6e 74 72 79 3b  ab->pFirstEntry;
9dc0: 20 70 45 6e 74 72 79 3b 20 70 45 6e 74 72 79 3d   pEntry; pEntry=
9dd0: 70 4e 65 78 74 29 7b 0a 20 20 20 20 70 4e 65 78  pNext){.    pNex
9de0: 74 20 3d 20 70 45 6e 74 72 79 2d 3e 70 4e 65 78  t = pEntry->pNex
9df0: 74 3b 0a 20 20 20 20 73 71 6c 69 74 65 33 5f 66  t;.    sqlite3_f
9e00: 72 65 65 28 70 45 6e 74 72 79 29 3b 0a 20 20 7d  ree(pEntry);.  }
9e10: 0a 20 20 70 54 61 62 2d 3e 70 46 69 72 73 74 45  .  pTab->pFirstE
9e20: 6e 74 72 79 20 3d 20 30 3b 0a 20 20 70 54 61 62  ntry = 0;.  pTab
9e30: 2d 3e 70 4c 61 73 74 45 6e 74 72 79 20 3d 20 30  ->pLastEntry = 0
9e40: 3b 0a 20 20 66 63 6c 6f 73 65 28 70 54 61 62 2d  ;.  fclose(pTab-
9e50: 3e 70 57 72 69 74 65 46 64 29 3b 0a 20 20 70 54  >pWriteFd);.  pT
9e60: 61 62 2d 3e 70 57 72 69 74 65 46 64 20 3d 20 30  ab->pWriteFd = 0
9e70: 3b 0a 20 20 70 54 61 62 2d 3e 73 7a 43 75 72 72  ;.  pTab->szCurr
9e80: 65 6e 74 20 3d 20 30 3b 0a 20 20 70 54 61 62 2d  ent = 0;.  pTab-
9e90: 3e 73 7a 4f 72 69 67 20 3d 20 30 3b 0a 7d 0a 0a  >szOrig = 0;.}..
9ea0: 73 74 61 74 69 63 20 69 6e 74 20 7a 69 70 66 69  static int zipfi
9eb0: 6c 65 42 65 67 69 6e 28 73 71 6c 69 74 65 33 5f  leBegin(sqlite3_
9ec0: 76 74 61 62 20 2a 70 56 74 61 62 29 7b 0a 20 20  vtab *pVtab){.  
9ed0: 5a 69 70 66 69 6c 65 54 61 62 20 2a 70 54 61 62  ZipfileTab *pTab
9ee0: 20 3d 20 28 5a 69 70 66 69 6c 65 54 61 62 2a 29   = (ZipfileTab*)
9ef0: 70 56 74 61 62 3b 0a 20 20 69 6e 74 20 72 63 20  pVtab;.  int rc 
9f00: 3d 20 53 51 4c 49 54 45 5f 4f 4b 3b 0a 0a 20 20  = SQLITE_OK;..  
9f10: 61 73 73 65 72 74 28 20 70 54 61 62 2d 3e 70 57  assert( pTab->pW
9f20: 72 69 74 65 46 64 3d 3d 30 20 29 3b 0a 0a 20 20  riteFd==0 );..  
9f30: 2f 2a 20 54 68 69 73 20 74 61 62 6c 65 20 69 73  /* This table is
9f40: 20 6f 6e 6c 79 20 77 72 69 74 61 62 6c 65 20 69   only writable i
9f50: 66 20 61 20 64 65 66 61 75 6c 74 20 61 72 63 68  f a default arch
9f60: 69 76 65 20 70 61 74 68 20 77 61 73 20 73 70 65  ive path was spe
9f70: 63 69 66 69 65 64 20 0a 20 20 2a 2a 20 61 73 20  cified .  ** as 
9f80: 70 61 72 74 20 6f 66 20 74 68 65 20 43 52 45 41  part of the CREA
9f90: 54 45 20 56 49 52 54 55 41 4c 20 54 41 42 4c 45  TE VIRTUAL TABLE
9fa0: 20 73 74 61 74 65 6d 65 6e 74 2e 20 2a 2f 0a 20   statement. */. 
9fb0: 20 69 66 28 20 70 54 61 62 2d 3e 7a 46 69 6c 65   if( pTab->zFile
9fc0: 3d 3d 30 20 29 7b 0a 20 20 20 20 70 54 61 62 2d  ==0 ){.    pTab-
9fd0: 3e 62 61 73 65 2e 7a 45 72 72 4d 73 67 20 3d 20  >base.zErrMsg = 
9fe0: 73 71 6c 69 74 65 33 5f 6d 70 72 69 6e 74 66 28  sqlite3_mprintf(
9ff0: 0a 20 20 20 20 20 20 20 20 22 7a 69 70 66 69 6c  .        "zipfil
a000: 65 3a 20 77 72 69 74 69 6e 67 20 72 65 71 75 69  e: writing requi
a010: 72 65 73 20 61 20 64 65 66 61 75 6c 74 20 61 72  res a default ar
a020: 63 68 69 76 65 22 0a 20 20 20 20 29 3b 0a 20 20  chive".    );.  
a030: 20 20 72 65 74 75 72 6e 20 53 51 4c 49 54 45 5f    return SQLITE_
a040: 45 52 52 4f 52 3b 0a 20 20 7d 0a 0a 20 20 2f 2a  ERROR;.  }..  /*
a050: 20 4f 70 65 6e 20 61 20 77 72 69 74 65 20 66 64   Open a write fd
a060: 20 6f 6e 20 74 68 65 20 66 69 6c 65 2e 20 41 6c   on the file. Al
a070: 73 6f 20 6c 6f 61 64 20 74 68 65 20 65 6e 74 69  so load the enti
a080: 72 65 20 63 65 6e 74 72 61 6c 20 64 69 72 65 63  re central direc
a090: 74 6f 72 79 0a 20 20 2a 2a 20 73 74 72 75 63 74  tory.  ** struct
a0a0: 75 72 65 20 69 6e 74 6f 20 6d 65 6d 6f 72 79 2e  ure into memory.
a0b0: 20 44 75 72 69 6e 67 20 74 68 65 20 74 72 61 6e   During the tran
a0c0: 73 61 63 74 69 6f 6e 20 61 6e 79 20 6e 65 77 20  saction any new 
a0d0: 66 69 6c 65 20 64 61 74 61 20 69 73 20 0a 20 20  file data is .  
a0e0: 2a 2a 20 61 70 70 65 6e 64 65 64 20 74 6f 20 74  ** appended to t
a0f0: 68 65 20 61 72 63 68 69 76 65 20 66 69 6c 65 2c  he archive file,
a100: 20 62 75 74 20 74 68 65 20 63 65 6e 74 72 61 6c   but the central
a110: 20 64 69 72 65 63 74 6f 72 79 20 69 73 20 61 63   directory is ac
a120: 63 75 6d 75 6c 61 74 65 64 0a 20 20 2a 2a 20 69  cumulated.  ** i
a130: 6e 20 6d 61 69 6e 2d 6d 65 6d 6f 72 79 20 75 6e  n main-memory un
a140: 74 69 6c 20 74 68 65 20 74 72 61 6e 73 61 63 74  til the transact
a150: 69 6f 6e 20 69 73 20 63 6f 6d 6d 69 74 74 65 64  ion is committed
a160: 2e 20 20 2a 2f 0a 20 20 70 54 61 62 2d 3e 70 57  .  */.  pTab->pW
a170: 72 69 74 65 46 64 20 3d 20 66 6f 70 65 6e 28 70  riteFd = fopen(p
a180: 54 61 62 2d 3e 7a 46 69 6c 65 2c 20 22 61 62 2b  Tab->zFile, "ab+
a190: 22 29 3b 0a 20 20 69 66 28 20 70 54 61 62 2d 3e  ");.  if( pTab->
a1a0: 70 57 72 69 74 65 46 64 3d 3d 30 20 29 7b 0a 20  pWriteFd==0 ){. 
a1b0: 20 20 20 70 54 61 62 2d 3e 62 61 73 65 2e 7a 45     pTab->base.zE
a1c0: 72 72 4d 73 67 20 3d 20 73 71 6c 69 74 65 33 5f  rrMsg = sqlite3_
a1d0: 6d 70 72 69 6e 74 66 28 0a 20 20 20 20 20 20 20  mprintf(.       
a1e0: 20 22 7a 69 70 66 69 6c 65 3a 20 66 61 69 6c 65   "zipfile: faile
a1f0: 64 20 74 6f 20 6f 70 65 6e 20 66 69 6c 65 20 25  d to open file %
a200: 73 20 66 6f 72 20 77 72 69 74 69 6e 67 22 2c 20  s for writing", 
a210: 70 54 61 62 2d 3e 7a 46 69 6c 65 0a 20 20 20 20  pTab->zFile.    
a220: 29 3b 0a 20 20 20 20 72 63 20 3d 20 53 51 4c 49  );.    rc = SQLI
a230: 54 45 5f 45 52 52 4f 52 3b 0a 20 20 7d 65 6c 73  TE_ERROR;.  }els
a240: 65 7b 0a 20 20 20 20 66 73 65 65 6b 28 70 54 61  e{.    fseek(pTa
a250: 62 2d 3e 70 57 72 69 74 65 46 64 2c 20 30 2c 20  b->pWriteFd, 0, 
a260: 53 45 45 4b 5f 45 4e 44 29 3b 0a 20 20 20 20 70  SEEK_END);.    p
a270: 54 61 62 2d 3e 73 7a 43 75 72 72 65 6e 74 20 3d  Tab->szCurrent =
a280: 20 70 54 61 62 2d 3e 73 7a 4f 72 69 67 20 3d 20   pTab->szOrig = 
a290: 28 69 36 34 29 66 74 65 6c 6c 28 70 54 61 62 2d  (i64)ftell(pTab-
a2a0: 3e 70 57 72 69 74 65 46 64 29 3b 0a 20 20 20 20  >pWriteFd);.    
a2b0: 72 63 20 3d 20 7a 69 70 66 69 6c 65 4c 6f 61 64  rc = zipfileLoad
a2c0: 44 69 72 65 63 74 6f 72 79 28 70 54 61 62 29 3b  Directory(pTab);
a2d0: 0a 20 20 7d 0a 0a 20 20 69 66 28 20 72 63 21 3d  .  }..  if( rc!=
a2e0: 53 51 4c 49 54 45 5f 4f 4b 20 29 7b 0a 20 20 20  SQLITE_OK ){.   
a2f0: 20 7a 69 70 66 69 6c 65 43 6c 65 61 6e 75 70 54   zipfileCleanupT
a300: 72 61 6e 73 61 63 74 69 6f 6e 28 70 54 61 62 29  ransaction(pTab)
a310: 3b 0a 20 20 7d 0a 0a 20 20 72 65 74 75 72 6e 20  ;.  }..  return 
a320: 72 63 3b 0a 7d 0a 0a 73 74 61 74 69 63 20 69 6e  rc;.}..static in
a330: 74 20 7a 69 70 66 69 6c 65 43 6f 6d 6d 69 74 28  t zipfileCommit(
a340: 73 71 6c 69 74 65 33 5f 76 74 61 62 20 2a 70 56  sqlite3_vtab *pV
a350: 74 61 62 29 7b 0a 20 20 5a 69 70 66 69 6c 65 54  tab){.  ZipfileT
a360: 61 62 20 2a 70 54 61 62 20 3d 20 28 5a 69 70 66  ab *pTab = (Zipf
a370: 69 6c 65 54 61 62 2a 29 70 56 74 61 62 3b 0a 20  ileTab*)pVtab;. 
a380: 20 69 6e 74 20 72 63 20 3d 20 53 51 4c 49 54 45   int rc = SQLITE
a390: 5f 4f 4b 3b 0a 20 20 69 66 28 20 70 54 61 62 2d  _OK;.  if( pTab-
a3a0: 3e 70 57 72 69 74 65 46 64 20 29 7b 0a 20 20 20  >pWriteFd ){.   
a3b0: 20 69 36 34 20 69 4f 66 66 73 65 74 20 3d 20 70   i64 iOffset = p
a3c0: 54 61 62 2d 3e 73 7a 43 75 72 72 65 6e 74 3b 0a  Tab->szCurrent;.
a3d0: 20 20 20 20 5a 69 70 66 69 6c 65 45 6e 74 72 79      ZipfileEntry
a3e0: 20 2a 70 3b 0a 20 20 20 20 5a 69 70 66 69 6c 65   *p;.    Zipfile
a3f0: 45 4f 43 44 20 65 6f 63 64 3b 0a 20 20 20 20 69  EOCD eocd;.    i
a400: 6e 74 20 6e 45 6e 74 72 79 20 3d 20 30 3b 0a 0a  nt nEntry = 0;..
a410: 20 20 20 20 2f 2a 20 57 72 69 74 65 20 6f 75 74      /* Write out
a420: 20 61 6c 6c 20 75 6e 64 65 6c 65 74 65 64 20 65   all undeleted e
a430: 6e 74 72 69 65 73 20 2a 2f 0a 20 20 20 20 66 6f  ntries */.    fo
a440: 72 28 70 3d 70 54 61 62 2d 3e 70 46 69 72 73 74  r(p=pTab->pFirst
a450: 45 6e 74 72 79 3b 20 72 63 3d 3d 53 51 4c 49 54  Entry; rc==SQLIT
a460: 45 5f 4f 4b 20 26 26 20 70 3b 20 70 3d 70 2d 3e  E_OK && p; p=p->
a470: 70 4e 65 78 74 29 7b 0a 20 20 20 20 20 20 69 66  pNext){.      if
a480: 28 20 70 2d 3e 62 44 65 6c 65 74 65 64 20 29 20  ( p->bDeleted ) 
a490: 63 6f 6e 74 69 6e 75 65 3b 0a 20 20 20 20 20 20  continue;.      
a4a0: 72 63 20 3d 20 7a 69 70 66 69 6c 65 41 70 70 65  rc = zipfileAppe
a4b0: 6e 64 44 61 74 61 28 70 54 61 62 2c 20 70 2d 3e  ndData(pTab, p->
a4c0: 61 43 64 73 45 6e 74 72 79 2c 20 70 2d 3e 6e 43  aCdsEntry, p->nC
a4d0: 64 73 45 6e 74 72 79 29 3b 0a 20 20 20 20 20 20  dsEntry);.      
a4e0: 6e 45 6e 74 72 79 2b 2b 3b 0a 20 20 20 20 7d 0a  nEntry++;.    }.
a4f0: 0a 20 20 20 20 2f 2a 20 57 72 69 74 65 20 6f 75  .    /* Write ou
a500: 74 20 74 68 65 20 45 4f 43 44 20 72 65 63 6f 72  t the EOCD recor
a510: 64 20 2a 2f 0a 20 20 20 20 65 6f 63 64 2e 69 44  d */.    eocd.iD
a520: 69 73 6b 20 3d 20 30 3b 0a 20 20 20 20 65 6f 63  isk = 0;.    eoc
a530: 64 2e 69 46 69 72 73 74 44 69 73 6b 20 3d 20 30  d.iFirstDisk = 0
a540: 3b 0a 20 20 20 20 65 6f 63 64 2e 6e 45 6e 74 72  ;.    eocd.nEntr
a550: 79 20 3d 20 28 75 31 36 29 6e 45 6e 74 72 79 3b  y = (u16)nEntry;
a560: 0a 20 20 20 20 65 6f 63 64 2e 6e 45 6e 74 72 79  .    eocd.nEntry
a570: 54 6f 74 61 6c 20 3d 20 28 75 31 36 29 6e 45 6e  Total = (u16)nEn
a580: 74 72 79 3b 0a 20 20 20 20 65 6f 63 64 2e 6e 53  try;.    eocd.nS
a590: 69 7a 65 20 3d 20 28 75 33 32 29 28 70 54 61 62  ize = (u32)(pTab
a5a0: 2d 3e 73 7a 43 75 72 72 65 6e 74 20 2d 20 69 4f  ->szCurrent - iO
a5b0: 66 66 73 65 74 29 3b 0a 20 20 20 20 65 6f 63 64  ffset);.    eocd
a5c0: 2e 69 4f 66 66 73 65 74 20 3d 20 28 75 33 32 29  .iOffset = (u32)
a5d0: 69 4f 66 66 73 65 74 3b 0a 20 20 20 20 72 63 20  iOffset;.    rc 
a5e0: 3d 20 7a 69 70 66 69 6c 65 41 70 70 65 6e 64 45  = zipfileAppendE
a5f0: 4f 43 44 28 70 54 61 62 2c 20 26 65 6f 63 64 29  OCD(pTab, &eocd)
a600: 3b 0a 0a 20 20 20 20 7a 69 70 66 69 6c 65 43 6c  ;..    zipfileCl
a610: 65 61 6e 75 70 54 72 61 6e 73 61 63 74 69 6f 6e  eanupTransaction
a620: 28 70 54 61 62 29 3b 0a 20 20 7d 0a 20 20 72 65  (pTab);.  }.  re
a630: 74 75 72 6e 20 72 63 3b 0a 7d 0a 0a 73 74 61 74  turn rc;.}..stat
a640: 69 63 20 69 6e 74 20 7a 69 70 66 69 6c 65 52 6f  ic int zipfileRo
a650: 6c 6c 62 61 63 6b 28 73 71 6c 69 74 65 33 5f 76  llback(sqlite3_v
a660: 74 61 62 20 2a 70 56 74 61 62 29 7b 0a 20 20 72  tab *pVtab){.  r
a670: 65 74 75 72 6e 20 7a 69 70 66 69 6c 65 43 6f 6d  eturn zipfileCom
a680: 6d 69 74 28 70 56 74 61 62 29 3b 0a 7d 0a 0a 2f  mit(pVtab);.}../
a690: 2a 0a 2a 2a 20 52 65 67 69 73 74 65 72 20 74 68  *.** Register th
a6a0: 65 20 22 7a 69 70 66 69 6c 65 22 20 76 69 72 74  e "zipfile" virt
a6b0: 75 61 6c 20 74 61 62 6c 65 2e 0a 2a 2f 0a 73 74  ual table..*/.st
a6c0: 61 74 69 63 20 69 6e 74 20 7a 69 70 66 69 6c 65  atic int zipfile
a6d0: 52 65 67 69 73 74 65 72 28 73 71 6c 69 74 65 33  Register(sqlite3
a6e0: 20 2a 64 62 29 7b 0a 20 20 73 74 61 74 69 63 20   *db){.  static 
a6f0: 73 71 6c 69 74 65 33 5f 6d 6f 64 75 6c 65 20 7a  sqlite3_module z
a700: 69 70 66 69 6c 65 4d 6f 64 75 6c 65 20 3d 20 7b  ipfileModule = {
a710: 0a 20 20 20 20 31 2c 20 20 20 20 20 20 20 20 20  .    1,         
a720: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
a730: 2f 2a 20 69 56 65 72 73 69 6f 6e 20 2a 2f 0a 20  /* iVersion */. 
a740: 20 20 20 7a 69 70 66 69 6c 65 43 6f 6e 6e 65 63     zipfileConnec
a750: 74 2c 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a  t,            /*
a760: 20 78 43 72 65 61 74 65 20 2a 2f 0a 20 20 20 20   xCreate */.    
a770: 7a 69 70 66 69 6c 65 43 6f 6e 6e 65 63 74 2c 20  zipfileConnect, 
a780: 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 78 43             /* xC
a790: 6f 6e 6e 65 63 74 20 2a 2f 0a 20 20 20 20 7a 69  onnect */.    zi
a7a0: 70 66 69 6c 65 42 65 73 74 49 6e 64 65 78 2c 20  pfileBestIndex, 
a7b0: 20 20 20 20 20 20 20 20 20 2f 2a 20 78 42 65 73           /* xBes
a7c0: 74 49 6e 64 65 78 20 2a 2f 0a 20 20 20 20 7a 69  tIndex */.    zi
a7d0: 70 66 69 6c 65 44 69 73 63 6f 6e 6e 65 63 74 2c  pfileDisconnect,
a7e0: 20 20 20 20 20 20 20 20 20 2f 2a 20 78 44 69 73           /* xDis
a7f0: 63 6f 6e 6e 65 63 74 20 2a 2f 0a 20 20 20 20 7a  connect */.    z
a800: 69 70 66 69 6c 65 44 69 73 63 6f 6e 6e 65 63 74  ipfileDisconnect
a810: 2c 20 20 20 20 20 20 20 20 20 2f 2a 20 78 44 65  ,         /* xDe
a820: 73 74 72 6f 79 20 2a 2f 0a 20 20 20 20 7a 69 70  stroy */.    zip
a830: 66 69 6c 65 4f 70 65 6e 2c 20 20 20 20 20 20 20  fileOpen,       
a840: 20 20 20 20 20 20 20 20 2f 2a 20 78 4f 70 65 6e          /* xOpen
a850: 20 2d 20 6f 70 65 6e 20 61 20 63 75 72 73 6f 72   - open a cursor
a860: 20 2a 2f 0a 20 20 20 20 7a 69 70 66 69 6c 65 43   */.    zipfileC
a870: 6c 6f 73 65 2c 20 20 20 20 20 20 20 20 20 20 20  lose,           
a880: 20 20 20 2f 2a 20 78 43 6c 6f 73 65 20 2d 20 63     /* xClose - c
a890: 6c 6f 73 65 20 61 20 63 75 72 73 6f 72 20 2a 2f  lose a cursor */
a8a0: 0a 20 20 20 20 7a 69 70 66 69 6c 65 46 69 6c 74  .    zipfileFilt
a8b0: 65 72 2c 20 20 20 20 20 20 20 20 20 20 20 20 20  er,             
a8c0: 2f 2a 20 78 46 69 6c 74 65 72 20 2d 20 63 6f 6e  /* xFilter - con
a8d0: 66 69 67 75 72 65 20 73 63 61 6e 20 63 6f 6e 73  figure scan cons
a8e0: 74 72 61 69 6e 74 73 20 2a 2f 0a 20 20 20 20 7a  traints */.    z
a8f0: 69 70 66 69 6c 65 4e 65 78 74 2c 20 20 20 20 20  ipfileNext,     
a900: 20 20 20 20 20 20 20 20 20 20 2f 2a 20 78 4e 65            /* xNe
a910: 78 74 20 2d 20 61 64 76 61 6e 63 65 20 61 20 63  xt - advance a c
a920: 75 72 73 6f 72 20 2a 2f 0a 20 20 20 20 7a 69 70  ursor */.    zip
a930: 66 69 6c 65 45 6f 66 2c 20 20 20 20 20 20 20 20  fileEof,        
a940: 20 20 20 20 20 20 20 20 2f 2a 20 78 45 6f 66 20          /* xEof 
a950: 2d 20 63 68 65 63 6b 20 66 6f 72 20 65 6e 64 20  - check for end 
a960: 6f 66 20 73 63 61 6e 20 2a 2f 0a 20 20 20 20 7a  of scan */.    z
a970: 69 70 66 69 6c 65 43 6f 6c 75 6d 6e 2c 20 20 20  ipfileColumn,   
a980: 20 20 20 20 20 20 20 20 20 20 2f 2a 20 78 43 6f            /* xCo
a990: 6c 75 6d 6e 20 2d 20 72 65 61 64 20 64 61 74 61  lumn - read data
a9a0: 20 2a 2f 0a 20 20 20 20 7a 69 70 66 69 6c 65 52   */.    zipfileR
a9b0: 6f 77 69 64 2c 20 20 20 20 20 20 20 20 20 20 20  owid,           
a9c0: 20 20 20 2f 2a 20 78 52 6f 77 69 64 20 2d 20 72     /* xRowid - r
a9d0: 65 61 64 20 64 61 74 61 20 2a 2f 0a 20 20 20 20  ead data */.    
a9e0: 7a 69 70 66 69 6c 65 55 70 64 61 74 65 2c 20 20  zipfileUpdate,  
a9f0: 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 78 55             /* xU
aa00: 70 64 61 74 65 20 2a 2f 0a 20 20 20 20 7a 69 70  pdate */.    zip
aa10: 66 69 6c 65 42 65 67 69 6e 2c 20 20 20 20 20 20  fileBegin,      
aa20: 20 20 20 20 20 20 20 20 2f 2a 20 78 42 65 67 69          /* xBegi
aa30: 6e 20 2a 2f 0a 20 20 20 20 30 2c 20 20 20 20 20  n */.    0,     
aa40: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
aa50: 20 20 20 20 2f 2a 20 78 53 79 6e 63 20 2a 2f 0a      /* xSync */.
aa60: 20 20 20 20 7a 69 70 66 69 6c 65 43 6f 6d 6d 69      zipfileCommi
aa70: 74 2c 20 20 20 20 20 20 20 20 20 20 20 20 20 2f  t,             /
aa80: 2a 20 78 43 6f 6d 6d 69 74 20 2a 2f 0a 20 20 20  * xCommit */.   
aa90: 20 7a 69 70 66 69 6c 65 52 6f 6c 6c 62 61 63 6b   zipfileRollback
aaa0: 2c 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 78  ,           /* x
aab0: 52 6f 6c 6c 62 61 63 6b 20 2a 2f 0a 20 20 20 20  Rollback */.    
aac0: 30 2c 20 20 20 20 20 20 20 20 20 20 20 20 20 20  0,              
aad0: 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 78 46             /* xF
aae0: 69 6e 64 4d 65 74 68 6f 64 20 2a 2f 0a 20 20 20  indMethod */.   
aaf0: 20 30 2c 20 20 20 20 20 20 20 20 20 20 20 20 20   0,             
ab00: 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 78              /* x
ab10: 52 65 6e 61 6d 65 20 2a 2f 0a 20 20 7d 3b 0a 0a  Rename */.  };..
ab20: 20 20 69 6e 74 20 72 63 20 3d 20 73 71 6c 69 74    int rc = sqlit
ab30: 65 33 5f 63 72 65 61 74 65 5f 6d 6f 64 75 6c 65  e3_create_module
ab40: 28 64 62 2c 20 22 7a 69 70 66 69 6c 65 22 20 20  (db, "zipfile"  
ab50: 2c 20 26 7a 69 70 66 69 6c 65 4d 6f 64 75 6c 65  , &zipfileModule
ab60: 2c 20 30 29 3b 0a 20 20 72 65 74 75 72 6e 20 72  , 0);.  return r
ab70: 63 3b 0a 7d 0a 23 65 6c 73 65 20 20 20 20 20 20  c;.}.#else      
ab80: 20 20 20 2f 2a 20 53 51 4c 49 54 45 5f 4f 4d 49     /* SQLITE_OMI
ab90: 54 5f 56 49 52 54 55 41 4c 54 41 42 4c 45 20 2a  T_VIRTUALTABLE *
aba0: 2f 0a 23 20 64 65 66 69 6e 65 20 7a 69 70 66 69  /.# define zipfi
abb0: 6c 65 52 65 67 69 73 74 65 72 28 78 29 20 53 51  leRegister(x) SQ
abc0: 4c 49 54 45 5f 4f 4b 0a 23 65 6e 64 69 66 0a 0a  LITE_OK.#endif..
abd0: 23 69 66 64 65 66 20 5f 57 49 4e 33 32 0a 5f 5f  #ifdef _WIN32.__
abe0: 64 65 63 6c 73 70 65 63 28 64 6c 6c 65 78 70 6f  declspec(dllexpo
abf0: 72 74 29 0a 23 65 6e 64 69 66 0a 69 6e 74 20 73  rt).#endif.int s
ac00: 71 6c 69 74 65 33 5f 7a 69 70 66 69 6c 65 5f 69  qlite3_zipfile_i
ac10: 6e 69 74 28 0a 20 20 73 71 6c 69 74 65 33 20 2a  nit(.  sqlite3 *
ac20: 64 62 2c 20 0a 20 20 63 68 61 72 20 2a 2a 70 7a  db, .  char **pz
ac30: 45 72 72 4d 73 67 2c 20 0a 20 20 63 6f 6e 73 74  ErrMsg, .  const
ac40: 20 73 71 6c 69 74 65 33 5f 61 70 69 5f 72 6f 75   sqlite3_api_rou
ac50: 74 69 6e 65 73 20 2a 70 41 70 69 0a 29 7b 0a 20  tines *pApi.){. 
ac60: 20 53 51 4c 49 54 45 5f 45 58 54 45 4e 53 49 4f   SQLITE_EXTENSIO
ac70: 4e 5f 49 4e 49 54 32 28 70 41 70 69 29 3b 0a 20  N_INIT2(pApi);. 
ac80: 20 28 76 6f 69 64 29 70 7a 45 72 72 4d 73 67 3b   (void)pzErrMsg;
ac90: 20 20 2f 2a 20 55 6e 75 73 65 64 20 70 61 72 61    /* Unused para
aca0: 6d 65 74 65 72 20 2a 2f 0a 20 20 72 65 74 75 72  meter */.  retur
acb0: 6e 20 7a 69 70 66 69 6c 65 52 65 67 69 73 74 65  n zipfileRegiste
acc0: 72 28 64 62 29 3b 0a 7d 0a                       r(db);.}.