haml-more 0.4.0.a

Sign up to get free protection for your applications and to get access to all the features.
Files changed (225) hide show
  1. data/README.md +79 -0
  2. data/lib/haml/more/coffee_script.rb +137 -0
  3. data/lib/haml/more/content_for.rb +25 -0
  4. data/lib/haml/more.rb +45 -0
  5. data/lib/haml-more.rb +1 -0
  6. data/lib/sass/more.rb +16 -0
  7. data/lib/sass-more.rb +1 -0
  8. data/spec/sass/more_spec.rb +21 -0
  9. data/vendor/coffee-script/Cakefile +57 -0
  10. data/vendor/coffee-script/LICENSE +22 -0
  11. data/vendor/coffee-script/README +41 -0
  12. data/vendor/coffee-script/Rakefile +20 -0
  13. data/vendor/coffee-script/bin/cake +7 -0
  14. data/vendor/coffee-script/bin/coffee +7 -0
  15. data/vendor/coffee-script/documentation/coffee/aliases.coffee +9 -0
  16. data/vendor/coffee-script/documentation/coffee/arguments.coffee +4 -0
  17. data/vendor/coffee-script/documentation/coffee/array_comprehensions.coffee +7 -0
  18. data/vendor/coffee-script/documentation/coffee/assignment.coffee +2 -0
  19. data/vendor/coffee-script/documentation/coffee/cake_tasks.coffee +5 -0
  20. data/vendor/coffee-script/documentation/coffee/comparisons.coffee +5 -0
  21. data/vendor/coffee-script/documentation/coffee/conditionals.coffee +9 -0
  22. data/vendor/coffee-script/documentation/coffee/embedded.coffee +5 -0
  23. data/vendor/coffee-script/documentation/coffee/existence.coffee +8 -0
  24. data/vendor/coffee-script/documentation/coffee/expressions.coffee +9 -0
  25. data/vendor/coffee-script/documentation/coffee/expressions_assignment.coffee +1 -0
  26. data/vendor/coffee-script/documentation/coffee/expressions_comprehension.coffee +3 -0
  27. data/vendor/coffee-script/documentation/coffee/expressions_try.coffee +6 -0
  28. data/vendor/coffee-script/documentation/coffee/fat_arrow.coffee +6 -0
  29. data/vendor/coffee-script/documentation/coffee/functions.coffee +2 -0
  30. data/vendor/coffee-script/documentation/coffee/heredocs.coffee +5 -0
  31. data/vendor/coffee-script/documentation/coffee/multiple_return_values.coffee +5 -0
  32. data/vendor/coffee-script/documentation/coffee/object_comprehensions.coffee +4 -0
  33. data/vendor/coffee-script/documentation/coffee/object_extraction.coffee +13 -0
  34. data/vendor/coffee-script/documentation/coffee/objects_and_arrays.coffee +13 -0
  35. data/vendor/coffee-script/documentation/coffee/overview.coffee +29 -0
  36. data/vendor/coffee-script/documentation/coffee/parallel_assignment.coffee +4 -0
  37. data/vendor/coffee-script/documentation/coffee/range_comprehensions.coffee +6 -0
  38. data/vendor/coffee-script/documentation/coffee/scope.coffee +5 -0
  39. data/vendor/coffee-script/documentation/coffee/slices.coffee +6 -0
  40. data/vendor/coffee-script/documentation/coffee/soaks.coffee +1 -0
  41. data/vendor/coffee-script/documentation/coffee/splats.coffee +25 -0
  42. data/vendor/coffee-script/documentation/coffee/splices.coffee +5 -0
  43. data/vendor/coffee-script/documentation/coffee/strings.coffee +8 -0
  44. data/vendor/coffee-script/documentation/coffee/super.coffee +34 -0
  45. data/vendor/coffee-script/documentation/coffee/switch.coffee +10 -0
  46. data/vendor/coffee-script/documentation/coffee/try.coffee +7 -0
  47. data/vendor/coffee-script/documentation/coffee/while.coffee +10 -0
  48. data/vendor/coffee-script/documentation/css/docs.css +213 -0
  49. data/vendor/coffee-script/documentation/css/idle.css +63 -0
  50. data/vendor/coffee-script/documentation/css/logo.png +0 -0
  51. data/vendor/coffee-script/documentation/index.html.erb +967 -0
  52. data/vendor/coffee-script/documentation/js/aliases.js +14 -0
  53. data/vendor/coffee-script/documentation/js/arguments.js +8 -0
  54. data/vendor/coffee-script/documentation/js/array_comprehensions.js +26 -0
  55. data/vendor/coffee-script/documentation/js/assignment.js +5 -0
  56. data/vendor/coffee-script/documentation/js/cake_tasks.js +14 -0
  57. data/vendor/coffee-script/documentation/js/comparisons.js +5 -0
  58. data/vendor/coffee-script/documentation/js/conditionals.js +12 -0
  59. data/vendor/coffee-script/documentation/js/embedded.js +6 -0
  60. data/vendor/coffee-script/documentation/js/existence.js +7 -0
  61. data/vendor/coffee-script/documentation/js/expressions.js +13 -0
  62. data/vendor/coffee-script/documentation/js/expressions_assignment.js +4 -0
  63. data/vendor/coffee-script/documentation/js/expressions_comprehension.js +12 -0
  64. data/vendor/coffee-script/documentation/js/expressions_try.js +9 -0
  65. data/vendor/coffee-script/documentation/js/fat_arrow.js +15 -0
  66. data/vendor/coffee-script/documentation/js/functions.js +9 -0
  67. data/vendor/coffee-script/documentation/js/heredocs.js +4 -0
  68. data/vendor/coffee-script/documentation/js/intro.js +7 -0
  69. data/vendor/coffee-script/documentation/js/multiple_return_values.js +11 -0
  70. data/vendor/coffee-script/documentation/js/object_comprehensions.js +17 -0
  71. data/vendor/coffee-script/documentation/js/object_extraction.js +17 -0
  72. data/vendor/coffee-script/documentation/js/objects_and_arrays.js +10 -0
  73. data/vendor/coffee-script/documentation/js/overview.js +43 -0
  74. data/vendor/coffee-script/documentation/js/parallel_assignment.js +8 -0
  75. data/vendor/coffee-script/documentation/js/punctuation.js +8 -0
  76. data/vendor/coffee-script/documentation/js/range_comprehensions.js +21 -0
  77. data/vendor/coffee-script/documentation/js/scope.js +10 -0
  78. data/vendor/coffee-script/documentation/js/slices.js +6 -0
  79. data/vendor/coffee-script/documentation/js/soaks.js +4 -0
  80. data/vendor/coffee-script/documentation/js/splats.js +16 -0
  81. data/vendor/coffee-script/documentation/js/splices.js +5 -0
  82. data/vendor/coffee-script/documentation/js/strings.js +9 -0
  83. data/vendor/coffee-script/documentation/js/super.js +37 -0
  84. data/vendor/coffee-script/documentation/js/switch.js +18 -0
  85. data/vendor/coffee-script/documentation/js/try.js +10 -0
  86. data/vendor/coffee-script/documentation/js/while.js +22 -0
  87. data/vendor/coffee-script/documentation/underscore.html +627 -0
  88. data/vendor/coffee-script/examples/beautiful_code/binary_search.coffee +16 -0
  89. data/vendor/coffee-script/examples/beautiful_code/quicksort_runtime.coffee +13 -0
  90. data/vendor/coffee-script/examples/beautiful_code/regular_expression_matcher.coffee +34 -0
  91. data/vendor/coffee-script/examples/blocks.coffee +57 -0
  92. data/vendor/coffee-script/examples/code.coffee +173 -0
  93. data/vendor/coffee-script/examples/computer_science/README +4 -0
  94. data/vendor/coffee-script/examples/computer_science/binary_search.coffee +25 -0
  95. data/vendor/coffee-script/examples/computer_science/bubble_sort.coffee +11 -0
  96. data/vendor/coffee-script/examples/computer_science/linked_list.coffee +106 -0
  97. data/vendor/coffee-script/examples/computer_science/luhn_algorithm.coffee +36 -0
  98. data/vendor/coffee-script/examples/computer_science/merge_sort.coffee +19 -0
  99. data/vendor/coffee-script/examples/computer_science/selection_sort.coffee +23 -0
  100. data/vendor/coffee-script/examples/poignant.coffee +186 -0
  101. data/vendor/coffee-script/examples/potion.coffee +205 -0
  102. data/vendor/coffee-script/examples/underscore.coffee +603 -0
  103. data/vendor/coffee-script/examples/web_server.coffee +12 -0
  104. data/vendor/coffee-script/extras/CoffeeScript.tmbundle/Preferences/CoffeeScript.tmPreferences +24 -0
  105. data/vendor/coffee-script/extras/CoffeeScript.tmbundle/Syntaxes/CoffeeScript.tmLanguage +361 -0
  106. data/vendor/coffee-script/extras/CoffeeScript.tmbundle/info.plist +10 -0
  107. data/vendor/coffee-script/extras/EXTRAS +20 -0
  108. data/vendor/coffee-script/extras/coffee.vim +117 -0
  109. data/vendor/coffee-script/index.html +1847 -0
  110. data/vendor/coffee-script/lib/bin/cake +7 -0
  111. data/vendor/coffee-script/lib/bin/coffee +7 -0
  112. data/vendor/coffee-script/lib/cake.js +80 -0
  113. data/vendor/coffee-script/lib/coffee-script.js +61 -0
  114. data/vendor/coffee-script/lib/command_line.js +201 -0
  115. data/vendor/coffee-script/lib/grammar.js +564 -0
  116. data/vendor/coffee-script/lib/lexer.js +405 -0
  117. data/vendor/coffee-script/lib/narwhal.js +44 -0
  118. data/vendor/coffee-script/lib/nodes.js +1328 -0
  119. data/vendor/coffee-script/lib/optparse.js +117 -0
  120. data/vendor/coffee-script/lib/parser.js +536 -0
  121. data/vendor/coffee-script/lib/repl.js +32 -0
  122. data/vendor/coffee-script/lib/rewriter.js +383 -0
  123. data/vendor/coffee-script/lib/scope.js +114 -0
  124. data/vendor/coffee-script/package.json +7 -0
  125. data/vendor/coffee-script/src/cake.coffee +45 -0
  126. data/vendor/coffee-script/src/coffee-script.coffee +45 -0
  127. data/vendor/coffee-script/src/command_line.coffee +130 -0
  128. data/vendor/coffee-script/src/grammar.coffee +456 -0
  129. data/vendor/coffee-script/src/lexer.coffee +327 -0
  130. data/vendor/coffee-script/src/narwhal.coffee +42 -0
  131. data/vendor/coffee-script/src/nodes.coffee +1045 -0
  132. data/vendor/coffee-script/src/optparse.coffee +79 -0
  133. data/vendor/coffee-script/src/repl.coffee +23 -0
  134. data/vendor/coffee-script/src/rewriter.coffee +253 -0
  135. data/vendor/coffee-script/src/scope.coffee +75 -0
  136. data/vendor/coffee-script/test/test_arguments.coffee +34 -0
  137. data/vendor/coffee-script/test/test_array_comprehension.coffee +42 -0
  138. data/vendor/coffee-script/test/test_assignment.coffee +26 -0
  139. data/vendor/coffee-script/test/test_blocks.coffee +4 -0
  140. data/vendor/coffee-script/test/test_calling_super.coffee +42 -0
  141. data/vendor/coffee-script/test/test_chained_calls.coffee +25 -0
  142. data/vendor/coffee-script/test/test_destructuring_assignment.coffee +62 -0
  143. data/vendor/coffee-script/test/test_everything.coffee +29 -0
  144. data/vendor/coffee-script/test/test_exceptions.coffee +2 -0
  145. data/vendor/coffee-script/test/test_existence.coffee +81 -0
  146. data/vendor/coffee-script/test/test_expressions.coffee +30 -0
  147. data/vendor/coffee-script/test/test_fancy_if_statement.coffee +26 -0
  148. data/vendor/coffee-script/test/test_functions.coffee +80 -0
  149. data/vendor/coffee-script/test/test_funky_comments.coffee +25 -0
  150. data/vendor/coffee-script/test/test_heredocs.coffee +46 -0
  151. data/vendor/coffee-script/test/test_lexical_scope.coffee +10 -0
  152. data/vendor/coffee-script/test/test_literals.coffee +56 -0
  153. data/vendor/coffee-script/test/test_nested_comprehensions.coffee +11 -0
  154. data/vendor/coffee-script/test/test_newline_escaping.coffee +6 -0
  155. data/vendor/coffee-script/test/test_operations.coffee +18 -0
  156. data/vendor/coffee-script/test/test_range_comprehension.coffee +20 -0
  157. data/vendor/coffee-script/test/test_ranges_and_slices.coffee +16 -0
  158. data/vendor/coffee-script/test/test_splats.coffee +47 -0
  159. data/vendor/coffee-script/test/test_splices.coffee +5 -0
  160. data/vendor/coffee-script/test/test_switch.coffee +64 -0
  161. data/vendor/coffee-script/test/test_while.coffee +30 -0
  162. data/vendor/coffee-script/vendor/jison/Jakefile +31 -0
  163. data/vendor/coffee-script/vendor/jison/README.md +347 -0
  164. data/vendor/coffee-script/vendor/jison/bin/jison +3 -0
  165. data/vendor/coffee-script/vendor/jison/bin/json2jison +3 -0
  166. data/vendor/coffee-script/vendor/jison/examples/ansic.jison +415 -0
  167. data/vendor/coffee-script/vendor/jison/examples/basic.json +8 -0
  168. data/vendor/coffee-script/vendor/jison/examples/basic2.json +9 -0
  169. data/vendor/coffee-script/vendor/jison/examples/basic2_lex.json +16 -0
  170. data/vendor/coffee-script/vendor/jison/examples/basic_lex.json +15 -0
  171. data/vendor/coffee-script/vendor/jison/examples/calculator.jison +38 -0
  172. data/vendor/coffee-script/vendor/jison/examples/calculator.jisonlex +14 -0
  173. data/vendor/coffee-script/vendor/jison/examples/calculator.json +42 -0
  174. data/vendor/coffee-script/vendor/jison/examples/classy.json +105 -0
  175. data/vendor/coffee-script/vendor/jison/examples/classy_ast.json +126 -0
  176. data/vendor/coffee-script/vendor/jison/examples/dism.json +25 -0
  177. data/vendor/coffee-script/vendor/jison/examples/dism_lr0.json +26 -0
  178. data/vendor/coffee-script/vendor/jison/examples/json.js +80 -0
  179. data/vendor/coffee-script/vendor/jison/examples/json_ast.js +83 -0
  180. data/vendor/coffee-script/vendor/jison/examples/precedence.json +26 -0
  181. data/vendor/coffee-script/vendor/jison/examples/reduce_conflict.json +13 -0
  182. data/vendor/coffee-script/vendor/jison/lib/jison/bnf.js +43 -0
  183. data/vendor/coffee-script/vendor/jison/lib/jison/jisonlex.js +18 -0
  184. data/vendor/coffee-script/vendor/jison/lib/jison/json2jison.js +146 -0
  185. data/vendor/coffee-script/vendor/jison/lib/jison/lexer.js +224 -0
  186. data/vendor/coffee-script/vendor/jison/lib/jison/util/bnf-parser.js +383 -0
  187. data/vendor/coffee-script/vendor/jison/lib/jison/util/lex-parser.js +407 -0
  188. data/vendor/coffee-script/vendor/jison/lib/jison/util/set.js +94 -0
  189. data/vendor/coffee-script/vendor/jison/lib/jison/util/typal.js +90 -0
  190. data/vendor/coffee-script/vendor/jison/lib/jison.js +1414 -0
  191. data/vendor/coffee-script/vendor/jison/package.json +14 -0
  192. data/vendor/coffee-script/vendor/jison/src/bnf.jison +110 -0
  193. data/vendor/coffee-script/vendor/jison/src/bnf.jisonlex +25 -0
  194. data/vendor/coffee-script/vendor/jison/src/bnf.lex.json +24 -0
  195. data/vendor/coffee-script/vendor/jison/src/jisonlex.jison +129 -0
  196. data/vendor/coffee-script/vendor/jison/src/jisonlex.jisonlex +31 -0
  197. data/vendor/coffee-script/vendor/jison/src/jisonlex.lex.json +30 -0
  198. data/vendor/coffee-script/vendor/jison/tests/all-tests.js +8 -0
  199. data/vendor/coffee-script/vendor/jison/tests/grammar/bnf.js +91 -0
  200. data/vendor/coffee-script/vendor/jison/tests/grammar/bnf_parse.js +65 -0
  201. data/vendor/coffee-script/vendor/jison/tests/grammar/grammar-tests.js +10 -0
  202. data/vendor/coffee-script/vendor/jison/tests/grammar/json2jison.js +24 -0
  203. data/vendor/coffee-script/vendor/jison/tests/grammar/lex/ansic.jisonlex +115 -0
  204. data/vendor/coffee-script/vendor/jison/tests/grammar/lex/bnf.jisonlex +25 -0
  205. data/vendor/coffee-script/vendor/jison/tests/grammar/lex/bnf.lex.json +24 -0
  206. data/vendor/coffee-script/vendor/jison/tests/grammar/lex/lex_grammar.jisonlex +31 -0
  207. data/vendor/coffee-script/vendor/jison/tests/grammar/lex/lex_grammar.lex.json +30 -0
  208. data/vendor/coffee-script/vendor/jison/tests/grammar/lex.jison +119 -0
  209. data/vendor/coffee-script/vendor/jison/tests/grammar/lex.js +58 -0
  210. data/vendor/coffee-script/vendor/jison/tests/grammar/lex_parse.js +117 -0
  211. data/vendor/coffee-script/vendor/jison/tests/lexer/lexer-tests.js +6 -0
  212. data/vendor/coffee-script/vendor/jison/tests/lexer/regexplexer.js +417 -0
  213. data/vendor/coffee-script/vendor/jison/tests/parser/actions.js +311 -0
  214. data/vendor/coffee-script/vendor/jison/tests/parser/api.js +236 -0
  215. data/vendor/coffee-script/vendor/jison/tests/parser/generator.js +196 -0
  216. data/vendor/coffee-script/vendor/jison/tests/parser/lalr.js +183 -0
  217. data/vendor/coffee-script/vendor/jison/tests/parser/lr0.js +72 -0
  218. data/vendor/coffee-script/vendor/jison/tests/parser/lr1.js +119 -0
  219. data/vendor/coffee-script/vendor/jison/tests/parser/parser-tests.js +14 -0
  220. data/vendor/coffee-script/vendor/jison/tests/parser/precedence.js +237 -0
  221. data/vendor/coffee-script/vendor/jison/tests/parser/slr.js +52 -0
  222. data/vendor/coffee-script/vendor/jison/tests/parser/tables.js +126 -0
  223. data/vendor/coffee-script/vendor/jison/tests/performance.js +110 -0
  224. data/vendor/coffee-script/vendor/jison/tests/setup.js +3 -0
  225. metadata +324 -0
@@ -0,0 +1,603 @@
1
+
2
+ # Underscore.coffee
3
+ # (c) 2010 Jeremy Ashkenas, DocumentCloud Inc.
4
+ # Underscore is freely distributable under the terms of the MIT license.
5
+ # Portions of Underscore are inspired by or borrowed from Prototype.js,
6
+ # Oliver Steele's Functional, and John Resig's Micro-Templating.
7
+ # For all details and documentation:
8
+ # http://documentcloud.github.com/underscore/
9
+
10
+
11
+ # ------------------------- Baseline setup ---------------------------------
12
+
13
+ # Establish the root object, "window" in the browser, or "global" on the server.
14
+ root: this
15
+
16
+
17
+ # Save the previous value of the "_" variable.
18
+ previousUnderscore: root._
19
+
20
+
21
+ # If Underscore is called as a function, it returns a wrapped object that
22
+ # can be used OO-style. This wrapper holds altered versions of all the
23
+ # underscore functions. Wrapped objects may be chained.
24
+ wrapper: (obj) ->
25
+ this._wrapped: obj
26
+ this
27
+
28
+
29
+ # Establish the object that gets thrown to break out of a loop iteration.
30
+ breaker: if typeof(StopIteration) is 'undefined' then '__break__' else StopIteration
31
+
32
+
33
+ # Create a safe reference to the Underscore object forreference below.
34
+ _: root._: (obj) -> new wrapper(obj)
35
+
36
+
37
+ # Export the Underscore object for CommonJS.
38
+ if typeof(exports) != 'undefined' then exports._: _
39
+
40
+
41
+ # Create quick reference variables for speed access to core prototypes.
42
+ slice: Array::slice
43
+ unshift: Array::unshift
44
+ toString: Object::toString
45
+ hasOwnProperty: Object::hasOwnProperty
46
+ propertyIsEnumerable: Object::propertyIsEnumerable
47
+
48
+
49
+ # Current version.
50
+ _.VERSION: '0.5.8'
51
+
52
+
53
+ # ------------------------ Collection Functions: ---------------------------
54
+
55
+ # The cornerstone, an each implementation.
56
+ # Handles objects implementing forEach, arrays, and raw objects.
57
+ _.each: (obj, iterator, context) ->
58
+ index: 0
59
+ try
60
+ return obj.forEach(iterator, context) if obj.forEach
61
+ if _.isNumber(obj.length)
62
+ return iterator.call(context, obj[i], i, obj) for i in [0...obj.length]
63
+ iterator.call(context, val, key, obj) for key, val of obj
64
+ catch e
65
+ throw e if e isnt breaker
66
+ obj
67
+
68
+
69
+ # Return the results of applying the iterator to each element. Use JavaScript
70
+ # 1.6's version of map, if possible.
71
+ _.map: (obj, iterator, context) ->
72
+ return obj.map(iterator, context) if (obj and _.isFunction(obj.map))
73
+ results: []
74
+ _.each obj, (value, index, list) ->
75
+ results.push(iterator.call(context, value, index, list))
76
+ results
77
+
78
+
79
+ # Reduce builds up a single result from a list of values. Also known as
80
+ # inject, or foldl. Uses JavaScript 1.8's version of reduce, if possible.
81
+ _.reduce: (obj, memo, iterator, context) ->
82
+ return obj.reduce(_.bind(iterator, context), memo) if (obj and _.isFunction(obj.reduce))
83
+ _.each obj, (value, index, list) ->
84
+ memo: iterator.call(context, memo, value, index, list)
85
+ memo
86
+
87
+
88
+ # The right-associative version of reduce, also known as foldr. Uses
89
+ # JavaScript 1.8's version of reduceRight, if available.
90
+ _.reduceRight: (obj, memo, iterator, context) ->
91
+ return obj.reduceRight(_.bind(iterator, context), memo) if (obj and _.isFunction(obj.reduceRight))
92
+ _.each _.clone(_.toArray(obj)).reverse(), (value, index) ->
93
+ memo: iterator.call(context, memo, value, index, obj)
94
+ memo
95
+
96
+
97
+ # Return the first value which passes a truth test.
98
+ _.detect: (obj, iterator, context) ->
99
+ result: null
100
+ _.each obj, (value, index, list) ->
101
+ if iterator.call(context, value, index, list)
102
+ result: value
103
+ _.breakLoop()
104
+ result
105
+
106
+
107
+ # Return all the elements that pass a truth test. Use JavaScript 1.6's
108
+ # filter(), if it exists.
109
+ _.select: (obj, iterator, context) ->
110
+ if obj and _.isFunction(obj.filter) then return obj.filter(iterator, context)
111
+ results: []
112
+ _.each obj, (value, index, list) ->
113
+ results.push(value) if iterator.call(context, value, index, list)
114
+ results
115
+
116
+
117
+ # Return all the elements for which a truth test fails.
118
+ _.reject: (obj, iterator, context) ->
119
+ results: []
120
+ _.each obj, (value, index, list) ->
121
+ results.push(value) if not iterator.call(context, value, index, list)
122
+ results
123
+
124
+
125
+ # Determine whether all of the elements match a truth test. Delegate to
126
+ # JavaScript 1.6's every(), if it is present.
127
+ _.all: (obj, iterator, context) ->
128
+ iterator ||= _.identity
129
+ return obj.every(iterator, context) if obj and _.isFunction(obj.every)
130
+ result: true
131
+ _.each obj, (value, index, list) ->
132
+ _.breakLoop() unless (result: result and iterator.call(context, value, index, list))
133
+ result
134
+
135
+
136
+ # Determine if at least one element in the object matches a truth test. Use
137
+ # JavaScript 1.6's some(), if it exists.
138
+ _.any: (obj, iterator, context) ->
139
+ iterator ||= _.identity
140
+ return obj.some(iterator, context) if obj and _.isFunction(obj.some)
141
+ result: false
142
+ _.each obj, (value, index, list) ->
143
+ _.breakLoop() if (result: iterator.call(context, value, index, list))
144
+ result
145
+
146
+
147
+ # Determine if a given value is included in the array or object,
148
+ # based on '==='.
149
+ _.include: (obj, target) ->
150
+ return _.indexOf(obj, target) isnt -1 if obj and _.isFunction(obj.indexOf)
151
+ for key, val of obj
152
+ return true if val is target
153
+ false
154
+
155
+
156
+ # Invoke a method with arguments on every item in a collection.
157
+ _.invoke: (obj, method) ->
158
+ args: _.rest(arguments, 2)
159
+ (if method then val[method] else val).apply(val, args) for val in obj
160
+
161
+
162
+ # Convenience version of a common use case of map: fetching a property.
163
+ _.pluck: (obj, key) ->
164
+ _.map(obj, ((val) -> val[key]))
165
+
166
+
167
+ # Return the maximum item or (item-based computation).
168
+ _.max: (obj, iterator, context) ->
169
+ return Math.max.apply(Math, obj) if not iterator and _.isArray(obj)
170
+ result: {computed: -Infinity}
171
+ _.each obj, (value, index, list) ->
172
+ computed: if iterator then iterator.call(context, value, index, list) else value
173
+ computed >= result.computed and (result: {value: value, computed: computed})
174
+ result.value
175
+
176
+
177
+ # Return the minimum element (or element-based computation).
178
+ _.min: (obj, iterator, context) ->
179
+ return Math.min.apply(Math, obj) if not iterator and _.isArray(obj)
180
+ result: {computed: Infinity}
181
+ _.each obj, (value, index, list) ->
182
+ computed: if iterator then iterator.call(context, value, index, list) else value
183
+ computed < result.computed and (result: {value: value, computed: computed})
184
+ result.value
185
+
186
+
187
+ # Sort the object's values by a criteria produced by an iterator.
188
+ _.sortBy: (obj, iterator, context) ->
189
+ _.pluck(((_.map obj, (value, index, list) ->
190
+ {value: value, criteria: iterator.call(context, value, index, list)}
191
+ ).sort((left, right) ->
192
+ a: left.criteria; b: right.criteria
193
+ if a < b then -1 else if a > b then 1 else 0
194
+ )), 'value')
195
+
196
+
197
+ # Use a comparator function to figure out at what index an object should
198
+ # be inserted so as to maintain order. Uses binary search.
199
+ _.sortedIndex: (array, obj, iterator) ->
200
+ iterator ||= _.identity
201
+ low: 0; high: array.length
202
+ while low < high
203
+ mid: (low + high) >> 1
204
+ if iterator(array[mid]) < iterator(obj) then low: mid + 1 else high: mid
205
+ low
206
+
207
+
208
+ # Convert anything iterable into a real, live array.
209
+ _.toArray: (iterable) ->
210
+ return [] if (!iterable)
211
+ return iterable.toArray() if (iterable.toArray)
212
+ return iterable if (_.isArray(iterable))
213
+ return slice.call(iterable) if (_.isArguments(iterable))
214
+ _.values(iterable)
215
+
216
+
217
+ # Return the number of elements in an object.
218
+ _.size: (obj) -> _.toArray(obj).length
219
+
220
+
221
+ # -------------------------- Array Functions: ------------------------------
222
+
223
+ # Get the first element of an array. Passing "n" will return the first N
224
+ # values in the array. Aliased as "head". The "guard" check allows it to work
225
+ # with _.map.
226
+ _.first: (array, n, guard) ->
227
+ if n and not guard then slice.call(array, 0, n) else array[0]
228
+
229
+
230
+ # Returns everything but the first entry of the array. Aliased as "tail".
231
+ # Especially useful on the arguments object. Passing an "index" will return
232
+ # the rest of the values in the array from that index onward. The "guard"
233
+ # check allows it to work with _.map.
234
+ _.rest: (array, index, guard) ->
235
+ slice.call(array, if _.isUndefined(index) or guard then 1 else index)
236
+
237
+
238
+ # Get the last element of an array.
239
+ _.last: (array) -> array[array.length - 1]
240
+
241
+
242
+ # Trim out all falsy values from an array.
243
+ _.compact: (array) -> item for item in array when item
244
+
245
+
246
+ # Return a completely flattened version of an array.
247
+ _.flatten: (array) ->
248
+ _.reduce array, [], (memo, value) ->
249
+ return memo.concat(_.flatten(value)) if _.isArray(value)
250
+ memo.push(value)
251
+ memo
252
+
253
+
254
+ # Return a version of the array that does not contain the specified value(s).
255
+ _.without: (array) ->
256
+ values: _.rest(arguments)
257
+ val for val in _.toArray(array) when not _.include(values, val)
258
+
259
+
260
+ # Produce a duplicate-free version of the array. If the array has already
261
+ # been sorted, you have the option of using a faster algorithm.
262
+ _.uniq: (array, isSorted) ->
263
+ memo: []
264
+ for el, i in _.toArray(array)
265
+ memo.push(el) if i is 0 || (if isSorted is true then _.last(memo) isnt el else not _.include(memo, el))
266
+ memo
267
+
268
+
269
+ # Produce an array that contains every item shared between all the
270
+ # passed-in arrays.
271
+ _.intersect: (array) ->
272
+ rest: _.rest(arguments)
273
+ _.select _.uniq(array), (item) ->
274
+ _.all rest, (other) ->
275
+ _.indexOf(other, item) >= 0
276
+
277
+
278
+ # Zip together multiple lists into a single array -- elements that share
279
+ # an index go together.
280
+ _.zip: ->
281
+ length: _.max(_.pluck(arguments, 'length'))
282
+ results: new Array(length)
283
+ for i in [0...length]
284
+ results[i]: _.pluck(arguments, String(i))
285
+ results
286
+
287
+
288
+ # If the browser doesn't supply us with indexOf (I'm looking at you, MSIE),
289
+ # we need this function. Return the position of the first occurence of an
290
+ # item in an array, or -1 if the item is not included in the array.
291
+ _.indexOf: (array, item) ->
292
+ return array.indexOf(item) if array.indexOf
293
+ i: 0; l: array.length
294
+ while l - i
295
+ if array[i] is item then return i else i++
296
+ -1
297
+
298
+
299
+ # Provide JavaScript 1.6's lastIndexOf, delegating to the native function,
300
+ # if possible.
301
+ _.lastIndexOf: (array, item) ->
302
+ return array.lastIndexOf(item) if array.lastIndexOf
303
+ i: array.length
304
+ while i
305
+ if array[i] is item then return i else i--
306
+ -1
307
+
308
+
309
+ # Generate an integer Array containing an arithmetic progression. A port of
310
+ # the native Python range() function. See:
311
+ # http://docs.python.org/library/functions.html#range
312
+ _.range: (start, stop, step) ->
313
+ a: arguments
314
+ solo: a.length <= 1
315
+ i: start: if solo then 0 else a[0]
316
+ stop: if solo then a[0] else a[1]
317
+ step: a[2] or 1
318
+ len: Math.ceil((stop - start) / step)
319
+ return [] if len <= 0
320
+ range: new Array(len)
321
+ idx: 0
322
+ while true
323
+ return range if (if step > 0 then i - stop else stop - i) >= 0
324
+ range[idx]: i
325
+ idx++
326
+ i+= step
327
+
328
+
329
+ # ----------------------- Function Functions: -----------------------------
330
+
331
+ # Create a function bound to a given object (assigning 'this', and arguments,
332
+ # optionally). Binding with arguments is also known as 'curry'.
333
+ _.bind: (func, obj) ->
334
+ args: _.rest(arguments, 2)
335
+ -> func.apply(obj or root, args.concat(arguments))
336
+
337
+
338
+ # Bind all of an object's methods to that object. Useful for ensuring that
339
+ # all callbacks defined on an object belong to it.
340
+ _.bindAll: (obj) ->
341
+ funcs: if arguments.length > 1 then _.rest(arguments) else _.functions(obj)
342
+ _.each(funcs, (f) -> obj[f]: _.bind(obj[f], obj))
343
+ obj
344
+
345
+
346
+ # Delays a function for the given number of milliseconds, and then calls
347
+ # it with the arguments supplied.
348
+ _.delay: (func, wait) ->
349
+ args: _.rest(arguments, 2)
350
+ setTimeout((-> func.apply(func, args)), wait)
351
+
352
+
353
+ # Defers a function, scheduling it to run after the current call stack has
354
+ # cleared.
355
+ _.defer: (func) ->
356
+ _.delay.apply(_, [func, 1].concat(_.rest(arguments)))
357
+
358
+
359
+ # Returns the first function passed as an argument to the second,
360
+ # allowing you to adjust arguments, run code before and after, and
361
+ # conditionally execute the original function.
362
+ _.wrap: (func, wrapper) ->
363
+ -> wrapper.apply(wrapper, [func].concat(arguments))
364
+
365
+
366
+ # Returns a function that is the composition of a list of functions, each
367
+ # consuming the return value of the function that follows.
368
+ _.compose: ->
369
+ funcs: arguments
370
+ ->
371
+ args: arguments
372
+ for i in [(funcs.length - 1)..0]
373
+ args: [funcs[i].apply(this, args)]
374
+ args[0]
375
+
376
+
377
+ # ------------------------- Object Functions: ----------------------------
378
+
379
+ # Retrieve the names of an object's properties.
380
+ _.keys: (obj) ->
381
+ return _.range(0, obj.length) if _.isArray(obj)
382
+ key for key, val of obj
383
+
384
+
385
+ # Retrieve the values of an object's properties.
386
+ _.values: (obj) ->
387
+ _.map(obj, _.identity)
388
+
389
+
390
+ # Return a sorted list of the function names available in Underscore.
391
+ _.functions: (obj) ->
392
+ _.select(_.keys(obj), (key) -> _.isFunction(obj[key])).sort()
393
+
394
+
395
+ # Extend a given object with all of the properties in a source object.
396
+ _.extend: (destination, source) ->
397
+ for key, val of source
398
+ destination[key]: val
399
+ destination
400
+
401
+
402
+ # Create a (shallow-cloned) duplicate of an object.
403
+ _.clone: (obj) ->
404
+ return obj.slice(0) if _.isArray(obj)
405
+ _.extend({}, obj)
406
+
407
+
408
+ # Invokes interceptor with the obj, and then returns obj.
409
+ # The primary purpose of this method is to "tap into" a method chain, in order to perform operations on intermediate results within the chain.
410
+ _.tap: (obj, interceptor) ->
411
+ interceptor(obj)
412
+ obj
413
+
414
+
415
+ # Perform a deep comparison to check if two objects are equal.
416
+ _.isEqual: (a, b) ->
417
+ # Check object identity.
418
+ return true if a is b
419
+ # Different types?
420
+ atype: typeof(a); btype: typeof(b)
421
+ return false if atype isnt btype
422
+ # Basic equality test (watch out for coercions).
423
+ return true if `a == b`
424
+ # One is falsy and the other truthy.
425
+ return false if (!a and b) or (a and !b)
426
+ # One of them implements an isEqual()?
427
+ return a.isEqual(b) if a.isEqual
428
+ # Check dates' integer values.
429
+ return a.getTime() is b.getTime() if _.isDate(a) and _.isDate(b)
430
+ # Both are NaN?
431
+ return true if _.isNaN(a) and _.isNaN(b)
432
+ # Compare regular expressions.
433
+ if _.isRegExp(a) and _.isRegExp(b)
434
+ return a.source is b.source and
435
+ a.global is b.global and
436
+ a.ignoreCase is b.ignoreCase and
437
+ a.multiline is b.multiline
438
+ # If a is not an object by this point, we can't handle it.
439
+ return false if atype isnt 'object'
440
+ # Check for different array lengths before comparing contents.
441
+ return false if a.length and (a.length isnt b.length)
442
+ # Nothing else worked, deep compare the contents.
443
+ aKeys: _.keys(a); bKeys: _.keys(b)
444
+ # Different object sizes?
445
+ return false if aKeys.length isnt bKeys.length
446
+ # Recursive comparison of contents.
447
+ # for (var key in a) if (!_.isEqual(a[key], b[key])) return false;
448
+ return true
449
+
450
+
451
+ # Is a given array or object empty?
452
+ _.isEmpty: (obj) -> _.keys(obj).length is 0
453
+
454
+
455
+ # Is a given value a DOM element?
456
+ _.isElement: (obj) -> obj and obj.nodeType is 1
457
+
458
+
459
+ # Is a given value an array?
460
+ _.isArray: (obj) -> !!(obj and obj.concat and obj.unshift)
461
+
462
+
463
+ # Is a given variable an arguments object?
464
+ _.isArguments: (obj) -> obj and _.isNumber(obj.length) and not obj.concat and
465
+ not obj.substr and not obj.apply and not propertyIsEnumerable.call(obj, 'length')
466
+
467
+
468
+ # Is the given value a function?
469
+ _.isFunction: (obj) -> !!(obj and obj.constructor and obj.call and obj.apply)
470
+
471
+
472
+ # Is the given value a string?
473
+ _.isString: (obj) -> !!(obj is '' or (obj and obj.charCodeAt and obj.substr))
474
+
475
+
476
+ # Is a given value a number?
477
+ _.isNumber: (obj) -> (obj is +obj) or toString.call(obj) is '[object Number]'
478
+
479
+
480
+ # Is a given value a Date?
481
+ _.isDate: (obj) -> !!(obj and obj.getTimezoneOffset and obj.setUTCFullYear)
482
+
483
+
484
+ # Is the given value a regular expression?
485
+ _.isRegExp: (obj) -> !!(obj and obj.exec and (obj.ignoreCase or obj.ignoreCase is false))
486
+
487
+
488
+ # Is the given value NaN -- this one is interesting. NaN != NaN, and
489
+ # isNaN(undefined) == true, so we make sure it's a number first.
490
+ _.isNaN: (obj) -> _.isNumber(obj) and window.isNaN(obj)
491
+
492
+
493
+ # Is a given value equal to null?
494
+ _.isNull: (obj) -> obj is null
495
+
496
+
497
+ # Is a given variable undefined?
498
+ _.isUndefined: (obj) -> typeof obj is 'undefined'
499
+
500
+
501
+ # -------------------------- Utility Functions: --------------------------
502
+
503
+ # Run Underscore.js in noConflict mode, returning the '_' variable to its
504
+ # previous owner. Returns a reference to the Underscore object.
505
+ _.noConflict: ->
506
+ root._: previousUnderscore
507
+ this
508
+
509
+
510
+ # Keep the identity function around for default iterators.
511
+ _.identity: (value) -> value
512
+
513
+
514
+ # Break out of the middle of an iteration.
515
+ _.breakLoop: -> throw breaker
516
+
517
+
518
+ # Generate a unique integer id (unique within the entire client session).
519
+ # Useful for temporary DOM ids.
520
+ idCounter: 0
521
+ _.uniqueId: (prefix) ->
522
+ (prefix or '') + idCounter++
523
+
524
+
525
+ # By default, Underscore uses ERB-style template delimiters, change the
526
+ # following template settings to use alternative delimiters.
527
+ _.templateSettings: {
528
+ start: '<%'
529
+ end: '%>'
530
+ interpolate: /<%=(.+?)%>/g
531
+ }
532
+
533
+
534
+ # JavaScript templating a-la ERB, pilfered from John Resig's
535
+ # "Secrets of the JavaScript Ninja", page 83.
536
+ # Single-quote fix from Rick Strahl's version.
537
+ _.template: (str, data) ->
538
+ c: _.templateSettings
539
+ fn: new Function 'obj',
540
+ 'var p=[],print=function(){p.push.apply(p,arguments);};' +
541
+ 'with(obj){p.push(\'' +
542
+ str.replace(/[\r\t\n]/g, " ")
543
+ .replace(new RegExp("'(?=[^"+c.end[0]+"]*"+c.end+")","g"),"\t")
544
+ .split("'").join("\\'")
545
+ .split("\t").join("'")
546
+ .replace(c.interpolate, "',$1,'")
547
+ .split(c.start).join("');")
548
+ .split(c.end).join("p.push('") +
549
+ "');}return p.join('');"
550
+ if data then fn(data) else fn
551
+
552
+
553
+ # ------------------------------- Aliases ----------------------------------
554
+
555
+ _.forEach: _.each
556
+ _.foldl: _.inject: _.reduce
557
+ _.foldr: _.reduceRight
558
+ _.filter: _.select
559
+ _.every: _.all
560
+ _.some: _.any
561
+ _.head: _.first
562
+ _.tail: _.rest
563
+ _.methods: _.functions
564
+
565
+
566
+ # ------------------------ Setup the OOP Wrapper: --------------------------
567
+
568
+ # Helper function to continue chaining intermediate results.
569
+ result: (obj, chain) ->
570
+ if chain then _(obj).chain() else obj
571
+
572
+
573
+ # Add all of the Underscore functions to the wrapper object.
574
+ _.each _.functions(_), (name) ->
575
+ method: _[name]
576
+ wrapper.prototype[name]: ->
577
+ unshift.call(arguments, this._wrapped)
578
+ result(method.apply(_, arguments), this._chain)
579
+
580
+
581
+ # Add all mutator Array functions to the wrapper.
582
+ _.each ['pop', 'push', 'reverse', 'shift', 'sort', 'splice', 'unshift'], (name) ->
583
+ method: Array.prototype[name]
584
+ wrapper.prototype[name]: ->
585
+ method.apply(this._wrapped, arguments)
586
+ result(this._wrapped, this._chain)
587
+
588
+
589
+ # Add all accessor Array functions to the wrapper.
590
+ _.each ['concat', 'join', 'slice'], (name) ->
591
+ method: Array.prototype[name]
592
+ wrapper.prototype[name]: ->
593
+ result(method.apply(this._wrapped, arguments), this._chain)
594
+
595
+
596
+ # Start chaining a wrapped Underscore object.
597
+ wrapper::chain: ->
598
+ this._chain: true
599
+ this
600
+
601
+
602
+ # Extracts the result from a wrapped and chained object.
603
+ wrapper::value: -> this._wrapped
@@ -0,0 +1,12 @@
1
+ # Contributed by Jason Huggins
2
+
3
+ http: require 'http'
4
+
5
+ server: http.createServer (req, res) ->
6
+ res.sendHeader 200, {'Content-Type': 'text/plain'}
7
+ res.sendBody 'Hello, World!'
8
+ res.finish()
9
+
10
+ server.listen 3000
11
+
12
+ puts "Server running at http://localhost:3000/"
@@ -0,0 +1,24 @@
1
+ <?xml version="1.0" encoding="UTF-8"?>
2
+ <!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
3
+ <plist version="1.0">
4
+ <dict>
5
+ <key>name</key>
6
+ <string>comments</string>
7
+ <key>scope</key>
8
+ <string>source.coffee</string>
9
+ <key>settings</key>
10
+ <dict>
11
+ <key>shellVariables</key>
12
+ <array>
13
+ <dict>
14
+ <key>name</key>
15
+ <string>TM_COMMENT_START</string>
16
+ <key>value</key>
17
+ <string># </string>
18
+ </dict>
19
+ </array>
20
+ </dict>
21
+ <key>uuid</key>
22
+ <string>0A92C6F6-4D73-4859-B38C-4CC19CBC191F</string>
23
+ </dict>
24
+ </plist>