Thomas Bruederli
2013-01-28 6782fe1fd7d3230350153ba307dd5d49b9670604
program/include/rcmail_output_html.php
@@ -164,6 +164,7 @@
        }
        $this->config->set('skin_path', $skin_path);
        $this->base_path = $skin_path;
        // register skin path(s)
        $this->skin_paths = array();
@@ -214,7 +215,7 @@
     * @param string Additional path to search in
     * @return mixed Relative path to the requested file or False if not found
     */
    public function get_skin_file($file, &$skin_path, $add_path = null)
    public function get_skin_file($file, &$skin_path = null, $add_path = null)
    {
        $skin_paths = $this->skin_paths;
        if ($add_path)
@@ -379,7 +380,7 @@
        // unlock interface after iframe load
        $unlock = preg_replace('/[^a-z0-9]/i', '', $_REQUEST['_unlock']);
        if ($this->framed) {
            array_unshift($this->js_commands, array('set_busy', false, null, $unlock));
            array_unshift($this->js_commands, array('iframe_loaded', $unlock));
        }
        else if ($unlock) {
            array_unshift($this->js_commands, array('hide_message', $unlock));
@@ -462,6 +463,7 @@
            if (is_readable($path)) {
                $this->config->set('skin_path', $skin_path);
                $this->base_path = preg_replace('!plugins/\w+/!', '', $skin_path);  // set base_path to core skin directory (not plugin's skin)
                $skin_dir = preg_replace('!^plugins/!', '', $skin_path);
                break;
            }
            else {
@@ -643,6 +645,7 @@
    protected function file_callback($matches)
    {
        $file = $matches[3];
        $file[0] = preg_replace('!^/this/!', '/', $file[0]);
        // correct absolute paths
        if ($file[0] == '/') {
@@ -670,7 +673,10 @@
     */
    public function just_parse($input)
    {
        return $this->parse_xml($input);
        $input = $this->parse_conditions($input);
        $input = $this->parse_xml($input);
        return $input;
    }
@@ -1545,10 +1551,10 @@
                }
            }
        }
        else if (is_array($default_host) && ($host = array_pop($default_host))) {
        else if (is_array($default_host) && ($host = key($default_host)) !== null) {
            $hide_host = true;
            $input_host = new html_hiddenfield(array(
                'name' => '_host', 'id' => 'rcmloginhost', 'value' => $host) + $attrib);
                'name' => '_host', 'id' => 'rcmloginhost', 'value' => is_numeric($host) ? $default_host[$host] : $host) + $attrib);
        }
        else if (empty($default_host)) {
            $input_host = new html_inputfield(array('name' => '_host', 'id' => 'rcmloginhost')