|
1
|
|
|
<?php
|
|
2
|
|
|
/**
|
|
3
|
|
|
* An example of a project-specific implementation.
|
|
4
|
|
|
*
|
|
5
|
|
|
* After registering this autoload function with SPL, the following line
|
|
6
|
|
|
* would cause the function to attempt to load the \Foo\Bar\Baz\Qux class
|
|
7
|
|
|
* from /path/to/project/src/Baz/Qux.php:
|
|
8
|
|
|
*
|
|
9
|
|
|
* new \Foo\Bar\Baz\Qux;
|
|
10
|
|
|
*
|
|
11
|
|
|
* @param string $class The fully-qualified class name.
|
|
12
|
|
|
* @return void
|
|
13
|
|
|
*/
|
|
14
|
|
|
spl_autoload_register(
|
|
15
|
|
|
function ($class) {
|
|
16
|
|
|
// project-specific namespace prefix
|
|
17
|
|
|
//$prefix = 'Foo\\Bar\\';
|
|
18
|
|
|
$prefix = 'Jovis\\';
|
|
19
|
|
|
// base directory for the namespace prefix
|
|
20
|
|
|
$base_dir = __DIR__ . '/src/';
|
|
21
|
|
|
// does the class use the namespace prefix?
|
|
22
|
|
|
$len = strlen($prefix);
|
|
23
|
|
|
if (strncmp($prefix, $class, $len) !== 0) {
|
|
24
|
|
|
// no, move to the next registered autoloader
|
|
25
|
|
|
return;
|
|
26
|
|
|
}
|
|
27
|
|
|
// get the relative class name
|
|
28
|
|
|
$relative_class = substr($class, $len);
|
|
29
|
|
|
// replace the namespace prefix with the base directory, replace namespace
|
|
30
|
|
|
// separators with directory separators in the relative class name, append
|
|
31
|
|
|
// with .php
|
|
32
|
|
|
$file = $base_dir . str_replace('\\', '/', $relative_class) . '.php';
|
|
33
|
|
|
// if the file exists, require it
|
|
34
|
|
|
if (file_exists($file)) {
|
|
35
|
|
|
include $file;
|
|
36
|
|
|
}
|
|
37
|
|
|
}
|
|
38
|
|
|
); |