at-rule-empty-line-before
Require or disallow an empty line before at-rules.
a {} /* โ */@media {} /* โ *//** โ * This line */
This rule ignores:
- at-rules that are the very first node in the source
@import
in Less.
The fix
option can automatically fix all of the problems reported by this rule. We recommend to enable indentation
rule for better autofixing results with this rule.
#
Optionsstring
: "always"|"never"
"always"
#
There must always be an empty line before at-rules.
The following patterns are considered problems:
a {} @media {}
a {}@media {}
The following patterns are not considered problems:
a {}
@media {}
"never"
#
There must never be an empty line before at-rules.
The following patterns are considered problems:
a {}
@media {}
The following patterns are not considered problems:
a {} @media {}
a {}@media {}
#
Optional secondary optionsexcept: ["after-same-name", "inside-block", "blockless-after-same-name-blockless", "blockless-after-blockless", "first-nested"]
#
"after-same-name"
#
Reverse the primary option for at-rules that follow another at-rule with the same name.
This means that you can group your at-rules by name.
For example, with "always"
:
The following patterns are not considered problems:
@charset "UTF-8";
@import url(x.css);@import url(y.css);
@media (min-width: 100px) {}@media (min-width: 200px) {}
a {
@extends .foo; @extends .bar;
@include x; @include y {}}
"inside-block"
#
Reverse the primary option for at-rules that are inside a block.
For example, with "always"
:
The following patterns are considered problems:
a {
@extend foo; color: pink;}
b { color: pink;
@extend foo;}
The following patterns are not considered problems:
a { @extend foo; color: pink;}
b { color: pink; @extend foo;}
"blockless-after-same-name-blockless"
#
Reverse the primary option for blockless at-rules that follow another blockless at-rule with the same name.
This means that you can group your blockless at-rules by name.
Shared-line comments do not affect this option.
For example, with "always"
:
The following patterns are not considered problems:
@charset "UTF-8";
@import url(x.css);@import url(y.css);
@charset "UTF-8";
@import url(x.css); /* comment */@import url(y.css);
a {
@extends .foo; @extends .bar;
@include loop; @include doo;}
"blockless-after-blockless"
#
Reverse the primary option for blockless at-rules that follow another blockless at-rule.
Shared-line comments do not affect this option.
For example, with "always"
:
The following patterns are considered problems:
@import url(x.css);
@import url(y.css);
@media print {}
The following patterns are not considered problems:
@import url(x.css);@import url(y.css);
@media print {}
@import url(x.css); /* comment */@import url(y.css);
@media print {}
"first-nested"
#
Reverse the primary option for at-rules that are nested and the first child of their parent node.
For example, with "always"
:
The following patterns are considered problems:
a {
@extend foo; color: pink;}
b { color: pink; @extend foo;}
The following patterns are not considered problems:
a { @extend foo; color: pink;}
b { color: pink;
@extend foo;}
ignore: ["after-comment", "first-nested", "inside-block", "blockless-after-same-name-blockless", "blockless-after-blockless"]
#
"after-comment"
#
Ignore at-rules that follow a comment.
Shared-line comments do not trigger this option.
The following patterns are not considered problems:
/* comment */@media {}
/* comment */
@media {}
@media {} /* comment */
@media {}
"first-nested"
#
Ignore at-rules that are nested and the first child of their parent node.
For example, with "always"
:
The following patterns are not considered problems:
@supports { @media {}
@media {}}
"inside-block"
#
Ignore at-rules that are inside a block.
For example, with "always"
:
The following patterns are not considered problems:
a { @extend foo; color: pink;}
a {
@extend foo; color: pink;}
b { color: pink; @extend foo;}
b { color: pink;
@extend foo;}
"blockless-after-same-name-blockless"
#
Ignore blockless at-rules that follow another blockless at-rule with the same name.
This means that you can group your blockless at-rules by name.
For example, with "always"
:
The following patterns are not considered problems:
@charset "UTF-8";
@import url(x.css);@import url(y.css);
a {
@extends .foo; @extends .bar;
@include loop; @include doo;}
"blockless-after-blockless"
#
Ignore blockless at-rules that follow another blockless at-rule.
For example, with "always"
:
The following patterns are not considered problems:
@import url(x.css);
@import url(y.css);
@media print {}
@import url(x.css);@import url(y.css);
@media print {}
ignoreAtRules: ["array", "of", "at-rules"]
#
Ignore specified at-rules.
For example, with "always"
.
Given:
["import"]
The following patterns are not considered problems:
@charset "UTF-8";@import {}