haml-edge 2.3.187 → 2.3.188

Sign up to get free protection for your applications and to get access to all the features.
Files changed (41) hide show
  1. data/EDGE_GEM_VERSION +1 -1
  2. data/VERSION +1 -1
  3. data/lib/sass/script/operation.rb +1 -0
  4. data/lib/sass/script/parser.rb +3 -3
  5. data/test/haml/spec/README.md +97 -0
  6. data/test/haml/spec/lua_haml_spec.lua +30 -0
  7. data/test/haml/spec/ruby_haml_test.rb +19 -0
  8. data/test/haml/spec/tests.json +534 -0
  9. data/test/sass/conversion_test.rb +2 -2
  10. data/test/sass/script_conversion_test.rb +24 -0
  11. data/vendor/fssm/LICENSE +20 -0
  12. data/vendor/fssm/README.markdown +55 -0
  13. data/vendor/fssm/Rakefile +59 -0
  14. data/vendor/fssm/VERSION.yml +5 -0
  15. data/vendor/fssm/example.rb +9 -0
  16. data/vendor/fssm/fssm.gemspec +77 -0
  17. data/vendor/fssm/lib/fssm/backends/fsevents.rb +36 -0
  18. data/vendor/fssm/lib/fssm/backends/inotify.rb +26 -0
  19. data/vendor/fssm/lib/fssm/backends/polling.rb +25 -0
  20. data/vendor/fssm/lib/fssm/backends/rubycocoa/fsevents.rb +131 -0
  21. data/vendor/fssm/lib/fssm/monitor.rb +26 -0
  22. data/vendor/fssm/lib/fssm/path.rb +91 -0
  23. data/vendor/fssm/lib/fssm/pathname.rb +502 -0
  24. data/vendor/fssm/lib/fssm/state/directory.rb +57 -0
  25. data/vendor/fssm/lib/fssm/state/file.rb +24 -0
  26. data/vendor/fssm/lib/fssm/support.rb +63 -0
  27. data/vendor/fssm/lib/fssm/tree.rb +176 -0
  28. data/vendor/fssm/lib/fssm.rb +33 -0
  29. data/vendor/fssm/profile/prof-cache.rb +40 -0
  30. data/vendor/fssm/profile/prof-fssm-pathname.html +1231 -0
  31. data/vendor/fssm/profile/prof-pathname.rb +68 -0
  32. data/vendor/fssm/profile/prof-plain-pathname.html +988 -0
  33. data/vendor/fssm/profile/prof.html +2379 -0
  34. data/vendor/fssm/spec/path_spec.rb +75 -0
  35. data/vendor/fssm/spec/root/duck/quack.txt +0 -0
  36. data/vendor/fssm/spec/root/file.css +0 -0
  37. data/vendor/fssm/spec/root/file.rb +0 -0
  38. data/vendor/fssm/spec/root/file.yml +0 -0
  39. data/vendor/fssm/spec/root/moo/cow.txt +0 -0
  40. data/vendor/fssm/spec/spec_helper.rb +14 -0
  41. metadata +36 -1
data/EDGE_GEM_VERSION CHANGED
@@ -1 +1 @@
1
- 2.3.187
1
+ 2.3.188
data/VERSION CHANGED
@@ -1 +1 @@
1
- 2.3.187
1
+ 2.3.188
@@ -5,6 +5,7 @@ require 'sass/script/color'
5
5
  require 'sass/script/functions'
6
6
  require 'sass/script/unary_operation'
7
7
  require 'sass/script/interpolation'
8
+ require 'sass/script/string_interpolation'
8
9
 
9
10
  module Sass::Script
10
11
  # A SassScript parse node representing a binary operation,
@@ -310,9 +310,9 @@ RUBY
310
310
  line = @lexer.line
311
311
  mid = parse_interpolated
312
312
  last = assert_expr(:string)
313
- op = Operation.new(first.value, node(Operation.new(mid, last, :plus)), :plus)
314
- op.line = line
315
- op
313
+ interp = StringInterpolation.new(first.value, mid, last)
314
+ interp.line = line
315
+ interp
316
316
  end
317
317
 
318
318
  def number
@@ -0,0 +1,97 @@
1
+ # Haml Spec #
2
+
3
+ Haml Spec provides a basic suite of tests for Haml interpreters.
4
+
5
+ It is intented for developers who are creating or maintaining an implementation
6
+ of the [Haml](http://haml-lang.com) markup language.
7
+
8
+ At the moment, there are test runners for the [original Haml](http://github.com/nex3/haml)
9
+ in Ruby, and for [Lua Haml](http://github.com/norman/lua-haml). Support for
10
+ other versions of Haml will be added if their developers/maintainers
11
+ are interested in using it.
12
+
13
+ ## The Tests ##
14
+
15
+ The tests are kept in JSON format for portability across languages. Each test
16
+ is a JSON object with expected input, output, local variables and configuration
17
+ parameters (see below). The test suite only provides tests for features which
18
+ are portable, therefore no tests for script are provided, nor for external
19
+ filters such as :markdown or :textile.
20
+
21
+ The one major exception to this are the tests for interpolation, which you may
22
+ need to modify with a regular expression to run under PHP or Perl, which
23
+ require a symbol before variable names. These tests are included despite being
24
+ less than 100% portable because interpolation is an important part of Haml and
25
+ can be tricky to implement.
26
+
27
+ ## Running the Tests ##
28
+
29
+ ### Ruby ###
30
+
31
+ In order to make it as easy as possible for non-Ruby programmers to run the
32
+ Ruby Haml tests, the Ruby test runner uses test/unit, rather than something
33
+ fancier like Rspec. To run them you probably only need to install `haml`, and
34
+ possibly `ruby` if your platform doesn't come with it by default. If you're
35
+ using Ruby 1.8.x, you'll also need to install `json`:
36
+
37
+ sudo gem install haml
38
+ # for Ruby 1.8.x; check using "ruby --version" if unsure
39
+ sudo gem install json
40
+
41
+ Then, running the Ruby test suite is easy:
42
+
43
+ ruby ruby_haml_test.rb
44
+
45
+ ### Lua ###
46
+
47
+ The Lua test depends on [Telescope](http://telescope.luaforge.net/),
48
+ [jason4lua](http://json.luaforge.net/), and
49
+ [Lua Haml](http://github.com/norman/lua-haml). Install and
50
+ run `tsc lua_haml_spec.lua`.
51
+
52
+ ## Contributing ##
53
+
54
+ ### Getting it ###
55
+
56
+ You can access the [Git repository](http://github.com/norman/haml-spec) at:
57
+
58
+ git://github.com/norman/haml-spec.git
59
+
60
+ Patches are *very* welcome, as are test runners for your Haml implementation.
61
+
62
+ As long as any test you add run against Ruby Haml and are not redundant, I'll
63
+ be very happy to add them.
64
+
65
+ ### Test JSON format ###
66
+
67
+ "test name" : {
68
+ "haml" : "haml input",
69
+ "html" : "expected html output",
70
+ "result" : "expected test result",
71
+ "locals" : "local vars",
72
+ "config" : "config params"
73
+ }
74
+
75
+ * test name: This should be a *very* brief description of what's being tested. It can
76
+ be used by the test runners to name test methods, or to exclude certain tests from being
77
+ run.
78
+ * haml: The Haml code to be evaluated. Always required.
79
+ * html: The HTML output that should be generated. Required unless "result" is "error".
80
+ * result: Can be "pass" or "error". If it's absent, then "pass" is assumed. If it's "error",
81
+ then the goal of the test is to make sure that malformed Haml code generates an error.
82
+ * locals: An object containing local variables needed for the test.
83
+ * config: An object containing configuration parameters used to run the test.
84
+ The configuration parameters should be usable directly by Ruby's Haml with no
85
+ modification. If your implementation uses config parameters with different
86
+ names, you may need to process them to make them match your implementation.
87
+ If your implementation has options that do not exist in Ruby's Haml, then you
88
+ should add tests for this in your implementation's test rather than here.
89
+
90
+ ## License ##
91
+
92
+ This project is released under the [WTFPL](http://sam.zoy.org/wtfpl/) in order
93
+ to be as usable as possible in any project, commercial or free.
94
+
95
+ ## Author ##
96
+
97
+ [Norman Clarke](mailto:norman@njclarke.com)
@@ -0,0 +1,30 @@
1
+ require 'luarocks.require'
2
+ require 'json'
3
+ require 'telescope'
4
+ require 'haml'
5
+
6
+ local function get_tests(filename)
7
+ local self = debug.getinfo(1).short_src
8
+ if self:match("/") then return "./" .. self:gsub("[^/]*%.lua$", "/" .. filename)
9
+ elseif self:match("\\") then return self:gsub("[^\\]*%.lua$", "\\" .. filename)
10
+ else return filename
11
+ end
12
+ end
13
+
14
+ local fh = assert(io.open(get_tests("tests.json")))
15
+ local input = fh:read '*a'
16
+ fh:close()
17
+
18
+ local contexts = json.decode(input)
19
+
20
+ describe("LuaHaml", function()
21
+ for context, expectations in pairs(contexts) do
22
+ describe("When handling " .. context, function()
23
+ for name, exp in pairs(expectations) do
24
+ it(string.format("should correctly render %s", name), function()
25
+ assert_equal(haml.render(exp.haml, exp.config or {}, exp.locals or {}), exp.html)
26
+ end)
27
+ end
28
+ end)
29
+ end
30
+ end)
@@ -0,0 +1,19 @@
1
+ require "test/unit"
2
+ require "json"
3
+ require "haml"
4
+
5
+ class HamlTest < Test::Unit::TestCase
6
+ contexts = JSON.parse(File.read(File.dirname(__FILE__) + "/tests.json"))
7
+ contexts.each do |context|
8
+ context[1].each do |name, test|
9
+ class_eval(<<-EOTEST)
10
+ def test_#{name.gsub(/\s+|[^a-zA-Z0-9_]/, "_")}
11
+ locals = Hash[*(#{test}["locals"] || {}).collect {|k, v| [k.to_sym, v] }.flatten]
12
+ options = Hash[*(#{test}["config"] || {}).collect {|k, v| [k.to_sym, v.to_sym] }.flatten]
13
+ engine = Haml::Engine.new(#{test}["haml"], options)
14
+ assert_equal(engine.render(Object.new, locals).chomp, #{test}["html"])
15
+ end
16
+ EOTEST
17
+ end
18
+ end
19
+ end