SQLITE_NOTICE(283): recovered 1 frames from WAL file /fossil/sqlite.fossil-wal

SQLite: Hex Artifact Content
/ Hex Artifact Content
Login
SQLite training in Houston TX on 2019-11-05 (details)
Part of the 2019 Tcl Conference

Artifact 3cb415073754cb8ff076f26173143c3cd293a9da:


0000: 23 20 32 30 30 31 20 53 65 70 74 65 6d 62 65 72  # 2001 September
0010: 20 31 35 0a 23 0a 23 20 54 68 65 20 61 75 74 68   15.#.# The auth
0020: 6f 72 20 64 69 73 63 6c 61 69 6d 73 20 63 6f 70  or disclaims cop
0030: 79 72 69 67 68 74 20 74 6f 20 74 68 69 73 20 73  yright to this s
0040: 6f 75 72 63 65 20 63 6f 64 65 2e 20 20 49 6e 20  ource code.  In 
0050: 70 6c 61 63 65 20 6f 66 0a 23 20 61 20 6c 65 67  place 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 23  is a blessing:.#
0080: 0a 23 20 20 20 20 4d 61 79 20 79 6f 75 20 64 6f  .#    May you do
0090: 20 67 6f 6f 64 20 61 6e 64 20 6e 6f 74 20 65 76   good and not ev
00a0: 69 6c 2e 0a 23 20 20 20 20 4d 61 79 20 79 6f 75  il..#    May you
00b0: 20 66 69 6e 64 20 66 6f 72 67 69 76 65 6e 65 73   find forgivenes
00c0: 73 20 66 6f 72 20 79 6f 75 72 73 65 6c 66 20 61  s for yourself a
00d0: 6e 64 20 66 6f 72 67 69 76 65 20 6f 74 68 65 72  nd forgive other
00e0: 73 2e 0a 23 20 20 20 20 4d 61 79 20 79 6f 75 20  s..#    May you 
00f0: 73 68 61 72 65 20 66 72 65 65 6c 79 2c 20 6e 65  share freely, ne
0100: 76 65 72 20 74 61 6b 69 6e 67 20 6d 6f 72 65 20  ver taking more 
0110: 74 68 61 6e 20 79 6f 75 20 67 69 76 65 2e 0a 23  than you give..#
0120: 0a 23 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  .#**************
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 0a 23 20 54 68 69 73  *********.# This
0170: 20 66 69 6c 65 20 69 6d 70 6c 65 6d 65 6e 74 73   file implements
0180: 20 72 65 67 72 65 73 73 69 6f 6e 20 74 65 73 74   regression test
0190: 73 20 66 6f 72 20 53 51 4c 69 74 65 20 6c 69 62  s for SQLite lib
01a0: 72 61 72 79 2e 20 20 54 68 65 0a 23 20 66 6f 63  rary.  The.# foc
01b0: 75 73 20 6f 66 20 74 68 69 73 20 66 69 6c 65 20  us of this file 
01c0: 69 73 20 74 65 73 74 69 6e 67 20 74 68 65 20 73  is testing the s
01d0: 71 6c 69 74 65 5f 2a 5f 70 72 69 6e 74 66 28 29  qlite_*_printf()
01e0: 20 69 6e 74 65 72 66 61 63 65 2e 0a 23 0a 23 20   interface..#.# 
01f0: 24 49 64 3a 20 70 72 69 6e 74 66 2e 74 65 73 74  $Id: printf.test
0200: 2c 76 20 31 2e 34 20 32 30 30 31 2f 30 39 2f 32  ,v 1.4 2001/09/2
0210: 30 20 30 31 3a 34 34 3a 34 33 20 64 72 68 20 45  0 01:44:43 drh E
0220: 78 70 20 24 0a 0a 73 65 74 20 74 65 73 74 64 69  xp $..set testdi
0230: 72 20 5b 66 69 6c 65 20 64 69 72 6e 61 6d 65 20  r [file dirname 
0240: 24 61 72 67 76 30 5d 0a 73 6f 75 72 63 65 20 24  $argv0].source $
0250: 74 65 73 74 64 69 72 2f 74 65 73 74 65 72 2e 74  testdir/tester.t
0260: 63 6c 0a 0a 73 65 74 20 6e 20 31 0a 66 6f 72 65  cl..set n 1.fore
0270: 61 63 68 20 76 20 7b 31 20 32 20 35 20 31 30 20  ach v {1 2 5 10 
0280: 39 39 20 31 30 30 20 31 30 30 30 30 30 30 20 39  99 100 1000000 9
0290: 39 39 39 39 39 39 39 39 20 30 20 2d 31 20 2d 32  99999999 0 -1 -2
02a0: 20 2d 35 20 2d 31 30 20 2d 39 39 20 2d 31 30 30   -5 -10 -99 -100
02b0: 20 2d 39 39 39 39 39 39 39 7d 20 7b 0a 20 20 64   -9999999} {.  d
02c0: 6f 5f 74 65 73 74 20 70 72 69 6e 74 66 2d 31 2e  o_test printf-1.
02d0: 24 6e 2e 31 20 5b 73 75 62 73 74 20 7b 0a 20 20  $n.1 [subst {.  
02e0: 20 20 73 71 6c 69 74 65 5f 6d 70 72 69 6e 74 66    sqlite_mprintf
02f0: 5f 69 6e 74 20 7b 54 68 72 65 65 20 69 6e 74 65  _int {Three inte
0300: 67 65 72 73 3a 20 25 64 20 25 78 20 25 6f 7d 20  gers: %d %x %o} 
0310: 24 76 20 24 76 20 24 76 0a 20 20 7d 5d 20 5b 66  $v $v $v.  }] [f
0320: 6f 72 6d 61 74 20 7b 54 68 72 65 65 20 69 6e 74  ormat {Three int
0330: 65 67 65 72 73 3a 20 25 64 20 25 78 20 25 6f 7d  egers: %d %x %o}
0340: 20 24 76 20 24 76 20 24 76 5d 0a 20 20 64 6f 5f   $v $v $v].  do_
0350: 74 65 73 74 20 70 72 69 6e 74 66 2d 31 2e 24 6e  test printf-1.$n
0360: 2e 32 20 5b 73 75 62 73 74 20 7b 0a 20 20 20 20  .2 [subst {.    
0370: 73 71 6c 69 74 65 5f 6d 70 72 69 6e 74 66 5f 69  sqlite_mprintf_i
0380: 6e 74 20 7b 54 68 72 65 65 20 69 6e 74 65 67 65  nt {Three intege
0390: 72 73 3a 20 28 25 36 64 29 20 28 25 36 78 29 20  rs: (%6d) (%6x) 
03a0: 28 25 36 6f 29 7d 20 24 76 20 24 76 20 24 76 0a  (%6o)} $v $v $v.
03b0: 20 20 7d 5d 20 5b 66 6f 72 6d 61 74 20 7b 54 68    }] [format {Th
03c0: 72 65 65 20 69 6e 74 65 67 65 72 73 3a 20 28 25  ree integers: (%
03d0: 36 64 29 20 28 25 36 78 29 20 28 25 36 6f 29 7d  6d) (%6x) (%6o)}
03e0: 20 24 76 20 24 76 20 24 76 5d 0a 20 20 64 6f 5f   $v $v $v].  do_
03f0: 74 65 73 74 20 70 72 69 6e 74 66 2d 31 2e 24 6e  test printf-1.$n
0400: 2e 33 20 5b 73 75 62 73 74 20 7b 0a 20 20 20 20  .3 [subst {.    
0410: 73 71 6c 69 74 65 5f 6d 70 72 69 6e 74 66 5f 69  sqlite_mprintf_i
0420: 6e 74 20 7b 54 68 72 65 65 20 69 6e 74 65 67 65  nt {Three intege
0430: 72 73 3a 20 28 25 2d 36 64 29 20 28 25 2d 36 78  rs: (%-6d) (%-6x
0440: 29 20 28 25 2d 36 6f 29 7d 20 24 76 20 24 76 20  ) (%-6o)} $v $v 
0450: 24 76 0a 20 20 7d 5d 20 5b 66 6f 72 6d 61 74 20  $v.  }] [format 
0460: 7b 54 68 72 65 65 20 69 6e 74 65 67 65 72 73 3a  {Three integers:
0470: 20 28 25 2d 36 64 29 20 28 25 2d 36 78 29 20 28   (%-6d) (%-6x) (
0480: 25 2d 36 6f 29 7d 20 24 76 20 24 76 20 24 76 5d  %-6o)} $v $v $v]
0490: 0a 20 20 64 6f 5f 74 65 73 74 20 70 72 69 6e 74  .  do_test print
04a0: 66 2d 31 2e 24 6e 2e 34 20 5b 73 75 62 73 74 20  f-1.$n.4 [subst 
04b0: 7b 0a 20 20 20 20 73 71 6c 69 74 65 5f 6d 70 72  {.    sqlite_mpr
04c0: 69 6e 74 66 5f 69 6e 74 20 7b 54 68 72 65 65 20  intf_int {Three 
04d0: 69 6e 74 65 67 65 72 73 3a 20 28 25 2b 36 64 29  integers: (%+6d)
04e0: 20 28 25 2b 36 78 29 20 28 25 2b 36 6f 29 7d 20   (%+6x) (%+6o)} 
04f0: 24 76 20 24 76 20 24 76 0a 20 20 7d 5d 20 5b 66  $v $v $v.  }] [f
0500: 6f 72 6d 61 74 20 7b 54 68 72 65 65 20 69 6e 74  ormat {Three int
0510: 65 67 65 72 73 3a 20 28 25 2b 36 64 29 20 28 25  egers: (%+6d) (%
0520: 2b 36 78 29 20 28 25 2b 36 6f 29 7d 20 24 76 20  +6x) (%+6o)} $v 
0530: 24 76 20 24 76 5d 0a 20 20 64 6f 5f 74 65 73 74  $v $v].  do_test
0540: 20 70 72 69 6e 74 66 2d 31 2e 24 6e 2e 35 20 5b   printf-1.$n.5 [
0550: 73 75 62 73 74 20 7b 0a 20 20 20 20 73 71 6c 69  subst {.    sqli
0560: 74 65 5f 6d 70 72 69 6e 74 66 5f 69 6e 74 20 7b  te_mprintf_int {
0570: 54 68 72 65 65 20 69 6e 74 65 67 65 72 73 3a 20  Three integers: 
0580: 28 25 30 36 64 29 20 28 25 30 36 78 29 20 28 25  (%06d) (%06x) (%
0590: 30 36 6f 29 7d 20 24 76 20 24 76 20 24 76 0a 20  06o)} $v $v $v. 
05a0: 20 7d 5d 20 5b 66 6f 72 6d 61 74 20 7b 54 68 72   }] [format {Thr
05b0: 65 65 20 69 6e 74 65 67 65 72 73 3a 20 28 25 30  ee integers: (%0
05c0: 36 64 29 20 28 25 30 36 78 29 20 28 25 30 36 6f  6d) (%06x) (%06o
05d0: 29 7d 20 24 76 20 24 76 20 24 76 5d 0a 20 20 64  )} $v $v $v].  d
05e0: 6f 5f 74 65 73 74 20 70 72 69 6e 74 66 2d 31 2e  o_test printf-1.
05f0: 24 6e 2e 36 20 5b 73 75 62 73 74 20 7b 0a 20 20  $n.6 [subst {.  
0600: 20 20 73 71 6c 69 74 65 5f 6d 70 72 69 6e 74 66    sqlite_mprintf
0610: 5f 69 6e 74 20 7b 54 68 72 65 65 20 69 6e 74 65  _int {Three inte
0620: 67 65 72 73 3a 20 28 25 20 36 64 29 20 28 25 20  gers: (% 6d) (% 
0630: 36 78 29 20 28 25 20 36 6f 29 7d 20 24 76 20 24  6x) (% 6o)} $v $
0640: 76 20 24 76 0a 20 20 7d 5d 20 5b 66 6f 72 6d 61  v $v.  }] [forma
0650: 74 20 7b 54 68 72 65 65 20 69 6e 74 65 67 65 72  t {Three integer
0660: 73 3a 20 28 25 20 36 64 29 20 28 25 20 36 78 29  s: (% 6d) (% 6x)
0670: 20 28 25 20 36 6f 29 7d 20 24 76 20 24 76 20 24   (% 6o)} $v $v $
0680: 76 5d 0a 20 20 69 6e 63 72 20 6e 0a 7d 0a 0a 0a  v].  incr n.}...
0690: 69 66 20 7b 24 3a 3a 74 63 6c 5f 70 6c 61 74 66  if {$::tcl_platf
06a0: 6f 72 6d 28 70 6c 61 74 66 6f 72 6d 29 21 3d 22  orm(platform)!="
06b0: 77 69 6e 64 6f 77 73 22 7d 20 7b 0a 0a 73 65 74  windows"} {..set
06c0: 20 6d 20 31 0a 66 6f 72 65 61 63 68 20 7b 61 20   m 1.foreach {a 
06d0: 62 7d 20 7b 31 20 31 20 35 20 35 20 31 30 20 31  b} {1 1 5 5 10 1
06e0: 30 20 31 30 20 35 7d 20 7b 0a 20 20 73 65 74 20  0 10 5} {.  set 
06f0: 6e 20 31 0a 20 20 66 6f 72 65 61 63 68 20 78 20  n 1.  foreach x 
0700: 7b 30 2e 30 30 31 20 31 2e 30 65 2d 32 30 20 31  {0.001 1.0e-20 1
0710: 2e 30 20 30 2e 30 20 31 30 30 2e 30 20 39 2e 39  .0 0.0 100.0 9.9
0720: 39 39 39 39 20 2d 30 2e 30 30 35 34 33 20 2d 31  9999 -0.00543 -1
0730: 2e 30 20 2d 39 39 2e 39 39 39 39 39 7d 20 7b 0a  .0 -99.99999} {.
0740: 20 20 20 20 64 6f 5f 74 65 73 74 20 70 72 69 6e      do_test prin
0750: 74 66 2d 32 2e 24 6d 2e 24 6e 2e 31 20 5b 73 75  tf-2.$m.$n.1 [su
0760: 62 73 74 20 7b 0a 20 20 20 20 20 20 73 71 6c 69  bst {.      sqli
0770: 74 65 5f 6d 70 72 69 6e 74 66 5f 64 6f 75 62 6c  te_mprintf_doubl
0780: 65 20 7b 41 20 64 6f 75 62 6c 65 3a 20 25 2a 2e  e {A double: %*.
0790: 2a 66 7d 20 24 61 20 24 62 20 24 78 0a 20 20 20  *f} $a $b $x.   
07a0: 20 7d 5d 20 5b 66 6f 72 6d 61 74 20 7b 41 20 64   }] [format {A d
07b0: 6f 75 62 6c 65 3a 20 25 2a 2e 2a 66 7d 20 24 61  ouble: %*.*f} $a
07c0: 20 24 62 20 24 78 5d 0a 20 20 20 20 64 6f 5f 74   $b $x].    do_t
07d0: 65 73 74 20 70 72 69 6e 74 66 2d 32 2e 24 6d 2e  est printf-2.$m.
07e0: 24 6e 2e 32 20 5b 73 75 62 73 74 20 7b 0a 20 20  $n.2 [subst {.  
07f0: 20 20 20 20 73 71 6c 69 74 65 5f 6d 70 72 69 6e      sqlite_mprin
0800: 74 66 5f 64 6f 75 62 6c 65 20 7b 41 20 64 6f 75  tf_double {A dou
0810: 62 6c 65 3a 20 25 2a 2e 2a 65 7d 20 24 61 20 24  ble: %*.*e} $a $
0820: 62 20 24 78 0a 20 20 20 20 7d 5d 20 5b 66 6f 72  b $x.    }] [for
0830: 6d 61 74 20 7b 41 20 64 6f 75 62 6c 65 3a 20 25  mat {A double: %
0840: 2a 2e 2a 65 7d 20 24 61 20 24 62 20 24 78 5d 0a  *.*e} $a $b $x].
0850: 20 20 20 20 64 6f 5f 74 65 73 74 20 70 72 69 6e      do_test prin
0860: 74 66 2d 32 2e 24 6d 2e 24 6e 2e 33 20 5b 73 75  tf-2.$m.$n.3 [su
0870: 62 73 74 20 7b 0a 20 20 20 20 20 20 73 71 6c 69  bst {.      sqli
0880: 74 65 5f 6d 70 72 69 6e 74 66 5f 64 6f 75 62 6c  te_mprintf_doubl
0890: 65 20 7b 41 20 64 6f 75 62 6c 65 3a 20 25 2a 2e  e {A double: %*.
08a0: 2a 67 7d 20 24 61 20 24 62 20 24 78 0a 20 20 20  *g} $a $b $x.   
08b0: 20 7d 5d 20 5b 66 6f 72 6d 61 74 20 7b 41 20 64   }] [format {A d
08c0: 6f 75 62 6c 65 3a 20 25 2a 2e 2a 67 7d 20 24 61  ouble: %*.*g} $a
08d0: 20 24 62 20 24 78 5d 0a 20 20 20 20 64 6f 5f 74   $b $x].    do_t
08e0: 65 73 74 20 70 72 69 6e 74 66 2d 32 2e 24 6d 2e  est printf-2.$m.
08f0: 24 6e 2e 34 20 5b 73 75 62 73 74 20 7b 0a 20 20  $n.4 [subst {.  
0900: 20 20 20 20 73 71 6c 69 74 65 5f 6d 70 72 69 6e      sqlite_mprin
0910: 74 66 5f 64 6f 75 62 6c 65 20 7b 41 20 64 6f 75  tf_double {A dou
0920: 62 6c 65 3a 20 25 64 20 25 64 20 25 67 7d 20 24  ble: %d %d %g} $
0930: 61 20 24 62 20 24 78 0a 20 20 20 20 7d 5d 20 5b  a $b $x.    }] [
0940: 66 6f 72 6d 61 74 20 7b 41 20 64 6f 75 62 6c 65  format {A double
0950: 3a 20 25 64 20 25 64 20 25 67 7d 20 24 61 20 24  : %d %d %g} $a $
0960: 62 20 24 78 5d 0a 20 20 20 20 64 6f 5f 74 65 73  b $x].    do_tes
0970: 74 20 70 72 69 6e 74 66 2d 32 2e 24 6d 2e 24 6e  t printf-2.$m.$n
0980: 2e 35 20 5b 73 75 62 73 74 20 7b 0a 20 20 20 20  .5 [subst {.    
0990: 20 20 73 71 6c 69 74 65 5f 6d 70 72 69 6e 74 66    sqlite_mprintf
09a0: 5f 64 6f 75 62 6c 65 20 7b 41 20 64 6f 75 62 6c  _double {A doubl
09b0: 65 3a 20 25 64 20 25 64 20 25 23 67 7d 20 24 61  e: %d %d %#g} $a
09c0: 20 24 62 20 24 78 0a 20 20 20 20 7d 5d 20 5b 66   $b $x.    }] [f
09d0: 6f 72 6d 61 74 20 7b 41 20 64 6f 75 62 6c 65 3a  ormat {A double:
09e0: 20 25 64 20 25 64 20 25 23 67 7d 20 24 61 20 24   %d %d %#g} $a $
09f0: 62 20 24 78 5d 0a 20 20 20 20 69 6e 63 72 20 6e  b $x].    incr n
0a00: 0a 20 20 7d 0a 20 20 69 6e 63 72 20 6d 0a 7d 0a  .  }.  incr m.}.
0a10: 0a 7d 0a 0a 64 6f 5f 74 65 73 74 20 70 72 69 6e  .}..do_test prin
0a20: 74 66 2d 33 2e 31 20 7b 0a 20 20 73 71 6c 69 74  tf-3.1 {.  sqlit
0a30: 65 5f 6d 70 72 69 6e 74 66 5f 73 74 72 20 7b 41  e_mprintf_str {A
0a40: 20 53 74 72 69 6e 67 3a 20 28 25 2a 2e 2a 73 29   String: (%*.*s)
0a50: 7d 20 31 30 20 31 30 20 7b 54 68 69 73 20 69 73  } 10 10 {This is
0a60: 20 74 68 65 20 73 74 72 69 6e 67 7d 0a 7d 20 5b   the string}.} [
0a70: 66 6f 72 6d 61 74 20 7b 41 20 53 74 72 69 6e 67  format {A String
0a80: 3a 20 28 25 2a 2e 2a 73 29 7d 20 31 30 20 31 30  : (%*.*s)} 10 10
0a90: 20 7b 54 68 69 73 20 69 73 20 74 68 65 20 73 74   {This is the st
0aa0: 72 69 6e 67 7d 5d 0a 64 6f 5f 74 65 73 74 20 70  ring}].do_test p
0ab0: 72 69 6e 74 66 2d 33 2e 32 20 7b 0a 20 20 73 71  rintf-3.2 {.  sq
0ac0: 6c 69 74 65 5f 6d 70 72 69 6e 74 66 5f 73 74 72  lite_mprintf_str
0ad0: 20 7b 41 20 53 74 72 69 6e 67 3a 20 28 25 2a 2e   {A String: (%*.
0ae0: 2a 73 29 7d 20 31 30 20 35 20 7b 54 68 69 73 20  *s)} 10 5 {This 
0af0: 69 73 20 74 68 65 20 73 74 72 69 6e 67 7d 0a 7d  is the string}.}
0b00: 20 5b 66 6f 72 6d 61 74 20 7b 41 20 53 74 72 69   [format {A Stri
0b10: 6e 67 3a 20 28 25 2a 2e 2a 73 29 7d 20 31 30 20  ng: (%*.*s)} 10 
0b20: 35 20 7b 54 68 69 73 20 69 73 20 74 68 65 20 73  5 {This is the s
0b30: 74 72 69 6e 67 7d 5d 0a 64 6f 5f 74 65 73 74 20  tring}].do_test 
0b40: 70 72 69 6e 74 66 2d 33 2e 33 20 7b 0a 20 20 73  printf-3.3 {.  s
0b50: 71 6c 69 74 65 5f 6d 70 72 69 6e 74 66 5f 73 74  qlite_mprintf_st
0b60: 72 20 7b 41 20 53 74 72 69 6e 67 3a 20 28 25 2a  r {A String: (%*
0b70: 2e 2a 73 29 7d 20 2d 31 30 20 35 20 7b 54 68 69  .*s)} -10 5 {Thi
0b80: 73 20 69 73 20 74 68 65 20 73 74 72 69 6e 67 7d  s is the string}
0b90: 0a 7d 20 5b 66 6f 72 6d 61 74 20 7b 41 20 53 74  .} [format {A St
0ba0: 72 69 6e 67 3a 20 28 25 2a 2e 2a 73 29 7d 20 2d  ring: (%*.*s)} -
0bb0: 31 30 20 35 20 7b 54 68 69 73 20 69 73 20 74 68  10 5 {This is th
0bc0: 65 20 73 74 72 69 6e 67 7d 5d 0a 64 6f 5f 74 65  e string}].do_te
0bd0: 73 74 20 70 72 69 6e 74 66 2d 33 2e 34 20 7b 0a  st printf-3.4 {.
0be0: 20 20 73 71 6c 69 74 65 5f 6d 70 72 69 6e 74 66    sqlite_mprintf
0bf0: 5f 73 74 72 20 7b 25 64 20 25 64 20 41 20 53 74  _str {%d %d A St
0c00: 72 69 6e 67 3a 20 28 25 73 29 7d 20 31 20 32 20  ring: (%s)} 1 2 
0c10: 7b 54 68 69 73 20 69 73 20 74 68 65 20 73 74 72  {This is the str
0c20: 69 6e 67 7d 0a 7d 20 5b 66 6f 72 6d 61 74 20 7b  ing}.} [format {
0c30: 25 64 20 25 64 20 41 20 53 74 72 69 6e 67 3a 20  %d %d A String: 
0c40: 28 25 73 29 7d 20 31 20 32 20 7b 54 68 69 73 20  (%s)} 1 2 {This 
0c50: 69 73 20 74 68 65 20 73 74 72 69 6e 67 7d 5d 0a  is the string}].
0c60: 64 6f 5f 74 65 73 74 20 70 72 69 6e 74 66 2d 33  do_test printf-3
0c70: 2e 35 20 7b 0a 20 20 73 71 6c 69 74 65 5f 6d 70  .5 {.  sqlite_mp
0c80: 72 69 6e 74 66 5f 73 74 72 20 7b 25 64 20 25 64  rintf_str {%d %d
0c90: 20 41 20 53 74 72 69 6e 67 3a 20 28 25 33 30 73   A String: (%30s
0ca0: 29 7d 20 31 20 32 20 7b 54 68 69 73 20 69 73 20  )} 1 2 {This is 
0cb0: 74 68 65 20 73 74 72 69 6e 67 7d 0a 7d 20 5b 66  the string}.} [f
0cc0: 6f 72 6d 61 74 20 7b 25 64 20 25 64 20 41 20 53  ormat {%d %d A S
0cd0: 74 72 69 6e 67 3a 20 28 25 33 30 73 29 7d 20 31  tring: (%30s)} 1
0ce0: 20 32 20 7b 54 68 69 73 20 69 73 20 74 68 65 20   2 {This is the 
0cf0: 73 74 72 69 6e 67 7d 5d 0a 64 6f 5f 74 65 73 74  string}].do_test
0d00: 20 70 72 69 6e 74 66 2d 33 2e 36 20 7b 0a 20 20   printf-3.6 {.  
0d10: 73 71 6c 69 74 65 5f 6d 70 72 69 6e 74 66 5f 73  sqlite_mprintf_s
0d20: 74 72 20 7b 25 64 20 25 64 20 41 20 53 74 72 69  tr {%d %d A Stri
0d30: 6e 67 3a 20 28 25 2d 33 30 73 29 7d 20 31 20 32  ng: (%-30s)} 1 2
0d40: 20 7b 54 68 69 73 20 69 73 20 74 68 65 20 73 74   {This is the st
0d50: 72 69 6e 67 7d 0a 7d 20 5b 66 6f 72 6d 61 74 20  ring}.} [format 
0d60: 7b 25 64 20 25 64 20 41 20 53 74 72 69 6e 67 3a  {%d %d A String:
0d70: 20 28 25 2d 33 30 73 29 7d 20 31 20 32 20 7b 54   (%-30s)} 1 2 {T
0d80: 68 69 73 20 69 73 20 74 68 65 20 73 74 72 69 6e  his is the strin
0d90: 67 7d 5d 0a 0a 64 6f 5f 74 65 73 74 20 70 72 69  g}]..do_test pri
0da0: 6e 74 66 2d 34 2e 31 20 7b 0a 20 20 73 71 6c 69  ntf-4.1 {.  sqli
0db0: 74 65 5f 6d 70 72 69 6e 74 66 5f 73 74 72 20 7b  te_mprintf_str {
0dc0: 25 64 20 25 64 20 41 20 71 75 6f 74 65 64 20 73  %d %d A quoted s
0dd0: 74 72 69 6e 67 3a 20 27 25 71 27 7d 20 31 20 32  tring: '%q'} 1 2
0de0: 20 7b 48 69 20 59 27 61 6c 6c 7d 0a 7d 20 7b 31   {Hi Y'all}.} {1
0df0: 20 32 20 41 20 71 75 6f 74 65 64 20 73 74 72 69   2 A quoted stri
0e00: 6e 67 3a 20 27 48 69 20 59 27 27 61 6c 6c 27 7d  ng: 'Hi Y''all'}
0e10: 0a 0a 64 6f 5f 74 65 73 74 20 70 72 69 6e 74 66  ..do_test printf
0e20: 2d 35 2e 31 20 7b 0a 20 20 73 65 74 20 78 20 5b  -5.1 {.  set x [
0e30: 73 71 6c 69 74 65 5f 6d 70 72 69 6e 74 66 5f 73  sqlite_mprintf_s
0e40: 74 72 20 7b 25 64 20 25 64 20 25 31 30 30 30 30  tr {%d %d %10000
0e50: 30 73 7d 20 30 20 30 20 7b 48 65 6c 6c 6f 7d 5d  0s} 0 0 {Hello}]
0e60: 0a 20 20 73 74 72 69 6e 67 20 6c 65 6e 67 74 68  .  string length
0e70: 20 24 78 0a 7d 20 7b 39 39 34 7d 0a 64 6f 5f 74   $x.} {994}.do_t
0e80: 65 73 74 20 70 72 69 6e 74 66 2d 35 2e 32 20 7b  est printf-5.2 {
0e90: 0a 20 20 73 71 6c 69 74 65 5f 6d 70 72 69 6e 74  .  sqlite_mprint
0ea0: 66 5f 73 74 72 20 7b 25 64 20 25 64 20 28 25 2d  f_str {%d %d (%-
0eb0: 31 30 2e 31 30 73 29 20 25 7d 20 2d 39 20 2d 31  10.10s) %} -9 -1
0ec0: 30 20 7b 48 65 6c 6c 6f 48 65 6c 6c 6f 48 65 6c  0 {HelloHelloHel
0ed0: 6c 6f 7d 0a 7d 20 7b 2d 39 20 2d 31 30 20 28 48  lo}.} {-9 -10 (H
0ee0: 65 6c 6c 6f 48 65 6c 6c 6f 29 20 25 7d 0a 64 6f  elloHello) %}.do
0ef0: 5f 74 65 73 74 20 70 72 69 6e 74 66 2d 35 2e 33  _test printf-5.3
0f00: 20 7b 0a 20 20 73 71 6c 69 74 65 5f 6d 70 72 69   {.  sqlite_mpri
0f10: 6e 74 66 5f 73 74 72 20 7b 25 25 20 25 64 20 25  ntf_str {%% %d %
0f20: 64 20 28 25 3d 31 30 73 29 7d 20 35 20 36 20 48  d (%=10s)} 5 6 H
0f30: 65 6c 6c 6f 0a 7d 20 7b 25 20 35 20 36 20 28 20  ello.} {% 5 6 ( 
0f40: 20 48 65 6c 6c 6f 20 20 20 29 7d 0a 0a 66 69 6e   Hello   )}..fin
0f50: 69 73 68 5f 74 65 73 74 0a                       ish_test.