123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160 |
- <?php namespace Laravel;
- /*
- |--------------------------------------------------------------------------
- | PHP Display Errors Configuration
- |--------------------------------------------------------------------------
- |
- | Register the constants used by the framework. These are things like file
- | extensions and other information that we want to be able to access with
- | just a simple constant.
- |
- */
- define('EXT', '.php');
- define('CRLF', "\r\n");
- define('BLADE_EXT', '.blade.php');
- define('DEFAULT_BUNDLE', 'application');
- define('MB_STRING', (int) function_exists('mb_get_info'));
- /*
- |--------------------------------------------------------------------------
- | Require Core Classes
- |--------------------------------------------------------------------------
- |
- | Here we will just load in the classes that are used for every request
- | or are used by the configuration class. It is quicker and simpler to
- | just manually load them in instead of using the auto-loader.
- |
- */
- require path('sys').'ioc'.EXT;
- require path('sys').'event'.EXT;
- require path('sys').'bundle'.EXT;
- require path('sys').'config'.EXT;
- require path('sys').'helpers'.EXT;
- require path('sys').'autoloader'.EXT;
- /*
- |--------------------------------------------------------------------------
- | Register The Framework Auto-Loader
- |--------------------------------------------------------------------------
- |
- | Next we'll register the Autoloader class on the SPL auto-loader stack
- | so it can lazy-load our class files as we need them. This class and
- | method will be called each time a class is needed but has not been
- | defined yet and will load the appropriate file.
- |
- */
- spl_autoload_register(array('Laravel\\Autoloader', 'load'));
- /*
- |--------------------------------------------------------------------------
- | Register The Laravel Namespace
- |--------------------------------------------------------------------------
- |
- | Register the "Laravel" namespace and its directory mapping so the class
- | loader can quickly load all of the core classes using PSR-0 style load
- | conventions throughout the "laravel" directory since all core classes
- | are namespaced into the "Laravel" namespace.
- |
- */
- Autoloader::namespaces(array('Laravel' => path('sys')));
- /*
- |--------------------------------------------------------------------------
- | Register Eloquent Mappings
- |--------------------------------------------------------------------------
- |
- | A few of the Eloquent ORM classes use a non PSR-0 naming standard so
- | we will just map them with hard-coded paths here since PSR-0 uses
- | underscores as directory hierarchy indicators.
- |
- */
- Autoloader::map(array(
- 'Laravel\\Database\\Eloquent\\Relationships\\Belongs_To'
- => path('sys').'database/eloquent/relationships/belongs_to'.EXT,
- 'Laravel\\Database\\Eloquent\\Relationships\\Has_Many'
- => path('sys').'database/eloquent/relationships/has_many'.EXT,
- 'Laravel\\Database\\Eloquent\\Relationships\\Has_Many_And_Belongs_To'
- => path('sys').'database/eloquent/relationships/has_many_and_belongs_to'.EXT,
- 'Laravel\\Database\\Eloquent\\Relationships\\Has_One'
- => path('sys').'database/eloquent/relationships/has_one'.EXT,
- 'Laravel\\Database\\Eloquent\\Relationships\\Has_One_Or_Many'
- => path('sys').'database/eloquent/relationships/has_one_or_many'.EXT,
- ));
- /*
- |--------------------------------------------------------------------------
- | Register The Symfony Components
- |--------------------------------------------------------------------------
- |
- | Laravel's "Artisan" CLI makes use of the Symfony Console component to
- | build a wonderful CLI environment that is both robust and testable.
- | We'll register the component's namespace here.
- |
- */
- Autoloader::namespaces(array(
- 'Symfony\Component\Console' => path('base').'vendor/Symfony/Component/Console',
- ));
- /*
- |--------------------------------------------------------------------------
- | Set The CLI Options Array
- |--------------------------------------------------------------------------
- |
- | If the current request is from the Artisan command-line interface, we
- | will parse the command line arguments and options and set them the
- | array of options in the $_SERVER global array for convenience.
- |
- */
- if (defined('STDIN'))
- {
- $console = CLI\Command::options($_SERVER['argv']);
- list($arguments, $options) = $console;
- $options = array_change_key_case($options, CASE_UPPER);
- $_SERVER['CLI'] = $options;
- }
- /*
- |--------------------------------------------------------------------------
- | Set The CLI Laravel Environment
- |--------------------------------------------------------------------------
- |
- | Next we'll set the LARAVEL_ENV variable if the current request is from
- | the Artisan command-line interface. Since the environment is often
- | specified within an Apache .htaccess file, we need to set it here
- | when the request is not coming through Apache.
- |
- */
- if (isset($_SERVER['CLI']['ENV']))
- {
- $_SERVER['LARAVEL_ENV'] = $_SERVER['CLI']['ENV'];
- }
- /*
- |--------------------------------------------------------------------------
- | Register The Laravel Bundles
- |--------------------------------------------------------------------------
- |
- | Finally we will register all of the bundles that have been defined for
- | the application. None of them will be started, yet but will be setup
- | so that they may be started by the developer at any time.
- |
- */
- $bundles = require path('app').'bundles'.EXT;
- foreach ($bundles as $bundle => $config)
- {
- Bundle::register($bundle, $config);
- }
|