Hex Artifact Content

Artifact 559c05a44b13ae1ea9eb18b7872435605427b1d529a9f0af1f6f80ed09111aa9:


0000: 2f 2a 0a 20 2a 20 43 72 79 70 74 6f 67 72 61 70  /*. * Cryptograp
0010: 68 69 63 20 55 74 69 6c 69 74 79 20 46 75 6e 63  hic Utility Func
0020: 74 69 6f 6e 73 0a 20 2a 0a 20 2a 20 50 72 6f 76  tions. *. * Prov
0030: 69 64 65 73 20 63 6f 6d 6d 61 6e 64 73 20 74 6f  ides commands to
0040: 20 64 65 72 69 76 65 20 6b 65 79 73 2e 0a 20 2a   derive keys.. *
0050: 0a 20 2a 20 43 6f 70 79 72 69 67 68 74 20 28 43  . * Copyright (C
0060: 29 20 32 30 32 33 20 42 72 69 61 6e 20 4f 27 48  ) 2023 Brian O'H
0070: 61 67 61 6e 0a 20 2a 0a 20 2a 2f 0a 0a 23 69 6e  agan. *. */..#in
0080: 63 6c 75 64 65 20 22 74 6c 73 49 6e 74 2e 68 22  clude "tlsInt.h"
0090: 0a 23 69 6e 63 6c 75 64 65 20 22 74 63 6c 4f 70  .#include "tclOp
00a0: 74 73 2e 68 22 0a 23 69 6e 63 6c 75 64 65 20 3c  ts.h".#include <
00b0: 6f 70 65 6e 73 73 6c 2f 65 76 70 2e 68 3e 0a 0a  openssl/evp.h>..
00c0: 0a 2f 2a 0a 20 2a 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ./*. *----------
00d0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
00e0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
00f0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0100: 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 20 2a 0a 20 2a 20  ---------. *. * 
0110: 55 74 69 6c 5f 47 65 74 43 69 70 68 65 72 20 2d  Util_GetCipher -
0120: 2d 0a 20 2a 0a 20 2a 09 47 65 74 20 73 79 6d 6d  -. *. *.Get symm
0130: 65 74 72 69 63 20 63 69 70 68 65 72 20 66 72 6f  etric cipher fro
0140: 6d 20 54 63 6c 4f 62 6a 0a 20 2a 0a 20 2a 20 52  m TclObj. *. * R
0150: 65 74 75 72 6e 73 3a 0a 20 2a 09 50 6f 69 6e 74  eturns:. *.Point
0160: 65 72 20 74 6f 20 74 79 70 65 20 6f 72 20 4e 55  er to type or NU
0170: 4c 4c 0a 20 2a 0a 20 2a 20 53 69 64 65 20 65 66  LL. *. * Side ef
0180: 66 65 63 74 73 3a 0a 20 2a 09 4e 6f 6e 65 0a 20  fects:. *.None. 
0190: 2a 0a 20 2a 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  *. *------------
01a0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
01b0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
01c0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
01d0: 2d 2d 2d 2d 2d 2d 2d 0a 20 2a 2f 0a 45 56 50 5f  -------. */.EVP_
01e0: 43 49 50 48 45 52 20 2a 55 74 69 6c 5f 47 65 74  CIPHER *Util_Get
01f0: 43 69 70 68 65 72 28 54 63 6c 5f 49 6e 74 65 72  Cipher(Tcl_Inter
0200: 70 20 2a 69 6e 74 65 72 70 2c 20 54 63 6c 5f 4f  p *interp, Tcl_O
0210: 62 6a 20 2a 63 69 70 68 65 72 4f 62 6a 2c 20 69  bj *cipherObj, i
0220: 6e 74 20 6e 6f 5f 6e 75 6c 6c 29 20 7b 0a 20 20  nt no_null) {.  
0230: 20 20 45 56 50 5f 43 49 50 48 45 52 20 2a 63 69    EVP_CIPHER *ci
0240: 70 68 65 72 20 3d 20 4e 55 4c 4c 3b 0a 20 20 20  pher = NULL;.   
0250: 20 63 68 61 72 20 2a 6e 61 6d 65 20 3d 20 4e 55   char *name = NU
0260: 4c 4c 3b 0a 0a 20 20 20 20 69 66 20 28 63 69 70  LL;..    if (cip
0270: 68 65 72 4f 62 6a 20 21 3d 20 4e 55 4c 4c 29 20  herObj != NULL) 
0280: 7b 0a 09 6e 61 6d 65 20 3d 20 54 63 6c 5f 47 65  {..name = Tcl_Ge
0290: 74 53 74 72 69 6e 67 28 63 69 70 68 65 72 4f 62  tString(cipherOb
02a0: 6a 29 3b 0a 23 69 66 20 4f 50 45 4e 53 53 4c 5f  j);.#if OPENSSL_
02b0: 56 45 52 53 49 4f 4e 5f 4e 55 4d 42 45 52 20 3c  VERSION_NUMBER <
02c0: 20 30 78 33 30 30 30 30 30 30 30 4c 0a 09 63 69   0x30000000L..ci
02d0: 70 68 65 72 20 3d 20 45 56 50 5f 67 65 74 5f 63  pher = EVP_get_c
02e0: 69 70 68 65 72 62 79 6e 61 6d 65 28 6e 61 6d 65  ipherbyname(name
02f0: 29 3b 0a 23 65 6c 73 65 0a 09 63 69 70 68 65 72  );.#else..cipher
0300: 20 3d 20 45 56 50 5f 43 49 50 48 45 52 5f 66 65   = EVP_CIPHER_fe
0310: 74 63 68 28 4e 55 4c 4c 2c 20 6e 61 6d 65 2c 20  tch(NULL, name, 
0320: 4e 55 4c 4c 29 3b 0a 23 65 6e 64 69 66 0a 09 69  NULL);.#endif..i
0330: 66 20 28 63 69 70 68 65 72 20 3d 3d 20 4e 55 4c  f (cipher == NUL
0340: 4c 29 20 7b 0a 09 20 20 20 20 54 63 6c 5f 41 70  L) {..    Tcl_Ap
0350: 70 65 6e 64 52 65 73 75 6c 74 28 69 6e 74 65 72  pendResult(inter
0360: 70 2c 20 22 69 6e 76 61 6c 69 64 20 63 69 70 68  p, "invalid ciph
0370: 65 72 20 5c 22 22 2c 20 6e 61 6d 65 2c 20 22 5c  er \"", name, "\
0380: 22 22 2c 20 28 63 68 61 72 20 2a 29 20 4e 55 4c  "", (char *) NUL
0390: 4c 29 3b 0a 09 7d 0a 20 20 20 20 7d 20 65 6c 73  L);..}.    } els
03a0: 65 20 69 66 20 28 6e 6f 5f 6e 75 6c 6c 29 20 7b  e if (no_null) {
03b0: 0a 09 54 63 6c 5f 41 70 70 65 6e 64 52 65 73 75  ..Tcl_AppendResu
03c0: 6c 74 28 69 6e 74 65 72 70 2c 20 22 6e 6f 20 63  lt(interp, "no c
03d0: 69 70 68 65 72 22 2c 20 28 63 68 61 72 20 2a 29  ipher", (char *)
03e0: 20 4e 55 4c 4c 29 3b 0a 20 20 20 20 7d 0a 20 20   NULL);.    }.  
03f0: 20 20 72 65 74 75 72 6e 20 63 69 70 68 65 72 3b    return cipher;
0400: 0a 7d 0a 0a 2f 2a 0a 20 2a 2d 2d 2d 2d 2d 2d 2d  .}../*. *-------
0410: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0420: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0430: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0440: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 20 2a 0a  ------------. *.
0450: 20 2a 20 55 74 69 6c 5f 47 65 74 44 69 67 65 73   * Util_GetDiges
0460: 74 20 2d 2d 0a 20 2a 0a 20 2a 09 47 65 74 20 6d  t --. *. *.Get m
0470: 65 73 73 61 67 65 20 64 69 67 65 73 74 20 28 4d  essage digest (M
0480: 44 29 20 6f 72 20 68 61 73 68 20 66 72 6f 6d 20  D) or hash from 
0490: 54 63 6c 4f 62 6a 0a 20 2a 0a 20 2a 20 52 65 74  TclObj. *. * Ret
04a0: 75 72 6e 73 3a 0a 20 2a 09 50 6f 69 6e 74 65 72  urns:. *.Pointer
04b0: 20 74 6f 20 74 79 70 65 20 6f 72 20 4e 55 4c 4c   to type or NULL
04c0: 0a 20 2a 0a 20 2a 20 53 69 64 65 20 65 66 66 65  . *. * Side effe
04d0: 63 74 73 3a 0a 20 2a 09 4e 6f 6e 65 0a 20 2a 0a  cts:. *.None. *.
04e0: 20 2a 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d   *--------------
04f0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0500: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0510: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0520: 2d 2d 2d 2d 2d 0a 20 2a 2f 0a 45 56 50 5f 4d 44  -----. */.EVP_MD
0530: 20 2a 55 74 69 6c 5f 47 65 74 44 69 67 65 73 74   *Util_GetDigest
0540: 28 54 63 6c 5f 49 6e 74 65 72 70 20 2a 69 6e 74  (Tcl_Interp *int
0550: 65 72 70 2c 20 54 63 6c 5f 4f 62 6a 20 2a 64 69  erp, Tcl_Obj *di
0560: 67 65 73 74 4f 62 6a 2c 20 69 6e 74 20 6e 6f 5f  gestObj, int no_
0570: 6e 75 6c 6c 29 20 7b 0a 20 20 20 20 45 56 50 5f  null) {.    EVP_
0580: 4d 44 20 2a 6d 64 20 3d 20 4e 55 4c 4c 3b 0a 20  MD *md = NULL;. 
0590: 20 20 20 63 68 61 72 20 2a 6e 61 6d 65 20 3d 20     char *name = 
05a0: 4e 55 4c 4c 3b 0a 0a 20 20 20 20 69 66 20 28 64  NULL;..    if (d
05b0: 69 67 65 73 74 4f 62 6a 20 21 3d 20 4e 55 4c 4c  igestObj != NULL
05c0: 29 20 7b 0a 09 6e 61 6d 65 20 3d 20 54 63 6c 5f  ) {..name = Tcl_
05d0: 47 65 74 53 74 72 69 6e 67 28 64 69 67 65 73 74  GetString(digest
05e0: 4f 62 6a 29 3b 0a 23 69 66 20 4f 50 45 4e 53 53  Obj);.#if OPENSS
05f0: 4c 5f 56 45 52 53 49 4f 4e 5f 4e 55 4d 42 45 52  L_VERSION_NUMBER
0600: 20 3c 20 30 78 33 30 30 30 30 30 30 30 4c 0a 09   < 0x30000000L..
0610: 6d 64 20 3d 20 45 56 50 5f 67 65 74 5f 64 69 67  md = EVP_get_dig
0620: 65 73 74 62 79 6e 61 6d 65 28 6e 61 6d 65 29 3b  estbyname(name);
0630: 0a 23 65 6c 73 65 0a 09 6d 64 20 3d 20 45 56 50  .#else..md = EVP
0640: 5f 4d 44 5f 66 65 74 63 68 28 4e 55 4c 4c 2c 20  _MD_fetch(NULL, 
0650: 6e 61 6d 65 2c 20 4e 55 4c 4c 29 3b 0a 23 65 6e  name, NULL);.#en
0660: 64 69 66 0a 09 69 66 20 28 6d 64 20 3d 3d 20 4e  dif..if (md == N
0670: 55 4c 4c 29 20 7b 0a 09 20 20 20 20 54 63 6c 5f  ULL) {..    Tcl_
0680: 41 70 70 65 6e 64 52 65 73 75 6c 74 28 69 6e 74  AppendResult(int
0690: 65 72 70 2c 20 22 69 6e 76 61 6c 69 64 20 64 69  erp, "invalid di
06a0: 67 65 73 74 20 5c 22 22 2c 20 6e 61 6d 65 2c 20  gest \"", name, 
06b0: 22 5c 22 22 2c 20 28 63 68 61 72 20 2a 29 20 4e  "\"", (char *) N
06c0: 55 4c 4c 29 3b 0a 09 7d 0a 20 20 20 20 7d 20 65  ULL);..}.    } e
06d0: 6c 73 65 20 69 66 20 28 6e 6f 5f 6e 75 6c 6c 29  lse if (no_null)
06e0: 20 7b 0a 09 54 63 6c 5f 41 70 70 65 6e 64 52 65   {..Tcl_AppendRe
06f0: 73 75 6c 74 28 69 6e 74 65 72 70 2c 20 22 6e 6f  sult(interp, "no
0700: 20 64 69 67 65 73 74 22 2c 20 28 63 68 61 72 20   digest", (char 
0710: 2a 29 20 4e 55 4c 4c 29 3b 0a 20 20 20 20 7d 0a  *) NULL);.    }.
0720: 20 20 20 20 72 65 74 75 72 6e 20 6d 64 3b 0a 7d      return md;.}
0730: 0a 0a 2f 2a 0a 20 2a 2d 2d 2d 2d 2d 2d 2d 2d 2d  ../*. *---------
0740: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0750: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0760: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0770: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 20 2a 0a 20 2a  ----------. *. *
0780: 20 55 74 69 6c 5f 47 65 74 49 56 20 2d 2d 0a 20   Util_GetIV --. 
0790: 2a 0a 20 2a 09 47 65 74 20 65 6e 63 72 79 70 74  *. *.Get encrypt
07a0: 69 6f 6e 20 69 6e 69 74 69 61 6c 69 7a 61 74 69  ion initializati
07b0: 6f 6e 20 76 65 63 74 6f 72 20 6f 72 20 73 65 65  on vector or see
07c0: 64 20 66 72 6f 6d 20 54 63 6c 4f 62 6a 0a 20 2a  d from TclObj. *
07d0: 0a 20 2a 20 52 65 74 75 72 6e 73 3a 0a 20 2a 09  . * Returns:. *.
07e0: 50 6f 69 6e 74 65 72 20 74 6f 20 74 79 70 65 20  Pointer to type 
07f0: 6f 72 20 4e 55 4c 4c 2c 20 61 6e 64 20 73 69 7a  or NULL, and siz
0800: 65 0a 20 2a 0a 20 2a 20 53 69 64 65 20 65 66 66  e. *. * Side eff
0810: 65 63 74 73 3a 0a 20 2a 09 4e 6f 6e 65 0a 20 2a  ects:. *.None. *
0820: 0a 20 2a 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  . *-------------
0830: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0840: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0850: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0860: 2d 2d 2d 2d 2d 2d 0a 20 2a 2f 0a 75 6e 73 69 67  ------. */.unsig
0870: 6e 65 64 20 63 68 61 72 20 2a 55 74 69 6c 5f 47  ned char *Util_G
0880: 65 74 49 56 28 54 63 6c 5f 49 6e 74 65 72 70 20  etIV(Tcl_Interp 
0890: 2a 69 6e 74 65 72 70 2c 20 54 63 6c 5f 4f 62 6a  *interp, Tcl_Obj
08a0: 20 2a 69 76 4f 62 6a 2c 20 54 63 6c 5f 53 69 7a   *ivObj, Tcl_Siz
08b0: 65 20 2a 6c 65 6e 2c 20 69 6e 74 20 6d 61 78 2c  e *len, int max,
08c0: 20 69 6e 74 20 6e 6f 5f 6e 75 6c 6c 29 20 7b 0a   int no_null) {.
08d0: 20 20 20 20 75 6e 73 69 67 6e 65 64 20 63 68 61      unsigned cha
08e0: 72 20 2a 69 76 20 3d 20 4e 55 4c 4c 3b 0a 20 20  r *iv = NULL;.  
08f0: 20 20 2a 6c 65 6e 20 3d 20 30 3b 0a 20 20 20 20    *len = 0;.    
0900: 54 63 6c 5f 53 69 7a 65 20 73 69 7a 65 20 3d 20  Tcl_Size size = 
0910: 30 3b 0a 0a 20 20 20 20 69 66 20 28 69 76 4f 62  0;..    if (ivOb
0920: 6a 20 21 3d 20 4e 55 4c 4c 29 20 7b 0a 09 69 76  j != NULL) {..iv
0930: 20 3d 20 54 63 6c 5f 47 65 74 42 79 74 65 41 72   = Tcl_GetByteAr
0940: 72 61 79 46 72 6f 6d 4f 62 6a 28 69 76 4f 62 6a  rayFromObj(ivObj
0950: 2c 20 26 73 69 7a 65 29 3b 0a 09 2a 6c 65 6e 20  , &size);..*len 
0960: 3d 20 28 69 6e 74 29 20 73 69 7a 65 3b 0a 20 20  = (int) size;.  
0970: 20 20 7d 20 65 6c 73 65 20 69 66 20 28 6e 6f 5f    } else if (no_
0980: 6e 75 6c 6c 29 20 7b 0a 09 54 63 6c 5f 41 70 70  null) {..Tcl_App
0990: 65 6e 64 52 65 73 75 6c 74 28 69 6e 74 65 72 70  endResult(interp
09a0: 2c 20 22 6e 6f 20 69 6e 69 74 69 61 6c 69 7a 61  , "no initializa
09b0: 74 69 6f 6e 20 76 65 63 74 6f 72 20 28 49 56 29  tion vector (IV)
09c0: 22 2c 20 28 63 68 61 72 20 2a 29 20 4e 55 4c 4c  ", (char *) NULL
09d0: 29 3b 0a 09 72 65 74 75 72 6e 20 4e 55 4c 4c 3b  );..return NULL;
09e0: 0a 20 20 20 20 7d 0a 0a 20 20 20 20 69 66 20 28  .    }..    if (
09f0: 6d 61 78 20 3e 20 30 20 26 26 20 2a 6c 65 6e 20  max > 0 && *len 
0a00: 3e 20 6d 61 78 29 20 7b 0a 09 54 63 6c 5f 53 65  > max) {..Tcl_Se
0a10: 74 4f 62 6a 52 65 73 75 6c 74 28 69 6e 74 65 72  tObjResult(inter
0a20: 70 2c 20 54 63 6c 5f 4f 62 6a 50 72 69 6e 74 66  p, Tcl_ObjPrintf
0a30: 28 22 49 56 20 74 6f 6f 20 6c 6f 6e 67 2e 20 4d  ("IV too long. M
0a40: 75 73 74 20 62 65 20 3c 3d 20 25 64 20 62 79 74  ust be <= %d byt
0a50: 65 73 22 2c 20 6d 61 78 29 29 3b 0a 09 72 65 74  es", max));..ret
0a60: 75 72 6e 20 4e 55 4c 4c 3b 0a 20 20 20 20 7d 0a  urn NULL;.    }.
0a70: 20 20 20 20 72 65 74 75 72 6e 20 69 76 3b 0a 7d      return iv;.}
0a80: 0a 0a 2f 2a 0a 20 2a 2d 2d 2d 2d 2d 2d 2d 2d 2d  ../*. *---------
0a90: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0aa0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0ab0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0ac0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 20 2a 0a 20 2a  ----------. *. *
0ad0: 20 55 74 69 6c 5f 47 65 74 4b 65 79 20 2d 2d 0a   Util_GetKey --.
0ae0: 20 2a 0a 20 2a 09 47 65 74 20 65 6e 63 72 79 70   *. *.Get encryp
0af0: 74 69 6f 6e 20 6b 65 79 20 6f 72 20 70 61 73 73  tion key or pass
0b00: 77 6f 72 64 20 66 72 6f 6d 20 54 63 6c 4f 62 6a  word from TclObj
0b10: 0a 20 2a 0a 20 2a 20 52 65 74 75 72 6e 73 3a 0a  . *. * Returns:.
0b20: 20 2a 09 50 6f 69 6e 74 65 72 20 74 6f 20 74 79   *.Pointer to ty
0b30: 70 65 20 6f 72 20 4e 55 4c 4c 2c 20 61 6e 64 20  pe or NULL, and 
0b40: 73 69 7a 65 0a 20 2a 0a 20 2a 20 53 69 64 65 20  size. *. * Side 
0b50: 65 66 66 65 63 74 73 3a 0a 20 2a 09 4e 6f 6e 65  effects:. *.None
0b60: 0a 20 2a 0a 20 2a 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  . *. *----------
0b70: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0b80: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0b90: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0ba0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 20 2a 2f 0a 75 6e  ---------. */.un
0bb0: 73 69 67 6e 65 64 20 63 68 61 72 20 2a 55 74 69  signed char *Uti
0bc0: 6c 5f 47 65 74 4b 65 79 28 54 63 6c 5f 49 6e 74  l_GetKey(Tcl_Int
0bd0: 65 72 70 20 2a 69 6e 74 65 72 70 2c 20 54 63 6c  erp *interp, Tcl
0be0: 5f 4f 62 6a 20 2a 6b 65 79 4f 62 6a 2c 20 54 63  _Obj *keyObj, Tc
0bf0: 6c 5f 53 69 7a 65 20 2a 6c 65 6e 2c 20 63 68 61  l_Size *len, cha
0c00: 72 20 2a 6e 61 6d 65 2c 20 69 6e 74 20 6d 61 78  r *name, int max
0c10: 2c 20 69 6e 74 20 6e 6f 5f 6e 75 6c 6c 29 20 7b  , int no_null) {
0c20: 0a 20 20 20 20 75 6e 73 69 67 6e 65 64 20 63 68  .    unsigned ch
0c30: 61 72 20 2a 6b 65 79 20 3d 20 4e 55 4c 4c 3b 0a  ar *key = NULL;.
0c40: 20 20 20 20 2a 6c 65 6e 20 3d 20 30 3b 0a 0a 20      *len = 0;.. 
0c50: 20 20 20 69 66 20 28 6b 65 79 4f 62 6a 20 21 3d     if (keyObj !=
0c60: 20 4e 55 4c 4c 29 20 7b 0a 09 6b 65 79 20 3d 20   NULL) {..key = 
0c70: 54 63 6c 5f 47 65 74 42 79 74 65 41 72 72 61 79  Tcl_GetByteArray
0c80: 46 72 6f 6d 4f 62 6a 28 6b 65 79 4f 62 6a 2c 20  FromObj(keyObj, 
0c90: 6c 65 6e 29 3b 0a 20 20 20 20 7d 20 65 6c 73 65  len);.    } else
0ca0: 20 69 66 20 28 6e 6f 5f 6e 75 6c 6c 29 20 7b 0a   if (no_null) {.
0cb0: 09 54 63 6c 5f 41 70 70 65 6e 64 52 65 73 75 6c  .Tcl_AppendResul
0cc0: 74 28 69 6e 74 65 72 70 2c 20 22 6e 6f 20 22 2c  t(interp, "no ",
0cd0: 20 6e 61 6d 65 2c 20 28 63 68 61 72 20 2a 29 20   name, (char *) 
0ce0: 4e 55 4c 4c 29 3b 0a 09 72 65 74 75 72 6e 20 4e  NULL);..return N
0cf0: 55 4c 4c 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20  ULL;.    }..    
0d00: 69 66 20 28 6d 61 78 20 3e 20 30 20 26 26 20 2a  if (max > 0 && *
0d10: 6c 65 6e 20 3e 20 6d 61 78 29 20 7b 0a 09 54 63  len > max) {..Tc
0d20: 6c 5f 53 65 74 4f 62 6a 52 65 73 75 6c 74 28 69  l_SetObjResult(i
0d30: 6e 74 65 72 70 2c 20 54 63 6c 5f 4f 62 6a 50 72  nterp, Tcl_ObjPr
0d40: 69 6e 74 66 28 22 49 6e 76 61 6c 69 64 20 25 73  intf("Invalid %s
0d50: 20 6c 65 6e 67 74 68 2e 20 4d 75 73 74 20 62 65   length. Must be
0d60: 20 3c 3d 20 25 64 20 62 79 74 65 73 22 2c 20 6e   <= %d bytes", n
0d70: 61 6d 65 2c 20 6d 61 78 29 29 3b 0a 09 72 65 74  ame, max));..ret
0d80: 75 72 6e 20 4e 55 4c 4c 3b 0a 20 20 20 20 7d 0a  urn NULL;.    }.
0d90: 20 20 20 20 72 65 74 75 72 6e 20 6b 65 79 3b 0a      return key;.
0da0: 7d 0a 0a 2f 2a 0a 20 2a 2d 2d 2d 2d 2d 2d 2d 2d  }../*. *--------
0db0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0dc0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0dd0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0de0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 20 2a 0a 20  -----------. *. 
0df0: 2a 20 55 74 69 6c 5f 47 65 74 4d 41 43 20 2d 2d  * Util_GetMAC --
0e00: 0a 20 2a 0a 20 2a 09 47 65 74 20 4d 65 73 73 61  . *. *.Get Messa
0e10: 67 65 20 41 75 74 68 65 6e 74 69 63 61 74 69 6f  ge Authenticatio
0e20: 6e 20 43 6f 64 65 20 28 4d 41 43 29 20 66 72 6f  n Code (MAC) fro
0e30: 6d 20 54 63 6c 4f 62 6a 0a 20 2a 0a 20 2a 20 52  m TclObj. *. * R
0e40: 65 74 75 72 6e 73 3a 0a 20 2a 09 50 6f 69 6e 74  eturns:. *.Point
0e50: 65 72 20 74 6f 20 74 79 70 65 20 6f 72 20 4e 55  er to type or NU
0e60: 4c 4c 0a 20 2a 0a 20 2a 20 53 69 64 65 20 65 66  LL. *. * Side ef
0e70: 66 65 63 74 73 3a 0a 20 2a 09 4e 6f 6e 65 0a 20  fects:. *.None. 
0e80: 2a 0a 20 2a 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  *. *------------
0e90: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0ea0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0eb0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
0ec0: 2d 2d 2d 2d 2d 2d 2d 0a 20 2a 2f 0a 23 69 66 20  -------. */.#if 
0ed0: 4f 50 45 4e 53 53 4c 5f 56 45 52 53 49 4f 4e 5f  OPENSSL_VERSION_
0ee0: 4e 55 4d 42 45 52 20 3e 3d 20 30 78 33 30 30 30  NUMBER >= 0x3000
0ef0: 30 30 30 30 4c 0a 45 56 50 5f 4d 41 43 20 2a 55  0000L.EVP_MAC *U
0f00: 74 69 6c 5f 47 65 74 4d 41 43 28 54 63 6c 5f 49  til_GetMAC(Tcl_I
0f10: 6e 74 65 72 70 20 2a 69 6e 74 65 72 70 2c 20 54  nterp *interp, T
0f20: 63 6c 5f 4f 62 6a 20 2a 4d 61 63 4f 62 6a 2c 20  cl_Obj *MacObj, 
0f30: 69 6e 74 20 6e 6f 5f 6e 75 6c 6c 29 20 7b 0a 20  int no_null) {. 
0f40: 20 20 20 45 56 50 5f 4d 41 43 20 2a 6d 61 63 20     EVP_MAC *mac 
0f50: 3d 20 4e 55 4c 4c 3b 0a 20 20 20 20 63 68 61 72  = NULL;.    char
0f60: 20 2a 6e 61 6d 65 20 3d 20 4e 55 4c 4c 3b 0a 0a   *name = NULL;..
0f70: 20 20 20 20 69 66 20 28 4d 61 63 4f 62 6a 20 21      if (MacObj !
0f80: 3d 20 4e 55 4c 4c 29 20 7b 0a 09 6e 61 6d 65 20  = NULL) {..name 
0f90: 3d 20 54 63 6c 5f 47 65 74 53 74 72 69 6e 67 28  = Tcl_GetString(
0fa0: 4d 61 63 4f 62 6a 29 3b 0a 09 6d 61 63 20 3d 20  MacObj);..mac = 
0fb0: 45 56 50 5f 4d 41 43 5f 66 65 74 63 68 28 4e 55  EVP_MAC_fetch(NU
0fc0: 4c 4c 2c 20 6e 61 6d 65 2c 20 4e 55 4c 4c 29 3b  LL, name, NULL);
0fd0: 0a 09 69 66 20 28 6d 61 63 20 3d 3d 20 4e 55 4c  ..if (mac == NUL
0fe0: 4c 29 20 7b 0a 09 20 20 20 20 54 63 6c 5f 41 70  L) {..    Tcl_Ap
0ff0: 70 65 6e 64 52 65 73 75 6c 74 28 69 6e 74 65 72  pendResult(inter
1000: 70 2c 20 22 69 6e 76 61 6c 69 64 20 4d 41 43 20  p, "invalid MAC 
1010: 5c 22 22 2c 20 6e 61 6d 65 2c 20 22 5c 22 22 2c  \"", name, "\"",
1020: 20 28 63 68 61 72 20 2a 29 20 4e 55 4c 4c 29 3b   (char *) NULL);
1030: 0a 09 20 20 20 20 72 65 74 75 72 6e 20 4e 55 4c  ..    return NUL
1040: 4c 3b 0a 09 7d 0a 20 20 20 20 7d 20 65 6c 73 65  L;..}.    } else
1050: 20 69 66 20 28 6e 6f 5f 6e 75 6c 6c 29 20 7b 0a   if (no_null) {.
1060: 09 54 63 6c 5f 41 70 70 65 6e 64 52 65 73 75 6c  .Tcl_AppendResul
1070: 74 28 69 6e 74 65 72 70 2c 20 22 6e 6f 20 4d 41  t(interp, "no MA
1080: 43 22 2c 20 28 63 68 61 72 20 2a 29 20 4e 55 4c  C", (char *) NUL
1090: 4c 29 3b 0a 20 20 20 20 7d 0a 20 20 20 20 72 65  L);.    }.    re
10a0: 74 75 72 6e 20 6d 61 63 3b 0a 7d 0a 23 65 6e 64  turn mac;.}.#end
10b0: 69 66 0a 0a 2f 2a 0a 20 2a 2d 2d 2d 2d 2d 2d 2d  if../*. *-------
10c0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
10d0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
10e0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
10f0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 20 2a 0a  ------------. *.
1100: 20 2a 20 55 74 69 6c 5f 47 65 74 53 61 6c 74 20   * Util_GetSalt 
1110: 2d 2d 0a 20 2a 0a 20 2a 09 47 65 74 20 65 6e 63  --. *. *.Get enc
1120: 72 79 70 74 69 6f 6e 20 73 61 6c 74 20 66 72 6f  ryption salt fro
1130: 6d 20 54 63 6c 4f 62 6a 0a 20 2a 0a 20 2a 20 52  m TclObj. *. * R
1140: 65 74 75 72 6e 73 3a 0a 20 2a 09 50 6f 69 6e 74  eturns:. *.Point
1150: 65 72 20 74 6f 20 74 79 70 65 20 6f 72 20 4e 55  er to type or NU
1160: 4c 4c 2c 20 61 6e 64 20 73 69 7a 65 0a 20 2a 0a  LL, and size. *.
1170: 20 2a 20 53 69 64 65 20 65 66 66 65 63 74 73 3a   * Side effects:
1180: 0a 20 2a 09 4e 6f 6e 65 0a 20 2a 0a 20 2a 2d 2d  . *.None. *. *--
1190: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
11a0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
11b0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
11c0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
11d0: 2d 0a 20 2a 2f 0a 75 6e 73 69 67 6e 65 64 20 63  -. */.unsigned c
11e0: 68 61 72 20 2a 55 74 69 6c 5f 47 65 74 53 61 6c  har *Util_GetSal
11f0: 74 28 54 63 6c 5f 49 6e 74 65 72 70 20 2a 69 6e  t(Tcl_Interp *in
1200: 74 65 72 70 2c 20 54 63 6c 5f 4f 62 6a 20 2a 73  terp, Tcl_Obj *s
1210: 61 6c 74 4f 62 6a 2c 20 54 63 6c 5f 53 69 7a 65  altObj, Tcl_Size
1220: 20 2a 6c 65 6e 2c 20 69 6e 74 20 6d 61 78 2c 20   *len, int max, 
1230: 69 6e 74 20 6e 6f 5f 6e 75 6c 6c 29 20 7b 0a 20  int no_null) {. 
1240: 20 20 20 75 6e 73 69 67 6e 65 64 20 63 68 61 72     unsigned char
1250: 20 2a 73 61 6c 74 20 3d 20 4e 55 4c 4c 3b 0a 20   *salt = NULL;. 
1260: 20 20 20 2a 6c 65 6e 20 3d 20 30 3b 0a 0a 20 20     *len = 0;..  
1270: 20 20 69 66 20 28 73 61 6c 74 4f 62 6a 20 21 3d    if (saltObj !=
1280: 20 4e 55 4c 4c 29 20 7b 0a 09 73 61 6c 74 20 3d   NULL) {..salt =
1290: 20 54 63 6c 5f 47 65 74 42 79 74 65 41 72 72 61   Tcl_GetByteArra
12a0: 79 46 72 6f 6d 4f 62 6a 28 73 61 6c 74 4f 62 6a  yFromObj(saltObj
12b0: 2c 20 6c 65 6e 29 3b 0a 20 20 20 20 7d 20 65 6c  , len);.    } el
12c0: 73 65 20 69 66 20 28 6e 6f 5f 6e 75 6c 6c 29 20  se if (no_null) 
12d0: 7b 0a 09 54 63 6c 5f 41 70 70 65 6e 64 52 65 73  {..Tcl_AppendRes
12e0: 75 6c 74 28 69 6e 74 65 72 70 2c 20 22 6e 6f 20  ult(interp, "no 
12f0: 73 61 6c 74 22 2c 20 28 63 68 61 72 20 2a 29 20  salt", (char *) 
1300: 4e 55 4c 4c 29 3b 0a 09 72 65 74 75 72 6e 20 4e  NULL);..return N
1310: 55 4c 4c 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20  ULL;.    }..    
1320: 69 66 20 28 6d 61 78 20 3e 20 30 20 26 26 20 2a  if (max > 0 && *
1330: 6c 65 6e 20 3e 20 6d 61 78 29 20 7b 0a 09 54 63  len > max) {..Tc
1340: 6c 5f 53 65 74 4f 62 6a 52 65 73 75 6c 74 28 69  l_SetObjResult(i
1350: 6e 74 65 72 70 2c 20 54 63 6c 5f 4f 62 6a 50 72  nterp, Tcl_ObjPr
1360: 69 6e 74 66 28 22 53 61 6c 74 20 74 6f 6f 20 6c  intf("Salt too l
1370: 6f 6e 67 2e 20 4d 75 73 74 20 62 65 20 3c 3d 20  ong. Must be <= 
1380: 25 64 20 62 79 74 65 73 22 2c 20 6d 61 78 29 29  %d bytes", max))
1390: 3b 0a 09 72 65 74 75 72 6e 20 4e 55 4c 4c 3b 0a  ;..return NULL;.
13a0: 20 20 20 20 7d 0a 20 20 20 20 72 65 74 75 72 6e      }.    return
13b0: 20 73 61 6c 74 3b 0a 7d 0a 0a 2f 2a 2a 2a 2a 2a   salt;.}../*****
13c0: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
13d0: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
13e0: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
13f0: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2f 0a  **************/.
1400: 0a 2f 2a 0a 20 2a 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ./*. *----------
1410: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1420: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1430: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1440: 2d 2d 2d 2d 2d 2d 2d 2d 2d 0a 20 2a 0a 20 2a 20  ---------. *. * 
1450: 55 74 69 6c 5f 47 65 74 42 69 6e 61 72 79 41 72  Util_GetBinaryAr
1460: 72 61 79 20 2d 2d 0a 20 2a 0a 20 2a 09 47 65 74  ray --. *. *.Get
1470: 20 62 69 6e 61 72 79 20 61 72 72 61 79 20 66 72   binary array fr
1480: 6f 6d 20 54 63 6c 4f 62 6a 0a 20 2a 0a 20 2a 20  om TclObj. *. * 
1490: 52 65 74 75 72 6e 73 3a 0a 20 2a 09 50 6f 69 6e  Returns:. *.Poin
14a0: 74 65 72 20 74 6f 20 74 79 70 65 20 6f 72 20 4e  ter to type or N
14b0: 55 4c 4c 2c 20 61 6e 64 20 73 69 7a 65 0a 20 2a  ULL, and size. *
14c0: 0a 20 2a 20 53 69 64 65 20 65 66 66 65 63 74 73  . * Side effects
14d0: 3a 0a 20 2a 09 4e 6f 6e 65 0a 20 2a 0a 20 2a 2d  :. *.None. *. *-
14e0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
14f0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1500: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1510: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1520: 2d 2d 0a 20 2a 2f 0a 75 6e 73 69 67 6e 65 64 20  --. */.unsigned 
1530: 63 68 61 72 20 2a 55 74 69 6c 5f 47 65 74 42 69  char *Util_GetBi
1540: 6e 61 72 79 41 72 72 61 79 28 54 63 6c 5f 49 6e  naryArray(Tcl_In
1550: 74 65 72 70 20 2a 69 6e 74 65 72 70 2c 20 54 63  terp *interp, Tc
1560: 6c 5f 4f 62 6a 20 2a 64 61 74 61 4f 62 6a 2c 20  l_Obj *dataObj, 
1570: 54 63 6c 5f 53 69 7a 65 20 2a 6c 65 6e 2c 0a 09  Tcl_Size *len,..
1580: 63 68 61 72 20 2a 6e 61 6d 65 2c 20 54 63 6c 5f  char *name, Tcl_
1590: 53 69 7a 65 20 6d 69 6e 2c 20 54 63 6c 5f 53 69  Size min, Tcl_Si
15a0: 7a 65 20 6d 61 78 2c 20 69 6e 74 20 6e 6f 5f 6e  ze max, int no_n
15b0: 75 6c 6c 29 20 7b 0a 20 20 20 20 75 6e 73 69 67  ull) {.    unsig
15c0: 6e 65 64 20 63 68 61 72 20 2a 64 61 74 61 20 3d  ned char *data =
15d0: 20 4e 55 4c 4c 3b 0a 20 20 20 20 2a 6c 65 6e 20   NULL;.    *len 
15e0: 3d 20 30 3b 0a 0a 20 20 20 20 69 66 20 28 64 61  = 0;..    if (da
15f0: 74 61 4f 62 6a 20 21 3d 20 4e 55 4c 4c 29 20 7b  taObj != NULL) {
1600: 0a 09 64 61 74 61 20 3d 20 54 63 6c 5f 47 65 74  ..data = Tcl_Get
1610: 42 79 74 65 41 72 72 61 79 46 72 6f 6d 4f 62 6a  ByteArrayFromObj
1620: 28 64 61 74 61 4f 62 6a 2c 20 6c 65 6e 29 3b 0a  (dataObj, len);.
1630: 20 20 20 20 7d 20 65 6c 73 65 20 69 66 20 28 6e      } else if (n
1640: 6f 5f 6e 75 6c 6c 29 20 7b 0a 09 54 63 6c 5f 41  o_null) {..Tcl_A
1650: 70 70 65 6e 64 52 65 73 75 6c 74 28 69 6e 74 65  ppendResult(inte
1660: 72 70 2c 20 22 6e 6f 20 22 2c 20 6e 61 6d 65 2c  rp, "no ", name,
1670: 20 28 63 68 61 72 20 2a 29 20 4e 55 4c 4c 29 3b   (char *) NULL);
1680: 0a 09 72 65 74 75 72 6e 20 4e 55 4c 4c 3b 0a 20  ..return NULL;. 
1690: 20 20 20 7d 0a 0a 20 20 20 20 69 66 20 28 2a 6c     }..    if (*l
16a0: 65 6e 20 3c 20 6d 69 6e 29 20 7b 0a 09 54 63 6c  en < min) {..Tcl
16b0: 5f 53 65 74 4f 62 6a 52 65 73 75 6c 74 28 69 6e  _SetObjResult(in
16c0: 74 65 72 70 2c 20 54 63 6c 5f 4f 62 6a 50 72 69  terp, Tcl_ObjPri
16d0: 6e 74 66 28 22 49 6e 76 61 6c 69 64 20 6c 65 6e  ntf("Invalid len
16e0: 67 74 68 20 66 6f 72 20 5c 22 25 73 5c 22 3a 20  gth for \"%s\": 
16f0: 6d 75 73 74 20 62 65 20 3e 3d 20 25 64 22 2c 20  must be >= %d", 
1700: 6e 61 6d 65 2c 20 6d 69 6e 29 29 3b 0a 09 72 65  name, min));..re
1710: 74 75 72 6e 20 4e 55 4c 4c 3b 0a 20 20 20 20 7d  turn NULL;.    }
1720: 20 65 6c 73 65 20 69 66 20 28 6d 61 78 20 3e 20   else if (max > 
1730: 30 20 26 26 20 2a 6c 65 6e 20 3e 20 6d 61 78 29  0 && *len > max)
1740: 20 7b 0a 09 54 63 6c 5f 53 65 74 4f 62 6a 52 65   {..Tcl_SetObjRe
1750: 73 75 6c 74 28 69 6e 74 65 72 70 2c 20 54 63 6c  sult(interp, Tcl
1760: 5f 4f 62 6a 50 72 69 6e 74 66 28 22 49 6e 76 61  _ObjPrintf("Inva
1770: 6c 69 64 20 6c 65 6e 67 74 68 20 66 6f 72 20 5c  lid length for \
1780: 22 25 73 5c 22 3a 20 6d 75 73 74 20 62 65 20 3c  "%s\": must be <
1790: 3d 20 25 64 22 2c 20 6e 61 6d 65 2c 20 6d 61 78  = %d", name, max
17a0: 29 29 3b 0a 09 72 65 74 75 72 6e 20 4e 55 4c 4c  ));..return NULL
17b0: 3b 0a 20 20 20 20 7d 0a 20 20 20 20 72 65 74 75  ;.    }.    retu
17c0: 72 6e 20 64 61 74 61 3b 0a 7d 0a 0a 2f 2a 0a 20  rn data;.}../*. 
17d0: 2a 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  *---------------
17e0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
17f0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1800: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
1810: 2d 2d 2d 2d 0a 20 2a 0a 20 2a 20 55 74 69 6c 5f  ----. *. * Util_
1820: 47 65 74 49 6e 74 20 2d 2d 0a 20 2a 0a 20 2a 09  GetInt --. *. *.
1830: 47 65 74 20 69 6e 74 65 67 65 72 20 76 61 6c 75  Get integer valu
1840: 65 20 66 72 6f 6d 20 54 63 6c 4f 62 6a 0a 20 2a  e from TclObj. *
1850: 0a 20 2a 20 52 65 74 75 72 6e 73 3a 0a 20 2a 09  . * Returns:. *.
1860: 54 43 4c 5f 4f 4b 20 6f 72 20 54 43 4c 5f 45 52  TCL_OK or TCL_ER
1870: 52 4f 52 0a 20 2a 0a 20 2a 20 53 69 64 65 20 65  ROR. *. * Side e
1880: 66 66 65 63 74 73 3a 0a 20 2a 09 4e 6f 6e 65 0a  ffects:. *.None.
1890: 20 2a 0a 20 2a 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d   *. *-----------
18a0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
18b0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
18c0: 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d 2d  ----------------
18d0: 2d 2d 2d 2d 2d 2d 2d 2d 0a 20 2a 2f 0a 0a 69 6e  --------. */..in
18e0: 74 20 55 74 69 6c 5f 47 65 74 49 6e 74 28 54 63  t Util_GetInt(Tc
18f0: 6c 5f 49 6e 74 65 72 70 20 2a 69 6e 74 65 72 70  l_Interp *interp
1900: 2c 20 54 63 6c 5f 4f 62 6a 20 2a 64 61 74 61 4f  , Tcl_Obj *dataO
1910: 62 6a 2c 20 69 6e 74 20 2a 76 61 6c 75 65 2c 20  bj, int *value, 
1920: 63 68 61 72 20 2a 6e 61 6d 65 2c 20 69 6e 74 20  char *name, int 
1930: 6d 69 6e 2c 20 69 6e 74 20 6d 61 78 29 20 7b 0a  min, int max) {.
1940: 0a 20 20 20 20 69 66 20 28 64 61 74 61 4f 62 6a  .    if (dataObj
1950: 20 21 3d 20 4e 55 4c 4c 29 20 7b 0a 09 69 66 20   != NULL) {..if 
1960: 28 54 63 6c 5f 47 65 74 49 6e 74 46 72 6f 6d 4f  (Tcl_GetIntFromO
1970: 62 6a 28 69 6e 74 65 72 70 2c 20 64 61 74 61 4f  bj(interp, dataO
1980: 62 6a 2c 20 76 61 6c 75 65 29 20 21 3d 20 54 43  bj, value) != TC
1990: 4c 5f 4f 4b 29 20 7b 0a 09 20 20 20 20 72 65 74  L_OK) {..    ret
19a0: 75 72 6e 20 54 43 4c 5f 45 52 52 4f 52 3b 0a 09  urn TCL_ERROR;..
19b0: 7d 0a 20 20 20 20 7d 0a 0a 20 20 20 20 2f 2a 20  }.    }..    /* 
19c0: 56 61 6c 69 64 61 74 65 20 72 61 6e 67 65 20 2a  Validate range *
19d0: 2f 0a 20 20 20 20 69 66 20 28 2a 76 61 6c 75 65  /.    if (*value
19e0: 20 3c 20 6d 69 6e 29 20 7b 0a 09 54 63 6c 5f 53   < min) {..Tcl_S
19f0: 65 74 4f 62 6a 52 65 73 75 6c 74 28 69 6e 74 65  etObjResult(inte
1a00: 72 70 2c 20 54 63 6c 5f 4f 62 6a 50 72 69 6e 74  rp, Tcl_ObjPrint
1a10: 66 28 22 69 6e 76 61 6c 69 64 20 76 61 6c 75 65  f("invalid value
1a20: 20 5c 22 25 64 5c 22 20 66 6f 72 20 6f 70 74 69   \"%d\" for opti
1a30: 6f 6e 20 5c 22 25 73 5c 22 3a 20 6d 75 73 74 20  on \"%s\": must 
1a40: 62 65 20 3e 3d 20 25 64 22 2c 20 2a 76 61 6c 75  be >= %d", *valu
1a50: 65 2c 20 6e 61 6d 65 2c 20 6d 69 6e 29 29 3b 0a  e, name, min));.
1a60: 09 72 65 74 75 72 6e 20 54 43 4c 5f 45 52 52 4f  .return TCL_ERRO
1a70: 52 3b 0a 20 20 20 20 7d 20 65 6c 73 65 20 69 66  R;.    } else if
1a80: 20 28 6d 61 78 20 3e 20 30 20 26 26 20 2a 76 61   (max > 0 && *va
1a90: 6c 75 65 20 3e 20 6d 61 78 29 20 7b 0a 09 54 63  lue > max) {..Tc
1aa0: 6c 5f 53 65 74 4f 62 6a 52 65 73 75 6c 74 28 69  l_SetObjResult(i
1ab0: 6e 74 65 72 70 2c 20 54 63 6c 5f 4f 62 6a 50 72  nterp, Tcl_ObjPr
1ac0: 69 6e 74 66 28 22 69 6e 76 61 6c 69 64 20 76 61  intf("invalid va
1ad0: 6c 75 65 20 5c 22 25 64 5c 22 20 66 6f 72 20 6f  lue \"%d\" for o
1ae0: 70 74 69 6f 6e 20 5c 22 25 73 5c 22 3a 20 6d 75  ption \"%s\": mu
1af0: 73 74 20 62 65 20 3c 3d 20 25 64 22 2c 20 2a 76  st be <= %d", *v
1b00: 61 6c 75 65 2c 20 6e 61 6d 65 2c 20 6d 61 78 29  alue, name, max)
1b10: 29 3b 0a 09 72 65 74 75 72 6e 20 54 43 4c 5f 45  );..return TCL_E
1b20: 52 52 4f 52 3b 0a 20 20 20 20 7d 0a 20 20 20 20  RROR;.    }.    
1b30: 72 65 74 75 72 6e 20 54 43 4c 5f 4f 4b 3b 0a 7d  return TCL_OK;.}
1b40: 0a 0a                                            ..