all repos — NoPaste @ 3e3c433f026c49e04d0efa0f0f39fc688ed32bb1

Resurrected - The PussTheCat.org fork of NoPaste

scripts/CodeMirror/mode/sass/test.js (view raw)

  1// CodeMirror, copyright (c) by Marijn Haverbeke and others
  2// Distributed under an MIT license: https://codemirror.net/LICENSE
  3
  4(function() {
  5  var mode = CodeMirror.getMode({indentUnit: 2}, "sass");
  6  // Since Sass has an indent-based syntax, is almost impossible to test correctly the indentation in all cases.
  7  // So disable it for tests.
  8  mode.indent = undefined;
  9  function MT(name) { test.mode(name, mode, Array.prototype.slice.call(arguments, 1)); }
 10
 11  MT("comment",
 12     "[comment // this is a comment]",
 13     "[comment   also this is a comment]")
 14
 15  MT("comment_multiline",
 16     "[comment /* this is a comment]",
 17     "[comment   also this is a comment]")
 18
 19  MT("variable",
 20     "[variable-2 $page-width][operator :] [number 800][unit px]")
 21
 22  MT("global_attributes",
 23     "[tag body]",
 24     "  [property font][operator :]",
 25     "    [property family][operator :] [atom sans-serif]",
 26     "    [property size][operator :] [number 30][unit em]",
 27     "    [property weight][operator :] [atom bold]")
 28
 29  MT("scoped_styles",
 30     "[builtin #contents]",
 31     "  [property width][operator :] [variable-2 $page-width]",
 32     "  [builtin #sidebar]",
 33     "    [property float][operator :] [atom right]",
 34     "    [property width][operator :] [variable-2 $sidebar-width]",
 35     "  [builtin #main]",
 36     "    [property width][operator :] [variable-2 $page-width] [operator -] [variable-2 $sidebar-width]",
 37     "    [property background][operator :] [variable-2 $primary-color]",
 38     "    [tag h2]",
 39     "      [property color][operator :] [keyword blue]")
 40
 41  // Sass allows to write the colon as first char instead of a "separator".
 42  //   :color red
 43  // Not supported
 44  // MT("property_syntax",
 45  //    "[qualifier .foo]",
 46  //    "  [operator :][property color] [keyword red]")
 47
 48  MT("import",
 49     "[def @import] [string \"sass/variables\"]",
 50     // Probably it should parsed as above: as a string even without the " or '
 51     // "[def @import] [string sass/baz]"
 52     "[def @import] [tag sass][operator /][tag baz]")
 53
 54  MT("def",
 55     "[def @if] [variable-2 $foo] [def @else]")
 56
 57  MT("tag_on_more_lines",
 58    "[tag td],",
 59    "[tag th]",
 60    "  [property font-family][operator :] [string \"Arial\"], [atom serif]")
 61
 62  MT("important",
 63     "[qualifier .foo]",
 64     "  [property text-decoration][operator :] [atom none] [keyword !important]",
 65     "[tag h1]",
 66     "  [property font-size][operator :] [number 2.5][unit em]")
 67
 68  MT("selector",
 69     // SCSS doesn't highlight the :
 70     // "[tag h1]:[variable-3 before],",
 71     // "[tag h2]:[variable-3 before]",
 72     "[tag h1][variable-3 :before],",
 73     "[tag h2][variable-3 :before]",
 74     "  [property content][operator :] [string \"::\"]")
 75
 76  MT("definition_mixin_equal",
 77     "[variable-2 $defined-bs-type][operator :] [atom border-box] [keyword !default]",
 78     "[meta =bs][operator (][variable-2 $bs-type][operator :] [variable-2 $defined-bs-type][operator )]",
 79     "  [meta -webkit-][property box-sizing][operator :] [variable-2 $bs-type]",
 80     "  [property box-sizing][operator :] [variable-2 $bs-type]")
 81
 82  MT("definition_mixin_with_space",
 83     "[variable-2 $defined-bs-type][operator :] [atom border-box] [keyword !default]",
 84     "[def @mixin] [tag bs][operator (][variable-2 $bs-type][operator :] [variable-2 $defined-bs-type][operator )] ",
 85     "  [meta -moz-][property box-sizing][operator :] [variable-2 $bs-type]",
 86     "  [property box-sizing][operator :] [variable-2 $bs-type]")
 87
 88  MT("numbers_start_dot_include_plus",
 89     // The % is not highlighted correctly
 90     // "[meta =button-links][operator (][variable-2 $button-base][operator :] [atom darken][operator (][variable-2 $color11], [number 10][unit %][operator )][operator )]",
 91     "[meta =button-links][operator (][variable-2 $button-base][operator :] [atom darken][operator (][variable-2 $color11], [number 10][operator %))]",
 92     "  [property padding][operator :] [number .3][unit em] [number .6][unit em]",
 93     "  [variable-3 +border-radius][operator (][number 8][unit px][operator )]",
 94     "  [property background-color][operator :] [variable-2 $button-base]")
 95
 96  MT("include",
 97     "[qualifier .bar]",
 98     "  [def @include] [tag border-radius][operator (][number 8][unit px][operator )]")
 99
100  MT("reference_parent",
101     "[qualifier .col]",
102     "  [property clear][operator :] [atom both]",
103     // SCSS doesn't highlight the :
104     // "  &:[variable-3 after]",
105     "  &[variable-3 :after]",
106     "    [property content][operator :] [string '']",
107     "    [property clear][operator :] [atom both]")
108
109  MT("reference_parent_with_spaces",
110     "[tag section]",
111     "  [property border-left][operator :]  [number 20][unit px] [atom transparent] [atom solid] ",
112     "  &[qualifier .section3]",
113     "    [qualifier .title]",
114     "      [property color][operator :] [keyword white] ",
115     "    [qualifier .vermas]",
116     "      [property display][operator :] [atom none]")
117
118  MT("font_face",
119     "[def @font-face]",
120     "  [property font-family][operator :] [string 'icomoon']",
121     "  [property src][operator :] [atom url][operator (][string fonts/icomoon.ttf][operator )]")
122})();