optimus-less [](http://travis-ci.org/magnars/optimus-less)
February 18, 2015 · View on GitHub
A LESS asset loader for Optimus.
Install
Add [optimus-less "0.2.1"] to :dependencies in your project.clj.
Usage
Add (:require optimus-less.core) to the namespace declaration where
you're loading assets.
The load-less-asset function will be declared as a custom loader for
.less files with Optimus' load-asset multimethod. This is in turn
used by load-assets, load-bundle and load-bundles - so
everything works like before, but now it also supports LESS files. Score!
Considerations
-
The
.lessfiles are immediately transpiled into.cssfiles. This means you can safely bundle CSS and LESS files together. It also means that the bundle identifier has to be.css. Like so:(assets/load-bundle "public" "styles.css" ["/styles/reset.css" "/styles/main.less"]) -
The less transpiler is fast. That doesn't mean you should be compiling the entirety of Bootstrap.less with it. It'll take about 350 ms, and make your development environment sluggish. Use precompiled CSS sources for Bootstrap, and use optimus-less for your own files.
Contribute
Yes, please do.
Maybe you'd like to add some clever caching so we could even include the raw Bootstrap LESS files without a slowdown?
If you're looking to add other transpilers, I think that would be best in a separate project. But please do let me know about it, so I can link to it in the Optimus README. :-)
Remember to add tests for your feature or fix, or I'll certainly break it later.
Running the tests
lein midje will run all tests.
lein midje :autotest will run all the tests indefinitely. It sets up a
watcher on the code files. If they change, only the relevant tests will be
run again.
License
Copyright © 2014 Magnar Sveen
Distributed under the Eclipse Public License either version 1.0 or (at your option) any later version.