splitbrain / lesserphp
lesserphp is a compiler for LESS written in PHP based on leafo's lessphp.
Installs: 249
Dependents: 0
Suggesters: 0
Security: 0
Stars: 1
Watchers: 5
Forks: 527
Open Issues: 2
Requires
- php: >=7.4
Requires (Dev)
- phpunit/phpunit: ^9
- rector/rector: ^1.2
- squizlabs/php_codesniffer: ^3.8
Suggests
- ext-fileinfo: For mime type guessing of embedded files
README
LesserPHP is a compiler for LESS written in PHP. It is based on lessphp
by @leafo. The original has been abandoned in 2014. The fork by @MarcusSchwarz has been mostly abandoned in 2021. There are other forks with dubious status.
This is an opinionated fork with the goal to modernize the code base enough to be somewhat easier to maintain without completely rewriting it. It is meant to be used as a stable base for DokuWiki. This means features not needed for this goal are removed.
Please note that this fork is based on the 0.6.0-dev
branch of MarcusSchwarz/lesserphp
, not the much modernized master
branch. This has two reasons:
- The
master
was not up-to-date with all the bug fixes in the0.6.0-dev
branch (some of which had been contributed by DokuWiki developers) - I simply only noticed the considerable refactoring Marcus had done in the
master
branch after I had already started my own refactoring. I did not want to start over again. His approach is much more radical than mine and probably took more than the long weekend I had available for this.
Contributing and Bugs
Please report bugs to the issue tracker. Fixes are only likely when DokuWiki needs them, or you provide a pull request.
Feature Requests will be ignored unless accompanied by a pull request.
How to use in your PHP project
Don't. You really wouldn't want to start a new project using LESS. It simply seems that SASS has won the battle. Or maybe even skip the whole CSS preprocessor thing - modern CSS is quite powerful on its own.
If you are already using lessphp
in one of it's many forks, using this one isn't too different.
You can still look at the original documentation for the most part. The API is mostly the same. Refer to the upstream documentation the bundled Documentation for the LESS syntax itself. Keep in mind that some more modern features are not supported by LesserPHP.
To install it, use composer:
composer require splitbrain/lesserphp
The typical flow of LesserPHP is to create a new instance of Lessc
,
configure it how you like, then tell it to compile something using one built in
compile methods.
The compile
method compiles a string of LESS code to CSS.
<?php require __DIR__ . '/vendor/autoload.php'; $less = new LesserPHP\Lessc; echo $less->compile(".block { padding: 3 + 4px }");
The compileFile
method reads and compiles a file. It will either return the
result or write it to the path specified by an optional second argument.
<?php echo $less->compileFile("input.less");
If there's any problem compiling your code, an exception is thrown with a helpful message:
<?php try { $less->compile("invalid LESS } {"); } catch (LesserPHP\ParserException $e) { echo $e->getMessage(); }