$num_queries = isset($GLOBALS['db']) ? $GLOBALS['db']->num_queries : 0;
        switch ($type) {
            case 'file':
                // {
                $location = $_SERVER['REQUEST_URI'];
                break;
                // }
            // }
            case 'menu':
                // {
                $location = 'menu';
                break;
                // }
            // }
            case 'page':
                // {
                $location = $GLOBALS['PAGEDATA']->id . '|' . $GLOBALS['PAGEDATA']->getRelativeUrl();
                break;
                // }
            // }
            default:
                // {
                $location = 'unknown_type_' . $type;
                //}
        }
        $log->log($_SERVER['REMOTE_ADDR'] . '	' . $location . '	' . $_SERVER['HTTP_USER_AGENT'] . '	' . $_SERVER['HTTP_REFERER'] . '	' . memory_get_peak_usage() . '	' . $length . '	' . (microtime(true) - START_TIME) . '	' . $num_queries);
        ob_flush();
    }
}
ob_show_and_log('file');
 * @return text
 */
function AjaxMenu_getChildren($parentid, $currentpage = 0, $topParent = 0, $search_options = 0)
{
    return array($parentid, Menu_getChildren($parentid, $currentpage, 0, $topParent, $search_options));
}
kaejax_export('AjaxMenu_getChildren');
kaejax_handle_client_request();
kaejax_show_javascript();
$search_options = isset($_REQUEST['search_options']) ? $_REQUEST['search_options'] : 0;
if (!isset($_GET['pageid'])) {
    exit;
}
$md5 = md5($_GET['pageid'] . '|' . $search_options);
$cache = cache_load('menus', $md5);
ob_start();
if ($cache) {
    echo $cache;
} else {
    $d = 'var menu_cache=[' . json_encode(AjaxMenu_getChildren(0, $_GET['pageid'], 0, $search_options)) . '];';
    $p = Page::getInstance($_GET['pageid']);
    if (is_object($p)) {
        $pid = $p->getTopParentId();
        $d .= 'var currentTop=' . $pid . ';';
    }
    cache_save('menus', $md5, $d);
    echo $d;
}
echo file_get_contents('menu.js');
ob_show_and_log('menu');
// }
// { meta tags
$c .= '<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />';
if ($PAGEDATA->keywords) {
    $c .= '<meta http-equiv="keywords" content="' . htmlspecialchars($PAGEDATA->keywords) . '" />';
}
if ($PAGEDATA->description) {
    $c .= '<meta http-equiv="description" content="' . htmlspecialchars($PAGEDATA->description) . '"/>';
}
if (isset($PAGEDATA->vars['google-site-verification']) && $PAGEDATA->vars['google-site-verification']) {
    $c .= '<meta name="google-site-verification" content="' . htmlspecialchars($PAGEDATA->vars['google-site-verification']) . '" />';
}
// }
// { favicon
if (file_exists(USERBASE . '/f/skin_files/favicon.ico')) {
    $c .= '<link rel="shortcut icon" href="/f/skin_files/favicon.ico" />';
}
// }
$c .= plugin_trigger('building-metadata');
$smarty->assign('METADATA', $c);
// }
// { display the document
ob_start();
if (strpos($template, '/') === false) {
    $template = THEME_DIR . '/' . THEME . '/h/' . $template . '.html';
}
$t = $smarty->fetch($template);
echo str_replace(array('WW_SCRIPTS_GO_HERE', 'WW_CSS_GOES_HERE', '</body>'), array(WW_getScripts(), WW_getCSS(), WW_getInlineScripts() . '</body>'), $t);
header('X-page-generation: ' . (microtime(true) - $ww_startup) . 's');
ob_show_and_log('page', 'Content-type: text/html; Charset=utf-8');
// }
            $f = str_replace($matches[0][$i], $css, $f);
        }
        // }
        $f = str_replace('{{$THEMEDIR}}', '/ww.skins/' . THEME, $f);
        file_put_contents($parsed, $f);
    }
    $file = $parsed;
}
header('Content-Description: File Transfer');
header('Content-Type: ' . $mimetype);
header('Content-Transfer-Encoding: binary');
header('Expires-Active: On');
header('Cache-Control: max-age = 3600');
header('Expires: ' . date('r', time() + 3600));
header('Pragma:');
header('Content-Length: ' . filesize($file));
ob_clean();
flush();
ob_start();
readfile($file);
function get_mimetype($f)
{
    $mimetypes = array('ez' => 'application/andrew-inset', 'hqx' => 'application/mac-binhex40', 'cpt' => 'application/mac-compactpro', 'doc' => 'application/msword', 'bin' => 'application/octet-stream', 'dms' => 'application/octet-stream', 'lha' => 'application/octet-stream', 'lzh' => 'application/octet-stream', 'exe' => 'application/octet-stream', 'class' => 'application/octet-stream', 'so' => 'application/octet-stream', 'dll' => 'application/octet-stream', 'oda' => 'application/oda', 'pdf' => 'application/pdf', 'ai' => 'application/postscript', 'eps' => 'application/postscript', 'ps' => 'application/postscript', 'smi' => 'application/smil', 'smil' => 'application/smil', 'mif' => 'application/vnd.mif', 'xls' => 'application/vnd.ms-excel', 'ppt' => 'application/vnd.ms-powerpoint', 'wbxml' => 'application/vnd.wap.wbxml', 'wmlc' => 'application/vnd.wap.wmlc', 'wmlsc' => 'application/vnd.wap.wmlscriptc', 'bcpio' => 'application/x-bcpio', 'vcd' => 'application/x-cdlink', 'pgn' => 'application/x-chess-pgn', 'cpio' => 'application/x-cpio', 'csh' => 'application/x-csh', 'dcr' => 'application/x-director', 'dir' => 'application/x-director', 'dxr' => 'application/x-director', 'dvi' => 'application/x-dvi', 'spl' => 'application/x-futuresplash', 'gtar' => 'application/x-gtar', 'hdf' => 'application/x-hdf', 'js' => 'application/x-javascript', 'skp' => 'application/x-koan', 'skd' => 'application/x-koan', 'skt' => 'application/x-koan', 'skm' => 'application/x-koan', 'latex' => 'application/x-latex', 'nc' => 'application/x-netcdf', 'cdf' => 'application/x-netcdf', 'sh' => 'application/x-sh', 'shar' => 'application/x-shar', 'swf' => 'application/x-shockwave-flash', 'sit' => 'application/x-stuffit', 'sv4cpio' => 'application/x-sv4cpio', 'sv4crc' => 'application/x-sv4crc', 'tar' => 'application/x-tar', 'tcl' => 'application/x-tcl', 'tex' => 'application/x-tex', 'texinfo' => 'application/x-texinfo', 'texi' => 'application/x-texinfo', 't' => 'application/x-troff', 'tr' => 'application/x-troff', 'roff' => 'application/x-troff', 'man' => 'application/x-troff-man', 'me' => 'application/x-troff-me', 'ms' => 'application/x-troff-ms', 'ustar' => 'application/x-ustar', 'src' => 'application/x-wais-source', 'xhtml' => 'application/xhtml+xml', 'xht' => 'application/xhtml+xml', 'zip' => 'application/zip', 'au' => 'audio/basic', 'snd' => 'audio/basic', 'mid' => 'audio/midi', 'midi' => 'audio/midi', 'kar' => 'audio/midi', 'mpga' => 'audio/mpeg', 'mp2' => 'audio/mpeg', 'mp3' => 'audio/mpeg', 'aif' => 'audio/x-aiff', 'aiff' => 'audio/x-aiff', 'aifc' => 'audio/x-aiff', 'm3u' => 'audio/x-mpegurl', 'ram' => 'audio/x-pn-realaudio', 'rm' => 'audio/x-pn-realaudio', 'rpm' => 'audio/x-pn-realaudio-plugin', 'ra' => 'audio/x-realaudio', 'wav' => 'audio/x-wav', 'pdb' => 'chemical/x-pdb', 'xyz' => 'chemical/x-xyz', 'bmp' => 'image/bmp', 'gif' => 'image/gif', 'ief' => 'image/ief', 'jpeg' => 'image/jpeg', 'jpg' => 'image/jpeg', 'jpe' => 'image/jpeg', 'png' => 'image/png', 'tiff' => 'image/tiff', 'tif' => 'image/tiff', 'djvu' => 'image/vnd.djvu', 'djv' => 'image/vnd.djvu', 'wbmp' => 'image/vnd.wap.wbmp', 'ras' => 'image/x-cmu-raster', 'pnm' => 'image/x-portable-anymap', 'pbm' => 'image/x-portable-bitmap', 'pgm' => 'image/x-portable-graymap', 'ppm' => 'image/x-portable-pixmap', 'rgb' => 'image/x-rgb', 'xbm' => 'image/x-xbitmap', 'xpm' => 'image/x-xpixmap', 'xwd' => 'image/x-xwindowdump', 'igs' => 'model/iges', 'iges' => 'model/iges', 'msh' => 'model/mesh', 'mesh' => 'model/mesh', 'silo' => 'model/mesh', 'wrl' => 'model/vrml', 'vrml' => 'model/vrml', 'css' => 'text/css', 'html' => 'text/html', 'htm' => 'text/html', 'asc' => 'text/plain', 'txt' => 'text/plain', 'rtx' => 'text/richtext', 'rtf' => 'text/rtf', 'sgml' => 'text/sgml', 'sgm' => 'text/sgml', 'tsv' => 'text/tab-separated-values', 'wml' => 'text/vnd.wap.wml', 'wmls' => 'text/vnd.wap.wmlscript', 'etx' => 'text/x-setext', 'xsl' => 'text/xml', 'xml' => 'text/xml', 'mpeg' => 'video/mpeg', 'mpg' => 'video/mpeg', 'mpe' => 'video/mpeg', 'qt' => 'video/quicktime', 'mov' => 'video/quicktime', 'mxu' => 'video/vnd.mpegurl', 'avi' => 'video/x-msvideo', 'movie' => 'video/x-sgi-movie', 'ice' => 'x-conference/x-cooltalk');
    $extension = preg_replace('/.*\\./', '', $f);
    if (isset($mimetypes[$extension])) {
        return $mimetypes[$extension];
    }
    return 'unknown/mimetype';
}
ob_show_and_log('design_file');