Giter VIP home page Giter VIP logo

libsass's Introduction

Sass

@SassCSS on Twitter    stackoverflow    Gitter

Sass makes CSS fun again. Sass is an extension of CSS, adding nested rules, variables, mixins, selector inheritance, and more. It's translated to well-formatted, standard CSS using the command line tool or a plugin for your build system.

$font-stack: Helvetica, sans-serif;
$primary-color: #333;

body {
  font: 100% $font-stack;
  color: $primary-color;
}

@mixin border-radius($radius) {
  -webkit-border-radius: $radius;
     -moz-border-radius: $radius;
      -ms-border-radius: $radius;
          border-radius: $radius;
}

nav {
  ul {
    margin: 0;
    padding: 0;
    list-style: none;
  }

  li { @include border-radius(10px); }

  a {
    display: block;
    padding: 6px 12px;
    text-decoration: none;
  }
}

Install Sass

You can install Sass on Windows, Mac, or Linux by downloading the package for your operating system from GitHub and adding it to your PATH. That's all—there are no external dependencies and nothing else you need to install.

If you use Node.js, you can also install Sass using npm by running

npm install -g sass

However, please note that this will install the pure JavaScript implementation of Sass, which runs somewhat slower than the other options listed here. But it has the same interface, so it'll be easy to swap in another implementation later if you need a bit more speed!

See the Sass website for more ways to install Sass.

Once you have Sass installed, you can run the sass executable to compile .sass and .scss files to .css files. For example:

sass source/stylesheets/index.scss build/stylesheets/index.css

Learn Sass

Check out the Sass website for a guide on how to learn Sass!

This Repository

This repository isn't an implementation of Sass. Those live in sass/dart-sass and sass/libsass. Instead, it contains:

  • spec/, which contains specifications for language features.
  • proposal/, which contains in-progress proposals for changes to the language.
  • accepted/, which contains proposals that have been accepted and are either implemented or in the process of being implemented.

Note that this doesn't contain a full specification of Sass. Instead, feature specifications are written as needed when a new feature is being designed or when an implementor needs additional clarity about how something is supposed to work. This means many of the specs in spec/ only cover small portions of the features in question.

Versioning Policy

The proposals in this repository are versioned, to make it easy to track changes over time and to refer to older versions. Every version has a Git tag of the form proposal.<name>.draft-<version>. A new version should be created for each batch of changes.

Every version has a major version, and they may have a minor version as well (indicated <major>.<minor>). The minor version should be incremented for changes that don't affect the intended semantics of the proposal; otherwise, the major version should be incremented.

libsass's People

Stargazers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

Watchers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

libsass's Issues

Debug Output

Whoa... so much debug output... When I run sassc, I get the following output...

    stockton:sassc hcatlin$ ./bin/sassc interpolation.scss 
    MADE A DOC AND CONTEXT OBJ
    REGISTRY: 1
    parsing value schema: #{2 + 2}
    parsing value schema: #{world}
    css import inside block
    css import inside block
    PARSED
    evaluating schema of size 1
    evaluating schema of size 1
    evaluating schema of size 2
    EVALUATED
    foobar.css
    foobar.css
    foobar.css
    EMITTED
    Allocations:    74
    Destructions:   570
    Registry size:  74
    Deallocations:  74
    Deallocated 1 source string(s).

Variables are not resolved inside parentheses

This line will produce:
background: -moz-linear-gradient(top, $headerGradientStart 0%, $headerGradientEnd 166px, #ffffff 166px);

background: -moz-linear-gradient(top, $headerGradientStart 0%, $headerGradientEnd 166px, #ffffff 166px);

After removing the parentheses:
background: -moz-linear-gradient top, $headerGradientStart 0%, $headerGradientEnd 166px, #ffffff 166px;

variables are resolved:
background: -moz-linear-gradient top, white 0%, black 166px, #ffffff 166px;

error on UTF-8 with sugnature files

When trying to process file with UTF-8 with signature (BOM) encoding, getting error:

ERROR -- filename, line 1: invalid top-level expression

Partials aren't imported correctly

This might be posted in the wrong place (I was testing sassc so maybe that's where this should go). But sassc won't import partials the way vanilla SASS does it, using underscore for naming and then omitting both underscore and extensions in the import directive.

/* This will fail: */
@import "variables/measures";

/* This will succeed: */
@import "variables/_measures.scss";

intermittent fatal erros

Hi, Ive been getting the following errors intermittently when building sass;

node(14524,0x1017bb000) malloc: *** mmap(size=1152921504876556288) failed (error code=12)
*** error: can't allocate region
*** set a breakpoint in malloc_error_break to debug
terminate called throwing an exceptionAbort trap: 6

Not very helpful - but with some help from a issue I raised in node-sass I was able to get the following stack trace;

0 0x00007fff8a32dce2 in pthread_kill ()
1 0x00007fff8bcf57d2 in pthread_kill ()
2 0x00007fff8bce6a7a in abort ()
3 0x00007fff9141e7bc in abort_message ()
4 0x00007fff9141bfcf in default_terminate ()
5 0x00007fff8885b1cd in _objc_terminate ()
6 0x00007fff9141c001 in safe_handler_caller ()
7 0x00007fff9141c05c in std::terminate ()
8 0x00007fff9141d152 in __cxa_throw ()
9 0x00007fff848e8255 in std::throw_length_error ()
10 0x00007fff8490e84e in std::string::_Rep::_S_create ()
11 0x00007fff849102fa in std::string::_S_construct ()
12 0x00007fff849104a8 in std::basic_string, std::allocator >::basic_string ()
13 0x000000010172c0f8 in Sass::Token::to_string () at :68
14 0x000000010172c0f8 in Sass::Node::to_string (this=0x7fff8bd0f711, inside_of=Sass::Node::none) at ../libsass/node_emitters.cpp:68
15 0x000000010172f5d1 in std::string::data () at ../libsass/node_emitters.cpp:390
16 0x000000010172f5d1 in std::string::_M_data () at /usr/include/c++/4.2.1/bits/basic_string.h:2413
17 0x000000010172f5d1 in std::operator<< , std::allocator > () at /usr/include/c++/4.2.1/bits/basic_string.h:1542
18 0x000000010172f5d1 in Sass::Node::emit_nested_css (this=0x102844e88, buf=@0x1017ba708, depth=1, at_toplevel=false, in_media_query=true) at ../libsass/node_emitters.cpp:390
19 0x000000010172fa13 in std::operator<< std::char_traits () at /usr/include/c++/4.2.1/ostream:427
20 0x000000010172fa13 in Sass::Node::emit_nested_css (this=0x10300bf28, buf=@0x1017ba708, depth=, at_toplevel=, in_media_query=false) at ../libsass/node_emitters.cpp:428
21 0x000000010172f4df in Sass::Node::emit_nested_css (this=0x1017bac58, buf=@0x1017ba708, depth=0, at_toplevel=true, in_media_query=false) at ../libsass/node_emitters.cpp:379
22 0x0000000101709787 in std::basic_stringstream, std::allocator >::str () at /usr/include/c++/4.2.1/sstream:133
23 0x0000000101709787 in Sass::Document::emit_css (this=, style=) at ../libsass/document.cpp:141
24 0x0000000101733581 in std::string::_M_rep () at ../libsass/sass_interface.cpp:51
25 0x0000000101733581 in std::string::_M_data () at /usr/include/c++/4.2.1/bits/basic_string.h:605
26 0x0000000101733581 in std::string::size () at /usr/include/c++/4.2.1/bits/basic_string.h:287
27 0x0000000101733581 in process_document (doc=@0x1017bac20, style=0) at ../libsass/sass_interface.cpp:52
28 0x0000000101733157 in sass_compile (c_ctx=0x102800140) at ../libsass/sass_interface.cpp:65
29 0x00000001000462a8 in etp_proc ()
30 0x00007fff8bcf38bf in _pthread_start ()
31 0x00007fff8bcf6b75 in thread_start ()

Does that provide enough info to be of help?

Im running on a Mac - OS X 10.7.5
Im auto building sass with 'grunt watch' using -> grunt-sass which wraps -> node-sass which wraps -> libsass

Improve Makefile

I've created a homebrew formula so we can simply run brew install libsass but the Makefile doesn't have an install command.

I don't really know much about makefiles so I might need some help implementing it.

Homebrew formula here: andrew/homebrew@b5601ff

Incorrect Pseudo Identifier Parsing

Pseudo parsing in the library limits the formats or required a string constant, this does not work with the :lang identifier

The following is valid CSS

selector:lang(es) {

}

Libsass only supports

selector:lang('es') {

}

which is invalid.

The code in question is in document_parser.cpp

  Node Document::parse_pseudo() {
    if (lex< pseudo_not >()) {
    ...
      else if (lex< string_constant >()) {
        pseudo << context.new_Node(Node::string_constant, path, line, lexed);
      }
   ...

This can be resolved by changing the lexer to parse out an identifier instead of a string constant

   ...
      else if (lex< identifier >()) {
        pseudo << context.new_Node(Node::identifier, path, line, lexed);
      }
   ...

libsass does not accept parsing from stdin

Testing sassc I noticed that it doesn't accept input from stdin and looking to implement that I found that libsass doesn't accept input from stdin because it tries to fstat a file name to get it's size and preallocate memory to ready it all in memory.

Would be nice if we could use sassc/libsass accepts input from stdin that way it could be part of a sequence of filters through redirection.

cat some.scss | sed | sassc | sed | ...

Selector parsing is too strict

Valid and useful things like:

div > {
  span { ... }
  p { ... }
  etc { ... }
}

aren't recognized by the selector lookahead function.

Passing content blocks to a mixin

According to the reference, SCSS has to be able to pass content blocks to a mixin. For example:

@mixin apply-to-ie6-only {
  * html {
    @content;
  }
}
@include apply-to-ie6-only {
  #logo {
    background-image: url(/logo.gif);
  }
}

has to be compiled to:

* html #logo {
  background-image: url(/logo.gif);
}

However it causes an error:

ERROR -- test.scss, line 6: top-level @include directive must be terminated by ';'

Merge with sassc?

I'm not sure if this has already been discussed but is there a specific argument against libsass and sassc being in one repository? Having them separate seems to make things like git bisect/recursive make/continuous integration less simple than they could be.

STYLE_ constants obeyed

I got all excited about adding different output styles to my libsass binding to discover that only SASS_STYLE_NESTED is working!

Are there still plans to make the other style constants work?

Errors out on valid gradient syntax

Looks like it doesn't recognize a non-prefixed syntax

div {
  // works:
  background-image: -webkit-linear-gradient(top, #2F2727, #1a82f7);
  // breaks:
  background-image: linear-gradient(top, #2F2727, #1a82f7);
  @include background-image(linear-gradient(top, $color1, $color1));
}

Error message:

Segmentation fault: 11

Windows compilation issue

When trying to compile node-sass (https://github.com/andrew/node-sass) which wraps this library, it turns out this library is not portable enough to be compiled by Visual C++.

The compile log is here: https://gist.github.com/3885949

It seems to be mainly problems with char which should be const char, and the resulting influence on the parameter list of the templates used.

I also posted an issue with node-sass (sass/node-sass#28), but as the main compiler errors are generated by the libsass files, I thought posting an issue here too would be appropriate.

Incorrect include_paths option format

Now this parameter parsed via hardcoded specified separator character ':'.
This is not correct on some platforms, for ex. on Windows =)
I think, it would be better to specify custom separator or array of strings (better).

Unicode support

Internally the project uses 'char' instead of 'wchar_t' for manipulating strings.
So that means no Unicode support?

color functions are broken

The following scss code:

p {
    color: rgb(255, 128, 0);
}

results in:

p {
    color: alsetruetruefals; }

The Ruby sass implementation gives the correct result:

p {
    color: #ff8000; }

It seems that all of the color functions are broken in this way(darken, lighten, grayscale, etc...)

Embedded base64 image

Hi,

Say you have the following SCSS :

p:after {
content:url();
}

Compiling with latest libsass gives the following error :

ERROR -- my-data.scss, line 2: URI is missing ')'

It works well with ruby reference implementation.

Regards,
Étienne

RGBA value doesn't work

This code:

$mw_box_shadow: 0 1px 3px rgba(0,0,0,0.9);
div{
  -webkit-box-shadow: $mw_box_shadow;
}

spits out this error:

Segmentation fault: 11

But this works:

$mw_box_shadow: 0 1px 3px #333;
div{
  -webkit-box-shadow: $mw_box_shadow;
}

Running both of the above as an inline command without supplying the output file:

$ sassc main.scss

Imports fail if there's also a directory of the same name

As in Compass, say you have a partial and a directory with a similar name. On Linux (and likely on any Unix, where "everything is a file"), if you import only the basename of the partial (i.e., without the extension), then libsass will open the directory instead of the partial and fail to read anything.

Test case:

$ touch bar.scss
$ mkdir bar
$ cat > foo.scss << EOF
@import "bar";
EOF
$ sassc foo
ERROR -- foo.scss, line 1: error reading file "bar"

Implement custom importers

I would like to use libsass with user-generated SCSS templates, but exposing libsass to user creates security threat. By crafting @import directives users can read some, possibly sensitive files, for server filesystem.

I would be nice if libsass would have support for custom importers, and have control over access to filesystem.

Rendering '@charset "UTF-8";' gives an error.

Originally reported at sass/node-sass#23. node-sass module uses libsass.

When I try to use it, it outputs 'undefined'

var sass = require('node-sass');

sass.render('@charset "UTF-8";', function(err, css){
    console.log(css)
});

The node-sass developer confirms that the problem originates from libsass. He says the following error is displayed when he tries to use sassc (https://github.com/hcatlin/sassc) to render @charset "UTF-8";:

ERROR -- test.scss, line 1: top-level blockless directive must be terminated by ';'

.sass files not supported?

Given the test.sass file:
div
background-color: blue

when I run "./bin/sassc test.sass" I get the error:

ERROR -- test.sass, line 1: invalid top-level expression

Is there a flag I'm missing, or is sass not supported yet? Significant whitespace is awesome.

Parse error of conditionals inside mixin

The example bellow is extracted and adapted from "compass/typography/text/_replacement.scss" and do not compile with libsass :
ERROR -- test.scss:7: invalid property name

if the conditionals are commented it does work // @if is-url($img) { // } @else { //} , it seems that the parser doesn't recognize the @if conditional inside the mixin.

@function is-url($n) {
@return $n != '';
}

@mixin replace-text($img, $x: 50%, $y: 50%) {
//@include hide-text;
background: {
@if is-url($img) {
image: $img;
} @else {
image: image-url($img);
}
repeat: no-repeat;
position: $x $y;
}
}

@mixin large-text {
font: {
family: Arial;
size: 20px;
weight: bold;
}
color: #ff0000;
}

.dad {
@include replace-text('dad');
@include large-text;
}

Concatenation error

When I try to concatenate unquoted string with quoted:
bar + "foo"
it should produce unquoted string:
barfoo
but libsass produced mixed:
bar"foo"

Incorrect interpolation

When string is not top-level expression, like:

$bg = image.png;
background-image: url("#{$url}");

interpolation does not work, it produced:

background-image: url("#{$url}");

But if I use without url:

$bg = image.png;
background-image: "#{$url}";

it produce:

background-image: "image.png";

Discrepancies between libsass parsing and the ruby gem

Hi there, there seems to be some differences between libsass and the ruby gem regarding string handling.

e.g.
For desired css of the form;

background: url(/static_loc/img/beta.png);

I was able to write the following scss;

$base_url: "/static_loc/";
background-image: "url("#{$base_url}"img/beta.png)";

However, when I switched to the ruby gem (due to other issues) I had to omit several quotes to get the same css;

$base_url: "/static_loc/";
background-image: url(#{$base_url}img/beta.png);

Not a massive issue (I can probably refactor it so it works for both) but I thought it'd help to raise an issue as I assume you folks want to keep all sass parsers in sync?

Cheers,
Greg

Parser do not recognize @- browser specific rules

The actual parser do not recognize the @-webkit-keyframes rules it try to parse it as "directive" and throws "top-level blockless directive must be terminated by ';'" when it should interpret it as a block.

Actually I think it should check for "@-" and parse anything stating with it as a normal block.

examples:

@-webkit-keyframes uiDelayedFadeIn {
0% { @include opacity(0.01); }
50% { @include opacity(0.01); }
100% { @include opacity(1); }
}

@-webkit-keyframes bounce {
from {
left: 0px;
}
to {
left: 200px;
}
}

@-moz-document url-prefix() {
.fl { float:left; margin:12px 4px 0 0; padding:0; font-size:65px; line-height:62%; color:#ba1820; }
.fs { float:left; margin:12px 4px 10px 0; padding:0; font-size:65px; line-height:62%; color:#ba1820; }
}

No sass_free_folder_context() function

Although sass_interface.h header contains the prototype of void sass_free_folder_context(struct sass_folder_context *) function, sass_interface.cpp does not implement it. It occurs a link error.

segfault in current master

FYI, I tried merging the new libsass into our current node-sass repo that uses it. Something added in recently caused it to segfault. When I run it through gdb, it complains on this line:

string path_string(img_path_str);

This line is found in context.cpp on line 63. I haven't had time to investigate it, but it looks like this was new code added in a few hours ago.

Parse error report that can be understood by scite editor

Hello !
I started testing sassc/libsass and noticed that the current parse error reported by libsass isn't understood by scite so I modified two lines on sass_interface.cpp and with that scite now recognize the error and can jump to source and line.

Basically I changed the static string ", line" by ":" that was enough.

line 77: msg_stream << "ERROR -- " << e.path << /", line "/ ":" << e.line << ": " << e.message << endl;
line 117:msg_stream << "ERROR -- " << e.path << /", line "/ ":" << e.line << ": " << e.message << endl;

'if' function not implemented; causes arithmetic errors

The works when using plain scss --watch

The error

Failed to compile sass: gosass error: ERROR -- /Users/jeffpatzer/workspace/projects/jeffpatzer/assets/stylesheets/globals/_vertical_rhythm, line 109: argument to unit must be numeric

This line

$rhythm: $font-unit * ($lines * $base-line-height - $offset) / $font-size;

From the compass vertical rhythm file

// Taken from Compass's Vertical Rhythm module

// The base font size.
$base-font-size: 16px !default;

// The base line height determines the basic unit of vertical rhythm.
$base-line-height: 24px !default;

// Set the default border style for rhythm borders.
$default-rhythm-border-style: solid !default;

// The default font size in all browsers.
$browser-default-font-size: 16px;

// Set to false if you want to use absolute pixels in sizing your typography.
$relative-font-sizing: true !default;

// Allows the `adjust-font-size-to` mixin and the `lines-for-font-size` function
// to round the line height to the nearest half line height instead of the
// nearest integral line height to avoid large spacing between lines.
$round-to-nearest-half-line: false !default;

// Ensure there is at least this many pixels
// of vertical padding above and below the text.
$min-line-padding: 2px !default;

// $base-font-size but in your output unit of choice.
// Defaults to 1em when `$relative-font-sizing` is true.
$font-unit: if($relative-font-sizing, 1em, $base-font-size) !default;

// The basic unit of font rhythm.
$base-rhythm-unit: $base-line-height / $base-font-size * $font-unit;

// The leader is the amount of whitespace in a line.
// It might be useful in your calculations.
$base-leader: ($base-line-height - $base-font-size) * $font-unit / $base-font-size;

// The half-leader is the amount of whitespace above and below a line.
// It might be useful in your calculations.
$base-half-leader: $base-leader / 2;

// True if a number has a relative unit.
@function relative-unit($number) {
  @return unit($number) == "%" or unit($number) == "em" or unit($number) == "rem"
}

// True if a number has an absolute unit.
@function absolute-unit($number) {
  @return not (relative-unit($number) or unitless($number));
}

@if $relative-font-sizing and not relative-unit($font-unit) {
  @warn "$relative-font-sizing is true but $font-unit is set to #{$font-unit} which is not a relative unit.";
}

// Establishes a font baseline for the given font-size.
@mixin establish-baseline($font-size: $base-font-size) {
  // IE 6 refuses to resize fonts set in pixels and it weirdly resizes fonts
  // whose root is set in ems. So we set the root font size in percentages of
  // the default font size.
  * html {
    font-size: 100% * ($font-size / $browser-default-font-size);
  }
  html {
    font-size: $font-size;
    @include adjust-leading-to(1, if($relative-font-sizing, $font-size, $base-font-size));
  }
}

// Resets the line-height to 1 vertical rhythm unit.
// Does not work on elements whose font-size is different from $base-font-size.
//
// @deprecated This mixin will be removed in the next release.
// Please use the `adjust-leading-to` mixin instead.
@mixin reset-baseline {
  @include adjust-leading-to(1, if($relative-font-sizing, $base-font-size, $base-font-size));
}

// Adjust a block to have a different font size and line height to maintain the
// rhythm. $lines specifies how many multiples of the baseline rhythm each line
// of this font should use up. It does not have to be an integer, but it
// defaults to the smallest integer that is large enough to fit the font.
// Use $from-size to adjust from a font-size other than the base font-size.
@mixin adjust-font-size-to($to-size, $lines: lines-for-font-size($to-size), $from-size: $base-font-size) {
  @if not $relative-font-sizing and $from-size != $base-font-size {
    @warn "$relative-font-sizing is false but a relative font size was passed to adjust-font-size-to";
  }
  font-size: $font-unit * $to-size / $from-size;
  @include adjust-leading-to($lines, if($relative-font-sizing, $to-size, $base-font-size));
}

// Adjust a block to have different line height to maintain the rhythm.
// $lines specifies how many multiples of the baseline rhythm each line of this
// font should use up. It does not have to be an integer, but it defaults to the
// smallest integer that is large enough to fit the font.
@mixin adjust-leading-to($lines, $font-size: $base-font-size) {
  line-height: rhythm($lines, $font-size);
}

// Calculate rhythm units.
@function rhythm(
  $lines: 1,
  $font-size: $base-font-size,
  $offset: 0
) {
  @if not $relative-font-sizing and $font-size != $base-font-size {
    @warn "$relative-font-sizing is false but a relative font size was passed to the rhythm function";
  }
  $rhythm: $font-unit * ($lines * $base-line-height - $offset) / $font-size;
  // Round the pixels down to nearest integer.
  @if unit($rhythm) == px {
    $rhythm: floor($rhythm);
  }
  @return $rhythm;
}

// Calculate the minimum multiple of rhythm units needed to contain the font-size.
@function lines-for-font-size($font-size) {
  $lines: if($round-to-nearest-half-line,
              ceil(2 * $font-size / $base-line-height) / 2,
              ceil($font-size / $base-line-height));
  @if $lines * $base-line-height - $font-size < $min-line-padding * 2 {
    $lines: $lines + if($round-to-nearest-half-line, 0.5, 1);
  }
  @return $lines;
}

// Apply leading whitespace. The $property can be margin or padding.
@mixin leader($lines: 1, $font-size: $base-font-size, $property: margin) {
  #{$property}-top: rhythm($lines, $font-size);
}

// Apply leading whitespace as padding.
@mixin padding-leader($lines: 1, $font-size: $base-font-size) {
  padding-top: rhythm($lines, $font-size);
}

// Apply leading whitespace as margin.
@mixin margin-leader($lines: 1, $font-size: $base-font-size) {
  margin-top: rhythm($lines, $font-size);
}

// Apply trailing whitespace. The $property can be margin or padding.
@mixin trailer($lines: 1, $font-size: $base-font-size, $property: margin) {
  #{$property}-bottom: rhythm($lines, $font-size);
}

// Apply trailing whitespace as padding.
@mixin padding-trailer($lines: 1, $font-size: $base-font-size) {
  padding-bottom: rhythm($lines, $font-size);
}

// Apply trailing whitespace as margin.
@mixin margin-trailer($lines: 1, $font-size: $base-font-size) {
  margin-bottom: rhythm($lines, $font-size);
}

// Shorthand mixin to apply whitespace for top and bottom margins and padding.
@mixin rhythm($leader: 0, $padding-leader: 0, $padding-trailer: 0, $trailer: 0, $font-size: $base-font-size) {
  @include leader($leader, $font-size);
  @include padding-leader($padding-leader, $font-size);
  @include padding-trailer($padding-trailer, $font-size);
  @include trailer($trailer, $font-size);
}

// Apply a border and whitespace to any side without destroying the vertical
// rhythm. The whitespace must be greater than the width of the border.
@mixin apply-side-rhythm-border($side, $width: 1px, $lines: 1, $font-size: $base-font-size, $border-style: $default-rhythm-border-style) {
  @if not $relative-font-sizing and $font-size != $base-font-size {
    @warn "$relative-font-sizing is false but a relative font size was passed to apply-side-rhythm-border";
  }
  border-#{$side}: {
    style: $border-style;
    width: $font-unit * $width / $font-size;
  };
  padding-#{$side}: rhythm($lines, $font-size, $offset: $width);
}

// Apply borders and whitespace equally to all sides.
@mixin rhythm-borders($width: 1px, $lines: 1, $font-size: $base-font-size, $border-style: $default-rhythm-border-style) {
  @if not $relative-font-sizing and $font-size != $base-font-size {
    @warn "$relative-font-sizing is false but a relative font size was passed to rhythm-borders";
  }
  border: {
    style: $border-style;
    width: $font-unit * $width / $font-size;
  };
  padding: rhythm($lines, $font-size, $offset: $width);
}

// Apply a leading border.
@mixin leading-border($width: 1px, $lines: 1, $font-size: $base-font-size, $border-style: $default-rhythm-border-style) {
  @include apply-side-rhythm-border(top, $width, $lines, $font-size, $border-style);
}

// Apply a trailing border.
@mixin trailing-border($width: 1px, $lines: 1, $font-size: $base-font-size, $border-style: $default-rhythm-border-style) {
  @include apply-side-rhythm-border(bottom, $width, $lines, $font-size, $border-style);
}

// Apply both leading and trailing borders.
@mixin horizontal-borders($width: 1px, $lines: 1, $font-size: $base-font-size, $border-style: $default-rhythm-border-style) {
  @include leading-border($width, $lines, $font-size, $border-style);
  @include trailing-border($width, $lines, $font-size, $border-style);
}

// Alias for `horizontal-borders` mixin.
@mixin h-borders($width: 1px, $lines: 1, $font-size: $base-font-size, $border-style: $default-rhythm-border-style) {
  @include horizontal-borders($width, $lines, $font-size, $border-style);
}

Warnings printed are not informative enough.

Here's a libsass warning:

WARNING: border-radius mixin is deprecated and will be removed in the next major version release.
         on line 3 of /home/noj/sandbox/testingmw/assets/stylesheets/bourbon/css3/border-radius

What the ruby sass compiler does:

WARNING: border-radius mixin is deprecated and will be removed in the next major version release.
         on line 3 of bourbon/css3/_border-radius.scss, in `border-radius'
         from line 125 of globals/_lib.scss, in `button_base'
         from line 145 of globals/_lib.scss
         from line 18 of main.scss

It would be nice if libsass could also print the stack trace so that we know where we're using the incorrect function.

Better detection of missing rbrace (etc.)

It currently falls upon the property/style parsing function to detect missing braces (because the selector lookahead will fall through). Add better checks for missing braces, and maybe check for strange characters during lookahead.

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.