getTraceAsString(); return $e->getMessage(); } Kohana::Log('error', $e->getTraceAsString()); Kohana::Log('debug', $e->getMessage()); return ""; } } public static function admin($theme) { return self::_get_block_helpers("admin", $theme); } public static function head($theme) { return self::_get_block_helpers("head", $theme); } public static function top($theme) { return self::_get_block_helpers("top", $theme); } public static function bottom($theme) { return self::_get_block_helpers("bottom", $theme); } public static function sidebar($theme) { return self::_get_block_helpers("sidebar", $theme); } public static function album($theme) { return self::_get_block_helpers("album", $theme); } public static function album_top($theme) { return self::_get_block_helpers("album_top", $theme); } public static function photo($theme) { return self::_get_block_helpers("photo", $theme); } private static function _get_block_helpers($method, $theme) { if (empty(self::$block_helpers[$method])) { foreach (module::get_list() as $module) { $helper_path = MODPATH . "$module->name/helpers/{$module->name}_block.php"; $helper_class = "{$module->name}_block"; if (file_exists($helper_path) && method_exists($helper_class, $method)) { self::$block_helpers[$method][] = "$helper_class"; } } } $blocks = ""; if (!empty(self::$block_helpers[$method])) { foreach (self::$block_helpers[$method] as $helper_class) { $blocks .= call_user_func_array(array($helper_class, $method), array($theme)) . "\n"; } } return $blocks; } }