2014-07-11 04:28:14 +02:00
|
|
|
|
---
|
2016-02-27 13:58:18 +01:00
|
|
|
|
title: LibSass
|
2014-07-11 04:28:14 +02:00
|
|
|
|
---
|
|
|
|
|
|
|
|
|
|
%p.introduction
|
2015-04-02 01:51:37 +02:00
|
|
|
|
We want everyone to enjoy Sass, no matter what language they use. Sass was
|
2016-09-17 12:12:21 +02:00
|
|
|
|
originally written in Ruby. LibSass is a C/C++ port of the Sass engine. The
|
|
|
|
|
point is to be simple, faster, and easy to integrate. Find out more about the
|
|
|
|
|
project over at
|
2014-07-11 04:28:14 +02:00
|
|
|
|
= succeed "." do
|
2016-09-17 12:12:21 +02:00
|
|
|
|
= link_to "GitHub", "http://github.com/sass/libsass"
|
2014-07-11 04:28:14 +02:00
|
|
|
|
|
|
|
|
|
:markdown
|
2014-10-04 00:17:39 +02:00
|
|
|
|
## Wrappers
|
2014-07-11 04:28:14 +02:00
|
|
|
|
|
2016-09-17 12:11:34 +02:00
|
|
|
|
LibSass is just a library. To run the code locally (i.e. to compile your
|
|
|
|
|
stylesheets), you need an implementer, or "wrapper". There are a number of
|
|
|
|
|
other wrappers for LibSass. We encourage you to write your own wrapper - the
|
2018-03-09 23:43:20 +01:00
|
|
|
|
whole point of LibSass is that we want to bring Sass to many other languages,
|
2016-09-17 12:11:34 +02:00
|
|
|
|
not just Ruby!
|
2014-07-11 04:28:14 +02:00
|
|
|
|
|
2016-09-17 12:11:34 +02:00
|
|
|
|
Below are the LibSass wrappers that we're currently aware of. Sometimes there
|
|
|
|
|
are multiple wrappers per language – in those cases, we put the most
|
|
|
|
|
recently-updated wrapper first.
|
2014-07-11 04:28:14 +02:00
|
|
|
|
|
2014-10-04 00:17:39 +02:00
|
|
|
|
%ul.slides
|
|
|
|
|
%li#sassc
|
|
|
|
|
:markdown
|
2015-06-06 00:11:10 +02:00
|
|
|
|
### Sass C
|
|
|
|
|
|
2018-03-09 23:43:20 +01:00
|
|
|
|
[SassC](https://github.com/sass/sassc) (get it?) is a wrapper written in
|
2016-09-17 12:11:34 +02:00
|
|
|
|
C.
|
2014-07-11 04:28:14 +02:00
|
|
|
|
|
2016-09-17 12:11:34 +02:00
|
|
|
|
To run the compiler on your local machine, you need to build SassC. To
|
|
|
|
|
build SassC, you must have either a local copy of the LibSass source or it
|
|
|
|
|
must be installed into your system. For development, please use the source
|
|
|
|
|
version. You must then setup an environment variable pointing to the
|
|
|
|
|
LibSass folder, for example:
|
2014-07-11 04:28:14 +02:00
|
|
|
|
|
2014-10-04 00:17:39 +02:00
|
|
|
|
~ partial "code-snippets/libsass-setup"
|
|
|
|
|
|
|
|
|
|
%p
|
2016-09-17 12:11:34 +02:00
|
|
|
|
The executable will be in the bin folder. To run it, simply try something
|
|
|
|
|
like:
|
2014-10-04 00:17:39 +02:00
|
|
|
|
|
|
|
|
|
~ partial "code-snippets/libsass-execute"
|
|
|
|
|
|
2018-03-09 23:43:20 +01:00
|
|
|
|
%li#crystal
|
|
|
|
|
:markdown
|
|
|
|
|
### Crystal
|
|
|
|
|
[sass.cr](https://github.com/straight-shoota/sass.cr)
|
|
|
|
|
is a LibSass wrapper for the
|
|
|
|
|
[Crystal programming language](https://crystal-lang.org/).
|
|
|
|
|
|
2014-10-04 00:17:39 +02:00
|
|
|
|
%li#go
|
|
|
|
|
:markdown
|
|
|
|
|
### Go
|
2016-01-20 16:36:36 +01:00
|
|
|
|
[go-libsass](https://github.com/wellington/go-libsass) has the most active
|
|
|
|
|
GoLang wrapper. [gosass](https://github.com/moovweb/gosass) is another
|
|
|
|
|
libsass wrapper.
|
2015-06-06 00:11:10 +02:00
|
|
|
|
|
2016-01-20 16:36:36 +01:00
|
|
|
|
[Wellington](http://getwt.io/) is an extension to libsass that adds
|
|
|
|
|
spriting. It is available on brew: `brew install wellington`
|
2015-06-06 00:11:10 +02:00
|
|
|
|
|
2016-01-20 16:36:36 +01:00
|
|
|
|
[C6](https://github.com/c9s/c6) is a SASS 3.2 compatible implementation
|
|
|
|
|
written in pure GoLang that aims to extend SASS.
|
|
|
|
|
[wellington/sass](https://github.com/wellington/sass) is an in-progress
|
|
|
|
|
pure Go sass lexer, parser, and compiler.
|
2014-10-04 00:17:39 +02:00
|
|
|
|
|
|
|
|
|
%li#java
|
|
|
|
|
:markdown
|
|
|
|
|
### Java
|
2017-03-29 02:39:02 +02:00
|
|
|
|
There is one Java wrapper – [jsass](https://github.com/bit3/jsass).
|
|
|
|
|
There is also a plugin for Maven -
|
2016-09-17 12:11:34 +02:00
|
|
|
|
[LibSass Maven plugin](https://github.com/warmuuh/libsass-maven-plugin).
|
2014-10-04 00:17:39 +02:00
|
|
|
|
|
|
|
|
|
%li#javascript
|
|
|
|
|
:markdown
|
|
|
|
|
### JavaScript
|
2018-03-17 00:20:00 +01:00
|
|
|
|
The [sass.js](https://github.com/medialize/sass.js) project makes
|
|
|
|
|
LibSass available as pure JavaScript. There's a way to [test it in the
|
|
|
|
|
browser](http://medialize.github.io/playground.sass.js/), too.
|
2014-10-04 00:17:39 +02:00
|
|
|
|
|
|
|
|
|
%li#lua
|
|
|
|
|
:markdown
|
|
|
|
|
### Lua
|
2018-03-09 23:43:20 +01:00
|
|
|
|
The Lua wrapper is found at
|
2016-09-17 12:11:34 +02:00
|
|
|
|
[lua-sass](https://github.com/craigbarnes/lua-sass).
|
2014-10-04 00:17:39 +02:00
|
|
|
|
|
|
|
|
|
%li#net
|
|
|
|
|
:markdown
|
|
|
|
|
### .NET
|
2016-09-17 12:11:34 +02:00
|
|
|
|
[libsass-net](https://github.com/darrenkopp/libsass-net) is updated
|
|
|
|
|
regularly, and is probably the best bet. There's also
|
|
|
|
|
[NSass](https://github.com/TBAPI-0KA/NSass), although it hasn't been
|
|
|
|
|
updated in a while.
|
2014-10-04 00:17:39 +02:00
|
|
|
|
|
|
|
|
|
%li#node
|
|
|
|
|
:markdown
|
|
|
|
|
### Node
|
2016-09-17 12:11:34 +02:00
|
|
|
|
The [node-sass](https://github.com/sass/node-sass) project has proven to
|
|
|
|
|
be popular, and we've taken it into the main Sass GitHub repo. Check out
|
|
|
|
|
its package page [here](https://www.npmjs.org/package/node-sass), and
|
|
|
|
|
[there's a dedicated twitter account](https://twitter.com/nodesass) for
|
|
|
|
|
updates.
|
2014-10-04 00:17:39 +02:00
|
|
|
|
|
|
|
|
|
%li#perl
|
|
|
|
|
:markdown
|
|
|
|
|
### Perl
|
2016-09-17 12:11:34 +02:00
|
|
|
|
The [CSS::Sass](https://github.com/sass/perl-libsass) project is updated
|
|
|
|
|
regularly. There's the
|
|
|
|
|
[Text-Sass-XS](https://github.com/ysasaki/Text-Sass-XS) project, too,
|
|
|
|
|
although it hasn't been updated in a while.
|
2014-10-04 00:17:39 +02:00
|
|
|
|
|
|
|
|
|
%li#php
|
|
|
|
|
:markdown
|
|
|
|
|
### PHP
|
2016-09-17 12:11:34 +02:00
|
|
|
|
The [SassPHP](https://github.com/sensational/sassphp) project is an
|
|
|
|
|
updated fork of an
|
|
|
|
|
[older PHP version](https://github.com/jamierumbelow/sassphp).
|
2014-10-04 00:17:39 +02:00
|
|
|
|
|
|
|
|
|
%li#python
|
|
|
|
|
:markdown
|
|
|
|
|
### Python
|
2018-03-09 23:43:20 +01:00
|
|
|
|
There are two Python projects that are updated regularly. The
|
2016-09-17 12:11:34 +02:00
|
|
|
|
[libsass-python](https://github.com/dahlia/libsass-python) project (there
|
|
|
|
|
are more details on
|
|
|
|
|
[its own website](http://hongminhee.org/libsass-python/)) and the
|
|
|
|
|
[python-scss](https://github.com/pistolero/python-scss) project.
|
2015-04-01 05:12:33 +02:00
|
|
|
|
|
2018-03-09 23:43:20 +01:00
|
|
|
|
Two other Python projects,
|
2016-09-17 12:11:34 +02:00
|
|
|
|
[pylibsass](https://github.com/rsenk330/pylibsass) and
|
|
|
|
|
[SassPython](https://github.com/marianoguerra/SassPython), haven't been
|
|
|
|
|
updated in a while.
|
2014-10-04 00:17:39 +02:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
%li#ruby
|
|
|
|
|
:markdown
|
|
|
|
|
### Ruby
|
2018-03-09 23:43:20 +01:00
|
|
|
|
LibSass has also been ported back into Ruby for the
|
2016-09-17 12:11:34 +02:00
|
|
|
|
[sassc-ruby](https://github.com/sass/sassc-ruby) project.
|
2014-10-04 00:17:39 +02:00
|
|
|
|
|
2018-03-19 17:11:16 +01:00
|
|
|
|
%li#rust
|
|
|
|
|
:markdown
|
|
|
|
|
### Rust
|
|
|
|
|
The [`sass_rs`](https://github.com/compass-rs/sass-rs) crate is a
|
|
|
|
|
LibSass wrapper and is updated regularly.
|
|
|
|
|
|
2014-10-04 00:17:39 +02:00
|
|
|
|
%li#scala
|
|
|
|
|
:markdown
|
|
|
|
|
### Scala
|
2018-03-09 23:43:20 +01:00
|
|
|
|
The only Scala project, [Sass-Scala](https://github.com/kkung/Sass-Scala),
|
2016-09-17 12:11:34 +02:00
|
|
|
|
hasn't been updated in a couple of years.
|
2014-07-11 04:28:14 +02:00
|
|
|
|
|
2016-02-27 13:58:18 +01:00
|
|
|
|
%h2 About LibSass
|
2014-07-11 04:28:14 +02:00
|
|
|
|
|
|
|
|
|
:markdown
|
|
|
|
|
This project is the brainchild of
|
2015-04-02 01:51:37 +02:00
|
|
|
|
[Hampton Catlin](http://twitter.com/hcatlin), the original creator of Sass,
|
2014-07-11 04:28:14 +02:00
|
|
|
|
and is sponsored by [Moovweb](http://moovweb.com/).
|
|
|
|
|
[Aaron Leung](http://github.com/akhleung) from Moovweb is the primary
|
|
|
|
|
developer.
|
|
|
|
|
|
|
|
|
|
%figure
|
2015-04-02 01:51:37 +02:00
|
|
|
|
= image_tag "logos/libsass.png", alt: "LibSass logo"
|
2014-07-11 04:28:14 +02:00
|
|
|
|
|
|
|
|
|
- content_for :complementary do
|
2014-10-04 00:17:39 +02:00
|
|
|
|
%h3 Wrappers
|
|
|
|
|
%ul.anchors
|
2015-04-02 01:51:37 +02:00
|
|
|
|
%li= link_to "SassC", "#sassc"
|
2018-03-09 23:43:20 +01:00
|
|
|
|
%li= link_to "Crystal", "#crystal"
|
2014-10-04 00:17:39 +02:00
|
|
|
|
%li= link_to "Go", "#go"
|
|
|
|
|
%li= link_to "Java", "#java"
|
|
|
|
|
%li= link_to "JavaScript", "#javascript"
|
|
|
|
|
%li= link_to "Lua", "#lua"
|
|
|
|
|
%li= link_to ".NET", "#net"
|
|
|
|
|
%li= link_to "Node", "#node"
|
|
|
|
|
%li= link_to "Perl", "#perl"
|
|
|
|
|
%li= link_to "PHP", "#php"
|
|
|
|
|
%li= link_to "Python", "#python"
|
|
|
|
|
%li= link_to "Ruby", "#ruby"
|
|
|
|
|
%li= link_to "Scala", "#scala"
|
|
|
|
|
|
|
|
|
|
|
2014-07-11 04:28:14 +02:00
|
|
|
|
%h3 Resources
|
|
|
|
|
|
|
|
|
|
%ul
|
|
|
|
|
- for project in data.libsass.resources
|
|
|
|
|
%li
|
|
|
|
|
= link_to project.name, project.url
|
|
|
|
|
—
|
|
|
|
|
= project.description
|