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 }..}