Index: openacs.org-dev/packages/acs-templating/tcl/util-procs.tcl =================================================================== RCS file: /usr/local/cvsroot/openacs.org-dev/packages/acs-templating/tcl/util-procs.tcl,v diff -u -r1.1.1.1 -r1.1.1.2 --- openacs.org-dev/packages/acs-templating/tcl/util-procs.tcl 9 Jul 2002 17:34:59 -0000 1.1.1.1 +++ openacs.org-dev/packages/acs-templating/tcl/util-procs.tcl 8 Oct 2002 15:46:50 -0000 1.1.1.2 @@ -13,17 +13,15 @@ namespace eval template::util {} namespace eval template::query {} -# @public get_opts - -# Builds an array named "opts" in the calling frame, containing all -# switches passed at the end of a proc. The array values are either -# switch parameters or 1 if no parameter was specified. - -# Problem: there is currently no way to specify an option parameter that -# begins with a dash. This particularly problematic for negative numbers. - ad_proc -public template::util::get_opts { argv } { + Builds an array named "opts" in the calling frame, containing all + switches passed at the end of a proc. The array values are either + switch parameters or 1 if no parameter was specified. + Problem: there is currently no way to specify an option parameter that + begins with a dash. This particularly problematic for negative numbers. +} { + upvar opts opts set size [llength $argv] @@ -59,17 +57,15 @@ # * Utility procedures for manipulating lists, arrays and ns_sets * # * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * -# @public list_opts +ad_proc -public template::util::list_opts { {array_ref opts} } { + Converts an array to an option list -# Converts an array to an option list + @param array_ref The name of the array in the calling frame containing + option-value pairs. Defaults to "opts". -# @param array_ref The name of the array in the calling frame containing -# option-value pairs. Defaults to "opts". + @return A list of option-value pairs suitable for appending to a command. +} { -# @return A list of option-value pairs suitable for appending to a command. - -ad_proc -public template::util::list_opts { {array_ref opts} } { - upvar $array_ref arr set ret [list] @@ -80,17 +76,15 @@ return $ret } -# @public is_nil +ad_proc -public template::util::is_nil { ref } { + Determines whether a variable both exists and is not an empty string. -# Determines whether a variable both exists and is not an empty string. + @param ref The name of a variable to test in the calling frame. -# @param ref The name of a variable to test in the calling frame. + @return 1 if the variable either not exist or is an empty string. 0 if + the variable is either an array reference or a non-empty scalar. +} { -# @return 1 if the variable either not exist or is an empty string. 0 if -# the variable is either an array reference or a non-empty scalar. - -ad_proc -public template::util::is_nil { ref } { - upvar $ref var # check for an array as well @@ -104,20 +98,18 @@ return $result } -# @public is_unique +ad_proc -public template::util::is_unique { table columns values } { + Queries a database table for the existence of a particular row. + Useful for validating form input to reduce the possibility of + unique constraint violations. -# Queries a database table for the existence of a particular row. -# Useful for validating form input to reduce the possibility of -# unique constraint violations. + @param table The name of a database table. + @param columns A list of columns on which to select the row. + @param values A list of values for each specified column. -# @param table The name of a database table. -# @param columns A list of columns on which to select the row. -# @param values A list of values for each specified column. + @return 1 if the row exists, 0 if not +} { -# @return 1 if the row exists, 0 if not - -ad_proc -public template::util::is_unique { table columns values } { - set query "select count(*) from $table where " for { set i 0 } { $i < [llength $columns] } { incr i } { @@ -128,49 +120,44 @@ append query [join $conditions " and "] - template::query get_count count onevalue $query + set count [db_string get_count $query] return [expr $count == 0] } +ad_proc -public template::util::is_true { x } { + interprets its argument as a boolean. -# @public is_true + @param x the value to test -# interprets its argument as a boolean. - -# @param x the value to test - -# @return 0 if the variable can be interpreted as false; 1 for true if it can't. - -ad_proc -public template::util::is_true { x } { + @return 0 if the variable can be interpreted as false; + 1 for true if it can't. +} { expr [lsearch -exact {0 f false n no off ""} [string tolower $x]] == -1 } - -# @public lpop - -# Removes the last item from a list. The operation is performed -# in-place, rather than returning the new list. - -# @param ref The name of a list in the calling frame on which to operate. - ad_proc -public template::util::lpop { ref } { + Removes the last item from a list. The operation is performed + in-place, rather than returning the new list. + @param ref The name of a list in the calling frame on which to operate. +} { + upvar $ref the_list set the_list [lrange $the_list 0 [expr [llength $the_list] - 2]] } -# Recursive procedure for building a hierarchical or multidimensional -# data structure in a list. - -# @param value Either a list or scalar value to store in the list. -# @param next A key value that determines the next node to -# traverse outward in the data structure. -# @param args Subsequent nodes to traverse. - ad_proc -public template::util::lnest { listref value next args } { + Recursive procedure for building a hierarchical or multidimensional + data structure in a list. + @param value Either a list or scalar value to store in the list. + @param next A key value that determines the next node to + traverse outward in the data structure. + @param args Subsequent nodes to traverse. +} { + upvar $listref inlist if { ! [info exists inlist] } { set inlist [list] @@ -225,19 +212,17 @@ set inlist [array get values] } -# @public set_to_list +ad_proc -public template::util::set_to_list { set args } { + Turns an ns_set into a key-value list, excluding any number of + specified keys. Useful for turning the contents on an ns_set into + a form that may be cached or manipulated as a native Tcl data structure. -# Turns an ns_set into a key-value list, excluding any number of -# specified keys. Useful for turning the contents on an ns_set into -# a form that may be cached or manipulated as a native Tcl data structure. + @param set A reference to an ns_set. + @param args Any number of key names to exclude from the list. -# @param set A reference to an ns_set. -# @param args Any number of key names to exclude from the list. + @return A list in the form { key value key value key value ... } +} { -# @return A list in the form { key value key value key value ... } - -ad_proc -public template::util::set_to_list { set args } { - set result [list] for { set i 0 } { $i < [ns_set size $set] } { incr i } { @@ -251,15 +236,13 @@ return $result } -# @public set_to_vars - -# Declare local variables for set values - -# @param set A reference to an ns_set. -# @param args Any number of keys to declare as local variables. - ad_proc -public template::util::set_to_vars { set args } { + Declare local variables for set values + @param set A reference to an ns_set. + @param args Any number of keys to declare as local variables. +} { + if { [llength $args] == 0 } { for { set i 0 } { $i < [ns_set size $set] } { incr i } { @@ -277,30 +260,25 @@ } } -# @public array_to_vars - -# Declare local variables for every key in an array. - -# @param arrayname The name of an array in the calling frame. - ad_proc -public template::util::array_to_vars { arrayname } { + Declare local variables for every key in an array. + @param arrayname The name of an array in the calling frame. +} { + upvar $arrayname arr foreach { key value } [array get arr] { uplevel "set \{${key}\} \{$value\}" } } -# @public vars_to_array - -# Place local variables into an array - -# @param arrayname The name of an array in the calling frame. -# @param args Any number of local variables to include in the array - ad_proc -public template::util::vars_to_array { arrayname args } { + Place local variables into an array + @param arrayname The name of an array in the calling frame. + @param args Any number of local variables to include in the array +} { upvar $arrayname arr foreach var $args { @@ -309,19 +287,17 @@ } } -# @public list_to_array - -# Converts a list of values into an array, using a list of -# corresponding column names for the array keys. - -# @param values A list of values -# @param array_ref The name of the array to create in the calling frame. -# @param columns A list of column names to use for the array keys. -# The length of this list should be the same as the values -# list. - ad_proc -public template::util::list_to_array { values array_ref columns } { + Converts a list of values into an array, using a list of + corresponding column names for the array keys. + @param values A list of values + @param array_ref The name of the array to create in the calling frame. + @param columns A list of column names to use for the array keys. + The length of this list should be the same as the values + list. +} { + upvar $array_ref array for { set i 0 } { $i < [llength $values] } { incr i } { @@ -333,12 +309,10 @@ } } -# @public list_of_lists_to_array - -# Converts a list of lists in the form { { key value } { key value } ... } -# to an array. - ad_proc -public template::util::list_of_lists_to_array { lists array_ref } { + Converts a list of lists in the form { { key value } { key value } ... } + to an array. +} { upvar $array_ref array @@ -351,17 +325,14 @@ } } -# @public list_to_lookup - -# Turn a list into an array where each key corresponds to an element -# of the list... Sort of like a sparse bitmap. Each value corresponds -# to the key's position in the input list. - -# @param values A list of values -# @param array_ref The name of the array to create in the calling frame. - ad_proc -public template::util::list_to_lookup { values array_ref } { - + Turn a list into an array where each key corresponds to an element + of the list... Sort of like a sparse bitmap. Each value corresponds + to the key's position in the input list. + + @param values A list of values + @param array_ref The name of the array to create in the calling frame. +} { upvar $array_ref array set i 1 @@ -372,11 +343,18 @@ } } -# Return a representation of a multirow data source as a list, -# suitable for passing by value in the form { { row } { row } { row } ... } ad_proc -public template::util::multirow_to_list { name } { + generate a list structure representitive of a multirow data source + @param name the name of an existing multirow data source + + @return a representation of a multirow data source as a list, + suitable for passing by value in the form { { row } { row } { row } ... } + + @see proc template::util::list_to_multirow +} { + upvar $name:rowcount rowcount set rows [list] @@ -391,7 +369,16 @@ } ad_proc -public template::util::list_to_multirow { name rows { level 1 } } { + populate a multirow data source from a list string gotten from + a call to template::util::multirow_to_list + @param name the name of a multirow data source + @param rows a representation of a multirow data source as a list, + suitable for passing by value in the form { { row } { row } { row } ... } + + @see proc template::util::multirow_to_list +} { + upvar $level $name:rowcount rowcount set rowcount [llength $rows] set rownum 1 @@ -434,44 +421,38 @@ # * Utility procedures for interacting with the file system * # * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * -# @public read_file +ad_proc -public template::util::read_file { path } { + Reads a text file. -# Reads a text file. + @param path The absolute path to the file -# @param path The absolute path to the file + @return A string with the contents of the file. +} { -# @return A string with the contents of the file. - -ad_proc -public template::util::read_file { path } { - set fd [open $path] set text [read $fd] close $fd return $text } -# @public write_file - -# Writes a text file - -# @param path The absolute path to the file -# @param text A string containing the text to write to the file. - ad_proc -public template::util::write_file { path text } { + Writes a text file + @param path The absolute path to the file + @param text A string containing the text to write to the file. +} { + file mkdir [file dirname $path] set fd [open $path w] puts $fd $text close $fd } -# @public url_to_file - -# Resolve a URL into an absolute file path. - ad_proc -public template::util::url_to_file { url {reference_url ""} } { + Resolve a URL into an absolute file path. +} { if { [string index $url 0] != "/" } { @@ -485,12 +466,9 @@ return [ns_normalizepath $path] } -# @public resolve_directory_url - -# Resolve the file name for a directory URL - ad_proc -public template::util::resolve_directory_url { url } { - + Resolve the file name for a directory URL +} { set path [ns_info pageroot]$url if { [file isdirectory $path] && [file exists ${path}index.adp] } { @@ -500,13 +478,10 @@ return $url } -# @public get_url_directory - -# Get the directory portion of a URL. If the URL has a trailing -# slash, then return the entire URL. - ad_proc -public template::util::get_url_directory { url } { - + Get the directory portion of a URL. If the URL has a trailing + slash, then return the entire URL. +} { set directory $url set lastchar [string range $url [expr [string length $url]-1] end] @@ -524,13 +499,10 @@ return $directory } -# @public get_cookie - -# Retrieve the value of a cookie and return it -# Return the default if no such cookie exists - ad_proc -public template::util::get_cookie { name {default_value ""} } { - + Retrieve the value of a cookie and return it + Return the default if no such cookie exists +} { set headers [ns_conn headers] set cookie [ns_set iget $headers Cookie] @@ -542,13 +514,11 @@ return $default_value } -# @public set_cookie - -# Create a cookie with specified parameters. The expiration state -# may be persistent, session, or a number of minutes from the current -# time. - ad_proc -public template::util::set_cookie { expire_state name value { domain "" } } { + Create a cookie with specified parameters. The expiration state + may be persistent, session, or a number of minutes from the current + time. +} { if { [string match $domain {}] } { set path "ns/server/[ns_info server]/module/nssock" @@ -577,12 +547,9 @@ ns_set put [ns_conn outputheaders] "Set-Cookie" $cookie } -# @public clear_cookie - -# Expires an existing cookie. - ad_proc -public template::util::clear_cookie { name { domain "" } } { - + Expires an existing cookie. +} { if { [string match $domain {}] } { set path "ns/server/[ns_info server]/module/nssock" set domain [ns_config $path Hostname] @@ -601,16 +568,15 @@ return $html } +ad_proc -public template::util::multirow_quote_html {multirow_ref column_ref} { + implements template::util::quote_html on the designated column of a multirow -# @public multirow_quote_html -# implements template::util::quote_html on the designated column of a multirow + @param multirow_ref name of the multirow + @param column_ref name of the column to be -# @param multirow_ref name of the multirow -# @param column_ref name of the column to be + @author simon +} { -# @author simon - -ad_proc -public template::util::multirow_quote_html {multirow_ref column_ref} { upvar $multirow_ref:rowcount rowcount for { set i 1 } { $i <= $rowcount } { incr i} { @@ -621,21 +587,27 @@ } -# @public multirow_foreach -# runs a block of code foreach row in a multirow +ad_proc -public template::util::multirow_foreach { name code_text } { + runs a block of code foreach row in a multirow -# @param name the name of the multirow over which the block of code is iterated -# @param code_text the block of code in the for loop; this block can reference -# any of the columns belonging to the multirow specified; with the multirow -# named "fake_multirow" containing columns named "spanky" and "foobar",to set the column -# spanky to the value of column foobar use: -# set fake_multirow.spanky @fake_multirow.foobar@ -# note: this block of code is evaluated in the same scope as the .tcl page that uses -# this procedure + @param name the name of the multirow over which the block of + code is iterated -# @author simon + @param code_text the block of code in the for loop; this block can + reference any of the columns belonging to the + multirow specified; with the multirow named + "fake_multirow" containing columns named "spanky" + and "foobar",to set the column spanky to the value + of column foobar use:
+ set fake_multirow.spanky + @fake_multirow.foobar@ +

+ note: this block of code is evaluated in the same + scope as the .tcl page that uses this procedure -ad_proc -public template::util::multirow_foreach { name code_text } { + @author simon +} { + upvar $name:rowcount rowcount $name:columns columns i i upvar running_code running_code @@ -660,15 +632,11 @@ } - - -# @public get_param - -# Retreive a stored parameter, or "" if no such parameter -# If section/key are present, read the parameter from the specified -# section.key in the INI file, and cache them under the given name - ad_proc -public template::util::get_param { name {section {}} {key {}} } { + Retreive a stored parameter, or "" if no such parameter + If section/key are present, read the parameter from the specified + section.key in the INI file, and cache them under the given name +} { if { ![nsv_exists __template_config $name] } { @@ -698,45 +666,39 @@ } } -# @public set_param - -# Set a stored parameter - ad_proc -public template::util::set_param { name value } { + Set a stored parameter +} { nsv_set __template_config $name $value } -# @public nvl - -# Analogous to SQL NVL - ad_proc -public template::util::nvl { value value_if_null } { + Analogous to SQL NVL +} { + if { [template::util::is_nil value] } { return $value_if_null } else { return $value } } -# @public number_list - -# Return a list of numbers, {1 2 3 ... n} - ad_proc -public template::util::number_list { last_number {start_at 0} } { + Return a list of numbers, {1 2 3 ... n} +} { + set ret [list] for {set i $start_at} { $i <= $ret } {incr i} { lappend ret $i } return $ret } - -# @public tcl_to_sql_list - -# Convert a TCL list to a SQL list, for use with the "in" statement -# why doesn't this use ns_dbquotevalue? - ad_proc -public template::util::tcl_to_sql_list { lst } { + Convert a TCL list to a SQL list, for use with the "in" statement + why doesn't this use ns_dbquotevalue? +} { + if { [llength $lst] > 0 } { set sql "'" append sql [join $lst "', '"] @@ -749,16 +711,19 @@ -# Get the template directory -# The body is doublequoted, so it is interpreted when this file is read -ad_proc -public template::get_resource_path {} " +ad_proc -public template::get_resource_path {} { + Get the template directory + The body is doublequoted, so it is interpreted when this file is read +} " return \"[file dir [file dir [info script]]]/resources\" " -# return the variables and arrays of one frame as HTML ad_proc -public stack_frame_values {level} { + return the variables and arrays of one frame as HTML +} { + set varlist "" foreach i [if $level { uplevel \#$level {info locals} @@ -788,8 +753,9 @@ -# return the whole call stack as HTML ad_proc -public stack_dump {} { + return the whole call stack as HTML +} { append page "

Tcl Call Trace