⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 rsrc001.tcl

📁 这是linux下运行的mysql软件包,可用于linux 下安装 php + mysql + apach 的网络配置
💻 TCL
字号:
# See the file LICENSE for redistribution information.## Copyright (c) 1996-2002#	Sleepycat Software.  All rights reserved.## $Id: rsrc001.tcl,v 11.23 2002/01/11 15:53:33 bostic Exp $## TEST	rsrc001# TEST	Recno backing file test.  Try different patterns of adding# TEST	records and making sure that the corresponding file matches.proc rsrc001 { } {	source ./include.tcl	puts "Rsrc001: Basic recno backing file writeback tests"	# We run this test essentially twice, once with a db file	# and once without (an in-memory database).	set rec1 "This is record 1"	set rec2 "This is record 2 This is record 2"	set rec3 "This is record 3 This is record 3 This is record 3"	set rec4 [replicate "This is record 4 " 512]	foreach testfile { "$testdir/rsrc001.db" "" } {		cleanup $testdir NULL		if { $testfile == "" } {			puts "Rsrc001: Testing with in-memory database."		} else {			puts "Rsrc001: Testing with disk-backed database."		}		# Create backing file for the empty-file test.		set oid1 [open $testdir/rsrc.txt w]		close $oid1		puts "\tRsrc001.a: Put to empty file."		set db [eval {berkdb_open -create -mode 0644\		    -recno -source $testdir/rsrc.txt} $testfile]		error_check_good dbopen [is_valid_db $db] TRUE		set txn ""		set ret [eval {$db put} $txn {1 $rec1}]		error_check_good put_to_empty $ret 0		error_check_good db_close [$db close] 0		# Now fill out the backing file and create the check file.		set oid1 [open $testdir/rsrc.txt a]		set oid2 [open $testdir/check.txt w]		# This one was already put into rsrc.txt.		puts $oid2 $rec1		# These weren't.		puts $oid1 $rec2		puts $oid2 $rec2		puts $oid1 $rec3		puts $oid2 $rec3		puts $oid1 $rec4		puts $oid2 $rec4		close $oid1		close $oid2		puts -nonewline "\tRsrc001.b: Read file, rewrite last record;"		puts " write it out and diff"		set db [eval {berkdb_open -create -mode 0644\		    -recno -source $testdir/rsrc.txt} $testfile]		error_check_good dbopen [is_valid_db $db] TRUE		# Read the last record; replace it (but we won't change it).		# Then close the file and diff the two files.		set dbc [eval {$db cursor} $txn]		error_check_good db_cursor [is_valid_cursor $dbc $db] TRUE		set rec [$dbc get -last]		error_check_good get_last [llength [lindex $rec 0]] 2		set key [lindex [lindex $rec 0] 0]		set data [lindex [lindex $rec 0] 1]		# Get the last record from the text file		set oid [open $testdir/rsrc.txt]		set laststr ""		while { [gets $oid str] != -1 } {			set laststr $str		}		close $oid		set data [sanitize_record $data]		error_check_good getlast $data $laststr		set ret [eval {$db put} $txn {$key $data}]		error_check_good replace_last $ret 0		error_check_good curs_close [$dbc close] 0		error_check_good db_sync [$db sync] 0		error_check_good db_sync [$db sync] 0		error_check_good \		    Rsrc001:diff($testdir/rsrc.txt,$testdir/check.txt) \		    [filecmp $testdir/rsrc.txt $testdir/check.txt] 0		puts -nonewline "\tRsrc001.c: "		puts "Append some records in tree and verify in file."		set oid [open $testdir/check.txt a]		for {set i 1} {$i < 10} {incr i} {			set rec [replicate "New Record $i" $i]			puts $oid $rec			incr key			set ret [eval {$db put} $txn {-append $rec}]			error_check_good put_append $ret $key		}		error_check_good db_sync [$db sync] 0		error_check_good db_sync [$db sync] 0		close $oid		set ret [filecmp $testdir/rsrc.txt $testdir/check.txt]		error_check_good \		    Rsrc001:diff($testdir/{rsrc.txt,check.txt}) $ret 0		puts "\tRsrc001.d: Append by record number"		set oid [open $testdir/check.txt a]		for {set i 1} {$i < 10} {incr i} {			set rec [replicate "New Record (set 2) $i" $i]			puts $oid $rec			incr key			set ret [eval {$db put} $txn {$key $rec}]			error_check_good put_byno $ret 0		}		error_check_good db_sync [$db sync] 0		error_check_good db_sync [$db sync] 0		close $oid		set ret [filecmp $testdir/rsrc.txt $testdir/check.txt]		error_check_good \		    Rsrc001:diff($testdir/{rsrc.txt,check.txt}) $ret 0		puts "\tRsrc001.e: Put beyond end of file."		set oid [open $testdir/check.txt a]		for {set i 1} {$i < 10} {incr i} {			puts $oid ""			incr key		}		set rec "Last Record"		puts $oid $rec		incr key		set ret [eval {$db put} $txn {$key $rec}]		error_check_good put_byno $ret 0		puts "\tRsrc001.f: Put beyond end of file, after reopen."		error_check_good db_close [$db close] 0		set db [eval {berkdb_open -create -mode 0644\		    -recno -source $testdir/rsrc.txt} $testfile]		error_check_good dbopen [is_valid_db $db] TRUE		set rec "Last record with reopen"		puts $oid $rec		incr key		set ret [eval {$db put} $txn {$key $rec}]		error_check_good put_byno_with_reopen $ret 0		puts "\tRsrc001.g:\		    Put several beyond end of file, after reopen with snapshot."		error_check_good db_close [$db close] 0		set db [eval {berkdb_open -create -mode 0644\		    -snapshot -recno -source $testdir/rsrc.txt} $testfile]		error_check_good dbopen [is_valid_db $db] TRUE		set rec "Really really last record with reopen"		puts $oid ""		puts $oid ""		puts $oid ""		puts $oid $rec		incr key		incr key		incr key		incr key		set ret [eval {$db put} $txn {$key $rec}]		error_check_good put_byno_with_reopen $ret 0		error_check_good db_sync [$db sync] 0		error_check_good db_sync [$db sync] 0		close $oid		set ret [filecmp $testdir/rsrc.txt $testdir/check.txt]		error_check_good \		    Rsrc001:diff($testdir/{rsrc.txt,check.txt}) $ret 0		puts "\tRsrc001.h: Verify proper syncing of changes on close."		error_check_good Rsrc001:db_close [$db close] 0		set db [eval {berkdb_open -create -mode 0644 -recno \		    -source $testdir/rsrc.txt} $testfile]		set oid [open $testdir/check.txt a]		for {set i 1} {$i < 10} {incr i} {			set rec [replicate "New Record $i" $i]			puts $oid $rec			set ret [eval {$db put} $txn {-append $rec}]			# Don't bother checking return;  we don't know what			# the key number is, and we'll pick up a failure			# when we compare.		}		error_check_good Rsrc001:db_close [$db close] 0		close $oid		set ret [filecmp $testdir/rsrc.txt $testdir/check.txt]		error_check_good Rsrc001:diff($testdir/{rsrc,check}.txt) $ret 0	}}# Strip CRs from a record.# Needed on Windows when a file is created as text (with CR/LF)# but read as binary (where CR is read as a separate character)proc sanitize_record { rec } {	source ./include.tcl	if { $is_windows_test != 1 } {		return $rec	}	regsub -all \15 $rec "" data	return $data}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -