|
hace 5 años | |
---|---|---|
.. | ||
bin | hace 5 años | |
lib | hace 5 años | |
.gitattributes | hace 5 años | |
.gitignore | hace 5 años | |
CHANGES.md | hace 5 años | |
LICENSE | hace 5 años | |
README.md | hace 5 años | |
composer.json | hace 5 años | |
lessc.inc.php | hace 5 años |
This is a PHP port of the official LESS processor http://lesscss.org.
The code structure of less.php mirrors that of the official processor which helps us ensure compatibility and allows for easy maintenance.
Please note, there are a few unsupported LESS features:
You can install the library with composer or manually.
Step 1. Edit your composer.json
:
{
"require": {
"oyejorge/less.php": "~1.7.0.9"
}
}
Step 2. Install it:
$ curl -sS https://getcomposer.org/installer | php
$ php composer.phar install
Step 1. Download the latest release and upload the php files to your server.
Step 2. Include the library:
require_once '[path to less.php]/Less.php';
Step 1. Download the source and upload the files in /lib/Less to a folder on your server.
Step 2. Include the library and register the Autoloader
require_once '[path to less.php]/Autoloader.php';
Less_Autoloader::register();
$parser = new Less_Parser();
$parser->parse( '@color: #4D926F; #header { color: @color; } h2 { color: @color; }' );
$css = $parser->getCss();
The parseFile() function takes two arguments:
$parser = new Less_Parser();
$parser->parseFile( '/var/www/mysite/bootstrap.less', 'http://example.com/mysite/' );
$css = $parser->getCss();
An exception will be thrown if the compiler encounters invalid less
try{
$parser = new Less_Parser();
$parser->parseFile( '/var/www/mysite/bootstrap.less', 'http://example.com/mysite/' );
$css = $parser->getCss();
}catch(Exception $e){
$error_message = $e->getMessage();
}
less.php can parse multiple sources to generate a single css file
$parser = new Less_Parser();
$parser->parseFile( '/var/www/mysite/bootstrap.less', '/mysite/' );
$parser->parse( '@color: #4D926F; #header { color: @color; } h2 { color: @color; }' );
$css = $parser->getCss();
less.php can tell you which .less files were imported and parsed.
$parser = new Less_Parser();
$parser->parseFile( '/var/www/mysite/bootstrap.less', '/mysite/' );
$css = $parser->getCss();
$imported_files = $parser->allParsedFiles();
You can tell less.php to remove comments and whitespace to generate minimized css files.
$options = array( 'compress'=>true );
$parser = new Less_Parser( $options );
$parser->parseFile( '/var/www/mysite/bootstrap.less', '/mysite/' );
$css = $parser->getCss();
You can use the getVariables() method to get an all variables defined and their value in a php associative array. Note than less have to be previously compiled
$parser = new Less_Parser;
$parser->parseFile( '/var/www/mysite/bootstrap.less');
$css = $parser->getCss();
$variables = $parser->getVariables();
You can use the ModifyVars() method to customize your css if you have variables stored in php associative arrays
$parser = new Less_Parser();
$parser->parseFile( '/var/www/mysite/bootstrap.less', '/mysite/' );
$parser->ModifyVars( array('font-size-base'=>'16px') );
$css = $parser->getCss();
By default, less.php will look for @imports in the directory of the file passed to parsefile(). If you're using parse() or if @imports reside in different directories, you can tell less.php where to look.
$directories = array( '/var/www/mysite/bootstrap/' => '/mysite/bootstrap/' );
$parser = new Less_Parser();
$parser->SetImportDirs( $directories );
$parser->parseFile( '/var/www/mysite/theme.less', '/mysite/' );
$css = $parser->getCss();
Compiling less code into css is a time consuming process, caching your results is highly recommended.
Use the Less_Cache class to save and reuse the results of compiled less files. This method will check the modified time and size of each less file (including imported files) and regenerate a new css file when changes are found. Note: When changes are found, this method will return a different file name for the new cached content.
$less_files = array( '/var/www/mysite/bootstrap.less' => '/mysite/' );
$options = array( 'cache_dir' => '/var/www/writable_folder' );
$css_file_name = Less_Cache::Get( $less_files, $options );
$compiled = file_get_contents( '/var/www/writable_folder/'.$css_file_name );
Passing options to Less_Cache::Get()
$less_files = array( '/var/www/mysite/bootstrap.less' => '/mysite/' );
$options = array( 'cache_dir' => '/var/www/writable_folder' );
$variables = array( 'width' => '100px' );
$css_file_name = Less_Cache::Get( $less_files, $options, $variables );
$compiled = file_get_contents( '/var/www/writable_folder/'.$css_file_name );
less.php will save serialized parser data for each .less file if a writable folder is passed to the SetCacheDir() method. Note: This feature only caches intermediate parsing results to improve the performance of repeated css generation. Your application should cache any css generated by less.php.
$options = array('cache_dir'=>'/var/www/writable_folder');
$parser = new Less_Parser( $options );
$parser->parseFile( '/var/www/mysite/bootstrap.less', '/mysite/' );
$css = $parser->getCss();
You can specify the caching technique used by changing the cache_method
option. Supported methods are:
php
: Creates valid PHP files which can be included without any changes (default method).var_export
: Like "php", but using PHPs var_export()
function without any optimizations.
It's recommended to use "php" instead.serialize
: Faster, but pretty memory-intense.callback
: Use custom callback functions to implement your own caching method. Give the "cache_callback_get" and
"cache_callback_set" options with callables (see PHPs call_user_func()
and is_callable()
functions). less.php
will pass the parser object (class Less_Parser
), the path to the parsed .less file ("/some/path/to/file.less") and
an identifier that will change every time the .less file is modified. The get
callback must return the ruleset
(an array with Less_Tree
objects) provided as fourth parameter of the set
callback. If something goes wrong,
return NULL
(cache doesn't exist) or FALSE
.Less.php supports v3 sourcemaps
The sourcemap will be appended to the generated css file.
$options = array( 'sourceMap' => true );
$parser = new Less_Parser($options);
$parser->parseFile( '/var/www/mysite/bootstrap.less', '/mysite/' );
$css = $parser->getCss();
$options = array(
'sourceMap' => true,
'sourceMapWriteTo' => '/var/www/mysite/writable_folder/filename.map',
'sourceMapURL' => '/mysite/writable_folder/filename.map',
);
$parser = new Less_Parser($options);
$parser->parseFile( '/var/www/mysite/bootstrap.less', '/mysite/' );
$css = $parser->getCss();
An additional script has been included to use the compiler from the command line. In the simplest invocation, you specify an input file and the compiled css is written to standard out:
$ lessc input.less > output.css
By using the -w flag you can watch a specified input file and have it compile as needed to the output file:
$ lessc -w input.less output.css
Errors from watch mode are written to standard out.
For more help, run lessc --help
This library can be used as drop-in replacement of lessphp to work with Drupal 7 less module.
How to install:
JBST has a built-in LESS compiler based on lessphp. Customize your WordPress theme with LESS.
How to use / install:
Use the built-in compiler to:
@navbar-default-color: blue;
- create a custom button: .btn-custom {
.button-variant(white; red; blue);
}
@footer_bg_color: black;
sets the background color of the footer to black.include-custom-font(@family: arial,@font-path, @path: @custom-font-dir, @weight: normal, @style: normal);
The compiler can also be download as plugin
This simple plugin will simply make the library available to other plugins and themes and can be used as a dependency using the TGM Library
How to install:
Projects looking for an easy transition from leafo/lessphp can use the lessc.inc.php adapter. To use, Download the less.php source code and unzip the files into your project so that the new 'lessc.inc.php' replaces the existing 'lessc.inc.php'.
Note, the 'setPreserveComments' will no longer have any effect on the compiled less.
less.php was originally ported to php by Matt Agar and then updated by Martin Jantošovič.