/ Hex Artifact Content
Login

Artifact 3ff0565057b8d23e20092d5c6c0b7cb0d932c51e:


0000: 2f 2a 0a 2a 2a 20 32 30 30 31 20 53 65 70 74 65  /*.** 2001 Septe
0010: 6d 62 65 72 20 31 35 0a 2a 2a 0a 2a 2a 20 54 68  mber 15.**.** Th
0020: 65 20 61 75 74 68 6f 72 20 64 69 73 63 6c 61 69  e author disclai
0030: 6d 73 20 63 6f 70 79 72 69 67 68 74 20 74 6f 20  ms copyright to 
0040: 74 68 69 73 20 73 6f 75 72 63 65 20 63 6f 64 65  this source code
0050: 2e 20 20 49 6e 20 70 6c 61 63 65 20 6f 66 0a 2a  .  In place of.*
0060: 2a 20 61 20 6c 65 67 61 6c 20 6e 6f 74 69 63 65  * a legal notice
0070: 2c 20 68 65 72 65 20 69 73 20 61 20 62 6c 65 73  , here is a bles
0080: 73 69 6e 67 3a 0a 2a 2a 0a 2a 2a 20 20 20 20 4d  sing:.**.**    M
0090: 61 79 20 79 6f 75 20 64 6f 20 67 6f 6f 64 20 61  ay you do good a
00a0: 6e 64 20 6e 6f 74 20 65 76 69 6c 2e 0a 2a 2a 20  nd not evil..** 
00b0: 20 20 20 4d 61 79 20 79 6f 75 20 66 69 6e 64 20     May you find 
00c0: 66 6f 72 67 69 76 65 6e 65 73 73 20 66 6f 72 20  forgiveness for 
00d0: 79 6f 75 72 73 65 6c 66 20 61 6e 64 20 66 6f 72  yourself and for
00e0: 67 69 76 65 20 6f 74 68 65 72 73 2e 0a 2a 2a 20  give others..** 
00f0: 20 20 20 4d 61 79 20 79 6f 75 20 73 68 61 72 65     May you share
0100: 20 66 72 65 65 6c 79 2c 20 6e 65 76 65 72 20 74   freely, never t
0110: 61 6b 69 6e 67 20 6d 6f 72 65 20 74 68 61 6e 20  aking more than 
0120: 79 6f 75 20 67 69 76 65 2e 0a 2a 2a 0a 2a 2a 2a  you give..**.***
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 2a 2a 0a 2a 2a 20 43 6f 64 65 20 66  ******.** Code f
0180: 6f 72 20 74 65 73 74 69 6e 67 20 74 68 65 20 75  or testing the u
0190: 74 66 2e 63 20 6d 6f 64 75 6c 65 20 69 6e 20 53  tf.c module in S
01a0: 51 4c 69 74 65 2e 20 20 54 68 69 73 20 63 6f 64  QLite.  This cod
01b0: 65 0a 2a 2a 20 69 73 20 6e 6f 74 20 69 6e 63 6c  e.** is not incl
01c0: 75 64 65 64 20 69 6e 20 74 68 65 20 53 51 4c 69  uded in the SQLi
01d0: 74 65 20 6c 69 62 72 61 72 79 2e 20 20 49 74 20  te library.  It 
01e0: 69 73 20 75 73 65 64 20 66 6f 72 20 61 75 74 6f  is used for auto
01f0: 6d 61 74 65 64 0a 2a 2a 20 74 65 73 74 69 6e 67  mated.** testing
0200: 20 6f 66 20 74 68 65 20 53 51 4c 69 74 65 20 6c   of the SQLite l
0210: 69 62 72 61 72 79 2e 0a 2a 2a 0a 2a 2a 20 24 49  ibrary..**.** $I
0220: 64 3a 20 0a 2a 2f 0a 23 69 6e 63 6c 75 64 65 20  d: .*/.#include 
0230: 22 73 71 6c 69 74 65 49 6e 74 2e 68 22 0a 23 69  "sqliteInt.h".#i
0240: 6e 63 6c 75 64 65 20 22 74 63 6c 2e 68 22 0a 23  nclude "tcl.h".#
0250: 69 6e 63 6c 75 64 65 20 3c 73 74 64 6c 69 62 2e  include <stdlib.
0260: 68 3e 0a 23 69 6e 63 6c 75 64 65 20 3c 73 74 72  h>.#include <str
0270: 69 6e 67 2e 68 3e 0a 0a 2f 2a 0a 2a 2a 20 52 65  ing.h>../*.** Re
0280: 74 75 72 6e 20 74 68 65 20 6e 75 6d 62 65 72 20  turn the number 
0290: 6f 66 20 62 79 74 65 73 20 75 70 20 74 6f 20 61  of bytes up to a
02a0: 6e 64 20 69 6e 63 6c 75 64 69 6e 67 20 74 68 65  nd including the
02b0: 20 66 69 72 73 74 20 5c 75 30 30 30 30 20 0a 2a   first \u0000 .*
02c0: 2a 20 63 68 61 72 61 63 74 65 72 20 69 6e 20 2a  * character in *
02d0: 70 53 74 72 2e 0a 2a 2f 0a 73 74 61 74 69 63 20  pStr..*/.static 
02e0: 69 6e 74 20 75 74 66 31 36 5f 6c 65 6e 67 74 68  int utf16_length
02f0: 28 63 6f 6e 73 74 20 75 6e 73 69 67 6e 65 64 20  (const unsigned 
0300: 63 68 61 72 20 2a 70 5a 29 7b 0a 20 20 63 6f 6e  char *pZ){.  con
0310: 73 74 20 75 6e 73 69 67 6e 65 64 20 63 68 61 72  st unsigned char
0320: 20 2a 70 43 31 20 3d 20 70 5a 3b 0a 20 20 63 6f   *pC1 = pZ;.  co
0330: 6e 73 74 20 75 6e 73 69 67 6e 65 64 20 63 68 61  nst unsigned cha
0340: 72 20 2a 70 43 32 20 3d 20 70 5a 2b 31 3b 0a 20  r *pC2 = pZ+1;. 
0350: 20 77 68 69 6c 65 28 20 2a 70 43 31 20 7c 7c 20   while( *pC1 || 
0360: 2a 70 43 32 20 29 7b 0a 20 20 20 20 70 43 31 20  *pC2 ){.    pC1 
0370: 2b 3d 20 32 3b 0a 20 20 20 20 70 43 32 20 2b 3d  += 2;.    pC2 +=
0380: 20 32 3b 0a 20 20 7d 0a 20 20 72 65 74 75 72 6e   2;.  }.  return
0390: 20 28 70 43 31 2d 70 5a 29 2b 32 3b 0a 7d 0a 0a   (pC1-pZ)+2;.}..
03a0: 73 74 61 74 69 63 20 69 6e 74 20 73 71 6c 69 74  static int sqlit
03b0: 65 5f 75 74 66 38 74 6f 31 36 6c 65 28 0a 20 20  e_utf8to16le(.  
03c0: 76 6f 69 64 20 2a 20 63 6c 69 65 6e 74 44 61 74  void * clientDat
03d0: 61 2c 0a 20 20 54 63 6c 5f 49 6e 74 65 72 70 20  a,.  Tcl_Interp 
03e0: 2a 69 6e 74 65 72 70 2c 0a 20 20 69 6e 74 20 6f  *interp,.  int o
03f0: 62 6a 63 2c 0a 20 20 54 63 6c 5f 4f 62 6a 20 2a  bjc,.  Tcl_Obj *
0400: 43 4f 4e 53 54 20 6f 62 6a 76 5b 5d 0a 29 7b 0a  CONST objv[].){.
0410: 20 20 75 6e 73 69 67 6e 65 64 20 63 68 61 72 20    unsigned char 
0420: 2a 6f 75 74 3b 0a 20 20 75 6e 73 69 67 6e 65 64  *out;.  unsigned
0430: 20 63 68 61 72 20 2a 69 6e 3b 0a 20 20 54 63 6c   char *in;.  Tcl
0440: 5f 4f 62 6a 20 2a 72 65 73 3b 0a 0a 20 20 69 66  _Obj *res;..  if
0450: 28 20 6f 62 6a 63 21 3d 32 20 29 7b 0a 20 20 20  ( objc!=2 ){.   
0460: 20 54 63 6c 5f 41 70 70 65 6e 64 52 65 73 75 6c   Tcl_AppendResul
0470: 74 28 69 6e 74 65 72 70 2c 20 22 77 72 6f 6e 67  t(interp, "wrong
0480: 20 23 20 61 72 67 73 3a 20 73 68 6f 75 6c 64 20   # args: should 
0490: 62 65 20 5c 22 22 2c 0a 20 20 20 20 20 20 20 20  be \"",.        
04a0: 54 63 6c 5f 47 65 74 53 74 72 69 6e 67 46 72 6f  Tcl_GetStringFro
04b0: 6d 4f 62 6a 28 6f 62 6a 76 5b 30 5d 2c 20 30 29  mObj(objv[0], 0)
04c0: 2c 20 22 3c 75 74 66 2d 38 20 65 6e 63 6f 64 65  , "<utf-8 encode
04d0: 64 2d 73 74 72 69 6e 67 3e 22 2c 20 30 29 3b 0a  d-string>", 0);.
04e0: 20 20 20 20 72 65 74 75 72 6e 20 54 43 4c 5f 45      return TCL_E
04f0: 52 52 4f 52 3b 0a 20 20 7d 0a 0a 20 20 69 6e 20  RROR;.  }..  in 
0500: 3d 20 54 63 6c 5f 47 65 74 42 79 74 65 41 72 72  = Tcl_GetByteArr
0510: 61 79 46 72 6f 6d 4f 62 6a 28 6f 62 6a 76 5b 31  ayFromObj(objv[1
0520: 5d 2c 20 30 29 3b 0a 20 20 6f 75 74 20 3d 20 28  ], 0);.  out = (
0530: 75 6e 73 69 67 6e 65 64 20 63 68 61 72 20 2a 29  unsigned char *)
0540: 73 71 6c 69 74 65 33 75 74 66 38 74 6f 31 36 6c  sqlite3utf8to16l
0550: 65 28 69 6e 2c 20 2d 31 29 3b 0a 20 20 72 65 73  e(in, -1);.  res
0560: 20 3d 20 54 63 6c 5f 4e 65 77 42 79 74 65 41 72   = Tcl_NewByteAr
0570: 72 61 79 4f 62 6a 28 6f 75 74 2c 20 75 74 66 31  rayObj(out, utf1
0580: 36 5f 6c 65 6e 67 74 68 28 6f 75 74 29 29 3b 0a  6_length(out));.
0590: 20 20 73 71 6c 69 74 65 46 72 65 65 28 6f 75 74    sqliteFree(out
05a0: 29 3b 0a 0a 20 20 54 63 6c 5f 53 65 74 4f 62 6a  );..  Tcl_SetObj
05b0: 52 65 73 75 6c 74 28 69 6e 74 65 72 70 2c 20 72  Result(interp, r
05c0: 65 73 29 3b 0a 0a 20 20 72 65 74 75 72 6e 20 54  es);..  return T
05d0: 43 4c 5f 4f 4b 3b 0a 7d 0a 0a 73 74 61 74 69 63  CL_OK;.}..static
05e0: 20 69 6e 74 20 73 71 6c 69 74 65 5f 75 74 66 38   int sqlite_utf8
05f0: 74 6f 31 36 62 65 28 0a 20 20 76 6f 69 64 20 2a  to16be(.  void *
0600: 20 63 6c 69 65 6e 74 44 61 74 61 2c 0a 20 20 54   clientData,.  T
0610: 63 6c 5f 49 6e 74 65 72 70 20 2a 69 6e 74 65 72  cl_Interp *inter
0620: 70 2c 0a 20 20 69 6e 74 20 6f 62 6a 63 2c 0a 20  p,.  int objc,. 
0630: 20 54 63 6c 5f 4f 62 6a 20 2a 43 4f 4e 53 54 20   Tcl_Obj *CONST 
0640: 6f 62 6a 76 5b 5d 0a 29 7b 0a 20 20 75 6e 73 69  objv[].){.  unsi
0650: 67 6e 65 64 20 63 68 61 72 20 2a 6f 75 74 3b 0a  gned char *out;.
0660: 20 20 75 6e 73 69 67 6e 65 64 20 63 68 61 72 20    unsigned char 
0670: 2a 69 6e 3b 0a 20 20 54 63 6c 5f 4f 62 6a 20 2a  *in;.  Tcl_Obj *
0680: 72 65 73 3b 0a 0a 20 20 69 66 28 20 6f 62 6a 63  res;..  if( objc
0690: 21 3d 32 20 29 7b 0a 20 20 20 20 54 63 6c 5f 41  !=2 ){.    Tcl_A
06a0: 70 70 65 6e 64 52 65 73 75 6c 74 28 69 6e 74 65  ppendResult(inte
06b0: 72 70 2c 20 22 77 72 6f 6e 67 20 23 20 61 72 67  rp, "wrong # arg
06c0: 73 3a 20 73 68 6f 75 6c 64 20 62 65 20 5c 22 22  s: should be \""
06d0: 2c 0a 20 20 20 20 20 20 20 20 54 63 6c 5f 47 65  ,.        Tcl_Ge
06e0: 74 53 74 72 69 6e 67 46 72 6f 6d 4f 62 6a 28 6f  tStringFromObj(o
06f0: 62 6a 76 5b 30 5d 2c 20 30 29 2c 20 22 3c 75 74  bjv[0], 0), "<ut
0700: 66 2d 38 20 65 6e 63 6f 64 65 64 2d 73 74 72 69  f-8 encoded-stri
0710: 6e 67 3e 22 2c 20 30 29 3b 0a 20 20 20 20 72 65  ng>", 0);.    re
0720: 74 75 72 6e 20 54 43 4c 5f 45 52 52 4f 52 3b 0a  turn TCL_ERROR;.
0730: 20 20 7d 0a 0a 20 20 69 6e 20 3d 20 54 63 6c 5f    }..  in = Tcl_
0740: 47 65 74 42 79 74 65 41 72 72 61 79 46 72 6f 6d  GetByteArrayFrom
0750: 4f 62 6a 28 6f 62 6a 76 5b 31 5d 2c 20 30 29 3b  Obj(objv[1], 0);
0760: 0a 20 20 6f 75 74 20 3d 20 28 75 6e 73 69 67 6e  .  out = (unsign
0770: 65 64 20 63 68 61 72 20 2a 29 73 71 6c 69 74 65  ed char *)sqlite
0780: 33 75 74 66 38 74 6f 31 36 62 65 28 69 6e 2c 20  3utf8to16be(in, 
0790: 2d 31 29 3b 0a 20 20 72 65 73 20 3d 20 54 63 6c  -1);.  res = Tcl
07a0: 5f 4e 65 77 42 79 74 65 41 72 72 61 79 4f 62 6a  _NewByteArrayObj
07b0: 28 6f 75 74 2c 20 75 74 66 31 36 5f 6c 65 6e 67  (out, utf16_leng
07c0: 74 68 28 6f 75 74 29 29 3b 0a 20 20 73 71 6c 69  th(out));.  sqli
07d0: 74 65 46 72 65 65 28 6f 75 74 29 3b 0a 0a 20 20  teFree(out);..  
07e0: 54 63 6c 5f 53 65 74 4f 62 6a 52 65 73 75 6c 74  Tcl_SetObjResult
07f0: 28 69 6e 74 65 72 70 2c 20 72 65 73 29 3b 0a 0a  (interp, res);..
0800: 20 20 72 65 74 75 72 6e 20 54 43 4c 5f 4f 4b 3b    return TCL_OK;
0810: 0a 7d 0a 0a 73 74 61 74 69 63 20 69 6e 74 20 73  .}..static int s
0820: 71 6c 69 74 65 5f 75 74 66 31 36 74 6f 31 36 6c  qlite_utf16to16l
0830: 65 28 0a 20 20 76 6f 69 64 20 2a 20 63 6c 69 65  e(.  void * clie
0840: 6e 74 44 61 74 61 2c 0a 20 20 54 63 6c 5f 49 6e  ntData,.  Tcl_In
0850: 74 65 72 70 20 2a 69 6e 74 65 72 70 2c 0a 20 20  terp *interp,.  
0860: 69 6e 74 20 6f 62 6a 63 2c 0a 20 20 54 63 6c 5f  int objc,.  Tcl_
0870: 4f 62 6a 20 2a 43 4f 4e 53 54 20 6f 62 6a 76 5b  Obj *CONST objv[
0880: 5d 0a 29 7b 0a 20 20 75 6e 73 69 67 6e 65 64 20  ].){.  unsigned 
0890: 63 68 61 72 20 2a 6f 75 74 3b 0a 20 20 75 6e 73  char *out;.  uns
08a0: 69 67 6e 65 64 20 63 68 61 72 20 2a 69 6e 3b 0a  igned char *in;.
08b0: 20 20 69 6e 74 20 69 6e 5f 6c 65 6e 3b 0a 20 20    int in_len;.  
08c0: 54 63 6c 5f 4f 62 6a 20 2a 72 65 73 3b 0a 0a 20  Tcl_Obj *res;.. 
08d0: 20 69 66 28 20 6f 62 6a 63 21 3d 32 20 29 7b 0a   if( objc!=2 ){.
08e0: 20 20 20 20 54 63 6c 5f 41 70 70 65 6e 64 52 65      Tcl_AppendRe
08f0: 73 75 6c 74 28 69 6e 74 65 72 70 2c 20 22 77 72  sult(interp, "wr
0900: 6f 6e 67 20 23 20 61 72 67 73 3a 20 73 68 6f 75  ong # args: shou
0910: 6c 64 20 62 65 20 5c 22 22 2c 0a 20 20 20 20 20  ld be \"",.     
0920: 20 20 20 54 63 6c 5f 47 65 74 53 74 72 69 6e 67     Tcl_GetString
0930: 46 72 6f 6d 4f 62 6a 28 6f 62 6a 76 5b 30 5d 2c  FromObj(objv[0],
0940: 20 30 29 2c 20 22 3c 75 74 66 2d 31 36 20 65 6e   0), "<utf-16 en
0950: 63 6f 64 65 64 2d 73 74 72 69 6e 67 3e 22 2c 20  coded-string>", 
0960: 30 29 3b 0a 20 20 20 20 72 65 74 75 72 6e 20 54  0);.    return T
0970: 43 4c 5f 45 52 52 4f 52 3b 0a 20 20 7d 0a 0a 20  CL_ERROR;.  }.. 
0980: 20 69 6e 20 3d 20 54 63 6c 5f 47 65 74 42 79 74   in = Tcl_GetByt
0990: 65 41 72 72 61 79 46 72 6f 6d 4f 62 6a 28 6f 62  eArrayFromObj(ob
09a0: 6a 76 5b 31 5d 2c 20 26 69 6e 5f 6c 65 6e 29 3b  jv[1], &in_len);
09b0: 0a 20 20 6f 75 74 20 3d 20 28 75 6e 73 69 67 6e  .  out = (unsign
09c0: 65 64 20 63 68 61 72 20 2a 29 73 71 6c 69 74 65  ed char *)sqlite
09d0: 4d 61 6c 6c 6f 63 28 69 6e 5f 6c 65 6e 29 3b 0a  Malloc(in_len);.
09e0: 20 20 6d 65 6d 63 70 79 28 6f 75 74 2c 20 69 6e    memcpy(out, in
09f0: 2c 20 69 6e 5f 6c 65 6e 29 3b 0a 20 20 0a 20 20  , in_len);.  .  
0a00: 73 71 6c 69 74 65 33 75 74 66 31 36 74 6f 31 36  sqlite3utf16to16
0a10: 6c 65 28 6f 75 74 2c 20 2d 31 29 3b 0a 20 20 72  le(out, -1);.  r
0a20: 65 73 20 3d 20 54 63 6c 5f 4e 65 77 42 79 74 65  es = Tcl_NewByte
0a30: 41 72 72 61 79 4f 62 6a 28 6f 75 74 2c 20 75 74  ArrayObj(out, ut
0a40: 66 31 36 5f 6c 65 6e 67 74 68 28 6f 75 74 29 29  f16_length(out))
0a50: 3b 0a 20 20 73 71 6c 69 74 65 46 72 65 65 28 6f  ;.  sqliteFree(o
0a60: 75 74 29 3b 0a 0a 20 20 54 63 6c 5f 53 65 74 4f  ut);..  Tcl_SetO
0a70: 62 6a 52 65 73 75 6c 74 28 69 6e 74 65 72 70 2c  bjResult(interp,
0a80: 20 72 65 73 29 3b 0a 0a 20 20 72 65 74 75 72 6e   res);..  return
0a90: 20 54 43 4c 5f 4f 4b 3b 0a 7d 0a 0a 73 74 61 74   TCL_OK;.}..stat
0aa0: 69 63 20 69 6e 74 20 73 71 6c 69 74 65 5f 75 74  ic int sqlite_ut
0ab0: 66 31 36 74 6f 31 36 62 65 28 0a 20 20 76 6f 69  f16to16be(.  voi
0ac0: 64 20 2a 20 63 6c 69 65 6e 74 44 61 74 61 2c 0a  d * clientData,.
0ad0: 20 20 54 63 6c 5f 49 6e 74 65 72 70 20 2a 69 6e    Tcl_Interp *in
0ae0: 74 65 72 70 2c 0a 20 20 69 6e 74 20 6f 62 6a 63  terp,.  int objc
0af0: 2c 0a 20 20 54 63 6c 5f 4f 62 6a 20 2a 43 4f 4e  ,.  Tcl_Obj *CON
0b00: 53 54 20 6f 62 6a 76 5b 5d 0a 29 7b 0a 20 20 75  ST objv[].){.  u
0b10: 6e 73 69 67 6e 65 64 20 63 68 61 72 20 2a 6f 75  nsigned char *ou
0b20: 74 3b 0a 20 20 75 6e 73 69 67 6e 65 64 20 63 68  t;.  unsigned ch
0b30: 61 72 20 2a 69 6e 3b 0a 20 20 69 6e 74 20 69 6e  ar *in;.  int in
0b40: 5f 6c 65 6e 3b 0a 20 20 54 63 6c 5f 4f 62 6a 20  _len;.  Tcl_Obj 
0b50: 2a 72 65 73 3b 0a 0a 20 20 69 66 28 20 6f 62 6a  *res;..  if( obj
0b60: 63 21 3d 32 20 29 7b 0a 20 20 20 20 54 63 6c 5f  c!=2 ){.    Tcl_
0b70: 41 70 70 65 6e 64 52 65 73 75 6c 74 28 69 6e 74  AppendResult(int
0b80: 65 72 70 2c 20 22 77 72 6f 6e 67 20 23 20 61 72  erp, "wrong # ar
0b90: 67 73 3a 20 73 68 6f 75 6c 64 20 62 65 20 5c 22  gs: should be \"
0ba0: 22 2c 0a 20 20 20 20 20 20 20 20 54 63 6c 5f 47  ",.        Tcl_G
0bb0: 65 74 53 74 72 69 6e 67 46 72 6f 6d 4f 62 6a 28  etStringFromObj(
0bc0: 6f 62 6a 76 5b 30 5d 2c 20 30 29 2c 20 22 3c 75  objv[0], 0), "<u
0bd0: 74 66 2d 31 36 20 65 6e 63 6f 64 65 64 2d 73 74  tf-16 encoded-st
0be0: 72 69 6e 67 3e 22 2c 20 30 29 3b 0a 20 20 20 20  ring>", 0);.    
0bf0: 72 65 74 75 72 6e 20 54 43 4c 5f 45 52 52 4f 52  return TCL_ERROR
0c00: 3b 0a 20 20 7d 0a 0a 20 20 69 6e 20 3d 20 54 63  ;.  }..  in = Tc
0c10: 6c 5f 47 65 74 42 79 74 65 41 72 72 61 79 46 72  l_GetByteArrayFr
0c20: 6f 6d 4f 62 6a 28 6f 62 6a 76 5b 31 5d 2c 20 26  omObj(objv[1], &
0c30: 69 6e 5f 6c 65 6e 29 3b 0a 20 20 6f 75 74 20 3d  in_len);.  out =
0c40: 20 28 75 6e 73 69 67 6e 65 64 20 63 68 61 72 20   (unsigned char 
0c50: 2a 29 73 71 6c 69 74 65 4d 61 6c 6c 6f 63 28 69  *)sqliteMalloc(i
0c60: 6e 5f 6c 65 6e 29 3b 0a 20 20 6d 65 6d 63 70 79  n_len);.  memcpy
0c70: 28 6f 75 74 2c 20 69 6e 2c 20 69 6e 5f 6c 65 6e  (out, in, in_len
0c80: 29 3b 0a 20 20 0a 20 20 73 71 6c 69 74 65 33 75  );.  .  sqlite3u
0c90: 74 66 31 36 74 6f 31 36 62 65 28 6f 75 74 2c 20  tf16to16be(out, 
0ca0: 2d 31 29 3b 0a 20 20 72 65 73 20 3d 20 54 63 6c  -1);.  res = Tcl
0cb0: 5f 4e 65 77 42 79 74 65 41 72 72 61 79 4f 62 6a  _NewByteArrayObj
0cc0: 28 6f 75 74 2c 20 75 74 66 31 36 5f 6c 65 6e 67  (out, utf16_leng
0cd0: 74 68 28 6f 75 74 29 29 3b 0a 20 20 73 71 6c 69  th(out));.  sqli
0ce0: 74 65 46 72 65 65 28 6f 75 74 29 3b 0a 0a 20 20  teFree(out);..  
0cf0: 54 63 6c 5f 53 65 74 4f 62 6a 52 65 73 75 6c 74  Tcl_SetObjResult
0d00: 28 69 6e 74 65 72 70 2c 20 72 65 73 29 3b 0a 0a  (interp, res);..
0d10: 20 20 72 65 74 75 72 6e 20 54 43 4c 5f 4f 4b 3b    return TCL_OK;
0d20: 0a 7d 0a 0a 73 74 61 74 69 63 20 69 6e 74 20 73  .}..static int s
0d30: 71 6c 69 74 65 5f 75 74 66 31 36 74 6f 38 28 0a  qlite_utf16to8(.
0d40: 20 20 76 6f 69 64 20 2a 20 63 6c 69 65 6e 74 44    void * clientD
0d50: 61 74 61 2c 0a 20 20 54 63 6c 5f 49 6e 74 65 72  ata,.  Tcl_Inter
0d60: 70 20 2a 69 6e 74 65 72 70 2c 0a 20 20 69 6e 74  p *interp,.  int
0d70: 20 6f 62 6a 63 2c 0a 20 20 54 63 6c 5f 4f 62 6a   objc,.  Tcl_Obj
0d80: 20 2a 43 4f 4e 53 54 20 6f 62 6a 76 5b 5d 0a 29   *CONST objv[].)
0d90: 7b 0a 20 20 75 6e 73 69 67 6e 65 64 20 63 68 61  {.  unsigned cha
0da0: 72 20 2a 6f 75 74 3b 0a 20 20 75 6e 73 69 67 6e  r *out;.  unsign
0db0: 65 64 20 63 68 61 72 20 2a 69 6e 3b 0a 20 20 54  ed char *in;.  T
0dc0: 63 6c 5f 4f 62 6a 20 2a 72 65 73 3b 0a 0a 20 20  cl_Obj *res;..  
0dd0: 69 66 28 20 6f 62 6a 63 21 3d 32 20 29 7b 0a 20  if( objc!=2 ){. 
0de0: 20 20 20 54 63 6c 5f 41 70 70 65 6e 64 52 65 73     Tcl_AppendRes
0df0: 75 6c 74 28 69 6e 74 65 72 70 2c 20 22 77 72 6f  ult(interp, "wro
0e00: 6e 67 20 23 20 61 72 67 73 3a 20 73 68 6f 75 6c  ng # args: shoul
0e10: 64 20 62 65 20 5c 22 22 2c 0a 20 20 20 20 20 20  d be \"",.      
0e20: 20 20 54 63 6c 5f 47 65 74 53 74 72 69 6e 67 46    Tcl_GetStringF
0e30: 72 6f 6d 4f 62 6a 28 6f 62 6a 76 5b 30 5d 2c 20  romObj(objv[0], 
0e40: 30 29 2c 20 22 3c 75 74 66 2d 31 36 20 65 6e 63  0), "<utf-16 enc
0e50: 6f 64 65 64 2d 73 74 72 69 6e 67 3e 22 2c 20 30  oded-string>", 0
0e60: 29 3b 0a 20 20 20 20 72 65 74 75 72 6e 20 54 43  );.    return TC
0e70: 4c 5f 45 52 52 4f 52 3b 0a 20 20 7d 0a 0a 20 20  L_ERROR;.  }..  
0e80: 69 6e 20 3d 20 54 63 6c 5f 47 65 74 42 79 74 65  in = Tcl_GetByte
0e90: 41 72 72 61 79 46 72 6f 6d 4f 62 6a 28 6f 62 6a  ArrayFromObj(obj
0ea0: 76 5b 31 5d 2c 20 30 29 3b 0a 20 20 6f 75 74 20  v[1], 0);.  out 
0eb0: 3d 20 73 71 6c 69 74 65 33 75 74 66 31 36 74 6f  = sqlite3utf16to
0ec0: 38 28 69 6e 2c 20 2d 31 29 3b 0a 20 20 72 65 73  8(in, -1);.  res
0ed0: 20 3d 20 54 63 6c 5f 4e 65 77 42 79 74 65 41 72   = Tcl_NewByteAr
0ee0: 72 61 79 4f 62 6a 28 6f 75 74 2c 20 73 74 72 6c  rayObj(out, strl
0ef0: 65 6e 28 6f 75 74 29 29 3b 0a 20 20 73 71 6c 69  en(out));.  sqli
0f00: 74 65 46 72 65 65 28 6f 75 74 29 3b 0a 0a 20 20  teFree(out);..  
0f10: 54 63 6c 5f 53 65 74 4f 62 6a 52 65 73 75 6c 74  Tcl_SetObjResult
0f20: 28 69 6e 74 65 72 70 2c 20 72 65 73 29 3b 0a 0a  (interp, res);..
0f30: 20 20 72 65 74 75 72 6e 20 54 43 4c 5f 4f 4b 3b    return TCL_OK;
0f40: 0a 7d 0a 0a 0a 2f 2a 0a 2a 2a 20 52 65 67 69 73  .}.../*.** Regis
0f50: 74 65 72 20 63 6f 6d 6d 61 6e 64 73 20 77 69 74  ter commands wit
0f60: 68 20 74 68 65 20 54 43 4c 20 69 6e 74 65 72 70  h the TCL interp
0f70: 72 65 74 65 72 2e 0a 2a 2f 0a 69 6e 74 20 53 71  reter..*/.int Sq
0f80: 6c 69 74 65 74 65 73 74 35 5f 49 6e 69 74 28 54  litetest5_Init(T
0f90: 63 6c 5f 49 6e 74 65 72 70 20 2a 69 6e 74 65 72  cl_Interp *inter
0fa0: 70 29 7b 0a 20 20 73 74 61 74 69 63 20 73 74 72  p){.  static str
0fb0: 75 63 74 20 7b 0a 20 20 20 20 63 68 61 72 20 2a  uct {.    char *
0fc0: 7a 4e 61 6d 65 3b 0a 20 20 20 20 54 63 6c 5f 43  zName;.    Tcl_C
0fd0: 6d 64 50 72 6f 63 20 2a 78 50 72 6f 63 3b 0a 20  mdProc *xProc;. 
0fe0: 20 7d 20 61 43 6d 64 5b 5d 20 3d 20 7b 0a 20 20   } aCmd[] = {.  
0ff0: 20 20 7b 20 22 73 71 6c 69 74 65 5f 75 74 66 31    { "sqlite_utf1
1000: 36 74 6f 38 22 2c 20 20 20 20 20 20 20 20 20 28  6to8",         (
1010: 54 63 6c 5f 43 6d 64 50 72 6f 63 2a 29 73 71 6c  Tcl_CmdProc*)sql
1020: 69 74 65 5f 75 74 66 31 36 74 6f 38 20 20 20 20  ite_utf16to8    
1030: 7d 2c 0a 20 20 20 20 7b 20 22 73 71 6c 69 74 65  },.    { "sqlite
1040: 5f 75 74 66 38 74 6f 31 36 6c 65 22 2c 20 20 20  _utf8to16le",   
1050: 20 20 20 20 28 54 63 6c 5f 43 6d 64 50 72 6f 63      (Tcl_CmdProc
1060: 2a 29 73 71 6c 69 74 65 5f 75 74 66 38 74 6f 31  *)sqlite_utf8to1
1070: 36 6c 65 20 20 7d 2c 0a 20 20 20 20 7b 20 22 73  6le  },.    { "s
1080: 71 6c 69 74 65 5f 75 74 66 38 74 6f 31 36 62 65  qlite_utf8to16be
1090: 22 2c 20 20 20 20 20 20 20 28 54 63 6c 5f 43 6d  ",       (Tcl_Cm
10a0: 64 50 72 6f 63 2a 29 73 71 6c 69 74 65 5f 75 74  dProc*)sqlite_ut
10b0: 66 38 74 6f 31 36 62 65 20 20 7d 2c 0a 20 20 20  f8to16be  },.   
10c0: 20 7b 20 22 73 71 6c 69 74 65 5f 75 74 66 31 36   { "sqlite_utf16
10d0: 74 6f 31 36 6c 65 22 2c 20 20 20 20 20 20 28 54  to16le",      (T
10e0: 63 6c 5f 43 6d 64 50 72 6f 63 2a 29 73 71 6c 69  cl_CmdProc*)sqli
10f0: 74 65 5f 75 74 66 31 36 74 6f 31 36 6c 65 20 7d  te_utf16to16le }
1100: 2c 0a 20 20 20 20 7b 20 22 73 71 6c 69 74 65 5f  ,.    { "sqlite_
1110: 75 74 66 31 36 74 6f 31 36 62 65 22 2c 20 20 20  utf16to16be",   
1120: 20 20 20 28 54 63 6c 5f 43 6d 64 50 72 6f 63 2a     (Tcl_CmdProc*
1130: 29 73 71 6c 69 74 65 5f 75 74 66 31 36 74 6f 31  )sqlite_utf16to1
1140: 36 62 65 20 7d 0a 20 20 7d 3b 0a 20 20 69 6e 74  6be }.  };.  int
1150: 20 69 3b 0a 20 20 66 6f 72 28 69 3d 30 3b 20 69   i;.  for(i=0; i
1160: 3c 73 69 7a 65 6f 66 28 61 43 6d 64 29 2f 73 69  <sizeof(aCmd)/si
1170: 7a 65 6f 66 28 61 43 6d 64 5b 30 5d 29 3b 20 69  zeof(aCmd[0]); i
1180: 2b 2b 29 7b 0a 20 20 20 20 54 63 6c 5f 43 72 65  ++){.    Tcl_Cre
1190: 61 74 65 43 6f 6d 6d 61 6e 64 28 69 6e 74 65 72  ateCommand(inter
11a0: 70 2c 20 61 43 6d 64 5b 69 5d 2e 7a 4e 61 6d 65  p, aCmd[i].zName
11b0: 2c 20 61 43 6d 64 5b 69 5d 2e 78 50 72 6f 63 2c  , aCmd[i].xProc,
11c0: 20 30 2c 20 30 29 3b 0a 20 20 7d 0a 0a 20 20 72   0, 0);.  }..  r
11d0: 65 74 75 72 6e 20 54 43 4c 5f 4f 4b 3b 0a 7d 0a  eturn TCL_OK;.}.