haml-edge 2.3.149 → 2.3.150

Sign up to get free protection for your applications and to get access to all the features.
Files changed (38) hide show
  1. data/EDGE_GEM_VERSION +1 -1
  2. data/VERSION +1 -1
  3. data/lib/haml/exec.rb +17 -10
  4. data/test/haml/spec/README.md +97 -0
  5. data/test/haml/spec/lua_haml_spec.lua +30 -0
  6. data/test/haml/spec/ruby_haml_test.rb +19 -0
  7. data/test/haml/spec/tests.json +534 -0
  8. data/vendor/fssm/LICENSE +20 -0
  9. data/vendor/fssm/README.markdown +55 -0
  10. data/vendor/fssm/Rakefile +59 -0
  11. data/vendor/fssm/VERSION.yml +5 -0
  12. data/vendor/fssm/example.rb +9 -0
  13. data/vendor/fssm/fssm.gemspec +77 -0
  14. data/vendor/fssm/lib/fssm/backends/fsevents.rb +36 -0
  15. data/vendor/fssm/lib/fssm/backends/inotify.rb +23 -0
  16. data/vendor/fssm/lib/fssm/backends/polling.rb +25 -0
  17. data/vendor/fssm/lib/fssm/backends/rubycocoa/fsevents.rb +131 -0
  18. data/vendor/fssm/lib/fssm/monitor.rb +26 -0
  19. data/vendor/fssm/lib/fssm/path.rb +91 -0
  20. data/vendor/fssm/lib/fssm/pathname.rb +502 -0
  21. data/vendor/fssm/lib/fssm/state/directory.rb +57 -0
  22. data/vendor/fssm/lib/fssm/state/file.rb +24 -0
  23. data/vendor/fssm/lib/fssm/support.rb +60 -0
  24. data/vendor/fssm/lib/fssm/tree.rb +176 -0
  25. data/vendor/fssm/lib/fssm.rb +33 -0
  26. data/vendor/fssm/profile/prof-cache.rb +40 -0
  27. data/vendor/fssm/profile/prof-fssm-pathname.html +1231 -0
  28. data/vendor/fssm/profile/prof-pathname.rb +68 -0
  29. data/vendor/fssm/profile/prof-plain-pathname.html +988 -0
  30. data/vendor/fssm/profile/prof.html +2379 -0
  31. data/vendor/fssm/spec/path_spec.rb +75 -0
  32. data/vendor/fssm/spec/root/duck/quack.txt +0 -0
  33. data/vendor/fssm/spec/root/file.css +0 -0
  34. data/vendor/fssm/spec/root/file.rb +0 -0
  35. data/vendor/fssm/spec/root/file.yml +0 -0
  36. data/vendor/fssm/spec/root/moo/cow.txt +0 -0
  37. data/vendor/fssm/spec/spec_helper.rb +14 -0
  38. metadata +36 -1
data/EDGE_GEM_VERSION CHANGED
@@ -1 +1 @@
1
- 2.3.149
1
+ 2.3.150
data/VERSION CHANGED
@@ -1 +1 @@
1
- 2.3.149
1
+ 2.3.150
data/lib/haml/exec.rb CHANGED
@@ -254,7 +254,8 @@ END
254
254
  # Processes the options set by the command-line arguments,
255
255
  # and runs the Sass compiler appropriately.
256
256
  def process_result
257
- if @args.first && @args.first.include?(':')
257
+ if !@options[:update] && !@options[:watch] &&
258
+ @args.first && @args.first.include?(':')
258
259
  if @args.size == 1
259
260
  @args = @args.first.split(':', 2)
260
261
  else
@@ -303,6 +304,20 @@ END
303
304
  require 'sass/plugin'
304
305
  ::Sass::Plugin.options[:unix_newlines] = @options[:unix_newlines]
305
306
 
307
+ if @args[1] && !@args[0].include?(':')
308
+ flag = @options[:update] ? "--update" : "--watch"
309
+ err =
310
+ if !File.exist?(@args[1])
311
+ "doesn't exist"
312
+ elsif @args[1] =~ /\.css$/
313
+ "is a CSS file"
314
+ end
315
+ raise <<MSG if err
316
+ File #{@args[1]} #{err}.
317
+ Did you mean: sass #{flag} #{@args[0]}:#{@args[1]}
318
+ MSG
319
+ end
320
+
306
321
  dirs, files = @args.map {|name| name.split(':', 2)}.
307
322
  map {|from, to| [from, to || from.gsub(/\..*?$/, '.css')]}.
308
323
  partition {|i, _| File.directory? i}
@@ -319,15 +334,7 @@ END
319
334
  ::Sass::Plugin.on_creating_directory {|dirname| puts_action :directory, :green, dirname}
320
335
  ::Sass::Plugin.on_deleting_css {|filename| puts_action :delete, :yellow, filename}
321
336
  ::Sass::Plugin.on_compilation_error do |error, _, _|
322
- unless error.is_a?(::Sass::SyntaxError)
323
- if error.is_a?(Errno::ENOENT) && error.message =~ /^No such file or directory - (.*)$/ && $1 == @args[1]
324
- flag = @options[:update] ? "--update" : "--watch"
325
- error.message << "\n Did you mean: sass #{flag} #{@args[0]}:#{@args[1]}"
326
- end
327
-
328
- raise error
329
- end
330
-
337
+ raise error unless error.is_a?(::Sass::SyntaxError)
331
338
  puts_action :error, :red, "#{error.sass_filename} (Line #{error.sass_line}: #{error.message})"
332
339
  end
333
340
 
@@ -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