diff options
Diffstat (limited to 'phpBB/common.php')
| -rw-r--r-- | phpBB/common.php | 66 | 
1 files changed, 43 insertions, 23 deletions
diff --git a/phpBB/common.php b/phpBB/common.php index 491addc5e0..81fe275008 100644 --- a/phpBB/common.php +++ b/phpBB/common.php @@ -2,11 +2,10 @@  /**  *  * @package phpBB3 -* @version $Id$  * @copyright (c) 2005 phpBB Group -* @license http://opensource.org/licenses/gpl-license.php GNU Public License +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2  * -* Minimum Requirement: PHP 4.3.3 +* Minimum Requirement: PHP 5.3.2  */  /** @@ -16,6 +15,8 @@ if (!defined('IN_PHPBB'))  	exit;  } +use Symfony\Component\EventDispatcher\EventDispatcher; +  require($phpbb_root_path . 'includes/startup.' . $phpEx);  if (file_exists($phpbb_root_path . 'config.' . $phpEx)) @@ -59,15 +60,6 @@ if (!defined('PHPBB_INSTALLED'))  	exit;  } -if (defined('DEBUG_EXTRA')) -{ -	$base_memory_usage = 0; -	if (function_exists('memory_get_usage')) -	{ -		$base_memory_usage = memory_get_usage(); -	} -} -  // Load Extensions  // dl() is deprecated and disabled by default as of PHP 5.3.  if (!empty($load_extensions) && function_exists('dl')) @@ -81,11 +73,7 @@ if (!empty($load_extensions) && function_exists('dl'))  }  // Include files -require($phpbb_root_path . 'includes/acm/acm_' . $acm_type . '.' . $phpEx); -require($phpbb_root_path . 'includes/cache.' . $phpEx); -require($phpbb_root_path . 'includes/template.' . $phpEx); -require($phpbb_root_path . 'includes/session.' . $phpEx); -require($phpbb_root_path . 'includes/auth.' . $phpEx); +require($phpbb_root_path . 'includes/class_loader.' . $phpEx);  require($phpbb_root_path . 'includes/functions.' . $phpEx);  require($phpbb_root_path . 'includes/functions_content.' . $phpEx); @@ -97,13 +85,28 @@ require($phpbb_root_path . 'includes/utf/utf_tools.' . $phpEx);  // Set PHP error handler to ours  set_error_handler(defined('PHPBB_MSG_HANDLER') ? PHPBB_MSG_HANDLER : 'msg_handler'); +// Setup class loader first +$phpbb_class_loader_ext = new phpbb_class_loader('phpbb_ext_', $phpbb_root_path . 'ext/', ".$phpEx"); +$phpbb_class_loader_ext->register(); +$phpbb_class_loader = new phpbb_class_loader('phpbb_', $phpbb_root_path . 'includes/', ".$phpEx"); +$phpbb_class_loader->register(); + +// set up caching +$cache_factory = new phpbb_cache_factory($acm_type); +$cache = $cache_factory->get_service(); +$phpbb_class_loader_ext->set_cache($cache->get_driver()); +$phpbb_class_loader->set_cache($cache->get_driver()); +  // Instantiate some basic classes -$user		= new user(); -$auth		= new auth(); -$template	= new template(); -$cache		= new cache(); +$phpbb_dispatcher = new phpbb_event_dispatcher(); +$request	= new phpbb_request(); +$user		= new phpbb_user(); +$auth		= new phpbb_auth();  $db			= new $sql_db(); +// make sure request_var uses this request instance +request_var('', 0, false, false, $request); // "dependency injection" for a function +  // Connect to DB  $db->sql_connect($dbhost, $dbuser, $dbpasswd, $dbname, $dbport, false, defined('PHPBB_DB_NEW_LINK') ? PHPBB_DB_NEW_LINK : false); @@ -111,7 +114,21 @@ $db->sql_connect($dbhost, $dbuser, $dbpasswd, $dbname, $dbport, false, defined('  unset($dbpasswd);  // Grab global variables, re-cache if necessary -$config = $cache->obtain_config(); +$config = new phpbb_config_db($db, $cache->get_driver(), CONFIG_TABLE); +set_config(null, null, null, $config); +set_config_count(null, null, null, $config); + +// load extensions +$phpbb_extension_manager = new phpbb_extension_manager($db, EXT_TABLE, $phpbb_root_path, ".$phpEx", $cache->get_driver()); + +// Initialize style +$phpbb_style_resource_locator = new phpbb_style_resource_locator(); +$phpbb_style_path_provider = new phpbb_style_extension_path_provider($phpbb_extension_manager, new phpbb_style_path_provider()); +$template = new phpbb_template($phpbb_root_path, $phpEx, $config, $user, $phpbb_style_resource_locator); +$phpbb_style = new phpbb_style($phpbb_root_path, $phpEx, $config, $user, $phpbb_style_resource_locator, $phpbb_style_path_provider, $template); + +$phpbb_subscriber_loader = new phpbb_event_extension_subscriber_loader($phpbb_dispatcher, $phpbb_extension_manager); +$phpbb_subscriber_loader->load();  // Add own hook handler  require($phpbb_root_path . 'includes/hooks/index.' . $phpEx); @@ -122,4 +139,7 @@ foreach ($cache->obtain_hooks() as $hook)  	@include($phpbb_root_path . 'includes/hooks/' . $hook . '.' . $phpEx);  } -?>
\ No newline at end of file +if (!$config['use_system_cron']) +{ +	$cron = new phpbb_cron_manager(new phpbb_cron_task_provider($phpbb_extension_manager), $cache->get_driver()); +}  | 
