+ $buffer = ob_get_contents(); // Grab the print_r output
+ ob_end_clean(); // Silently discard the output & stop buffering
+ print '<div align="left"><pre>';
+ print htmlentities($buffer);
+ print '</pre></div>';
+}
+
+
+/**
+ * SquirrelMail wrapper for popen()/proc_open()
+ *
+ * This emulates popen() by using proc_open() if at all
+ * possible (reverts seamlessly to popen() if proc_open()
+ * is not supported in current PHP installation).
+ *
+ * This is intended for use with the related sq_pclose(),
+ * sq_get_pipe_stdout() and sq_get_pipe_stderr() functions,
+ * the latter of which add an easy interface for retrieving
+ * output from a child process that was opened with traditional
+ * popen() syntax (in write mode), while not breaking under
+ * earlier versions of PHP.
+ *
+ * @param string $command The command identifying what to
+ * execute in the child process.
+ * @param string $mode The desired mode for the
+ * unidirectional pipe that is returned;
+ * either 'r' for read or 'w' for write.
+ *
+ * @return resource A handle on the desired read or write pipe
+ * to the child process, or FALSE if the
+ * process cannot be created.
+ *
+ * @since 1.5.2
+ *
+ */
+function sq_popen($command, $mode) {
+
+ $mode = strtolower($mode{0});
+
+
+ if (!function_exists('proc_open'))
+ return popen($command, $mode);
+
+
+ // set up our process store if not done already
+ //
+ global $processes;
+ if (empty($processes))
+ $processes = array();
+
+
+ // define read, write and error pipes
+ //
+ $descriptors = array(0 => array('pipe', 'r'),
+ 1 => array('pipe', 'w'),
+ 2 => array('pipe', 'w'));
+
+
+ // start the child process
+ //
+ $proc = proc_open($command, $descriptors, $pipes);
+ if (!is_resource($proc))
+ return FALSE;
+
+
+ // when in read mode, we'll return a handle to the child's write pipe
+ //
+ if ($mode == 'r')
+ $return_value = $pipes[1];
+ else if ($mode == 'w')
+ $return_value = $pipes[0];
+ else
+ die('sq_popen() expects $mode to be "r" or "w"');
+
+
+ // store the handle to the process and its pipes
+ // internally, keyed by whatever handle we'll be
+ // returning
+ //
+ $processes[$return_value] = array($proc, $pipes);
+
+
+ return $return_value;
+
+}
+
+
+/**
+ * Get STDERR output from a child process
+ *
+ * This is designed to be used with processes that were
+ * opened with sq_popen(), and will return any output
+ * that may be available from STDERR of the child process
+ * at the current time.
+ *
+ * If a value is given for $timeout_seconds, this function
+ * will wait that long for output in case there is none
+ * right now.
+ *
+ * In PHP environments that do not support proc_open(),
+ * an empty string will always be returned.
+ *
+ * @param resource $handle The handle to the child process,
+ * as returned from sq_popen().
+ * @param int $timeout_seconds The number of seconds to wait
+ * for output if there is none
+ * available immediately (OPTIONAL;
+ * default is not to wait)
+ * @param boolean $quiet When TRUE, errors are silently
+ * ignored (OPTIONAL; default is TRUE).
+ *
+ * @return string Any STDERR output that may have been found.
+ *
+ * @since 1.5.2
+ *
+ */
+function sq_get_pipe_stderr($handle, $timeout_seconds=0, $quiet=TRUE) {
+
+ // yes, we are testing for proc_OPEN
+ // because we need to know how the
+ // handle was actually OPENED
+ //
+ if (!function_exists('proc_open'))
+ return '';
+
+
+ // get our process out of the process store
+ //
+ global $processes;
+ if (!is_array($processes) || !isset($processes[$handle])) {
+ if (!quiet) {
+ plain_error_message(_("Failed to find corresponding open process handle"));
+ }
+ return '';