2001-12-01 15:20:48 +00:00
< ? php
// $Id$
function conf_init () {
2002-04-20 11:52:50 +00:00
global $HTTP_HOST ;
2001-12-01 15:20:48 +00:00
/*
** Try finding a matching configuration file by stripping the website ' s
** URI from left to right . If no configuration file is found , return a
** default value 'conf' .
*/
2002-04-20 11:52:50 +00:00
$file = strtolower ( strtr ( $HTTP_HOST . substr ( request_uri (), 0 , strrpos ( request_uri (), " / " )), " /: " , " .. " ));
2001-12-01 15:20:48 +00:00
while ( strlen ( $file ) > 4 ) {
if ( file_exists ( " includes/ $file .php " )) {
return $file ;
}
else {
$file = substr ( $file , strpos ( $file , " . " ) + 1 );
}
}
return " conf " ;
}
function error_handler ( $errno , $message , $filename , $line , $variables ) {
$types = array ( 1 => " error " , 2 => " warning " , 4 => " parse error " , 8 => " notice " , 16 => " core error " , 32 => " core warning " , 64 => " compile error " , 128 => " compile warning " , 256 => " user error " , 512 => " user warning " , 1024 => " user notice " );
$entry = $types [ $errno ] . " : $message in $filename on line $line . " ;
2002-04-20 11:52:50 +00:00
if (( $errno == 1 || $errno == 2 || $errno == 4 || $errno == 256 ) && error_reporting ()) {
2001-12-01 15:20:48 +00:00
watchdog ( " error " , $types [ $errno ] . " : $message in $filename on line $line . " );
print $entry ;
}
}
function watchdog ( $type , $message ) {
global $user ;
2002-05-12 16:13:37 +00:00
db_query ( " INSERT INTO watchdog (uid, type, message, location, hostname, timestamp) VALUES (' $user->uid ', '%s', '%s', '%s', '%s', '%s') " , $type , $message , request_uri (), getenv ( " REMOTE_ADDR " ), time ());
2001-12-01 15:20:48 +00:00
}
function throttle ( $type , $rate ) {
if ( ! user_access ( " access administration pages " )) {
if ( $throttle = db_fetch_object ( db_query ( " SELECT * FROM watchdog WHERE type = ' $type ' AND hostname = ' " . getenv ( " REMOTE_ADDR " ) . " ' AND " . time () . " - timestamp < $rate " ))) {
watchdog ( " warning " , " throttle: ' " . getenv ( " REMOTE_ADDR " ) . " ' exceeded submission rate - $throttle->type " );
die ( message_throttle ());
}
else {
watchdog ( $type , " throttle " );
}
}
}
2001-12-30 16:16:38 +00:00
function array2object ( $node ) {
if ( is_array ( $node )) {
foreach ( $node as $key => $value ) {
$object -> $key = $value ;
}
}
else {
$object = $node ;
}
return $object ;
}
function object2array ( $node ) {
if ( is_object ( $node )) {
foreach ( $node as $key => $value ) {
$array [ $key ] = $value ;
}
}
else {
$array = $node ;
}
return $array ;
}
2002-04-14 20:46:41 +00:00
function path_uri ( $brief = 0 ) {
2002-04-20 11:52:50 +00:00
global $HTTP_HOST ;
$path = $HTTP_HOST . substr ( request_uri (), 0 , strrpos ( request_uri (), " / " )) . " / " ;
2002-04-14 20:46:41 +00:00
if ( ! $brief ) {
$path = " http:// " . $path ;
}
return $path ;
2001-12-01 15:20:48 +00:00
}
2002-04-20 11:52:50 +00:00
function request_uri () {
2002-04-27 13:19:37 +00:00
// since request_uri() is only available on apache, we generate equivalent using other environment vars.
global $REQUEST_URI , $PATH_INFO , $QUERY_STRING ;
if ( $REQUEST_URI ) {
return $REQUEST_URI ;
}
else {
2002-05-11 16:21:48 +00:00
return $PATH_INFO . " ? " . $QUERY_STRING ;
2002-04-27 13:19:37 +00:00
}
2002-04-20 11:52:50 +00:00
}
2001-12-01 15:20:48 +00:00
function message_access () {
return t ( " You are not authorized to access to this page. " );
}
function message_na () {
return t ( " n/a " );
}
function message_throttle () {
return t ( " You exceeded the maximum submission rate. Please wait a few minutes and try again. " );
}
2001-12-27 15:27:44 +00:00
function locale_init () {
global $languages , $user ;
return ( $languages ? (( $user -> uid && $user -> language ) ? $user -> language : key ( $languages )) : 0 );
}
2002-04-20 11:52:50 +00:00
function t ( $string , $args = 0 ) {
2001-12-27 15:27:44 +00:00
global $languages ;
2002-04-24 20:55:20 +00:00
2002-05-02 18:47:35 +00:00
/*
** About the usage of t () . We try to keep strings whole as much as
** possible and are unafraid of HTML markup within translation strings
** if necessary . The suggested syntax for a link embedded within a
** translation string is for example :
**
** $msg = t ( " You must login below or <a href= \" %url \" >create a new
** account </ a > before viewing the next page . " , array ( " % url "
** => drupal_url ( array ( " mod " => " user " , " op " => " register " ),
** " module " )));
*/
2002-04-24 20:55:20 +00:00
$string = ( $languages && function_exists ( " locale " ) ? locale ( $string ) : $string );
2002-04-20 11:52:50 +00:00
if ( ! $args ) {
return $string ;
2002-04-22 09:05:36 +00:00
}
else {
2002-04-20 11:52:50 +00:00
return strtr ( $string , $args );
}
2001-12-27 15:27:44 +00:00
}
function variable_init ( $conf = array ()) {
$result = db_query ( " SELECT * FROM variable " );
while ( $variable = db_fetch_object ( $result )) {
if ( ! isset ( $conf [ $variable -> name ])) {
$conf [ $variable -> name ] = $variable -> value ;
}
}
return $conf ;
}
function variable_get ( $name , $default , $object = 0 ) {
global $conf ;
return isset ( $conf [ $name ]) ? $conf [ $name ] : $default ;
}
function variable_set ( $name , $value ) {
global $conf ;
2002-04-20 11:52:50 +00:00
db_query ( " DELETE FROM variable WHERE name = '%s' " , $name );
db_query ( " INSERT INTO variable (name, value) VALUES ('%s', '%s') " , $name , $value );
2001-12-27 15:27:44 +00:00
$conf [ $name ] = $value ;
}
function variable_del ( $name ) {
global $conf ;
2002-04-20 11:52:50 +00:00
db_query ( " DELETE FROM variable WHERE name = '%s' " , $name );
2001-12-27 15:27:44 +00:00
unset ( $conf [ $name ]);
}
2002-03-05 20:15:17 +00:00
/**
* Format a single result entry of a search query :
*
* @ param $item a single search result as returned by < module > _search of type
2002-04-14 20:46:41 +00:00
* array ( " count " => ... , " link " => ... , " title " => ... ,
2002-03-05 20:15:17 +00:00
* " user " => ... , " date " => ... , " keywords " => ... )
* @ param $type module type of this item
*/
2001-12-27 15:27:44 +00:00
function search_item ( $item , $type ) {
2002-04-27 13:19:37 +00:00
/*
** Modules may implement the " search_item " hook in order to overwrite
** the default function to display search results .
*/
if ( module_hook ( $type , " search_item " )) {
$output = module_invoke ( $type , " search_item " , $item );
}
else {
$output .= " <b> " . $item [ " count " ] . " <u><a href= \" " . $item [ " link " ] . " \" > " . $item [ " title " ] . " </a></u></b><br /> " ;
$output .= " <small> $type " . ( $item [ " user " ] ? " - " . $item [ " user " ] : " " ) . " " . ( $item [ " date " ] ? " - " . format_date ( $item [ " date " ], " small " ) : " " ) . " </small> " ;
$output .= " <br /><br /> " ;
}
2001-12-27 15:27:44 +00:00
return $output ;
}
2002-03-05 20:15:17 +00:00
/**
* Render a generic search form .
*
* " Generic " means " universal usable " - that is , usable not only from
2002-04-14 20:46:41 +00:00
* module . php ? mod = search , but also as a simple seach box ( without
* " Restrict search to " , help text , etc ) from theme ' s header etc .
* This means : provide options to only conditionally render certain
2002-03-05 20:15:17 +00:00
* parts of this form .
*
* @ param $action Form action . Defaults to module . php ? mod = search .
* @ param $query Query string . Defaults to global $keys .
2002-04-14 20:46:41 +00:00
* @ param $options != 0 : Render additional form fields / text
2002-03-05 20:15:17 +00:00
* ( " Restrict search to " , help text , etc ) .
*/
2001-12-27 15:27:44 +00:00
function search_form ( $action = 0 , $query = 0 , $options = 0 ) {
global $keys ;
if ( ! $action ) {
2002-04-20 11:52:50 +00:00
$action = drupal_url ( array ( " mod " => " search " ), " module " );
2001-12-27 15:27:44 +00:00
}
if ( ! $query ) {
$query = $keys ;
}
2002-03-05 20:15:17 +00:00
$output .= " <br /><input type= \" text \" size= \" 50 \" value= \" " . check_form ( $keys ) . " \" name= \" keys \" /> " ;
$output .= " <input type= \" submit \" value= \" " . t ( " Search " ) . " \" /> \n " ;
2001-12-27 15:27:44 +00:00
if ( $options != 0 ) {
$output .= " <br /> " ;
$output .= t ( " Restrict search to " ) . " : " ;
foreach ( module_list () as $name ) {
if ( module_hook ( $name , " search " )) {
2002-03-05 20:15:17 +00:00
$output .= " <input type= \" checkbox \" name= \" edit[type][ $name ] \" " . ( $edit [ " type " ][ $name ] ? " checked= \" checked \" " : " " ) . " /> " . t ( $name );
2001-12-27 15:27:44 +00:00
}
}
2002-03-05 20:15:17 +00:00
// TODO: (link to) search hints
2001-12-27 15:27:44 +00:00
}
2002-03-05 20:15:17 +00:00
$form .= " <br /> " ;
2001-12-27 15:27:44 +00:00
return form ( $output , " post " , $action );
}
/*
2002-03-05 20:15:17 +00:00
* Collect the search results :
*/
2001-12-27 15:27:44 +00:00
function search_data () {
global $keys , $edit ;
$keys = check_input ( $keys );
if ( $keys ) {
foreach ( module_list () as $name ) {
if ( module_hook ( $name , " search " ) && ( ! $edit [ " type " ] || $edit [ " type " ][ $name ]) && ( $result = module_invoke ( $name , " search " , check_query ( $keys )))) {
2002-03-05 20:15:17 +00:00
if ( $name == " node " || $name == " comment " ) {
$output .= " <b>Matching " . $name . " s ranked in order of relevance</b><br /> " ;
}
else {
$output .= " <b>Matching " . $name . " s</b><br /> " ;
}
2001-12-27 15:27:44 +00:00
foreach ( $result as $entry ) {
$output .= search_item ( $entry , $name );
}
}
}
2002-03-05 20:15:17 +00:00
if ( ! $output ) {
2001-12-27 15:27:44 +00:00
$output .= t ( " Your search yielded no results. " );
}
}
return $output ;
}
2002-03-05 20:15:17 +00:00
/**
* Display the search form and the resulting data .
*
2002-04-14 20:46:41 +00:00
* @ param $type If set , search only nodes of this type .
2002-03-05 20:15:17 +00:00
* Otherwise , search all types .
* @ param $action Form action . Defaults to module . php ? mod = search .
* @ param $query Query string . Defaults to global $keys .
2002-04-14 20:46:41 +00:00
* @ param $options != 0 : Render additional form fields / text
2002-03-05 20:15:17 +00:00
* ( " Restrict search to " , help text , etc ) .
*/
2001-12-27 15:27:44 +00:00
function search_type ( $type = 0 , $action = 0 , $query = 0 , $options = 0 ) {
global $edit ;
if ( $type ) {
$edit [ " type " ][ $type ] = " on " ;
}
return search_form ( $action , $query , $options ) . search_data ();
}
2002-04-14 20:46:41 +00:00
2001-12-01 15:20:48 +00:00
function drupal_goto ( $url ) {
/*
** It is advised to use " drupal_goto() " instead of PHP ' s " header() " as
** " drupal_goto() " will append the user ' s session ID to the URI when PHP
** is compiled with " --enable-trans-sid " .
*/
if ( SID == " " || strstr ( $url , SID )) {
header ( " Location: $url " );
}
else if ( strstr ( $url , " ? " ) && ! strstr ( $url , SID )) {
header ( " Location: $url & " . SID );
}
else {
header ( " Location: $url ? " . SID );
}
/*
** The " Location " header sends a REDIRECT status code to the http
** deamon . In some cases this can go wrong , so we make sure none
** of the code / below / gets executed when we redirect .
*/
exit ();
}
/*
** Stores the referer in a persistent variable :
*/
function referer_save () {
2002-04-20 11:52:50 +00:00
global $referer , $HTTP_REFERER ;
2001-12-01 15:20:48 +00:00
2002-04-20 11:52:50 +00:00
if ( ! strstr ( $HTTP_REFERER , request_uri ())) {
2001-12-01 15:20:48 +00:00
$referer = $HTTP_REFERER ;
session_register ( " referer " );
}
}
/*
** Restores the referer from a persistent variable :
*/
function referer_load () {
global $referer ;
if ( session_is_registered ( " referer " )) {
return $referer ;
}
else {
return 0 ;
}
}
function check_form ( $text ) {
return htmlspecialchars ( stripslashes ( $text ));
}
function check_export ( $text ) {
return htmlspecialchars ( stripslashes ( $text ));
}
function check_code ( $text ) {
return $text ;
}
function check_preview ( $text ) {
return check_output ( check_input ( $text ));
}
function check_query ( $text ) {
return addslashes ( stripslashes ( $text ));
}
function filter ( $text ) {
foreach ( module_list () as $name ) {
2002-03-05 20:15:17 +00:00
if ( module_hook ( $name , " filter " )) {
$text = module_invoke ( $name , " filter " , $text );
}
2001-12-01 15:20:48 +00:00
}
return $text ;
}
function check_input ( $text ) {
return check_query ( $text );
}
function check_output ( $text , $nl2br = 0 ) {
2001-12-30 16:16:38 +00:00
return ( $text ) ? ( $nl2br ? str_replace ( " \r " , " " , str_replace ( " \n " , " <br /> " , stripslashes ( $text ))) : stripslashes ( $text )) : message_na ();
2001-12-01 15:20:48 +00:00
}
function check_file ( $filename ) {
if ( is_uploaded_file ( $filename )) {
return 1 ;
}
else {
return 0 ;
}
}
2002-04-27 13:19:37 +00:00
function format_rss_channel ( $title , $link , $description , $items , $language = " en " , $args = array ()) {
// arbitrary elements may be added using the $args associative array
2001-12-01 15:20:48 +00:00
$output .= " <channel> \n " ;
$output .= " <title> " . htmlentities ( strip_tags ( $title )) . " </title> \n " ;
$output .= " <link> " . htmlentities ( strip_tags ( $link )) . " </link> \n " ;
$output .= " <description> " . htmlentities ( $description ) . " </description> \n " ;
$output .= " <language> " . htmlentities ( strip_tags ( $language )) . " </language> \n " ;
2002-04-27 13:19:37 +00:00
foreach ( $args as $key => $value ) {
2002-05-11 16:21:48 +00:00
$output .= " < $key > " . htmlentities ( strip_tags ( $value )) . " </ $key > " ;
2002-04-27 13:19:37 +00:00
}
2001-12-01 15:20:48 +00:00
$output .= $items ;
$output .= " </channel> \n " ;
return $output ;
}
2002-04-27 13:19:37 +00:00
function format_rss_item ( $title , $link , $description , $args = array ()) {
// arbitrary elements may be added using the $args associative array
2001-12-01 15:20:48 +00:00
$output .= " <item> \n " ;
$output .= " <title> " . htmlentities ( strip_tags ( $title )) . " </title> \n " ;
$output .= " <link> " . htmlentities ( strip_tags ( $link )) . " </link> \n " ;
$output .= " <description> " . htmlentities ( $description ) . " </description> \n " ;
2002-04-27 13:19:37 +00:00
foreach ( $args as $key => $value ) {
2002-05-11 16:21:48 +00:00
$output .= " < $key > " . htmlentities ( strip_tags ( $value )) . " </ $key > " ;
2002-04-27 13:19:37 +00:00
}
2001-12-01 15:20:48 +00:00
$output .= " </item> \n " ;
return $output ;
}
function format_plural ( $count , $singular , $plural ) {
return ( $count == 1 ) ? " $count " . t ( $singular ) : " $count " . t ( $plural );
}
function format_size ( $size ) {
$suffix = " bytes " ;
if ( $size > 1024 ) {
$size = round ( $size / 1024 , 2 );
$suffix = " KB " ;
}
if ( $size > 1024 ) {
$size = round ( $size / 1024 , 2 );
$suffix = " MB " ;
}
return " $size $suffix " ;
}
2002-01-05 16:28:34 +00:00
function cache_get ( $key ) {
2002-04-20 11:52:50 +00:00
$cache = db_fetch_object ( db_query ( " SELECT data FROM cache WHERE cid = '%s' " , $key ));
2002-01-05 16:28:34 +00:00
return $cache -> data ? $cache -> data : 0 ;
}
function cache_set ( $cid , $data , $expire = 0 ) {
2002-04-20 11:52:50 +00:00
if ( db_fetch_object ( db_query ( " SELECT cid FROM cache WHERE cid = '%s' " , $cid ))) {
db_query ( " UPDATE cache SET data = '%s' WHERE cid = '%s' " , $data , $cid );
2002-01-05 16:28:34 +00:00
}
else {
2002-04-20 11:52:50 +00:00
db_query ( " INSERT INTO cache (cid, data, expire) VALUES('%s', '%s', '%s') " , $cid , $data , $expire );
2002-01-05 16:28:34 +00:00
}
2001-12-01 15:20:48 +00:00
}
2002-01-05 16:28:34 +00:00
function cache_del ( $cid ) {
2002-04-20 11:52:50 +00:00
db_query ( " DELETE FROM cache WHERE cid = '%s' " , $cid );
2002-01-05 16:28:34 +00:00
}
function cache_clear () {
db_query ( " DELETE FROM cache WHERE expire < " . time () . " AND expire > 0 " );
}
function page_set_cache () {
2002-04-20 11:52:50 +00:00
global $user , $REQUEST_METHOD ;
2001-12-01 15:20:48 +00:00
if ( ! $user -> uid && $REQUEST_METHOD == " GET " ) {
2002-01-05 16:28:34 +00:00
if ( $data = ob_get_contents ()) {
2002-04-20 11:52:50 +00:00
cache_set ( request_uri (), $data , ( time () + variable_get ( " cache_clear " , 30 )));
2001-12-01 15:20:48 +00:00
}
}
}
2002-01-05 16:28:34 +00:00
function page_get_cache () {
2002-04-20 11:52:50 +00:00
global $user , $REQUEST_METHOD ;
2001-12-01 15:20:48 +00:00
if ( ! $user -> uid && $REQUEST_METHOD == " GET " ) {
2002-04-20 11:52:50 +00:00
if ( $cache = cache_get ( request_uri ())) {
2002-01-05 16:28:34 +00:00
cache_clear ();
}
else {
ob_start ();
2001-12-01 15:20:48 +00:00
}
}
2002-01-05 16:28:34 +00:00
return $cache ? $cache : 0 ;
2001-12-01 15:20:48 +00:00
}
function format_interval ( $timestamp ) {
$units = array ( " year|years " => 31536000 , " week|weeks " => 604800 , " day|days " => 86400 , " hour|hours " => 3600 , " min|min " => 60 , " sec|sec " => 1 );
2002-05-12 15:40:57 +00:00
foreach ( $units as $key => $value ) {
2001-12-01 15:20:48 +00:00
$key = explode ( " | " , $key );
if ( $timestamp >= $value ) {
$output .= ( $output ? " " : " " ) . format_plural ( floor ( $timestamp / $value ), $key [ 0 ], $key [ 1 ]);
$timestamp %= $value ;
}
}
return ( $output ) ? $output : " 0 sec " ;
}
function format_date ( $timestamp , $type = " medium " , $format = " " ) {
global $user ;
// $timestamp += ($user->timezone) ? $user->timezone - date("Z") : 0;
switch ( $type ) {
case " small " :
2002-04-24 21:04:37 +00:00
$date = date ( variable_get ( " date_format " , " m/d/Y - H:i " ), $timestamp );
2001-12-01 15:20:48 +00:00
break ;
case " medium " :
2002-04-24 21:04:37 +00:00
$date = t ( date ( " l " , $timestamp )) . " , " . date ( variable_get ( " date_format " , " m/d/Y - H:i " ), $timestamp );
2001-12-01 15:20:48 +00:00
break ;
case " large " :
$date = t ( date ( " l " , $timestamp )) . " , " . t ( date ( " F " , $timestamp )) . " " . date ( " d, Y - H:i " , $timestamp );
break ;
case " custom " :
for ( $i = strlen ( $format ); $i >= 0 ; $c = $format [ -- $i ]) {
if ( strstr ( " DFlMSw " , $c )) {
$date = t ( date ( $c , $timestamp )) . $date ;
}
else if ( strstr ( " AaBdgGhHiIjLmnrstTUYyZz " , $c )) {
$date = date ( $c , $timestamp ) . $date ;
}
else {
2002-05-12 15:40:57 +00:00
$date = $c . $date ;
2001-12-01 15:20:48 +00:00
}
}
break ;
default :
2002-04-24 21:04:37 +00:00
$date = t ( date ( " l " , $timestamp )) . " , " . date ( variable_get ( " date_format " , " m/d/Y - H:i " ), $timestamp );
2001-12-01 15:20:48 +00:00
}
return $date ;
}
function format_name ( $object ) {
2001-12-05 18:54:14 +00:00
global $PHP_SELF ;
2001-12-01 15:20:48 +00:00
if ( $object -> uid && $object -> name ) {
2001-12-05 18:54:14 +00:00
if ( strstr ( $PHP_SELF , " admin.php " )) {
2002-04-20 11:52:50 +00:00
$output = la ( $object -> name , array ( " mod " => " user " , " op " => " edit " , " id " => $object -> uid ));
2001-12-05 18:54:14 +00:00
}
else {
2002-04-20 11:52:50 +00:00
$output = lm ( $object -> name , array ( " mod " => " user " , " op " => " view " , " id " => $object -> uid ));
2001-12-05 18:54:14 +00:00
}
2001-12-01 15:20:48 +00:00
}
else {
2001-12-05 18:54:14 +00:00
$output = variable_get ( anonymous , " Anonymous " );
2001-12-01 15:20:48 +00:00
}
2001-12-05 18:54:14 +00:00
return $output ;
2001-12-01 15:20:48 +00:00
}
function format_tag ( $link , $text ) {
2002-05-03 20:27:53 +00:00
return l (( $text ? $text : $link ), array ( " title " => $link ));
2001-12-01 15:20:48 +00:00
}
function form ( $form , $method = " post " , $action = 0 , $options = 0 ) {
2002-04-20 11:52:50 +00:00
return " <form action= \" " . ( $action ? $action : request_uri ()) . " \" method= \" $method\ " " . ( $options ? " $options " : " " ) . " > \n $form </ form > \n " ;
2001-12-01 15:20:48 +00:00
}
function form_item ( $title , $value , $description = 0 ) {
2001-12-20 22:00:00 +00:00
return " <p> " . ( $title ? " <b> $title :</b><br /> " : " " ) . $value . ( $description ? " <br /><small><i> $description </i></small> " : " " ) . " </p> \n " ;
2001-12-01 15:20:48 +00:00
}
2001-12-20 21:44:46 +00:00
function form_checkbox ( $title , $name , $value = 1 , $checked = 0 , $description = 0 ) {
return form_item ( 0 , " <input type= \" checkbox \" name= \" edit[ $name ] \" value= \" " . $value . " \" " . ( $checked ? " checked= \" checked \" " : " " ) . " /> $title " , $description );
2001-12-01 15:20:48 +00:00
}
function form_textfield ( $title , $name , $value , $size , $maxlength , $description = 0 ) {
return form_item ( $title , " <input maxlength= \" $maxlength\ " name = \ " edit[ $name ] \" size= \" $size\ " value = \ " " . check_form ( $value ) . " \" /> " , $description );
}
function form_password ( $title , $name , $value , $size , $maxlength , $description = 0 ) {
return form_item ( $title , " <input type= \" password \" maxlength= \" $maxlength\ " name = \ " edit[ $name ] \" size= \" $size\ " value = \ " " . check_form ( $value ) . " \" /> " , $description );
}
function form_textarea ( $title , $name , $value , $cols , $rows , $description = 0 ) {
return form_item ( $title , " <textarea wrap= \" virtual \" cols= \" $cols\ " rows = \ " $rows\ " name = \ " edit[ $name ] \" > " . check_form ( $value ) . " </textarea> " , $description );
}
2002-04-14 20:46:41 +00:00
function form_select ( $title , $name , $value , $options , $description = 0 , $extra = 0 , $multiple = 0 ) {
2001-12-01 15:20:48 +00:00
if ( count ( $options ) > 0 ) {
2002-05-12 15:40:57 +00:00
foreach ( $options as $key => $choice ) {
2002-01-27 14:58:45 +00:00
$select .= " <option value= \" $key\ " " . (is_array( $value ) ? (in_array( $key , $value ) ? " selected = \ " selected \" " : " " ) : ( $key == $value ? " selected= \" selected \" " : " " )) . " > " . check_form ( $choice ) . " </option> " ;
}
2002-04-22 09:05:36 +00:00
return form_item ( $title , " <select name= \" edit[ $name ] " . ( $multiple ? " [] " : " " ) . " \" " . ( $multiple ? " multiple " : " " ) . ( $extra ? " $extra " : " " ) . " > $select </select> " , $description );
2001-12-01 15:20:48 +00:00
}
}
function form_file ( $title , $name , $size , $description = 0 ) {
return form_item ( $title , " <input type= \" file \" name= \" edit[ $name ] \" size= \" $size\ " /> \n " , $description );
}
function form_hidden ( $name , $value ) {
return " <input type= \" hidden \" name= \" edit[ $name ] \" value= \" " . check_form ( $value ) . " \" /> \n " ;
}
function form_submit ( $value ) {
return " <input type= \" submit \" name= \" op \" value= \" " . check_form ( $value ) . " \" /> \n " ;
}
2002-04-20 11:52:50 +00:00
/**
2002-05-05 19:04:26 +00:00
* Build an URL ; use this functions when you must write an URL
* for example in a form or a redirect .
2002-04-20 11:52:50 +00:00
*
* @ param $args dictionary of arguments to be passed to the script
* @ param $script script to be invoked ; optional , defaults to node
2002-05-12 15:40:57 +00:00
* @ param $anchor optional , anchor name
2002-04-20 11:52:50 +00:00
*/
2002-05-12 15:40:57 +00:00
function drupal_url ( $args = array (), $script = " node " , $anchor = " " ) {
2002-04-20 11:52:50 +00:00
$t = array ();
2002-05-02 18:47:35 +00:00
foreach ( $args as $key => $value ) {
2002-05-03 20:27:53 +00:00
$t [] = " $key = " . urlencode ( $value );
2002-04-20 11:52:50 +00:00
}
2002-05-12 15:40:57 +00:00
return " $script .php? " . implode ( " & " , $t ) . ( $anchor != " " ? " # " . $anchor : " " );
2002-04-20 11:52:50 +00:00
}
/**
2002-05-05 19:04:26 +00:00
* Build a HTML link ; use this functions when you must write a link
2002-04-20 11:52:50 +00:00
* to another drupal page
*
* @ param $args dictionary of arguments to be passed to the script
2002-04-27 13:19:37 +00:00
* @ param $text text of the link
2002-05-12 15:40:57 +00:00
* @ param $anchor optional , anchor name
2002-04-20 11:52:50 +00:00
* @ param $script script to be invoked ; optional , defaults to node
2002-04-27 13:19:37 +00:00
* @ param $attributes optional , dictionary of attributes for the < a > tag such as 'target' , 'name' , 'class' , etc .
2002-04-20 11:52:50 +00:00
*/
2002-05-12 15:40:57 +00:00
function l ( $text , $args = array (), $script = " node " , $anchor = " " , $attributes = array ()) {
2002-04-27 13:19:37 +00:00
$t = array ();
foreach ( $attributes as $key => $value ) {
$t [] = " $key = \" $value\ " " ;
}
2002-05-12 15:40:57 +00:00
return " <a href= \" " . drupal_url ( $args , $script , $anchor ) . " \" " . implode ( $t , " " ) . " > $text </a> " ;
2002-04-20 11:52:50 +00:00
}
2002-05-12 15:40:57 +00:00
function la ( $text , $args = array (), $anchor = " " , $attributes = array ()) {
2002-04-20 11:52:50 +00:00
// we don't call l() to avoid another duplication of the array
2002-04-27 13:19:37 +00:00
$t = array ();
foreach ( $attributes as $key => $value ) {
$t [] = " $key = \" $value\ " " ;
}
2002-05-12 15:40:57 +00:00
return " <a href= \" " . drupal_url ( $args , " admin " , $anchor ) . " \" " . implode ( $t , " " ) . " > $text </a> " ;
2002-04-20 11:52:50 +00:00
}
2002-05-12 15:40:57 +00:00
function lm ( $text , $args = array (), $anchor = " " , $attributes = array ()) {
2002-04-20 11:52:50 +00:00
// we don't call l() to avoid another duplication of the array
2002-04-27 13:19:37 +00:00
$t = array ();
foreach ( $attributes as $key => $value ) {
$t [] = " $key = \" $value\ " " ;
}
2002-05-12 15:40:57 +00:00
return " <a href= \" " . drupal_url ( $args , " module " , $anchor ) . " \" " . implode ( $t , " " ) . " > $text </a> " ;
2002-04-20 11:52:50 +00:00
}
2001-12-01 15:20:48 +00:00
function field_get ( $string , $name ) {
ereg ( " , $name =([^,]+) " , " , $string " , $regs );
return $regs [ 1 ];
}
function field_set ( $string , $name , $value ) {
$rval = ereg_replace ( " , $name =[^,]+ " , " " , " , $string " );
2002-03-05 20:15:17 +00:00
if ( $value ) {
$rval .= ( $rval == " , " ? " " : " , " ) . " $name = $value " ;
}
2001-12-01 15:20:48 +00:00
return substr ( $rval , 1 );
}
function link_page () {
2002-04-02 09:45:57 +00:00
global $custom_links ;
2002-04-14 20:46:41 +00:00
2002-04-02 09:45:57 +00:00
if ( is_array ( $custom_links )) {
return $custom_links ;
}
else {
$links [] = " <a href= \" index.php \" > " . t ( " home " ) . " </a> " ;
2002-04-14 20:46:41 +00:00
foreach ( module_list () as $name ) {
2002-04-02 09:45:57 +00:00
if ( module_hook ( $name , " link " )) {
$links = array_merge ( $links , module_invoke ( $name , " link " , " page " ));
2002-04-14 20:46:41 +00:00
}
2001-12-01 15:20:48 +00:00
}
2002-04-27 13:19:37 +00:00
2002-04-02 09:45:57 +00:00
return $links ;
2001-12-01 15:20:48 +00:00
}
2002-04-14 20:46:41 +00:00
}
2001-12-01 15:20:48 +00:00
function link_node ( $node , $main = 0 ) {
foreach ( module_list () as $name ) {
if ( module_hook ( $name , " link " )) {
$links = array_merge ( $links , module_invoke ( $name , " link " , " node " , $node , $main ));
}
}
return $links ? $links : array ();
}
function timer_start () {
global $timer ;
2001-12-30 16:16:38 +00:00
list ( $usec , $sec ) = explode ( " " , microtime ());
$timer = ( float ) $usec + ( float ) $sec ;
2001-12-01 15:20:48 +00:00
}
function timer_print () {
global $timer ;
2001-12-30 16:16:38 +00:00
list ( $usec , $sec ) = explode ( " " , microtime ());
$stop = ( float ) $usec + ( float ) $sec ;
$diff = $stop - $timer ;
print " <pre>execution time: $diff sec</pre> " ;
2001-12-23 21:47:02 +00:00
}
function query_print () {
global $queries ;
print " <pre> " ;
print_r ( $queries );
print " </pre> " ;
2001-12-01 15:20:48 +00:00
}
function page_header () {
if ( variable_get ( " dev_timer " , 0 )) {
timer_start ();
}
if ( variable_get ( " cache " , 0 )) {
2002-01-05 16:28:34 +00:00
if ( $data = page_get_cache ()) {
2001-12-01 15:20:48 +00:00
print $data ;
exit ();
}
}
}
function page_footer () {
if ( variable_get ( " dev_timer " , 0 )) {
timer_print ();
}
2001-12-23 21:47:02 +00:00
if ( variable_get ( " dev_query " , 0 )) {
query_print ();
}
2001-12-01 15:20:48 +00:00
if ( variable_get ( " cache " , 0 )) {
2002-01-05 16:28:34 +00:00
page_set_cache ();
2001-12-01 15:20:48 +00:00
}
}
$config = conf_init ();
unset ( $conf );
2002-01-27 14:58:45 +00:00
2001-12-01 15:20:48 +00:00
include_once " includes/ $config .php " ;
include_once " includes/database.inc " ;
include_once " includes/xmlrpc.inc " ;
include_once " includes/module.inc " ;
include_once " includes/theme.inc " ;
// initialize configuration variables:
$conf = variable_init ( $conf );
// initialize installed modules:
module_init ();
// initialize localization system:
$locale = locale_init ();
// initialize theme:
$theme = theme_init ();
// set error handler:
set_error_handler ( " error_handler " );
?>