pablo-sg-pacheco / wp-namespace-autoloader
A PHP autoloader class that follows the WordPress coding standards 2.0 and proposed 3.0 for class/interface/trait names and filenames
Installs: 30 045
Dependents: 2
Suggesters: 0
Security: 0
Stars: 42
Watchers: 3
Forks: 9
Open Issues: 7
Requires
- php: >=5.4
Requires (Dev)
- cweagans/composer-patches: ^1.0
- dealerdirect/phpcodesniffer-composer-installer: 0.7.0
- phpunit/phpunit: ^7
- squizlabs/php_codesniffer: dev-master
- wp-coding-standards/wpcs: ^2.3
This package is auto-updated.
Last update: 2024-11-30 01:53:45 UTC
README
A PHP autoloader class that follows the WordPress coding standards 2.0 applying PSR-4 specification and optionally supports proposed 3.0
Description
Namespaces and autoloaders are cool and help organizing your code. With these features you don't have to worry about including and requiring php files manually ever again and your code gets organized in folders.
This is a PSR-4 autoloader implementation following WordPress naming conventions 2.0 and proposed WordPress naming conventions 3.0
It means I'm doing these things:
- Converting classes filenames to lowercase
- Replacing underscores on class filenames by hyphens
- Prepending 'class-' before the final class name
- [Optional]: Prepending 'interface-' before the final interface name
- [Optional]: Prepending 'trait-' before the final trait name
Note
- Required PHP Version is PHP 5.4
Installation
You just have to require it just like a composer default dependency. You may have to use preferred-install as dist so you will be able to commit files as .git files will not be created
"require": { "pablo-sg-pacheco/wp-namespace-autoloader": "dev-master" }, "config": { "preferred-install": "dist" }
Usage
Firstly, load the composer dependencies like you are used to
<?php require __DIR__ . '/vendor/autoload.php';
Now you have to initialize it and you are good to go
<?php use Pablo_Pacheco\WP_Namespace_Autoloader\WP_Namespace_Autoloader; $autoloader = new WP_Namespace_Autoloader( array( 'directory' => __DIR__, // Directory of your project. It can be your theme or plugin. Defaults to __DIR__ (probably your best bet). 'namespace_prefix' => 'My_Project', // Main namespace of your project. E.g My_Project\Admin\Tests should be My_Project. Defaults to the namespace of the instantiating file. 'classes_dir' => 'src', // (optional). It is where your namespaced classes are located inside your project. If your classes are in the root level, leave this empty. If they are located on 'src' folder, write 'src' here 'prepend_class' => true, // (optional). Default true, prepends class- before the final class name 'prepend_interface' => true, // (optional). Default false, prepends interface- before the final interface name 'prepend_trait' => true, // (optional). Default false, prepends trait- before the final trait name ) ); $autoloader->init();
Now comes the cool part! If you have a simple class located on your_projct_root_folder\Admin_Pages\class-main-page.php like this, you can instantiate it and it's going to work
<?php namespace My_Project\Admin_Pages; class Main_Page{ }
Or if you have a simple interface located on your_projct_root_folder\Admin_Pages\interface-init.php
<?php namespace My_Project\Admin_Pages; interface Init { }
And you have a simple class implementing that interface located on your_projct_root_folder\Admin_Pages\class-main-page.php you can instantiate it and it's going to work
<?php namespace My_Project\Admin_Pages; class Main_Page implements Init { }
Or if you have a simple trait located on your_projct_root_folder\Admin_Pages\trait-my-trait.php
<?php namespace My_Project\Admin_Pages; trait My_Trait { }
And you have a simple class using that trait located on your_projct_root_folder\Admin_Pages\class-main-page.php you can instantiate it and it's going to work
<?php namespace My_Project\Admin_Pages; class Main_Page { use My_Trait }
Parameters
This class has parameters that make it flexible enough to fit any kind of project.
Examples
- Lowercases all folders using
lowercase => array('file','folders')
- Converts underscores to hyphens on folders too with
underscore_to_hyphen => array('file','folders')
- Doesn't prepend class before file with
prepend_class => false