Hex Artifact Content
Not logged in

Artifact 16c96d774ebb69c435168f56d23df938a76b6caf:

File tools/tclfossil/lib/vc/fossil/db-1.0.tm part of check-in [8c4b530084] - tclfossil: added schema command by mjanssen on 2008-02-19 21:58:14.

0000: 23 23 20 2d 2a 2d 20 74 63 6c 20 2d 2a 2d 0d 0a  ## -*- tcl -*-..
0010: 23 20 23 20 23 23 20 23 23 23 20 23 23 23 23 23  # # ## ### #####
0020: 20 23 23 23 23 23 23 23 23 20 23 23 23 23 23 23   ######## ######
0030: 23 23 23 23 23 23 23 20 23 23 23 23 23 23 23 23  ####### ########
0040: 23 23 23 23 23 23 23 23 23 23 23 23 23 0d 0a 23  #############..#
0050: 23 20 43 6f 70 79 72 69 67 68 74 20 28 63 29 20  # Copyright (c) 
0060: 32 30 30 38 20 4d 61 72 6b 20 4a 61 6e 73 73 65  2008 Mark Jansse
0070: 6e 2e 0d 0a 23 0d 0a 23 20 54 68 69 73 20 73 6f  n...#..# This so
0080: 66 74 77 61 72 65 20 69 73 20 6c 69 63 65 6e 73  ftware is licens
0090: 65 64 20 61 73 20 64 65 73 63 72 69 62 65 64 20  ed as described 
00a0: 69 6e 20 74 68 65 20 66 69 6c 65 20 4c 49 43 45  in the file LICE
00b0: 4e 53 45 2c 20 77 68 69 63 68 0d 0a 23 20 79 6f  NSE, which..# yo
00c0: 75 20 73 68 6f 75 6c 64 20 68 61 76 65 20 72 65  u should have re
00d0: 63 65 69 76 65 64 20 61 73 20 70 61 72 74 20 6f  ceived as part o
00e0: 66 20 74 68 69 73 20 64 69 73 74 72 69 62 75 74  f this distribut
00f0: 69 6f 6e 2e 0d 0a 23 0d 0a 23 20 54 68 69 73 20  ion...#..# This 
0100: 73 6f 66 74 77 61 72 65 20 63 6f 6e 73 69 73 74  software consist
0110: 73 20 6f 66 20 76 6f 6c 75 6e 74 61 72 79 20 63  s of voluntary c
0120: 6f 6e 74 72 69 62 75 74 69 6f 6e 73 20 6d 61 64  ontributions mad
0130: 65 20 62 79 20 6d 61 6e 79 0d 0a 23 20 69 6e 64  e by many..# ind
0140: 69 76 69 64 75 61 6c 73 2e 20 20 46 6f 72 20 65  ividuals.  For e
0150: 78 61 63 74 20 63 6f 6e 74 72 69 62 75 74 69 6f  xact contributio
0160: 6e 20 68 69 73 74 6f 72 79 2c 20 73 65 65 20 74  n history, see t
0170: 68 65 20 72 65 76 69 73 69 6f 6e 0d 0a 23 20 68  he revision..# h
0180: 69 73 74 6f 72 79 20 61 6e 64 20 6c 6f 67 73 2c  istory and logs,
0190: 20 61 76 61 69 6c 61 62 6c 65 20 61 74 20 68 74   available at ht
01a0: 74 70 3a 2f 2f 66 6f 73 73 69 6c 2d 73 63 6d 2e  tp://fossil-scm.
01b0: 68 77 61 63 69 2e 63 6f 6d 2f 66 6f 73 73 69 6c  hwaci.com/fossil
01c0: 0d 0a 23 20 23 20 23 23 20 23 23 23 20 23 23 23  ..# # ## ### ###
01d0: 23 23 20 23 23 23 23 23 23 23 23 20 23 23 23 23  ## ######## ####
01e0: 23 23 23 23 23 23 23 23 23 20 23 23 23 23 23 23  ######### ######
01f0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 0d  ###############.
0200: 0a 0d 0a 23 23 20 44 62 20 63 6f 6d 6d 61 6e 64  ...## Db command
0210: 73 0d 0a 0d 0a 23 20 23 20 23 23 20 23 23 23 20  s....# # ## ### 
0220: 23 23 23 23 23 20 23 23 23 23 23 23 23 23 20 23  ##### ######## #
0230: 23 23 23 23 23 23 23 23 23 23 23 23 20 23 23 23  ############ ###
0240: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
0250: 23 23 0d 0a 23 23 20 52 65 71 75 69 72 65 6d 65  ##..## Requireme
0260: 6e 74 73 0d 0a 0d 0a 70 61 63 6b 61 67 65 20 72  nts....package r
0270: 65 71 75 69 72 65 20 54 63 6c 20 38 2e 35 20 20  equire Tcl 8.5  
0280: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0290: 20 20 20 20 20 20 20 20 20 20 20 3b 20 23 20 52             ; # R
02a0: 65 71 75 69 72 65 64 20 72 75 6e 74 69 6d 65 2e  equired runtime.
02b0: 0d 0a 70 61 63 6b 61 67 65 20 72 65 71 75 69 72  ..package requir
02c0: 65 20 73 6e 69 74 20 20 20 20 20 20 20 20 20 20  e snit          
02d0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
02e0: 20 20 20 20 20 20 3b 20 23 20 4f 4f 20 73 79 73        ; # OO sys
02f0: 74 65 6d 2e 0d 0a 70 61 63 6b 61 67 65 20 72 65  tem...package re
0300: 71 75 69 72 65 20 73 71 6c 69 74 65 33 0d 0a 70  quire sqlite3..p
0310: 61 63 6b 61 67 65 20 72 65 71 75 69 72 65 20 76  ackage require v
0320: 63 3a 3a 66 6f 73 73 69 6c 3a 3a 73 63 68 65 6d  c::fossil::schem
0330: 61 20 20 20 20 20 20 31 2e 30 20 20 20 20 20 20  a      1.0      
0340: 20 20 20 3b 20 23 20 46 6f 73 73 69 6c 20 72 65     ; # Fossil re
0350: 70 6f 20 73 63 68 65 6d 61 0d 0a 0d 0a 70 61 63  po schema....pac
0360: 6b 61 67 65 20 70 72 6f 76 69 64 65 20 76 63 3a  kage provide vc:
0370: 3a 66 6f 73 73 69 6c 3a 3a 64 62 20 31 2e 30 0d  :fossil::db 1.0.
0380: 0a 0d 0a 23 20 23 20 23 23 20 23 23 23 20 23 23  ...# # ## ### ##
0390: 23 23 23 20 23 23 23 23 23 23 23 23 20 23 23 23  ### ######## ###
03a0: 23 23 23 23 23 23 23 23 23 23 20 23 23 23 23 23  ########## #####
03b0: 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23 23  ################
03c0: 0d 0a 23 23 0d 0a 0d 0a 0d 0a 0d 0a 6e 61 6d 65  ..##........name
03d0: 73 70 61 63 65 20 65 76 61 6c 20 3a 3a 76 63 3a  space eval ::vc:
03e0: 3a 66 6f 73 73 69 6c 20 7b 0d 0a 0d 0a 20 20 20  :fossil {....   
03f0: 20 73 6e 69 74 3a 3a 74 79 70 65 20 64 62 20 7b   snit::type db {
0400: 0d 0a 09 74 79 70 65 76 61 72 69 61 62 6c 65 20  ...typevariable 
0410: 73 63 68 65 6d 61 64 69 72 20 5b 66 69 6c 65 20  schemadir [file 
0420: 6a 6f 69 6e 20 5b 66 69 6c 65 20 64 69 72 6e 61  join [file dirna
0430: 6d 65 20 5b 69 6e 66 6f 20 73 63 72 69 70 74 5d  me [info script]
0440: 5d 20 73 63 68 65 6d 61 5d 0d 0a 20 20 20 20 20  ] schema]..     
0450: 20 20 20 74 79 70 65 76 61 72 69 61 62 6c 65 20     typevariable 
0460: 64 62 63 6d 64 20 5b 6e 61 6d 65 73 70 61 63 65  dbcmd [namespace
0470: 20 63 75 72 72 65 6e 74 5d 3a 3a 73 71 6c 64 62   current]::sqldb
0480: 0d 0a 0d 0a 09 74 79 70 65 6d 65 74 68 6f 64 20  .....typemethod 
0490: 63 72 65 61 74 65 5f 72 65 70 6f 73 69 74 6f 72  create_repositor
04a0: 79 20 7b 66 69 6c 65 6e 61 6d 65 7d 20 7b 0d 0a  y {filename} {..
04b0: 09 20 20 20 20 69 66 20 7b 5b 66 69 6c 65 20 65  .    if {[file e
04c0: 78 69 73 74 73 20 24 66 69 6c 65 6e 61 6d 65 5d  xists $filename]
04d0: 7d 20 7b 0d 0a 09 09 75 69 20 70 61 6e 69 63 20  } {....ui panic 
04e0: 22 66 69 6c 65 20 61 6c 72 65 61 64 79 20 65 78  "file already ex
04f0: 69 73 74 73 3a 20 24 66 69 6c 65 6e 61 6d 65 22  ists: $filename"
0500: 0d 0a 09 20 20 20 20 7d 0d 0a 09 20 20 20 20 64  ...    }...    d
0510: 62 20 69 6e 69 74 5f 64 61 74 61 62 61 73 65 20  b init_database 
0520: 24 66 69 6c 65 6e 61 6d 65 20 5b 73 63 68 65 6d  $filename [schem
0530: 61 20 72 65 70 6f 31 5d 20 5b 73 63 68 65 6d 61  a repo1] [schema
0540: 20 72 65 70 6f 32 5d 0d 0a 09 7d 0d 0a 0d 0a 09   repo2]...}.....
0550: 74 79 70 65 6d 65 74 68 6f 64 20 69 6e 69 74 5f  typemethod init_
0560: 64 61 74 61 62 61 73 65 20 7b 66 69 6c 65 6e 61  database {filena
0570: 6d 65 20 73 63 68 65 6d 61 20 61 72 67 73 7d 20  me schema args} 
0580: 7b 0d 0a 09 20 20 20 20 73 71 6c 69 74 65 33 20  {...    sqlite3 
0590: 24 64 62 63 6d 64 20 24 66 69 6c 65 6e 61 6d 65  $dbcmd $filename
05a0: 0d 0a 09 20 20 20 20 24 64 62 63 6d 64 20 74 72  ...    $dbcmd tr
05b0: 61 6e 73 61 63 74 69 6f 6e 20 7b 0d 0a 09 09 24  ansaction {....$
05c0: 64 62 63 6d 64 20 65 76 61 6c 20 24 73 63 68 65  dbcmd eval $sche
05d0: 6d 61 0d 0a 09 09 66 6f 72 65 61 63 68 20 73 63  ma....foreach sc
05e0: 68 65 6d 61 20 24 61 72 67 73 20 7b 0d 0a 09 09  hema $args {....
05f0: 20 20 20 20 24 64 62 63 6d 64 20 65 76 61 6c 20      $dbcmd eval 
0600: 24 73 63 68 65 6d 61 0d 0a 09 09 7d 0d 0a 09 20  $schema....}... 
0610: 20 20 20 7d 0d 0a 09 20 20 20 20 24 64 62 63 6d     }...    $dbcm
0620: 64 20 63 6c 6f 73 65 0d 0a 09 7d 0d 0a 20 20 20  d close...}..   
0630: 20 7d 0d 0a 7d                                    }..}