sass-site/old_source/libsass.html.haml

207 lines
6.2 KiB
Plaintext
Raw Normal View History

---
2016-02-27 13:58:18 +01:00
title: LibSass
2018-10-23 15:06:39 -07:00
introduction: >
LibSass is an implementation of Sass in C/C++, designed to be easy to
integrate into many different languages. However, as time wore on it ended up
lagging behind [Dart Sass](dart-sass) in features and CSS compatibility.
**LibSass is now deprecated**—new projects should use Dart Sass instead.
2018-10-23 15:06:39 -07:00
---
:markdown
## Wrappers
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
2018-10-23 15:06:39 -07:00
other wrappers for LibSass. We encourage you to write your own wrapper --- the
whole point of LibSass is that we want to bring Sass to many other languages,
not just Ruby!
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.
%ul.slides
%li#sassc
:markdown
2015-06-05 15:11:10 -07:00
### Sass C
[SassC](https://github.com/sass/sassc) (get it?) is a wrapper written in
C.
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:
2018-10-23 15:06:39 -07:00
= partial 'code-snippets/libsass-setup'
2018-10-23 15:06:39 -07:00
:markdown
2019-10-10 14:10:58 -07:00
The executable will be in the bin folder. To run it, try something
like:
2018-10-23 15:06:39 -07:00
= partial 'code-snippets/libsass-execute'
%li#crystal
:markdown
### Crystal
2018-10-23 15:06:39 -07:00
[sass.cr](https://github.com/straight-shoota/sass.cr) is a LibSass wrapper
for the [Crystal programming language](https://crystal-lang.org/).
%li#go
:markdown
### Go
2018-10-23 15:06:39 -07:00
[go-libsass](https://github.com/wellington/go-libsass) has the most active
2018-10-23 15:06:39 -07:00
GoLang wrapper. [gosass](https://github.com/moovweb/gosass) is another
LibSass wrapper.
2015-06-05 15:11:10 -07:00
2018-10-23 15:06:39 -07: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
2018-10-23 15:06:39 -07:00
pure Go Sass lexer, parser, and compiler.
%li#java
:markdown
### Java
2018-10-23 15:06:39 -07:00
There is one Java wrapper --- [jsass](https://github.com/bit3/jsass).
There is also a plugin for Maven --- [LibSass Maven
plugin](https://gitlab.com/haynes/libsass-maven-plugin).
%li#javascript
:markdown
### JavaScript
2018-10-23 15:06:39 -07:00
2018-03-16 16:20:00 -07: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.
%li#lua
:markdown
### Lua
2018-10-23 15:06:39 -07:00
The Lua wrapper is found at
[lua-sass](https://github.com/craigbarnes/lua-sass).
%li#net
:markdown
### .NET
2018-10-23 15:06:39 -07:00
[LibSass Host](https://github.com/Taritsyn/LibSassHost) is updated
regularly, and is probably the best bet. There's also
[libsass-net](https://github.com/darrenkopp/libsass-net) or [NSass](https://github.com/TBAPI-0KA/NSass),
although they haven't been updated in a while.
%li#node
:markdown
### Node
2018-10-23 15:06:39 -07: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.
%li#perl
:markdown
### Perl
2018-10-23 15:06:39 -07: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.
%li#php
:markdown
### PHP
2018-10-23 15:06:39 -07:00
The [SassPHP](https://github.com/absalomedia/sassphp) project is an
2018-10-23 15:06:39 -07:00
updated fork of an [older PHP
version](https://github.com/jamierumbelow/sassphp).
%li#python
:markdown
### Python
The [libsass-python](https://github.com/sass/libsass-python) project
is updated regularly. There are more details on
[its own website](https://sass.github.io/libsass-python/).
2018-10-23 15:06:39 -07:00
Three other Python projects,
[python-scss](https://github.com/pistolero/python-scss),
[pylibsass](https://github.com/rsenk330/pylibsass) and
[SassPython](https://github.com/marianoguerra/SassPython), haven't been
updated in a while.
%li#ruby
:markdown
### Ruby
2018-10-23 15:06:39 -07:00
LibSass has also been ported back into Ruby for the
[sassc-ruby](https://github.com/sass/sassc-ruby) project.
%li#r
:markdown
### R
The [R](https://www.r-project.org/) [Sass package](https://github.com/rstudio/sass)
wraps LibSass with additional caching and bundling methods.
[Extended documentation](https://rstudio.github.io/sass/).
2018-03-19 10:11:16 -06:00
%li#rust
:markdown
### Rust
2018-10-23 15:06:39 -07:00
The [`sass_rs`](https://github.com/compass-rs/sass-rs) crate is a LibSass
wrapper and is updated regularly.
2018-03-19 10:11:16 -06:00
%li#scala
:markdown
### Scala
2018-10-23 15:06:39 -07:00
The only Scala project, [Sass-Scala](https://github.com/kkung/Sass-Scala),
hasn't been updated in a couple of years.
2016-02-27 13:58:18 +01:00
%h2 About LibSass
:markdown
2018-10-23 15:06:39 -07:00
This project is the brainchild of [Hampton
Catlin](http://twitter.com/hcatlin), the original creator of Sass, and is
sponsored by [Moovweb](http://moovweb.com/). [Aaron
Leung](http://github.com/akhleung) from Moovweb is the primary developer.
%figure
2018-10-23 15:06:39 -07:00
= image_tag 'logos/libsass.png', alt: 'LibSass logo'
2018-10-23 15:06:39 -07:00
- content_for :navigation do
2019-12-12 19:26:12 -08:00
%h2 Wrappers
2018-12-27 16:31:28 -08:00
.sl-c-list-navigation-wrapper
:markdown
- [SassC](#sassc)
- [Crystal](#crystal)
- [Go](#go)
- [Java](#java)
- [JavaScript](#javascript)
- [Lua](#lua)
- [.NET](#net)
- [Node](#node)
- [Perl](#perl)
- [PHP](#php)
- [Python](#python)
- [R](#r)
2018-12-27 16:31:28 -08:00
- [Ruby](#ruby)
- [Scala](#scala)
2018-10-23 15:06:39 -07:00
- content_for :complementary do
2019-12-12 19:26:12 -08:00
%h2 Resources
%ul
- for project in data.libsass.resources
%li
= link_to project.name, project.url
—
= project.description