forked from Davisonpro/advanced-rest-api
-
Notifications
You must be signed in to change notification settings - Fork 0
/
autoload.php
54 lines (47 loc) · 1.64 KB
/
autoload.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
<?php
/**
* @package PHP Advanced API Guide
* @author Davison Pro <[email protected]>
* @copyright 2019 DavisonPro
* @version 1.0.0
* @since File available since Release 1.0.0
*/
/**
* @param $prefix - project-specific namespace prefix
* @param $baseDir - base directory for the namespace prefix
* @return Closure
*/
function autoload_register($prefix, $baseDir) {
return function ($class) use ($prefix, $baseDir) {
// does the class use the namespace prefix?
$len = strlen($prefix);
if (strncmp($prefix, $class, $len) !== 0) {
// no, move to the next registered autoloader
return;
}
// get the relative class name
$relative_class = substr($class, $len);
// replace the namespace prefix with the base directory, replace namespace
// separators with directory separators in the relative class name, append
// with .php
$file = $baseDir . str_replace('\\', '/', $relative_class) . '.php';
// if the file exists, require it
if (file_exists($file)) {
require $file;
}
};
}
/**
* An example of a project-specific implementation.
*
* After registering this autoload function with SPL, the following line
* would cause the function to attempt to load the \Foo\Bar\Baz\Qux class
* from /path/to/project/src/Baz/Qux.php:
*
* new \Foo\Bar\Baz\Qux;
*
* @param string $class The fully-qualified class name.
* @return void
*/
spl_autoload_register( autoload_register(API_NAMESPACE, API_DIR_CLASSES) );
spl_autoload_register( autoload_register(API_NAMESPACE, API_DIR_CONTROLLERS) );