X-Git-Url: https://jasonwoof.com/gitweb/?a=blobdiff_plain;f=misc.php;h=b18abd43b9f62aeeebf3cac3a7408705aa3af1c4;hb=3faf64c6a1e0cbd4f880da951775c41fb8a6f0ab;hp=4e1da442c27d93f42a9305afda42430f66b529ce;hpb=33991182df707af9558bc761bf2f58d1f3f950ef;p=wfpl.git diff --git a/misc.php b/misc.php index 4e1da44..b18abd4 100644 --- a/misc.php +++ b/misc.php @@ -1,20 +1,78 @@ . + +# returns an array containing just the elements of $pipes that are readable (without blocking) +# timeout 0 means don't wait, timeout NULL means wait indefinitely +function readable_sockets($pipes, $timeout = 0){ + $read = array_values($pipes); + $ret = stream_select($read, $write = NULL, $exceptions = NULL, $timeout); + if($ret === false) { + return false; + } + if($ret) { + return $read; + } else { + return array(); + } +} + + +# Parameters: +# command +# stdin +# Returns: (as array) +# exit code +# stdout +function exec_pipe($command, $stdin) { + $descriptorspec = array( + 0 => array('pipe', 'r'), // stdin is a pipe that the child will read from + 1 => array('pipe', 'w'), // stdout is a pipe that the child will write to + 2 => array('file', '/dev/null', 'w') // stderr is a pipe that the child will write to + ); + + $process = proc_open($command, $descriptorspec, $pipes); + + if (is_resource($process)) { + fwrite($pipes[0], $stdin); + fclose($pipes[0]); + + while (!feof($pipes[1])) { + $chunk = fread($pipes[1], 1024); + $stdout .= $chunk; + sleep(0.5); + } + + fclose($pipes[1]); + + // It is important that you close any pipes before calling + // proc_close in order to avoid a deadlock + $return_value = proc_close($process); + + return array($return_value, $stdout); } - $file_data = fread($fd, filesize($name)); - fclose($fd); - return $file_data; } + function unix_newlines($str) { $str = str_replace("\r\n", "\n", $str); return str_replace("\r", "\n", $str); } + # return current year (all 4 digits) function this_year() { return strftime('%Y'); @@ -22,7 +80,54 @@ function this_year() { # return the number of the current month (1..12) function this_month() { - return strftime('%m'); + return ereg_replace('^0', '', strftime('%m')); +} + +# return today's date in yyyy-mm-dd format +function today_ymd() { + return strftime('%Y-%m-%d'); +} + + +function get_text_between($text, $start_text, $end_text) { + $start = strpos($text, $start_text); + if($start === false) { + return false; + } + $text = substr($text, $start + strlen($start_text)); + $end = strpos($text, $end_text); + if($end === false) { + return false; + } + return substr($text, 0, $end); +} + +# php4 is broken, in that you cannot set a default value for a parameter that +# is passed by reference. So, this is set up to use the following screwy +# syntax: +# +# function foo($bar = 0) { +# if($bar !== 0) { +# $bar = $bar->ref; +# } +# ... +# } +# +# foo(); +# foo(ref($baz)); + +class stupid_reference { + var $ref; + function stupid_reference(&$ref) { + $this->ref = &$ref; + } +} +function ref(&$foo) { + return new stupid_reference($foo); +} + +function &last(&$array) { + if(count($array)) return $array[count($array) - 1]; } ?>