mack 0.8.2 → 0.8.3

Sign up to get free protection for your applications and to get access to all the features.
Files changed (602) hide show
  1. data/CHANGELOG +17 -1
  2. data/bin/env_handler.rb +1 -1
  3. data/bin/mack +2 -2
  4. data/bin/mackery-server +1 -1
  5. data/lib/gems.rb +6 -1
  6. data/lib/gems/builder-2.1.2/lib/blankslate.rb +2 -2
  7. data/lib/gems/builder-2.1.2/lib/builder/xchar.rb +3 -3
  8. data/lib/gems/builder-2.1.2/lib/builder/xmlbase.rb +9 -9
  9. data/lib/gems/builder-2.1.2/lib/builder/xmlmarkup.rb +15 -15
  10. data/lib/gems/configatron-2.2.2/lib/configatron.rb +9 -0
  11. data/lib/gems/{configatron-2.1.5 → configatron-2.2.2}/lib/configatron/configatron.rb +8 -6
  12. data/lib/gems/configatron-2.2.2/lib/configatron/core_ext/class.rb +26 -0
  13. data/lib/gems/{configatron-2.1.5/lib/configatron → configatron-2.2.2/lib/configatron/core_ext}/kernel.rb +0 -0
  14. data/lib/gems/configatron-2.2.2/lib/configatron/core_ext/object.rb +9 -0
  15. data/lib/gems/configatron-2.2.2/lib/configatron/core_ext/string.rb +84 -0
  16. data/lib/gems/configatron-2.2.2/lib/configatron/errors.rb +13 -0
  17. data/lib/gems/{configatron-2.1.5 → configatron-2.2.2}/lib/configatron/store.rb +37 -6
  18. data/lib/gems/cucumber-0.1.15/lib/autotest/cucumber.rb +6 -0
  19. data/lib/gems/cucumber-0.1.15/lib/autotest/cucumber_mixin.rb +130 -0
  20. data/lib/gems/cucumber-0.1.15/lib/autotest/cucumber_rails.rb +6 -0
  21. data/lib/gems/cucumber-0.1.15/lib/autotest/cucumber_rails_rspec.rb +6 -0
  22. data/lib/gems/cucumber-0.1.15/lib/autotest/cucumber_rspec.rb +6 -0
  23. data/lib/gems/cucumber-0.1.15/lib/autotest/discover.rb +9 -0
  24. data/lib/gems/cucumber-0.1.15/lib/cucumber.rb +19 -0
  25. data/lib/gems/cucumber-0.1.15/lib/cucumber/broadcaster.rb +20 -0
  26. data/lib/gems/cucumber-0.1.15/lib/cucumber/cli.rb +360 -0
  27. data/lib/gems/cucumber-0.1.15/lib/cucumber/core_ext/exception.rb +20 -0
  28. data/lib/gems/cucumber-0.1.15/lib/cucumber/core_ext/proc.rb +69 -0
  29. data/lib/gems/cucumber-0.1.15/lib/cucumber/core_ext/string.rb +29 -0
  30. data/lib/gems/cucumber-0.1.15/lib/cucumber/executor.rb +205 -0
  31. data/lib/gems/cucumber-0.1.15/lib/cucumber/formatters.rb +1 -0
  32. data/lib/gems/cucumber-0.1.15/lib/cucumber/formatters/ansicolor.rb +105 -0
  33. data/lib/gems/cucumber-0.1.15/lib/cucumber/formatters/autotest_formatter.rb +23 -0
  34. data/lib/gems/{rspec-1.1.11/story_server/prototype/stylesheets/rspec.css → cucumber-0.1.15/lib/cucumber/formatters/cucumber.css} +33 -37
  35. data/lib/gems/cucumber-0.1.15/lib/cucumber/formatters/cucumber.js +11 -0
  36. data/lib/gems/cucumber-0.1.15/lib/cucumber/formatters/html_formatter.rb +151 -0
  37. data/lib/gems/cucumber-0.1.15/lib/cucumber/formatters/jquery.js +32 -0
  38. data/lib/gems/cucumber-0.1.15/lib/cucumber/formatters/pretty_formatter.rb +285 -0
  39. data/lib/gems/cucumber-0.1.15/lib/cucumber/formatters/profile_formatter.rb +92 -0
  40. data/lib/gems/cucumber-0.1.15/lib/cucumber/formatters/progress_formatter.rb +61 -0
  41. data/lib/gems/cucumber-0.1.15/lib/cucumber/formatters/unicode.rb +35 -0
  42. data/lib/gems/cucumber-0.1.15/lib/cucumber/languages.yml +271 -0
  43. data/lib/gems/cucumber-0.1.15/lib/cucumber/model.rb +1 -0
  44. data/lib/gems/cucumber-0.1.15/lib/cucumber/model/table.rb +28 -0
  45. data/lib/gems/cucumber-0.1.15/lib/cucumber/platform.rb +32 -0
  46. data/lib/gems/cucumber-0.1.15/lib/cucumber/rails/rspec.rb +12 -0
  47. data/lib/gems/cucumber-0.1.15/lib/cucumber/rails/world.rb +73 -0
  48. data/lib/gems/cucumber-0.1.15/lib/cucumber/rake/task.rb +101 -0
  49. data/lib/gems/cucumber-0.1.15/lib/cucumber/step_methods.rb +49 -0
  50. data/lib/gems/cucumber-0.1.15/lib/cucumber/step_mother.rb +98 -0
  51. data/lib/gems/cucumber-0.1.15/lib/cucumber/tree.rb +16 -0
  52. data/lib/gems/cucumber-0.1.15/lib/cucumber/tree/feature.rb +89 -0
  53. data/lib/gems/cucumber-0.1.15/lib/cucumber/tree/features.rb +21 -0
  54. data/lib/gems/cucumber-0.1.15/lib/cucumber/tree/given_scenario.rb +13 -0
  55. data/lib/gems/cucumber-0.1.15/lib/cucumber/tree/scenario.rb +236 -0
  56. data/lib/gems/cucumber-0.1.15/lib/cucumber/tree/step.rb +173 -0
  57. data/lib/gems/cucumber-0.1.15/lib/cucumber/tree/table.rb +26 -0
  58. data/lib/gems/cucumber-0.1.15/lib/cucumber/tree/top_down_visitor.rb +23 -0
  59. data/lib/gems/cucumber-0.1.15/lib/cucumber/treetop_parser/feature.treetop.erb +254 -0
  60. data/lib/gems/cucumber-0.1.15/lib/cucumber/treetop_parser/feature_ar.rb +1951 -0
  61. data/lib/gems/cucumber-0.1.15/lib/cucumber/treetop_parser/feature_cy.rb +1951 -0
  62. data/lib/gems/cucumber-0.1.15/lib/cucumber/treetop_parser/feature_da.rb +1951 -0
  63. data/lib/gems/cucumber-0.1.15/lib/cucumber/treetop_parser/feature_de.rb +1951 -0
  64. data/lib/gems/cucumber-0.1.15/lib/cucumber/treetop_parser/feature_en-lol.rb +1951 -0
  65. data/lib/gems/cucumber-0.1.15/lib/cucumber/treetop_parser/feature_en-tx.rb +1951 -0
  66. data/lib/gems/cucumber-0.1.15/lib/cucumber/treetop_parser/feature_en.rb +1951 -0
  67. data/lib/gems/cucumber-0.1.15/lib/cucumber/treetop_parser/feature_es.rb +1951 -0
  68. data/lib/gems/cucumber-0.1.15/lib/cucumber/treetop_parser/feature_et.rb +1951 -0
  69. data/lib/gems/cucumber-0.1.15/lib/cucumber/treetop_parser/feature_fr.rb +1951 -0
  70. data/lib/gems/cucumber-0.1.15/lib/cucumber/treetop_parser/feature_id.rb +1951 -0
  71. data/lib/gems/cucumber-0.1.15/lib/cucumber/treetop_parser/feature_it.rb +1951 -0
  72. data/lib/gems/cucumber-0.1.15/lib/cucumber/treetop_parser/feature_ja.rb +1951 -0
  73. data/lib/gems/cucumber-0.1.15/lib/cucumber/treetop_parser/feature_ko.rb +1951 -0
  74. data/lib/gems/cucumber-0.1.15/lib/cucumber/treetop_parser/feature_lt.rb +1951 -0
  75. data/lib/gems/cucumber-0.1.15/lib/cucumber/treetop_parser/feature_nl.rb +1951 -0
  76. data/lib/gems/cucumber-0.1.15/lib/cucumber/treetop_parser/feature_no.rb +1951 -0
  77. data/lib/gems/cucumber-0.1.15/lib/cucumber/treetop_parser/feature_parser.rb +36 -0
  78. data/lib/gems/cucumber-0.1.15/lib/cucumber/treetop_parser/feature_pl.rb +1951 -0
  79. data/lib/gems/cucumber-0.1.15/lib/cucumber/treetop_parser/feature_pt.rb +1951 -0
  80. data/lib/gems/cucumber-0.1.15/lib/cucumber/treetop_parser/feature_ro.rb +1951 -0
  81. data/lib/gems/cucumber-0.1.15/lib/cucumber/treetop_parser/feature_ro2.rb +1951 -0
  82. data/lib/gems/cucumber-0.1.15/lib/cucumber/treetop_parser/feature_ru.rb +1951 -0
  83. data/lib/gems/cucumber-0.1.15/lib/cucumber/treetop_parser/feature_se.rb +1951 -0
  84. data/lib/gems/cucumber-0.1.15/lib/cucumber/treetop_parser/feature_zh-CN.rb +1951 -0
  85. data/lib/gems/cucumber-0.1.15/lib/cucumber/version.rb +10 -0
  86. data/lib/gems/cucumber-0.1.15/lib/cucumber/world.rb +1 -0
  87. data/lib/gems/cucumber-0.1.15/lib/cucumber/world/pending.rb +22 -0
  88. data/lib/gems/diff-lcs-1.1.2/lib/diff/lcs.rb +1105 -0
  89. data/lib/gems/diff-lcs-1.1.2/lib/diff/lcs/array.rb +21 -0
  90. data/lib/gems/diff-lcs-1.1.2/lib/diff/lcs/block.rb +51 -0
  91. data/lib/gems/diff-lcs-1.1.2/lib/diff/lcs/callbacks.rb +322 -0
  92. data/lib/gems/diff-lcs-1.1.2/lib/diff/lcs/change.rb +169 -0
  93. data/lib/gems/diff-lcs-1.1.2/lib/diff/lcs/hunk.rb +257 -0
  94. data/lib/gems/diff-lcs-1.1.2/lib/diff/lcs/ldiff.rb +226 -0
  95. data/lib/gems/diff-lcs-1.1.2/lib/diff/lcs/string.rb +19 -0
  96. data/lib/gems/polyglot-0.2.3/lib/polyglot.rb +62 -0
  97. data/lib/gems/polyglot-0.2.3/lib/polyglot/version.rb +9 -0
  98. data/lib/gems/{rack-0.4.0 → rack-0.9.1}/lib/rack.rb +7 -2
  99. data/lib/gems/{rack-0.4.0 → rack-0.9.1}/lib/rack/adapter/camping.rb +1 -1
  100. data/lib/gems/{rack-0.4.0 → rack-0.9.1}/lib/rack/auth/abstract/handler.rb +0 -0
  101. data/lib/gems/{rack-0.4.0 → rack-0.9.1}/lib/rack/auth/abstract/request.rb +0 -0
  102. data/lib/gems/{rack-0.4.0 → rack-0.9.1}/lib/rack/auth/basic.rb +0 -0
  103. data/lib/gems/{rack-0.4.0 → rack-0.9.1}/lib/rack/auth/digest/md5.rb +0 -0
  104. data/lib/gems/{rack-0.4.0 → rack-0.9.1}/lib/rack/auth/digest/nonce.rb +0 -0
  105. data/lib/gems/{rack-0.4.0 → rack-0.9.1}/lib/rack/auth/digest/params.rb +0 -0
  106. data/lib/gems/{rack-0.4.0 → rack-0.9.1}/lib/rack/auth/digest/request.rb +0 -0
  107. data/lib/gems/{rack-0.4.0 → rack-0.9.1}/lib/rack/auth/openid.rb +4 -3
  108. data/lib/gems/{rack-0.4.0 → rack-0.9.1}/lib/rack/builder.rb +12 -1
  109. data/lib/gems/{rack-0.4.0 → rack-0.9.1}/lib/rack/cascade.rb +0 -0
  110. data/lib/gems/{rack-0.4.0 → rack-0.9.1}/lib/rack/commonlogger.rb +0 -0
  111. data/lib/gems/rack-0.9.1/lib/rack/conditionalget.rb +43 -0
  112. data/lib/gems/rack-0.9.1/lib/rack/content_length.rb +25 -0
  113. data/lib/gems/rack-0.9.1/lib/rack/deflater.rb +87 -0
  114. data/lib/gems/rack-0.9.1/lib/rack/directory.rb +150 -0
  115. data/lib/gems/rack-0.9.1/lib/rack/file.rb +85 -0
  116. data/lib/gems/{rack-0.4.0 → rack-0.9.1}/lib/rack/handler.rb +4 -0
  117. data/lib/gems/{rack-0.4.0 → rack-0.9.1}/lib/rack/handler/cgi.rb +0 -0
  118. data/lib/gems/{rack-0.4.0 → rack-0.9.1}/lib/rack/handler/evented_mongrel.rb +1 -1
  119. data/lib/gems/{rack-0.4.0 → rack-0.9.1}/lib/rack/handler/fastcgi.rb +2 -0
  120. data/lib/gems/{rack-0.4.0 → rack-0.9.1}/lib/rack/handler/lsws.rb +0 -0
  121. data/lib/gems/{rack-0.4.0 → rack-0.9.1}/lib/rack/handler/mongrel.rb +6 -2
  122. data/lib/gems/{rack-0.4.0 → rack-0.9.1}/lib/rack/handler/scgi.rb +0 -0
  123. data/lib/gems/rack-0.9.1/lib/rack/handler/swiftiplied_mongrel.rb +8 -0
  124. data/lib/gems/rack-0.9.1/lib/rack/handler/thin.rb +15 -0
  125. data/lib/gems/{rack-0.4.0 → rack-0.9.1}/lib/rack/handler/webrick.rb +8 -4
  126. data/lib/gems/rack-0.9.1/lib/rack/head.rb +19 -0
  127. data/lib/gems/{rack-0.4.0 → rack-0.9.1}/lib/rack/lint.rb +74 -10
  128. data/lib/gems/{rack-0.4.0 → rack-0.9.1}/lib/rack/lobster.rb +13 -13
  129. data/lib/gems/rack-0.9.1/lib/rack/methodoverride.rb +27 -0
  130. data/lib/gems/rack-0.9.1/lib/rack/mime.rb +204 -0
  131. data/lib/gems/{rack-0.4.0 → rack-0.9.1}/lib/rack/mock.rb +0 -0
  132. data/lib/gems/{rack-0.4.0 → rack-0.9.1}/lib/rack/recursive.rb +0 -0
  133. data/lib/gems/{rack-0.4.0 → rack-0.9.1}/lib/rack/reloader.rb +0 -0
  134. data/lib/gems/{rack-0.4.0 → rack-0.9.1}/lib/rack/request.rb +10 -1
  135. data/lib/gems/{rack-0.4.0 → rack-0.9.1}/lib/rack/response.rb +7 -2
  136. data/lib/gems/{rack-0.4.0 → rack-0.9.1}/lib/rack/session/abstract/id.rb +14 -1
  137. data/lib/gems/{rack-0.4.0 → rack-0.9.1}/lib/rack/session/cookie.rb +19 -1
  138. data/lib/gems/{rack-0.4.0 → rack-0.9.1}/lib/rack/session/memcache.rb +1 -1
  139. data/lib/gems/{rack-0.4.0 → rack-0.9.1}/lib/rack/session/pool.rb +1 -1
  140. data/lib/gems/{rack-0.4.0 → rack-0.9.1}/lib/rack/showexceptions.rb +5 -1
  141. data/lib/gems/{rack-0.4.0 → rack-0.9.1}/lib/rack/showstatus.rb +3 -2
  142. data/lib/gems/{rack-0.4.0 → rack-0.9.1}/lib/rack/static.rb +0 -0
  143. data/lib/gems/{rack-0.4.0 → rack-0.9.1}/lib/rack/urlmap.rb +1 -1
  144. data/lib/gems/{rack-0.4.0 → rack-0.9.1}/lib/rack/utils.rb +42 -13
  145. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/bin/autospec +0 -0
  146. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/bin/spec +0 -0
  147. data/lib/gems/{rspec-1.1.11/plugins → rspec-1.1.12/lib/adapters}/mock_frameworks/flexmock.rb +1 -1
  148. data/lib/gems/{rspec-1.1.11/plugins → rspec-1.1.12/lib/adapters}/mock_frameworks/mocha.rb +1 -1
  149. data/lib/gems/{rspec-1.1.11/plugins → rspec-1.1.12/lib/adapters}/mock_frameworks/rr.rb +1 -1
  150. data/lib/gems/{rspec-1.1.11/plugins → rspec-1.1.12/lib/adapters}/mock_frameworks/rspec.rb +2 -2
  151. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/lib/autotest/discover.rb +0 -0
  152. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/lib/autotest/rspec.rb +4 -3
  153. data/lib/gems/rspec-1.1.12/lib/spec.rb +7 -0
  154. data/lib/gems/rspec-1.1.12/lib/spec/dsl.rb +1 -0
  155. data/lib/gems/{rspec-1.1.11/lib/spec/extensions → rspec-1.1.12/lib/spec/dsl}/main.rb +10 -10
  156. data/lib/gems/rspec-1.1.12/lib/spec/example.rb +186 -0
  157. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/lib/spec/example/before_and_after_hooks.rb +30 -24
  158. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/lib/spec/example/errors.rb +0 -0
  159. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/lib/spec/example/example_group.rb +1 -0
  160. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/lib/spec/example/example_group_factory.rb +26 -9
  161. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/lib/spec/example/example_group_methods.rb +138 -113
  162. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/lib/spec/example/example_matcher.rb +0 -0
  163. data/lib/gems/rspec-1.1.12/lib/spec/example/example_methods.rb +168 -0
  164. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/lib/spec/example/module_reopening_fix.rb +0 -0
  165. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/lib/spec/example/pending.rb +0 -0
  166. data/lib/gems/rspec-1.1.12/lib/spec/example/shared_example_group.rb +59 -0
  167. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/lib/spec/expectations.rb +22 -18
  168. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/lib/spec/expectations/differs/default.rb +0 -0
  169. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/lib/spec/expectations/errors.rb +0 -0
  170. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/lib/spec/expectations/extensions.rb +0 -0
  171. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/lib/spec/expectations/extensions/object.rb +0 -0
  172. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/lib/spec/expectations/extensions/string_and_symbol.rb +0 -0
  173. data/lib/gems/rspec-1.1.12/lib/spec/expectations/handler.rb +32 -0
  174. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/lib/spec/interop/test.rb +0 -0
  175. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/lib/spec/interop/test/unit/autorunner.rb +0 -0
  176. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/lib/spec/interop/test/unit/testcase.rb +19 -17
  177. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/lib/spec/interop/test/unit/testresult.rb +1 -1
  178. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/lib/spec/interop/test/unit/testsuite_adapter.rb +1 -1
  179. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/lib/spec/interop/test/unit/ui/console/testrunner.rb +0 -0
  180. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/lib/spec/matchers.rb +7 -28
  181. data/lib/gems/rspec-1.1.12/lib/spec/matchers/be.rb +208 -0
  182. data/lib/gems/rspec-1.1.12/lib/spec/matchers/be_close.rb +21 -0
  183. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/lib/spec/matchers/change.rb +0 -0
  184. data/lib/gems/rspec-1.1.12/lib/spec/matchers/eql.rb +25 -0
  185. data/lib/gems/rspec-1.1.12/lib/spec/matchers/equal.rb +25 -0
  186. data/lib/gems/rspec-1.1.12/lib/spec/matchers/errors.rb +5 -0
  187. data/lib/gems/rspec-1.1.12/lib/spec/matchers/exist.rb +16 -0
  188. data/lib/gems/rspec-1.1.12/lib/spec/matchers/generated_descriptions.rb +48 -0
  189. data/lib/gems/rspec-1.1.12/lib/spec/matchers/has.rb +18 -0
  190. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/lib/spec/matchers/have.rb +0 -0
  191. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/lib/spec/matchers/include.rb +12 -9
  192. data/lib/gems/rspec-1.1.12/lib/spec/matchers/match.rb +22 -0
  193. data/lib/gems/rspec-1.1.12/lib/spec/matchers/match_array.rb +79 -0
  194. data/lib/gems/rspec-1.1.12/lib/spec/matchers/method_missing.rb +9 -0
  195. data/lib/gems/rspec-1.1.12/lib/spec/matchers/operator_matcher.rb +70 -0
  196. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/lib/spec/matchers/raise_error.rb +4 -8
  197. data/lib/gems/rspec-1.1.12/lib/spec/matchers/respond_to.rb +71 -0
  198. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/lib/spec/matchers/satisfy.rb +0 -0
  199. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/lib/spec/matchers/simple_matcher.rb +0 -0
  200. data/lib/gems/rspec-1.1.12/lib/spec/matchers/throw_symbol.rb +106 -0
  201. data/lib/gems/rspec-1.1.12/lib/spec/matchers/wrap_expectation.rb +55 -0
  202. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/lib/spec/mocks.rb +0 -0
  203. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/lib/spec/mocks/argument_constraints.rb +77 -5
  204. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/lib/spec/mocks/argument_expectation.rb +0 -0
  205. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/lib/spec/mocks/error_generator.rb +0 -0
  206. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/lib/spec/mocks/errors.rb +0 -0
  207. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/lib/spec/mocks/extensions.rb +0 -0
  208. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/lib/spec/mocks/extensions/object.rb +0 -0
  209. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/lib/spec/mocks/framework.rb +0 -0
  210. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/lib/spec/mocks/message_expectation.rb +7 -7
  211. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/lib/spec/mocks/methods.rb +0 -0
  212. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/lib/spec/mocks/mock.rb +0 -0
  213. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/lib/spec/mocks/order_group.rb +0 -0
  214. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/lib/spec/mocks/proxy.rb +14 -12
  215. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/lib/spec/mocks/space.rb +0 -0
  216. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/lib/spec/mocks/spec_methods.rb +0 -0
  217. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/lib/spec/rake/spectask.rb +4 -6
  218. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/lib/spec/rake/verify_rcov.rb +0 -0
  219. data/lib/gems/rspec-1.1.12/lib/spec/ruby.rb +9 -0
  220. data/lib/gems/rspec-1.1.12/lib/spec/runner.rb +88 -0
  221. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/lib/spec/runner/backtrace_tweaker.rb +5 -3
  222. data/lib/gems/rspec-1.1.12/lib/spec/runner/class_and_arguments_parser.rb +14 -0
  223. data/lib/gems/rspec-1.1.12/lib/spec/runner/command_line.rb +15 -0
  224. data/lib/gems/{rspec-1.1.11/lib/spec/example → rspec-1.1.12/lib/spec/runner}/configuration.rb +46 -47
  225. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/lib/spec/runner/drb_command_line.rb +0 -0
  226. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/lib/spec/runner/example_group_runner.rb +15 -4
  227. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/lib/spec/runner/formatter/base_formatter.rb +0 -0
  228. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/lib/spec/runner/formatter/base_text_formatter.rb +4 -3
  229. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/lib/spec/runner/formatter/failing_example_groups_formatter.rb +0 -0
  230. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/lib/spec/runner/formatter/failing_examples_formatter.rb +0 -0
  231. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/lib/spec/runner/formatter/html_formatter.rb +14 -11
  232. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/lib/spec/runner/formatter/nested_text_formatter.rb +2 -2
  233. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/lib/spec/runner/formatter/profile_formatter.rb +0 -0
  234. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/lib/spec/runner/formatter/progress_bar_formatter.rb +0 -0
  235. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/lib/spec/runner/formatter/snippet_extractor.rb +0 -0
  236. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/lib/spec/runner/formatter/specdoc_formatter.rb +0 -0
  237. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/lib/spec/runner/formatter/story/html_formatter.rb +0 -0
  238. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/lib/spec/runner/formatter/story/plain_text_formatter.rb +0 -0
  239. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/lib/spec/runner/formatter/story/progress_bar_formatter.rb +0 -0
  240. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/lib/spec/runner/formatter/text_mate_formatter.rb +0 -0
  241. data/lib/gems/rspec-1.1.12/lib/spec/runner/heckle_runner.rb +74 -0
  242. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/lib/spec/runner/heckle_runner_unsupported.rb +0 -0
  243. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/lib/spec/runner/option_parser.rb +8 -4
  244. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/lib/spec/runner/options.rb +29 -14
  245. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/lib/spec/runner/reporter.rb +1 -1
  246. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/lib/spec/runner/spec_parser.rb +11 -9
  247. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/lib/spec/story.rb +0 -0
  248. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/lib/spec/story/extensions.rb +0 -0
  249. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/lib/spec/story/extensions/main.rb +0 -0
  250. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/lib/spec/story/extensions/regexp.rb +0 -0
  251. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/lib/spec/story/extensions/string.rb +0 -0
  252. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/lib/spec/story/given_scenario.rb +0 -0
  253. data/lib/gems/rspec-1.1.12/lib/spec/story/runner.rb +57 -0
  254. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/lib/spec/story/runner/plain_text_story_runner.rb +0 -0
  255. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/lib/spec/story/runner/scenario_collector.rb +0 -0
  256. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/lib/spec/story/runner/scenario_runner.rb +0 -0
  257. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/lib/spec/story/runner/story_mediator.rb +0 -0
  258. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/lib/spec/story/runner/story_parser.rb +0 -0
  259. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/lib/spec/story/runner/story_runner.rb +10 -6
  260. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/lib/spec/story/scenario.rb +0 -0
  261. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/lib/spec/story/step.rb +0 -0
  262. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/lib/spec/story/step_group.rb +0 -0
  263. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/lib/spec/story/step_mother.rb +0 -0
  264. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/lib/spec/story/story.rb +0 -0
  265. data/lib/gems/rspec-1.1.12/lib/spec/story/world.rb +124 -0
  266. data/lib/gems/{rspec-1.1.11 → rspec-1.1.12}/lib/spec/version.rb +4 -2
  267. data/lib/gems/rubyforge-1.0.1/lib/rubyforge.rb +475 -0
  268. data/lib/gems/rubyforge-1.0.1/lib/rubyforge/client.rb +134 -0
  269. data/lib/gems/rubyforge-1.0.1/lib/rubyforge/cookie_manager.rb +51 -0
  270. data/lib/gems/term-ansicolor-1.0.3/VERSION +1 -0
  271. data/lib/gems/term-ansicolor-1.0.3/lib/term/ansicolor.rb +220 -0
  272. data/lib/gems/{rspec-1.1.11/spec/spec/runner/empty_file.txt → treetop-1.2.4/lib/metagrammar.rb} +0 -0
  273. data/lib/gems/treetop-1.2.4/lib/treetop.rb +11 -0
  274. data/lib/gems/treetop-1.2.4/lib/treetop/bootstrap_gen_1_metagrammar.rb +45 -0
  275. data/lib/gems/treetop-1.2.4/lib/treetop/compiler.rb +6 -0
  276. data/lib/gems/treetop-1.2.4/lib/treetop/compiler/grammar_compiler.rb +40 -0
  277. data/lib/gems/treetop-1.2.4/lib/treetop/compiler/lexical_address_space.rb +17 -0
  278. data/lib/gems/treetop-1.2.4/lib/treetop/compiler/metagrammar.rb +2887 -0
  279. data/lib/gems/treetop-1.2.4/lib/treetop/compiler/metagrammar.treetop +404 -0
  280. data/lib/gems/treetop-1.2.4/lib/treetop/compiler/node_classes.rb +19 -0
  281. data/lib/gems/treetop-1.2.4/lib/treetop/compiler/node_classes/anything_symbol.rb +18 -0
  282. data/lib/gems/treetop-1.2.4/lib/treetop/compiler/node_classes/atomic_expression.rb +14 -0
  283. data/lib/gems/treetop-1.2.4/lib/treetop/compiler/node_classes/character_class.rb +19 -0
  284. data/lib/gems/treetop-1.2.4/lib/treetop/compiler/node_classes/choice.rb +31 -0
  285. data/lib/gems/treetop-1.2.4/lib/treetop/compiler/node_classes/declaration_sequence.rb +24 -0
  286. data/lib/gems/treetop-1.2.4/lib/treetop/compiler/node_classes/grammar.rb +28 -0
  287. data/lib/gems/treetop-1.2.4/lib/treetop/compiler/node_classes/inline_module.rb +27 -0
  288. data/lib/gems/treetop-1.2.4/lib/treetop/compiler/node_classes/nonterminal.rb +13 -0
  289. data/lib/gems/treetop-1.2.4/lib/treetop/compiler/node_classes/optional.rb +19 -0
  290. data/lib/gems/treetop-1.2.4/lib/treetop/compiler/node_classes/parenthesized_expression.rb +9 -0
  291. data/lib/gems/treetop-1.2.4/lib/treetop/compiler/node_classes/parsing_expression.rb +138 -0
  292. data/lib/gems/treetop-1.2.4/lib/treetop/compiler/node_classes/parsing_rule.rb +55 -0
  293. data/lib/gems/treetop-1.2.4/lib/treetop/compiler/node_classes/predicate.rb +45 -0
  294. data/lib/gems/treetop-1.2.4/lib/treetop/compiler/node_classes/repetition.rb +55 -0
  295. data/lib/gems/treetop-1.2.4/lib/treetop/compiler/node_classes/sequence.rb +68 -0
  296. data/lib/gems/treetop-1.2.4/lib/treetop/compiler/node_classes/terminal.rb +20 -0
  297. data/lib/gems/treetop-1.2.4/lib/treetop/compiler/node_classes/transient_prefix.rb +9 -0
  298. data/lib/gems/treetop-1.2.4/lib/treetop/compiler/node_classes/treetop_file.rb +9 -0
  299. data/lib/gems/treetop-1.2.4/lib/treetop/compiler/ruby_builder.rb +113 -0
  300. data/lib/gems/treetop-1.2.4/lib/treetop/ruby_extensions.rb +2 -0
  301. data/lib/gems/treetop-1.2.4/lib/treetop/ruby_extensions/string.rb +42 -0
  302. data/lib/gems/treetop-1.2.4/lib/treetop/runtime.rb +5 -0
  303. data/lib/gems/treetop-1.2.4/lib/treetop/runtime/compiled_parser.rb +87 -0
  304. data/lib/gems/treetop-1.2.4/lib/treetop/runtime/interval_skip_list.rb +4 -0
  305. data/lib/gems/treetop-1.2.4/lib/treetop/runtime/interval_skip_list/head_node.rb +15 -0
  306. data/lib/gems/treetop-1.2.4/lib/treetop/runtime/interval_skip_list/interval_skip_list.rb +200 -0
  307. data/lib/gems/treetop-1.2.4/lib/treetop/runtime/interval_skip_list/node.rb +164 -0
  308. data/lib/gems/treetop-1.2.4/lib/treetop/runtime/syntax_node.rb +72 -0
  309. data/lib/gems/treetop-1.2.4/lib/treetop/runtime/terminal_parse_failure.rb +16 -0
  310. data/lib/gems/treetop-1.2.4/lib/treetop/runtime/terminal_syntax_node.rb +17 -0
  311. data/lib/mack/application.rb +5 -5
  312. data/lib/mack/boot/configuration.rb +3 -1
  313. data/lib/mack/boot/console.rb +2 -2
  314. data/lib/mack/boot/core.rb +3 -3
  315. data/lib/mack/boot/environment.rb +1 -1
  316. data/lib/mack/boot/logging.rb +1 -1
  317. data/lib/mack/boot/logging/filter.rb +1 -1
  318. data/lib/mack/boot/paths.rb +34 -30
  319. data/lib/mack/boot/plugins.rb +2 -2
  320. data/lib/mack/controller/controller.rb +2 -2
  321. data/lib/mack/controller/request.rb +32 -32
  322. data/lib/mack/core_extensions/kernel.rb +1 -1
  323. data/lib/mack/generators/controller_generator/controller_generator.rb +14 -4
  324. data/lib/mack/generators/controller_generator/manifest.yml +7 -7
  325. data/lib/mack/generators/controller_generator/templates/test/controllers/rspec.rb.template +1 -1
  326. data/lib/mack/generators/controller_generator/templates/test/controllers/test_case.rb.template +1 -1
  327. data/lib/mack/generators/controller_helper_generator/manifest.yml +6 -6
  328. data/lib/mack/generators/mack_application_generator/mack_application_generator.rb +2 -2
  329. data/lib/mack/generators/mack_application_generator/manifest.yml +57 -54
  330. data/lib/mack/generators/mack_application_generator/templates/config/configatron/default.rb.template +1 -1
  331. data/lib/mack/generators/mack_application_generator/templates/config/database.yml.template +15 -15
  332. data/lib/mack/generators/mack_application_generator/templates/config/initializers/gems.rb.template +4 -1
  333. data/lib/mack/generators/mack_application_generator/templates/test/controllers/default_controller_spec.rb.template +1 -1
  334. data/lib/mack/generators/mack_application_generator/templates/test/controllers/default_controller_test.rb.template +1 -1
  335. data/lib/mack/generators/mack_application_generator/templates/test/spec_helper.rb.template +3 -3
  336. data/lib/mack/generators/mack_application_generator/templates/test/test_helper.rb.template +3 -3
  337. data/lib/mack/generators/passenger_generator/templates/config.ru.template +1 -1
  338. data/lib/mack/generators/view_helper_generator/manifest.yml +6 -6
  339. data/lib/mack/rendering/engine/builder.rb +1 -1
  340. data/lib/mack/routing/route_map.rb +1 -15
  341. data/lib/mack/routing/urls.rb +16 -2
  342. data/lib/mack/runner_helpers/request_logger.rb +1 -1
  343. data/lib/mack/tasks/mack_update_tasks.rake +5 -5
  344. data/lib/mack/tasks/rake_rules.rake +1 -1
  345. data/lib/mack/tasks/test_tasks.rake +2 -2
  346. data/lib/mack/testing/helpers.rb +24 -24
  347. data/lib/mack/testing/rspec.rb +5 -23
  348. data/lib/mack/testing/test_assertions.rb +0 -1
  349. data/lib/mack/utils/ansi/ansi_color.rb +1 -1
  350. data/lib/mack/version.rb +1 -1
  351. data/lib/mack/view/default_form_builder.rb +9 -0
  352. data/lib/mack/view/form_builder.rb +151 -0
  353. data/lib/mack/view_helpers/form_helpers.rb +7 -6
  354. data/lib/mack_core.rb +3 -3
  355. data/lib/mack_tasks.rb +1 -1
  356. metadata +381 -477
  357. data/lib/gems/builder-2.1.2/lib/builder/css.rb +0 -250
  358. data/lib/gems/configatron-2.1.5/lib/configatron.rb +0 -6
  359. data/lib/gems/configatron-2.1.5/lib/configatron/errors.rb +0 -7
  360. data/lib/gems/lockfile-1.4.3/bin/rlock +0 -360
  361. data/lib/gems/lockfile-1.4.3/bin/rlock-1.4.3 +0 -360
  362. data/lib/gems/logging-0.9.4/data/bad_logging_1.rb +0 -13
  363. data/lib/gems/logging-0.9.4/data/bad_logging_2.rb +0 -21
  364. data/lib/gems/logging-0.9.4/data/logging.rb +0 -42
  365. data/lib/gems/logging-0.9.4/data/logging.yaml +0 -63
  366. data/lib/gems/logging-0.9.4/data/simple_logging.rb +0 -13
  367. data/lib/gems/rack-0.4.0/bin/rackup +0 -172
  368. data/lib/gems/rack-0.4.0/lib/rack/deflater.rb +0 -63
  369. data/lib/gems/rack-0.4.0/lib/rack/directory.rb +0 -158
  370. data/lib/gems/rack-0.4.0/lib/rack/file.rb +0 -116
  371. data/lib/gems/rcov-0.8.1.2.0/ext/rcovrt/callsite.c +0 -242
  372. data/lib/gems/rcov-0.8.1.2.0/ext/rcovrt/extconf.rb +0 -11
  373. data/lib/gems/rcov-0.8.1.2.0/ext/rcovrt/rcovrt.c +0 -329
  374. data/lib/gems/rspec-1.1.11/lib/spec.rb +0 -32
  375. data/lib/gems/rspec-1.1.11/lib/spec/adapters.rb +0 -1
  376. data/lib/gems/rspec-1.1.11/lib/spec/adapters/ruby_engine.rb +0 -26
  377. data/lib/gems/rspec-1.1.11/lib/spec/adapters/ruby_engine/mri.rb +0 -8
  378. data/lib/gems/rspec-1.1.11/lib/spec/adapters/ruby_engine/rubinius.rb +0 -8
  379. data/lib/gems/rspec-1.1.11/lib/spec/example.rb +0 -12
  380. data/lib/gems/rspec-1.1.11/lib/spec/example/example_methods.rb +0 -105
  381. data/lib/gems/rspec-1.1.11/lib/spec/example/shared_example_group.rb +0 -52
  382. data/lib/gems/rspec-1.1.11/lib/spec/expectations/handler.rb +0 -52
  383. data/lib/gems/rspec-1.1.11/lib/spec/extensions.rb +0 -4
  384. data/lib/gems/rspec-1.1.11/lib/spec/extensions/class.rb +0 -24
  385. data/lib/gems/rspec-1.1.11/lib/spec/extensions/metaclass.rb +0 -7
  386. data/lib/gems/rspec-1.1.11/lib/spec/extensions/object.rb +0 -6
  387. data/lib/gems/rspec-1.1.11/lib/spec/matchers/be.rb +0 -221
  388. data/lib/gems/rspec-1.1.11/lib/spec/matchers/be_close.rb +0 -37
  389. data/lib/gems/rspec-1.1.11/lib/spec/matchers/eql.rb +0 -43
  390. data/lib/gems/rspec-1.1.11/lib/spec/matchers/equal.rb +0 -43
  391. data/lib/gems/rspec-1.1.11/lib/spec/matchers/exist.rb +0 -22
  392. data/lib/gems/rspec-1.1.11/lib/spec/matchers/has.rb +0 -34
  393. data/lib/gems/rspec-1.1.11/lib/spec/matchers/match.rb +0 -41
  394. data/lib/gems/rspec-1.1.11/lib/spec/matchers/operator_matcher.rb +0 -79
  395. data/lib/gems/rspec-1.1.11/lib/spec/matchers/respond_to.rb +0 -46
  396. data/lib/gems/rspec-1.1.11/lib/spec/matchers/throw_symbol.rb +0 -74
  397. data/lib/gems/rspec-1.1.11/lib/spec/runner.rb +0 -213
  398. data/lib/gems/rspec-1.1.11/lib/spec/runner/class_and_arguments_parser.rb +0 -16
  399. data/lib/gems/rspec-1.1.11/lib/spec/runner/command_line.rb +0 -17
  400. data/lib/gems/rspec-1.1.11/lib/spec/runner/heckle_runner.rb +0 -72
  401. data/lib/gems/rspec-1.1.11/lib/spec/story/runner.rb +0 -59
  402. data/lib/gems/rspec-1.1.11/lib/spec/story/world.rb +0 -128
  403. data/lib/gems/rspec-1.1.11/rake_tasks/examples.rake +0 -7
  404. data/lib/gems/rspec-1.1.11/rake_tasks/examples_with_rcov.rake +0 -9
  405. data/lib/gems/rspec-1.1.11/rake_tasks/failing_examples_with_html.rake +0 -9
  406. data/lib/gems/rspec-1.1.11/rake_tasks/verify_rcov.rake +0 -7
  407. data/lib/gems/rspec-1.1.11/spec/README.jruby +0 -15
  408. data/lib/gems/rspec-1.1.11/spec/autotest/autotest_helper.rb +0 -6
  409. data/lib/gems/rspec-1.1.11/spec/autotest/autotest_matchers.rb +0 -47
  410. data/lib/gems/rspec-1.1.11/spec/autotest/discover_spec.rb +0 -19
  411. data/lib/gems/rspec-1.1.11/spec/autotest/rspec_spec.rb +0 -150
  412. data/lib/gems/rspec-1.1.11/spec/rspec_suite.rb +0 -6
  413. data/lib/gems/rspec-1.1.11/spec/ruby_forker.rb +0 -13
  414. data/lib/gems/rspec-1.1.11/spec/spec.opts +0 -6
  415. data/lib/gems/rspec-1.1.11/spec/spec/adapters/ruby_engine_spec.rb +0 -16
  416. data/lib/gems/rspec-1.1.11/spec/spec/example/configuration_spec.rb +0 -296
  417. data/lib/gems/rspec-1.1.11/spec/spec/example/example_group_class_definition_spec.rb +0 -48
  418. data/lib/gems/rspec-1.1.11/spec/spec/example/example_group_factory_spec.rb +0 -165
  419. data/lib/gems/rspec-1.1.11/spec/spec/example/example_group_methods_spec.rb +0 -584
  420. data/lib/gems/rspec-1.1.11/spec/spec/example/example_group_spec.rb +0 -683
  421. data/lib/gems/rspec-1.1.11/spec/spec/example/example_matcher_spec.rb +0 -96
  422. data/lib/gems/rspec-1.1.11/spec/spec/example/example_methods_spec.rb +0 -169
  423. data/lib/gems/rspec-1.1.11/spec/spec/example/example_runner_spec.rb +0 -194
  424. data/lib/gems/rspec-1.1.11/spec/spec/example/nested_example_group_spec.rb +0 -71
  425. data/lib/gems/rspec-1.1.11/spec/spec/example/pending_module_spec.rb +0 -145
  426. data/lib/gems/rspec-1.1.11/spec/spec/example/predicate_matcher_spec.rb +0 -21
  427. data/lib/gems/rspec-1.1.11/spec/spec/example/shared_example_group_spec.rb +0 -281
  428. data/lib/gems/rspec-1.1.11/spec/spec/example/subclassing_example_group_spec.rb +0 -25
  429. data/lib/gems/rspec-1.1.11/spec/spec/expectations/differs/default_spec.rb +0 -127
  430. data/lib/gems/rspec-1.1.11/spec/spec/expectations/extensions/object_spec.rb +0 -95
  431. data/lib/gems/rspec-1.1.11/spec/spec/expectations/fail_with_spec.rb +0 -71
  432. data/lib/gems/rspec-1.1.11/spec/spec/extensions/main_spec.rb +0 -71
  433. data/lib/gems/rspec-1.1.11/spec/spec/interop/test/unit/resources/spec_that_fails.rb +0 -10
  434. data/lib/gems/rspec-1.1.11/spec/spec/interop/test/unit/resources/spec_that_passes.rb +0 -10
  435. data/lib/gems/rspec-1.1.11/spec/spec/interop/test/unit/resources/spec_with_errors.rb +0 -10
  436. data/lib/gems/rspec-1.1.11/spec/spec/interop/test/unit/resources/spec_with_options_hash.rb +0 -13
  437. data/lib/gems/rspec-1.1.11/spec/spec/interop/test/unit/resources/test_case_that_fails.rb +0 -10
  438. data/lib/gems/rspec-1.1.11/spec/spec/interop/test/unit/resources/test_case_that_passes.rb +0 -10
  439. data/lib/gems/rspec-1.1.11/spec/spec/interop/test/unit/resources/test_case_with_errors.rb +0 -10
  440. data/lib/gems/rspec-1.1.11/spec/spec/interop/test/unit/resources/testsuite_adapter_spec_with_test_unit.rb +0 -38
  441. data/lib/gems/rspec-1.1.11/spec/spec/interop/test/unit/spec_spec.rb +0 -52
  442. data/lib/gems/rspec-1.1.11/spec/spec/interop/test/unit/test_unit_spec_helper.rb +0 -14
  443. data/lib/gems/rspec-1.1.11/spec/spec/interop/test/unit/testcase_spec.rb +0 -49
  444. data/lib/gems/rspec-1.1.11/spec/spec/interop/test/unit/testsuite_adapter_spec.rb +0 -9
  445. data/lib/gems/rspec-1.1.11/spec/spec/matchers/be_close_spec.rb +0 -39
  446. data/lib/gems/rspec-1.1.11/spec/spec/matchers/be_spec.rb +0 -248
  447. data/lib/gems/rspec-1.1.11/spec/spec/matchers/change_spec.rb +0 -329
  448. data/lib/gems/rspec-1.1.11/spec/spec/matchers/description_generation_spec.rb +0 -153
  449. data/lib/gems/rspec-1.1.11/spec/spec/matchers/eql_spec.rb +0 -28
  450. data/lib/gems/rspec-1.1.11/spec/spec/matchers/equal_spec.rb +0 -28
  451. data/lib/gems/rspec-1.1.11/spec/spec/matchers/exist_spec.rb +0 -57
  452. data/lib/gems/rspec-1.1.11/spec/spec/matchers/handler_spec.rb +0 -150
  453. data/lib/gems/rspec-1.1.11/spec/spec/matchers/has_spec.rb +0 -63
  454. data/lib/gems/rspec-1.1.11/spec/spec/matchers/have_spec.rb +0 -394
  455. data/lib/gems/rspec-1.1.11/spec/spec/matchers/include_spec.rb +0 -64
  456. data/lib/gems/rspec-1.1.11/spec/spec/matchers/match_spec.rb +0 -37
  457. data/lib/gems/rspec-1.1.11/spec/spec/matchers/matcher_methods_spec.rb +0 -78
  458. data/lib/gems/rspec-1.1.11/spec/spec/matchers/mock_constraint_matchers_spec.rb +0 -24
  459. data/lib/gems/rspec-1.1.11/spec/spec/matchers/operator_matcher_spec.rb +0 -191
  460. data/lib/gems/rspec-1.1.11/spec/spec/matchers/raise_error_spec.rb +0 -315
  461. data/lib/gems/rspec-1.1.11/spec/spec/matchers/respond_to_spec.rb +0 -54
  462. data/lib/gems/rspec-1.1.11/spec/spec/matchers/satisfy_spec.rb +0 -36
  463. data/lib/gems/rspec-1.1.11/spec/spec/matchers/simple_matcher_spec.rb +0 -93
  464. data/lib/gems/rspec-1.1.11/spec/spec/matchers/throw_symbol_spec.rb +0 -54
  465. data/lib/gems/rspec-1.1.11/spec/spec/mocks/any_number_of_times_spec.rb +0 -36
  466. data/lib/gems/rspec-1.1.11/spec/spec/mocks/argument_expectation_spec.rb +0 -23
  467. data/lib/gems/rspec-1.1.11/spec/spec/mocks/at_least_spec.rb +0 -97
  468. data/lib/gems/rspec-1.1.11/spec/spec/mocks/at_most_spec.rb +0 -93
  469. data/lib/gems/rspec-1.1.11/spec/spec/mocks/bug_report_10260_spec.rb +0 -8
  470. data/lib/gems/rspec-1.1.11/spec/spec/mocks/bug_report_10263_spec.rb +0 -24
  471. data/lib/gems/rspec-1.1.11/spec/spec/mocks/bug_report_11545_spec.rb +0 -33
  472. data/lib/gems/rspec-1.1.11/spec/spec/mocks/bug_report_15719_spec.rb +0 -30
  473. data/lib/gems/rspec-1.1.11/spec/spec/mocks/bug_report_496.rb +0 -17
  474. data/lib/gems/rspec-1.1.11/spec/spec/mocks/bug_report_7611_spec.rb +0 -19
  475. data/lib/gems/rspec-1.1.11/spec/spec/mocks/bug_report_7805_spec.rb +0 -22
  476. data/lib/gems/rspec-1.1.11/spec/spec/mocks/bug_report_8165_spec.rb +0 -31
  477. data/lib/gems/rspec-1.1.11/spec/spec/mocks/bug_report_8302_spec.rb +0 -26
  478. data/lib/gems/rspec-1.1.11/spec/spec/mocks/failing_mock_argument_constraints_spec.rb +0 -95
  479. data/lib/gems/rspec-1.1.11/spec/spec/mocks/hash_including_matcher_spec.rb +0 -53
  480. data/lib/gems/rspec-1.1.11/spec/spec/mocks/mock_ordering_spec.rb +0 -84
  481. data/lib/gems/rspec-1.1.11/spec/spec/mocks/mock_space_spec.rb +0 -54
  482. data/lib/gems/rspec-1.1.11/spec/spec/mocks/mock_spec.rb +0 -555
  483. data/lib/gems/rspec-1.1.11/spec/spec/mocks/multiple_return_value_spec.rb +0 -113
  484. data/lib/gems/rspec-1.1.11/spec/spec/mocks/nil_expectation_warning_spec.rb +0 -53
  485. data/lib/gems/rspec-1.1.11/spec/spec/mocks/null_object_mock_spec.rb +0 -54
  486. data/lib/gems/rspec-1.1.11/spec/spec/mocks/once_counts_spec.rb +0 -53
  487. data/lib/gems/rspec-1.1.11/spec/spec/mocks/options_hash_spec.rb +0 -35
  488. data/lib/gems/rspec-1.1.11/spec/spec/mocks/partial_mock_spec.rb +0 -149
  489. data/lib/gems/rspec-1.1.11/spec/spec/mocks/partial_mock_using_mocks_directly_spec.rb +0 -66
  490. data/lib/gems/rspec-1.1.11/spec/spec/mocks/passing_mock_argument_constraints_spec.rb +0 -130
  491. data/lib/gems/rspec-1.1.11/spec/spec/mocks/precise_counts_spec.rb +0 -52
  492. data/lib/gems/rspec-1.1.11/spec/spec/mocks/record_messages_spec.rb +0 -26
  493. data/lib/gems/rspec-1.1.11/spec/spec/mocks/stub_spec.rb +0 -188
  494. data/lib/gems/rspec-1.1.11/spec/spec/mocks/twice_counts_spec.rb +0 -67
  495. data/lib/gems/rspec-1.1.11/spec/spec/package/bin_spec_spec.rb +0 -22
  496. data/lib/gems/rspec-1.1.11/spec/spec/runner/class_and_argument_parser_spec.rb +0 -23
  497. data/lib/gems/rspec-1.1.11/spec/spec/runner/command_line_spec.rb +0 -141
  498. data/lib/gems/rspec-1.1.11/spec/spec/runner/drb_command_line_spec.rb +0 -97
  499. data/lib/gems/rspec-1.1.11/spec/spec/runner/examples.txt +0 -2
  500. data/lib/gems/rspec-1.1.11/spec/spec/runner/failed.txt +0 -3
  501. data/lib/gems/rspec-1.1.11/spec/spec/runner/formatter/base_formatter_spec.rb +0 -112
  502. data/lib/gems/rspec-1.1.11/spec/spec/runner/formatter/failing_example_groups_formatter_spec.rb +0 -45
  503. data/lib/gems/rspec-1.1.11/spec/spec/runner/formatter/failing_examples_formatter_spec.rb +0 -33
  504. data/lib/gems/rspec-1.1.11/spec/spec/runner/formatter/html_formatted-1.8.4.html +0 -365
  505. data/lib/gems/rspec-1.1.11/spec/spec/runner/formatter/html_formatted-1.8.5-jruby.html +0 -387
  506. data/lib/gems/rspec-1.1.11/spec/spec/runner/formatter/html_formatted-1.8.5.html +0 -371
  507. data/lib/gems/rspec-1.1.11/spec/spec/runner/formatter/html_formatted-1.8.6-jruby.html +0 -381
  508. data/lib/gems/rspec-1.1.11/spec/spec/runner/formatter/html_formatted-1.8.6.html +0 -370
  509. data/lib/gems/rspec-1.1.11/spec/spec/runner/formatter/html_formatter_spec.rb +0 -61
  510. data/lib/gems/rspec-1.1.11/spec/spec/runner/formatter/nested_text_formatter_spec.rb +0 -318
  511. data/lib/gems/rspec-1.1.11/spec/spec/runner/formatter/profile_formatter_spec.rb +0 -65
  512. data/lib/gems/rspec-1.1.11/spec/spec/runner/formatter/progress_bar_formatter_spec.rb +0 -155
  513. data/lib/gems/rspec-1.1.11/spec/spec/runner/formatter/snippet_extractor_spec.rb +0 -18
  514. data/lib/gems/rspec-1.1.11/spec/spec/runner/formatter/spec_mate_formatter_spec.rb +0 -103
  515. data/lib/gems/rspec-1.1.11/spec/spec/runner/formatter/specdoc_formatter_spec.rb +0 -159
  516. data/lib/gems/rspec-1.1.11/spec/spec/runner/formatter/story/html_formatter_spec.rb +0 -135
  517. data/lib/gems/rspec-1.1.11/spec/spec/runner/formatter/story/plain_text_formatter_spec.rb +0 -600
  518. data/lib/gems/rspec-1.1.11/spec/spec/runner/formatter/story/progress_bar_formatter_spec.rb +0 -82
  519. data/lib/gems/rspec-1.1.11/spec/spec/runner/formatter/text_mate_formatted-1.8.4.html +0 -365
  520. data/lib/gems/rspec-1.1.11/spec/spec/runner/formatter/text_mate_formatted-1.8.6.html +0 -370
  521. data/lib/gems/rspec-1.1.11/spec/spec/runner/heckle_runner_spec.rb +0 -78
  522. data/lib/gems/rspec-1.1.11/spec/spec/runner/heckler_spec.rb +0 -13
  523. data/lib/gems/rspec-1.1.11/spec/spec/runner/noisy_backtrace_tweaker_spec.rb +0 -45
  524. data/lib/gems/rspec-1.1.11/spec/spec/runner/option_parser_spec.rb +0 -421
  525. data/lib/gems/rspec-1.1.11/spec/spec/runner/options_spec.rb +0 -450
  526. data/lib/gems/rspec-1.1.11/spec/spec/runner/output_one_time_fixture.rb +0 -7
  527. data/lib/gems/rspec-1.1.11/spec/spec/runner/output_one_time_fixture_runner.rb +0 -8
  528. data/lib/gems/rspec-1.1.11/spec/spec/runner/output_one_time_spec.rb +0 -16
  529. data/lib/gems/rspec-1.1.11/spec/spec/runner/quiet_backtrace_tweaker_spec.rb +0 -62
  530. data/lib/gems/rspec-1.1.11/spec/spec/runner/reporter_spec.rb +0 -238
  531. data/lib/gems/rspec-1.1.11/spec/spec/runner/resources/a_bar.rb +0 -0
  532. data/lib/gems/rspec-1.1.11/spec/spec/runner/resources/a_foo.rb +0 -0
  533. data/lib/gems/rspec-1.1.11/spec/spec/runner/resources/a_spec.rb +0 -1
  534. data/lib/gems/rspec-1.1.11/spec/spec/runner/spec.opts +0 -2
  535. data/lib/gems/rspec-1.1.11/spec/spec/runner/spec_drb.opts +0 -1
  536. data/lib/gems/rspec-1.1.11/spec/spec/runner/spec_parser/spec_parser_fixture.rb +0 -70
  537. data/lib/gems/rspec-1.1.11/spec/spec/runner/spec_parser_spec.rb +0 -85
  538. data/lib/gems/rspec-1.1.11/spec/spec/runner/spec_spaced.opts +0 -2
  539. data/lib/gems/rspec-1.1.11/spec/spec/runner_spec.rb +0 -11
  540. data/lib/gems/rspec-1.1.11/spec/spec/spec_classes.rb +0 -133
  541. data/lib/gems/rspec-1.1.11/spec/spec/story/builders.rb +0 -46
  542. data/lib/gems/rspec-1.1.11/spec/spec/story/extensions/main_spec.rb +0 -161
  543. data/lib/gems/rspec-1.1.11/spec/spec/story/extensions_spec.rb +0 -14
  544. data/lib/gems/rspec-1.1.11/spec/spec/story/given_scenario_spec.rb +0 -27
  545. data/lib/gems/rspec-1.1.11/spec/spec/story/runner/plain_text_story_runner_spec.rb +0 -90
  546. data/lib/gems/rspec-1.1.11/spec/spec/story/runner/scenario_collector_spec.rb +0 -27
  547. data/lib/gems/rspec-1.1.11/spec/spec/story/runner/scenario_runner_spec.rb +0 -214
  548. data/lib/gems/rspec-1.1.11/spec/spec/story/runner/story_mediator_spec.rb +0 -143
  549. data/lib/gems/rspec-1.1.11/spec/spec/story/runner/story_parser_spec.rb +0 -401
  550. data/lib/gems/rspec-1.1.11/spec/spec/story/runner/story_runner_spec.rb +0 -294
  551. data/lib/gems/rspec-1.1.11/spec/spec/story/runner_spec.rb +0 -93
  552. data/lib/gems/rspec-1.1.11/spec/spec/story/scenario_spec.rb +0 -18
  553. data/lib/gems/rspec-1.1.11/spec/spec/story/step_group_spec.rb +0 -157
  554. data/lib/gems/rspec-1.1.11/spec/spec/story/step_mother_spec.rb +0 -84
  555. data/lib/gems/rspec-1.1.11/spec/spec/story/step_spec.rb +0 -272
  556. data/lib/gems/rspec-1.1.11/spec/spec/story/story_helper.rb +0 -2
  557. data/lib/gems/rspec-1.1.11/spec/spec/story/story_spec.rb +0 -84
  558. data/lib/gems/rspec-1.1.11/spec/spec/story/world_spec.rb +0 -423
  559. data/lib/gems/rspec-1.1.11/spec/spec_helper.rb +0 -77
  560. data/lib/gems/rspec-1.1.11/stories/all.rb +0 -5
  561. data/lib/gems/rspec-1.1.11/stories/configuration/before_blocks.story +0 -21
  562. data/lib/gems/rspec-1.1.11/stories/configuration/stories.rb +0 -7
  563. data/lib/gems/rspec-1.1.11/stories/example_groups/autogenerated_docstrings +0 -45
  564. data/lib/gems/rspec-1.1.11/stories/example_groups/example_group_with_should_methods +0 -17
  565. data/lib/gems/rspec-1.1.11/stories/example_groups/nested_groups +0 -17
  566. data/lib/gems/rspec-1.1.11/stories/example_groups/output +0 -25
  567. data/lib/gems/rspec-1.1.11/stories/example_groups/stories.rb +0 -7
  568. data/lib/gems/rspec-1.1.11/stories/helper.rb +0 -6
  569. data/lib/gems/rspec-1.1.11/stories/interop/examples_and_tests_together +0 -30
  570. data/lib/gems/rspec-1.1.11/stories/interop/stories.rb +0 -7
  571. data/lib/gems/rspec-1.1.11/stories/interop/test_case_with_should_methods +0 -17
  572. data/lib/gems/rspec-1.1.11/stories/mock_framework_integration/stories.rb +0 -7
  573. data/lib/gems/rspec-1.1.11/stories/mock_framework_integration/use_flexmock.story +0 -9
  574. data/lib/gems/rspec-1.1.11/stories/pending_stories/README +0 -3
  575. data/lib/gems/rspec-1.1.11/stories/resources/helpers/cmdline.rb +0 -9
  576. data/lib/gems/rspec-1.1.11/stories/resources/helpers/story_helper.rb +0 -16
  577. data/lib/gems/rspec-1.1.11/stories/resources/matchers/smart_match.rb +0 -37
  578. data/lib/gems/rspec-1.1.11/stories/resources/spec/before_blocks_example.rb +0 -32
  579. data/lib/gems/rspec-1.1.11/stories/resources/spec/example_group_with_should_methods.rb +0 -12
  580. data/lib/gems/rspec-1.1.11/stories/resources/spec/simple_spec.rb +0 -8
  581. data/lib/gems/rspec-1.1.11/stories/resources/spec/spec_with_flexmock.rb +0 -18
  582. data/lib/gems/rspec-1.1.11/stories/resources/steps/running_rspec.rb +0 -50
  583. data/lib/gems/rspec-1.1.11/stories/resources/stories/failing_story.rb +0 -15
  584. data/lib/gems/rspec-1.1.11/stories/resources/test/spec_and_test_together.rb +0 -57
  585. data/lib/gems/rspec-1.1.11/stories/resources/test/test_case_with_should_methods.rb +0 -30
  586. data/lib/gems/rspec-1.1.11/stories/stories/multiline_steps.story +0 -23
  587. data/lib/gems/rspec-1.1.11/stories/stories/steps/multiline_steps.rb +0 -13
  588. data/lib/gems/rspec-1.1.11/stories/stories/stories.rb +0 -6
  589. data/lib/gems/rspec-1.1.11/story_server/prototype/javascripts/builder.js +0 -136
  590. data/lib/gems/rspec-1.1.11/story_server/prototype/javascripts/controls.js +0 -972
  591. data/lib/gems/rspec-1.1.11/story_server/prototype/javascripts/dragdrop.js +0 -976
  592. data/lib/gems/rspec-1.1.11/story_server/prototype/javascripts/effects.js +0 -1117
  593. data/lib/gems/rspec-1.1.11/story_server/prototype/javascripts/prototype.js +0 -4140
  594. data/lib/gems/rspec-1.1.11/story_server/prototype/javascripts/rspec.js +0 -149
  595. data/lib/gems/rspec-1.1.11/story_server/prototype/javascripts/scriptaculous.js +0 -58
  596. data/lib/gems/rspec-1.1.11/story_server/prototype/javascripts/slider.js +0 -276
  597. data/lib/gems/rspec-1.1.11/story_server/prototype/javascripts/sound.js +0 -55
  598. data/lib/gems/rspec-1.1.11/story_server/prototype/javascripts/unittest.js +0 -568
  599. data/lib/gems/rspec-1.1.11/story_server/prototype/lib/server.rb +0 -24
  600. data/lib/gems/rspec-1.1.11/story_server/prototype/stories.html +0 -176
  601. data/lib/gems/rspec-1.1.11/story_server/prototype/stylesheets/test.css +0 -90
  602. data/lib/mack/testing/test_case.rb +0 -52
@@ -5,73 +5,73 @@ body {
5
5
  padding:0pt;
6
6
  }
7
7
 
8
- #nav {
9
- border-bottom:1px solid #222222;
10
- border-top-style:solid;
11
- border-top-width:0.5em;
12
- font-family:Helvetica,Arial,sans-serif;
13
- font-size:1.1em;
14
- padding:0.2em 0pt;
15
- position:fixed;
16
- text-align:center;
17
- width:100%;
18
- z-index:50;
19
-
20
- background-color: #000000;
21
- opacity: 0.6;
22
- }
23
-
24
8
  #container {
25
9
  background:white none repeat scroll 0%;
26
10
  font-family:Helvetica,Arial,sans-serif;
27
11
  margin:0pt auto;
28
12
  position:relative;
29
13
  text-align:left;
30
- top:4.0em;
14
+ top:1.0em;
31
15
  width:78em;
32
16
  }
33
17
 
18
+ span {
19
+ font-weight: bold;
20
+ text-decoration: underline;
21
+ }
22
+
34
23
  dl {
35
24
  font: normal 11px "Lucida Grande", Helvetica, sans-serif;
25
+ margin-left: 5px;
36
26
  }
37
27
 
38
- dt {
39
- color: #fff;
28
+ dl.new {
29
+ border-left: 5px solid #444444;
40
30
  }
41
31
 
42
- dl.passed {
43
- border-left: 5px solid #65C400;
32
+ dl.pending {
33
+ border-left: 5px solid #FAF834;
44
34
  }
45
35
 
46
36
  dl.failed {
47
37
  border-left: 5px solid #C20000;
48
38
  }
49
39
 
40
+ dl.passed {
41
+ border-left: 5px solid #65C400;
42
+ }
43
+
50
44
  dt {
45
+ color: #fff;
51
46
  padding: 3px;
52
47
  font-weight: bold;
53
48
  }
54
49
 
55
- dd {
56
- margin: 0px 0px 0px 0px;
50
+ dl.new > dt {
51
+ background: #444444;
57
52
  }
58
53
 
59
- dd p {
60
- padding: 5px;
61
- margin-top: 0;
62
- margin-bottom: 5px;
54
+ dl.pending > dt {
55
+ color: #131313;
56
+ background: #FAF834;
63
57
  }
64
58
 
65
- dd > dl {
66
- margin-left: 5px;
59
+ dl.failed > dt {
60
+ background: #C20000;
67
61
  }
68
62
 
69
63
  dl.passed > dt {
70
64
  background: #65C400;
71
65
  }
72
66
 
73
- dl.failed > dt {
74
- background: #C20000;
67
+ dd {
68
+ margin: 0px 0px 0px 0px;
69
+ }
70
+
71
+ dd p, pre {
72
+ padding: 5px;
73
+ margin-top: 0;
74
+ margin-bottom: 5px;
75
75
  }
76
76
 
77
77
  dl.passed > dd > p, li.passed {
@@ -94,10 +94,6 @@ dl.new > dd > p, li.new {
94
94
  border-bottom: 1px solid #444444;
95
95
  }
96
96
 
97
- dl > dd > p.wastebin {
98
- background-color: black;
99
- }
100
-
101
97
  span.param, span.param_editor {
102
98
  font-weight: bold;
103
99
  }
@@ -106,12 +102,12 @@ input {
106
102
  width: 100%;
107
103
  }
108
104
 
109
- ul.steps {
105
+ ul {
110
106
  padding: 0px;
111
107
  list-style: none;
112
108
  }
113
109
 
114
- ul.steps > li {
110
+ ul > li {
115
111
  margin: 5px 0px 5px 5px;
116
112
  padding: 3px 3px 3px 5px;
117
113
  }
@@ -0,0 +1,11 @@
1
+ function stepPassed(id) {
2
+ $("#"+id).removeClass("new").addClass("passed");
3
+ }
4
+
5
+ function stepPending(id) {
6
+ $("#"+id).removeClass("new").addClass("pending");
7
+ }
8
+
9
+ function stepFailed(id, message, backtrace) {
10
+ $("#"+id).removeClass("new").addClass("failed").append("<div>" + message + "</div>").append("<pre>" + backtrace + "</pre>");
11
+ }
@@ -0,0 +1,151 @@
1
+ require 'cgi'
2
+
3
+ module Cucumber
4
+ module Formatters
5
+ class HtmlFormatter
6
+ def initialize(io, step_mother)
7
+ @io = io
8
+ @step_mother = step_mother
9
+ @errors = []
10
+ @scenario_table_header = []
11
+ end
12
+
13
+ def visit_features(features)
14
+ # IMPORTANT NOTICE ABOUT JQUERY BELOW. THE ORIGINAL BACKSLASHES (\) HAVE
15
+ # BEEN REPLACED BY DOUBLE BACKSLASHES (\\) IN THIS FILE TO MAKE SURE THEY
16
+ # ARE PRINTED PROPERLY WITH ONLY ONE BACKSLASH (\).
17
+ @io.puts(<<-HTML)
18
+ <?xml version="1.0" encoding="UTF-8"?>
19
+ <!DOCTYPE html
20
+ PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"
21
+ "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
22
+ <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">
23
+ <head>
24
+ <title>#{Cucumber.language['feature']}</title>
25
+ <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
26
+ <meta http-equiv="Expires" content="-1" />
27
+ <meta http-equiv="Pragma" content="no-cache" />
28
+ <script type="text/javascript">
29
+ #{IO.read(File.dirname(__FILE__) + '/jquery.js')}
30
+ #{IO.read(File.dirname(__FILE__) + '/cucumber.js')}
31
+ </script>
32
+ <style>
33
+ #{IO.read(File.dirname(__FILE__) + '/cucumber.css')}
34
+ </style>
35
+ </head>
36
+ <body>
37
+ <div id="container">
38
+ HTML
39
+ features.accept(self)
40
+ @io.puts %{ </div>}
41
+ end
42
+
43
+ def visit_feature(feature)
44
+ @io.puts %{ <dl class="feature new">}
45
+ feature.accept(self)
46
+ @io.puts %{ </dd>}
47
+ @io.puts %{ </dl>}
48
+ end
49
+
50
+ def visit_header(header)
51
+ header = header.gsub(/\n/, "<br />\n")
52
+ @io.puts %{ <dt>#{header}}
53
+ @io.puts %{ </dt>}
54
+ @io.puts %{ <dd>}
55
+ end
56
+
57
+ def visit_regular_scenario(scenario)
58
+ visit_scenario(scenario, Cucumber.language['scenario'])
59
+ end
60
+
61
+ def visit_scenario_outline(scenario)
62
+ visit_scenario(scenario, Cucumber.language['scenario_outline'])
63
+ end
64
+
65
+ def visit_row_scenario(scenario)
66
+ @io.puts %{ <dl class="new">}
67
+ @io.puts %{ <dt>#{Cucumber.language['scenario']}: #{scenario.name}</dt>}
68
+ @io.puts %{ <dd>}
69
+ @io.puts %{ <table cellpadding="3">}
70
+ @io.puts %{ <thead>}
71
+ @io.puts %{ <tr>}
72
+ @scenario_table_header.each do |column_header|
73
+ @io.puts %{ <th>#{column_header}</th>}
74
+ end
75
+ @io.puts %{ </tr>}
76
+ @io.puts %{ </thead>}
77
+ @io.puts %{ <tbody>}
78
+ scenario.accept(self)
79
+ @io.puts %{ </tbody>}
80
+ @io.puts %{ </table>}
81
+ @io.puts %{ </dd>}
82
+ @io.puts %{ </dl>}
83
+ end
84
+
85
+ def visit_row_step(step)
86
+ _, args, _ = step.regexp_args_proc(@step_mother)
87
+ args = step.visible_args if step.outline?
88
+ args.each do |arg|
89
+ @io.puts %{ <td id="#{step.id}"><span>#{arg}</span></td>}
90
+ end
91
+ end
92
+
93
+ def visit_regular_step(step)
94
+ regexp, _, _ = step.regexp_args_proc(@step_mother)
95
+ @io.puts %{ <li class="new" id="#{step.id}">#{step.keyword} #{step.format(regexp, '<span>%s</span>')}</li>}
96
+ end
97
+
98
+ def visit_step_outline(step)
99
+ regexp, _, _ = step.regexp_args_proc(@step_mother)
100
+ @io.puts %{ <li class="new" id="#{step.id}">#{step.keyword} #{CGI.escapeHTML(step.format(nil))}</li>}
101
+ end
102
+
103
+ def step_passed(step, regexp, args)
104
+ print_javascript_tag("stepPassed(#{step.id})")
105
+ end
106
+
107
+ def step_failed(step, regexp, args)
108
+ @errors << step.error
109
+ print_javascript_tag("stepFailed(#{step.id}, #{step.error.message.inspect}, #{step.error.backtrace.join("\n").inspect})")
110
+ end
111
+
112
+ def step_pending(step, regexp, args)
113
+ print_javascript_tag("stepPending(#{step.id})")
114
+ end
115
+
116
+ def step_skipped(step, regexp, args)
117
+ # noop
118
+ end
119
+
120
+ def step_traced(step, regexp, args)
121
+ # noop
122
+ end
123
+
124
+ def print_javascript_tag(js)
125
+ @io.puts %{ <script type="text/javascript">#{js}</script>}
126
+ end
127
+
128
+ def dump
129
+ @io.puts <<-HTML
130
+ </body>
131
+ </html>
132
+ HTML
133
+ end
134
+
135
+ private
136
+
137
+ def visit_scenario(scenario, scenario_or_scenario_outline_keyword)
138
+ @scenario_table_header = scenario.table_header
139
+ @io.puts %{ <dl class="new">}
140
+ @io.puts %{ <dt>#{scenario_or_scenario_outline_keyword}: #{scenario.name}</dt>}
141
+ @io.puts %{ <dd>}
142
+ @io.puts %{ <ul>}
143
+ scenario.accept(self)
144
+ @io.puts %{ </ul>}
145
+ @io.puts %{ </dd>}
146
+ @io.puts %{ </dl>}
147
+ end
148
+
149
+ end
150
+ end
151
+ end
@@ -0,0 +1,32 @@
1
+ /*
2
+ * jQuery 1.2.6 - New Wave Javascript
3
+ *
4
+ * Copyright (c) 2008 John Resig (jquery.com)
5
+ * Dual licensed under the MIT (MIT-LICENSE.txt)
6
+ * and GPL (GPL-LICENSE.txt) licenses.
7
+ *
8
+ * $Date: 2008-05-24 14:22:17 -0400 (Sat, 24 May 2008) $
9
+ * $Rev: 5685 $
10
+ */
11
+ (function(){var _jQuery=window.jQuery,_$=window.$;var jQuery=window.jQuery=window.$=function(selector,context){return new jQuery.fn.init(selector,context);};var quickExpr=/^[^<]*(<(.|\s)+>)[^>]*$|^#(\w+)$/,isSimple=/^.[^:#\[\.]*$/,undefined;jQuery.fn=jQuery.prototype={init:function(selector,context){selector=selector||document;if(selector.nodeType){this[0]=selector;this.length=1;return this;}if(typeof selector=="string"){var match=quickExpr.exec(selector);if(match&&(match[1]||!context)){if(match[1])selector=jQuery.clean([match[1]],context);else{var elem=document.getElementById(match[3]);if(elem){if(elem.id!=match[3])return jQuery().find(selector);return jQuery(elem);}selector=[];}}else
12
+ return jQuery(context).find(selector);}else if(jQuery.isFunction(selector))return jQuery(document)[jQuery.fn.ready?"ready":"load"](selector);return this.setArray(jQuery.makeArray(selector));},jquery:"1.2.6",size:function(){return this.length;},length:0,get:function(num){return num==undefined?jQuery.makeArray(this):this[num];},pushStack:function(elems){var ret=jQuery(elems);ret.prevObject=this;return ret;},setArray:function(elems){this.length=0;Array.prototype.push.apply(this,elems);return this;},each:function(callback,args){return jQuery.each(this,callback,args);},index:function(elem){var ret=-1;return jQuery.inArray(elem&&elem.jquery?elem[0]:elem,this);},attr:function(name,value,type){var options=name;if(name.constructor==String)if(value===undefined)return this[0]&&jQuery[type||"attr"](this[0],name);else{options={};options[name]=value;}return this.each(function(i){for(name in options)jQuery.attr(type?this.style:this,name,jQuery.prop(this,options[name],type,i,name));});},css:function(key,value){if((key=='width'||key=='height')&&parseFloat(value)<0)value=undefined;return this.attr(key,value,"curCSS");},text:function(text){if(typeof text!="object"&&text!=null)return this.empty().append((this[0]&&this[0].ownerDocument||document).createTextNode(text));var ret="";jQuery.each(text||this,function(){jQuery.each(this.childNodes,function(){if(this.nodeType!=8)ret+=this.nodeType!=1?this.nodeValue:jQuery.fn.text([this]);});});return ret;},wrapAll:function(html){if(this[0])jQuery(html,this[0].ownerDocument).clone().insertBefore(this[0]).map(function(){var elem=this;while(elem.firstChild)elem=elem.firstChild;return elem;}).append(this);return this;},wrapInner:function(html){return this.each(function(){jQuery(this).contents().wrapAll(html);});},wrap:function(html){return this.each(function(){jQuery(this).wrapAll(html);});},append:function(){return this.domManip(arguments,true,false,function(elem){if(this.nodeType==1)this.appendChild(elem);});},prepend:function(){return this.domManip(arguments,true,true,function(elem){if(this.nodeType==1)this.insertBefore(elem,this.firstChild);});},before:function(){return this.domManip(arguments,false,false,function(elem){this.parentNode.insertBefore(elem,this);});},after:function(){return this.domManip(arguments,false,true,function(elem){this.parentNode.insertBefore(elem,this.nextSibling);});},end:function(){return this.prevObject||jQuery([]);},find:function(selector){var elems=jQuery.map(this,function(elem){return jQuery.find(selector,elem);});return this.pushStack(/[^+>] [^+>]/.test(selector)||selector.indexOf("..")>-1?jQuery.unique(elems):elems);},clone:function(events){var ret=this.map(function(){if(jQuery.browser.msie&&!jQuery.isXMLDoc(this)){var clone=this.cloneNode(true),container=document.createElement("div");container.appendChild(clone);return jQuery.clean([container.innerHTML])[0];}else
13
+ return this.cloneNode(true);});var clone=ret.find("*").andSelf().each(function(){if(this[expando]!=undefined)this[expando]=null;});if(events===true)this.find("*").andSelf().each(function(i){if(this.nodeType==3)return;var events=jQuery.data(this,"events");for(var type in events)for(var handler in events[type])jQuery.event.add(clone[i],type,events[type][handler],events[type][handler].data);});return ret;},filter:function(selector){return this.pushStack(jQuery.isFunction(selector)&&jQuery.grep(this,function(elem,i){return selector.call(elem,i);})||jQuery.multiFilter(selector,this));},not:function(selector){if(selector.constructor==String)if(isSimple.test(selector))return this.pushStack(jQuery.multiFilter(selector,this,true));else
14
+ selector=jQuery.multiFilter(selector,this);var isArrayLike=selector.length&&selector[selector.length-1]!==undefined&&!selector.nodeType;return this.filter(function(){return isArrayLike?jQuery.inArray(this,selector)<0:this!=selector;});},add:function(selector){return this.pushStack(jQuery.unique(jQuery.merge(this.get(),typeof selector=='string'?jQuery(selector):jQuery.makeArray(selector))));},is:function(selector){return!!selector&&jQuery.multiFilter(selector,this).length>0;},hasClass:function(selector){return this.is("."+selector);},val:function(value){if(value==undefined){if(this.length){var elem=this[0];if(jQuery.nodeName(elem,"select")){var index=elem.selectedIndex,values=[],options=elem.options,one=elem.type=="select-one";if(index<0)return null;for(var i=one?index:0,max=one?index+1:options.length;i<max;i++){var option=options[i];if(option.selected){value=jQuery.browser.msie&&!option.attributes.value.specified?option.text:option.value;if(one)return value;values.push(value);}}return values;}else
15
+ return(this[0].value||"").replace(/\r/g,"");}return undefined;}if(value.constructor==Number)value+='';return this.each(function(){if(this.nodeType!=1)return;if(value.constructor==Array&&/radio|checkbox/.test(this.type))this.checked=(jQuery.inArray(this.value,value)>=0||jQuery.inArray(this.name,value)>=0);else if(jQuery.nodeName(this,"select")){var values=jQuery.makeArray(value);jQuery("option",this).each(function(){this.selected=(jQuery.inArray(this.value,values)>=0||jQuery.inArray(this.text,values)>=0);});if(!values.length)this.selectedIndex=-1;}else
16
+ this.value=value;});},html:function(value){return value==undefined?(this[0]?this[0].innerHTML:null):this.empty().append(value);},replaceWith:function(value){return this.after(value).remove();},eq:function(i){return this.slice(i,i+1);},slice:function(){return this.pushStack(Array.prototype.slice.apply(this,arguments));},map:function(callback){return this.pushStack(jQuery.map(this,function(elem,i){return callback.call(elem,i,elem);}));},andSelf:function(){return this.add(this.prevObject);},data:function(key,value){var parts=key.split(".");parts[1]=parts[1]?"."+parts[1]:"";if(value===undefined){var data=this.triggerHandler("getData"+parts[1]+"!",[parts[0]]);if(data===undefined&&this.length)data=jQuery.data(this[0],key);return data===undefined&&parts[1]?this.data(parts[0]):data;}else
17
+ return this.trigger("setData"+parts[1]+"!",[parts[0],value]).each(function(){jQuery.data(this,key,value);});},removeData:function(key){return this.each(function(){jQuery.removeData(this,key);});},domManip:function(args,table,reverse,callback){var clone=this.length>1,elems;return this.each(function(){if(!elems){elems=jQuery.clean(args,this.ownerDocument);if(reverse)elems.reverse();}var obj=this;if(table&&jQuery.nodeName(this,"table")&&jQuery.nodeName(elems[0],"tr"))obj=this.getElementsByTagName("tbody")[0]||this.appendChild(this.ownerDocument.createElement("tbody"));var scripts=jQuery([]);jQuery.each(elems,function(){var elem=clone?jQuery(this).clone(true)[0]:this;if(jQuery.nodeName(elem,"script"))scripts=scripts.add(elem);else{if(elem.nodeType==1)scripts=scripts.add(jQuery("script",elem).remove());callback.call(obj,elem);}});scripts.each(evalScript);});}};jQuery.fn.init.prototype=jQuery.fn;function evalScript(i,elem){if(elem.src)jQuery.ajax({url:elem.src,async:false,dataType:"script"});else
18
+ jQuery.globalEval(elem.text||elem.textContent||elem.innerHTML||"");if(elem.parentNode)elem.parentNode.removeChild(elem);}function now(){return+new Date;}jQuery.extend=jQuery.fn.extend=function(){var target=arguments[0]||{},i=1,length=arguments.length,deep=false,options;if(target.constructor==Boolean){deep=target;target=arguments[1]||{};i=2;}if(typeof target!="object"&&typeof target!="function")target={};if(length==i){target=this;--i;}for(;i<length;i++)if((options=arguments[i])!=null)for(var name in options){var src=target[name],copy=options[name];if(target===copy)continue;if(deep&&copy&&typeof copy=="object"&&!copy.nodeType)target[name]=jQuery.extend(deep,src||(copy.length!=null?[]:{}),copy);else if(copy!==undefined)target[name]=copy;}return target;};var expando="jQuery"+now(),uuid=0,windowData={},exclude=/z-?index|font-?weight|opacity|zoom|line-?height/i,defaultView=document.defaultView||{};jQuery.extend({noConflict:function(deep){window.$=_$;if(deep)window.jQuery=_jQuery;return jQuery;},isFunction:function(fn){return!!fn&&typeof fn!="string"&&!fn.nodeName&&fn.constructor!=Array&&/^[\s[]?function/.test(fn+"");},isXMLDoc:function(elem){return elem.documentElement&&!elem.body||elem.tagName&&elem.ownerDocument&&!elem.ownerDocument.body;},globalEval:function(data){data=jQuery.trim(data);if(data){var head=document.getElementsByTagName("head")[0]||document.documentElement,script=document.createElement("script");script.type="text/javascript";if(jQuery.browser.msie)script.text=data;else
19
+ script.appendChild(document.createTextNode(data));head.insertBefore(script,head.firstChild);head.removeChild(script);}},nodeName:function(elem,name){return elem.nodeName&&elem.nodeName.toUpperCase()==name.toUpperCase();},cache:{},data:function(elem,name,data){elem=elem==window?windowData:elem;var id=elem[expando];if(!id)id=elem[expando]=++uuid;if(name&&!jQuery.cache[id])jQuery.cache[id]={};if(data!==undefined)jQuery.cache[id][name]=data;return name?jQuery.cache[id][name]:id;},removeData:function(elem,name){elem=elem==window?windowData:elem;var id=elem[expando];if(name){if(jQuery.cache[id]){delete jQuery.cache[id][name];name="";for(name in jQuery.cache[id])break;if(!name)jQuery.removeData(elem);}}else{try{delete elem[expando];}catch(e){if(elem.removeAttribute)elem.removeAttribute(expando);}delete jQuery.cache[id];}},each:function(object,callback,args){var name,i=0,length=object.length;if(args){if(length==undefined){for(name in object)if(callback.apply(object[name],args)===false)break;}else
20
+ for(;i<length;)if(callback.apply(object[i++],args)===false)break;}else{if(length==undefined){for(name in object)if(callback.call(object[name],name,object[name])===false)break;}else
21
+ for(var value=object[0];i<length&&callback.call(value,i,value)!==false;value=object[++i]){}}return object;},prop:function(elem,value,type,i,name){if(jQuery.isFunction(value))value=value.call(elem,i);return value&&value.constructor==Number&&type=="curCSS"&&!exclude.test(name)?value+"px":value;},className:{add:function(elem,classNames){jQuery.each((classNames||"").split(/\s+/),function(i,className){if(elem.nodeType==1&&!jQuery.className.has(elem.className,className))elem.className+=(elem.className?" ":"")+className;});},remove:function(elem,classNames){if(elem.nodeType==1)elem.className=classNames!=undefined?jQuery.grep(elem.className.split(/\s+/),function(className){return!jQuery.className.has(classNames,className);}).join(" "):"";},has:function(elem,className){return jQuery.inArray(className,(elem.className||elem).toString().split(/\s+/))>-1;}},swap:function(elem,options,callback){var old={};for(var name in options){old[name]=elem.style[name];elem.style[name]=options[name];}callback.call(elem);for(var name in options)elem.style[name]=old[name];},css:function(elem,name,force){if(name=="width"||name=="height"){var val,props={position:"absolute",visibility:"hidden",display:"block"},which=name=="width"?["Left","Right"]:["Top","Bottom"];function getWH(){val=name=="width"?elem.offsetWidth:elem.offsetHeight;var padding=0,border=0;jQuery.each(which,function(){padding+=parseFloat(jQuery.curCSS(elem,"padding"+this,true))||0;border+=parseFloat(jQuery.curCSS(elem,"border"+this+"Width",true))||0;});val-=Math.round(padding+border);}if(jQuery(elem).is(":visible"))getWH();else
22
+ jQuery.swap(elem,props,getWH);return Math.max(0,val);}return jQuery.curCSS(elem,name,force);},curCSS:function(elem,name,force){var ret,style=elem.style;function color(elem){if(!jQuery.browser.safari)return false;var ret=defaultView.getComputedStyle(elem,null);return!ret||ret.getPropertyValue("color")=="";}if(name=="opacity"&&jQuery.browser.msie){ret=jQuery.attr(style,"opacity");return ret==""?"1":ret;}if(jQuery.browser.opera&&name=="display"){var save=style.outline;style.outline="0 solid black";style.outline=save;}if(name.match(/float/i))name=styleFloat;if(!force&&style&&style[name])ret=style[name];else if(defaultView.getComputedStyle){if(name.match(/float/i))name="float";name=name.replace(/([A-Z])/g,"-$1").toLowerCase();var computedStyle=defaultView.getComputedStyle(elem,null);if(computedStyle&&!color(elem))ret=computedStyle.getPropertyValue(name);else{var swap=[],stack=[],a=elem,i=0;for(;a&&color(a);a=a.parentNode)stack.unshift(a);for(;i<stack.length;i++)if(color(stack[i])){swap[i]=stack[i].style.display;stack[i].style.display="block";}ret=name=="display"&&swap[stack.length-1]!=null?"none":(computedStyle&&computedStyle.getPropertyValue(name))||"";for(i=0;i<swap.length;i++)if(swap[i]!=null)stack[i].style.display=swap[i];}if(name=="opacity"&&ret=="")ret="1";}else if(elem.currentStyle){var camelCase=name.replace(/\-(\w)/g,function(all,letter){return letter.toUpperCase();});ret=elem.currentStyle[name]||elem.currentStyle[camelCase];if(!/^\d+(px)?$/i.test(ret)&&/^\d/.test(ret)){var left=style.left,rsLeft=elem.runtimeStyle.left;elem.runtimeStyle.left=elem.currentStyle.left;style.left=ret||0;ret=style.pixelLeft+"px";style.left=left;elem.runtimeStyle.left=rsLeft;}}return ret;},clean:function(elems,context){var ret=[];context=context||document;if(typeof context.createElement=='undefined')context=context.ownerDocument||context[0]&&context[0].ownerDocument||document;jQuery.each(elems,function(i,elem){if(!elem)return;if(elem.constructor==Number)elem+='';if(typeof elem=="string"){elem=elem.replace(/(<(\w+)[^>]*?)\/>/g,function(all,front,tag){return tag.match(/^(abbr|br|col|img|input|link|meta|param|hr|area|embed)$/i)?all:front+"></"+tag+">";});var tags=jQuery.trim(elem).toLowerCase(),div=context.createElement("div");var wrap=!tags.indexOf("<opt")&&[1,"<select multiple='multiple'>","</select>"]||!tags.indexOf("<leg")&&[1,"<fieldset>","</fieldset>"]||tags.match(/^<(thead|tbody|tfoot|colg|cap)/)&&[1,"<table>","</table>"]||!tags.indexOf("<tr")&&[2,"<table><tbody>","</tbody></table>"]||(!tags.indexOf("<td")||!tags.indexOf("<th"))&&[3,"<table><tbody><tr>","</tr></tbody></table>"]||!tags.indexOf("<col")&&[2,"<table><tbody></tbody><colgroup>","</colgroup></table>"]||jQuery.browser.msie&&[1,"div<div>","</div>"]||[0,"",""];div.innerHTML=wrap[1]+elem+wrap[2];while(wrap[0]--)div=div.lastChild;if(jQuery.browser.msie){var tbody=!tags.indexOf("<table")&&tags.indexOf("<tbody")<0?div.firstChild&&div.firstChild.childNodes:wrap[1]=="<table>"&&tags.indexOf("<tbody")<0?div.childNodes:[];for(var j=tbody.length-1;j>=0;--j)if(jQuery.nodeName(tbody[j],"tbody")&&!tbody[j].childNodes.length)tbody[j].parentNode.removeChild(tbody[j]);if(/^\s/.test(elem))div.insertBefore(context.createTextNode(elem.match(/^\s*/)[0]),div.firstChild);}elem=jQuery.makeArray(div.childNodes);}if(elem.length===0&&(!jQuery.nodeName(elem,"form")&&!jQuery.nodeName(elem,"select")))return;if(elem[0]==undefined||jQuery.nodeName(elem,"form")||elem.options)ret.push(elem);else
23
+ ret=jQuery.merge(ret,elem);});return ret;},attr:function(elem,name,value){if(!elem||elem.nodeType==3||elem.nodeType==8)return undefined;var notxml=!jQuery.isXMLDoc(elem),set=value!==undefined,msie=jQuery.browser.msie;name=notxml&&jQuery.props[name]||name;if(elem.tagName){var special=/href|src|style/.test(name);if(name=="selected"&&jQuery.browser.safari)elem.parentNode.selectedIndex;if(name in elem&&notxml&&!special){if(set){if(name=="type"&&jQuery.nodeName(elem,"input")&&elem.parentNode)throw"type property can't be changed";elem[name]=value;}if(jQuery.nodeName(elem,"form")&&elem.getAttributeNode(name))return elem.getAttributeNode(name).nodeValue;return elem[name];}if(msie&&notxml&&name=="style")return jQuery.attr(elem.style,"cssText",value);if(set)elem.setAttribute(name,""+value);var attr=msie&&notxml&&special?elem.getAttribute(name,2):elem.getAttribute(name);return attr===null?undefined:attr;}if(msie&&name=="opacity"){if(set){elem.zoom=1;elem.filter=(elem.filter||"").replace(/alpha\([^)]*\)/,"")+(parseInt(value)+''=="NaN"?"":"alpha(opacity="+value*100+")");}return elem.filter&&elem.filter.indexOf("opacity=")>=0?(parseFloat(elem.filter.match(/opacity=([^)]*)/)[1])/100)+'':"";}name=name.replace(/-([a-z])/ig,function(all,letter){return letter.toUpperCase();});if(set)elem[name]=value;return elem[name];},trim:function(text){return(text||"").replace(/^\s+|\s+$/g,"");},makeArray:function(array){var ret=[];if(array!=null){var i=array.length;if(i==null||array.split||array.setInterval||array.call)ret[0]=array;else
24
+ while(i)ret[--i]=array[i];}return ret;},inArray:function(elem,array){for(var i=0,length=array.length;i<length;i++)if(array[i]===elem)return i;return-1;},merge:function(first,second){var i=0,elem,pos=first.length;if(jQuery.browser.msie){while(elem=second[i++])if(elem.nodeType!=8)first[pos++]=elem;}else
25
+ while(elem=second[i++])first[pos++]=elem;return first;},unique:function(array){var ret=[],done={};try{for(var i=0,length=array.length;i<length;i++){var id=jQuery.data(array[i]);if(!done[id]){done[id]=true;ret.push(array[i]);}}}catch(e){ret=array;}return ret;},grep:function(elems,callback,inv){var ret=[];for(var i=0,length=elems.length;i<length;i++)if(!inv!=!callback(elems[i],i))ret.push(elems[i]);return ret;},map:function(elems,callback){var ret=[];for(var i=0,length=elems.length;i<length;i++){var value=callback(elems[i],i);if(value!=null)ret[ret.length]=value;}return ret.concat.apply([],ret);}});var userAgent=navigator.userAgent.toLowerCase();jQuery.browser={version:(userAgent.match(/.+(?:rv|it|ra|ie)[\/: ]([\d.]+)/)||[])[1],safari:/webkit/.test(userAgent),opera:/opera/.test(userAgent),msie:/msie/.test(userAgent)&&!/opera/.test(userAgent),mozilla:/mozilla/.test(userAgent)&&!/(compatible|webkit)/.test(userAgent)};var styleFloat=jQuery.browser.msie?"styleFloat":"cssFloat";jQuery.extend({boxModel:!jQuery.browser.msie||document.compatMode=="CSS1Compat",props:{"for":"htmlFor","class":"className","float":styleFloat,cssFloat:styleFloat,styleFloat:styleFloat,readonly:"readOnly",maxlength:"maxLength",cellspacing:"cellSpacing"}});jQuery.each({parent:function(elem){return elem.parentNode;},parents:function(elem){return jQuery.dir(elem,"parentNode");},next:function(elem){return jQuery.nth(elem,2,"nextSibling");},prev:function(elem){return jQuery.nth(elem,2,"previousSibling");},nextAll:function(elem){return jQuery.dir(elem,"nextSibling");},prevAll:function(elem){return jQuery.dir(elem,"previousSibling");},siblings:function(elem){return jQuery.sibling(elem.parentNode.firstChild,elem);},children:function(elem){return jQuery.sibling(elem.firstChild);},contents:function(elem){return jQuery.nodeName(elem,"iframe")?elem.contentDocument||elem.contentWindow.document:jQuery.makeArray(elem.childNodes);}},function(name,fn){jQuery.fn[name]=function(selector){var ret=jQuery.map(this,fn);if(selector&&typeof selector=="string")ret=jQuery.multiFilter(selector,ret);return this.pushStack(jQuery.unique(ret));};});jQuery.each({appendTo:"append",prependTo:"prepend",insertBefore:"before",insertAfter:"after",replaceAll:"replaceWith"},function(name,original){jQuery.fn[name]=function(){var args=arguments;return this.each(function(){for(var i=0,length=args.length;i<length;i++)jQuery(args[i])[original](this);});};});jQuery.each({removeAttr:function(name){jQuery.attr(this,name,"");if(this.nodeType==1)this.removeAttribute(name);},addClass:function(classNames){jQuery.className.add(this,classNames);},removeClass:function(classNames){jQuery.className.remove(this,classNames);},toggleClass:function(classNames){jQuery.className[jQuery.className.has(this,classNames)?"remove":"add"](this,classNames);},remove:function(selector){if(!selector||jQuery.filter(selector,[this]).r.length){jQuery("*",this).add(this).each(function(){jQuery.event.remove(this);jQuery.removeData(this);});if(this.parentNode)this.parentNode.removeChild(this);}},empty:function(){jQuery(">*",this).remove();while(this.firstChild)this.removeChild(this.firstChild);}},function(name,fn){jQuery.fn[name]=function(){return this.each(fn,arguments);};});jQuery.each(["Height","Width"],function(i,name){var type=name.toLowerCase();jQuery.fn[type]=function(size){return this[0]==window?jQuery.browser.opera&&document.body["client"+name]||jQuery.browser.safari&&window["inner"+name]||document.compatMode=="CSS1Compat"&&document.documentElement["client"+name]||document.body["client"+name]:this[0]==document?Math.max(Math.max(document.body["scroll"+name],document.documentElement["scroll"+name]),Math.max(document.body["offset"+name],document.documentElement["offset"+name])):size==undefined?(this.length?jQuery.css(this[0],type):null):this.css(type,size.constructor==String?size:size+"px");};});function num(elem,prop){return elem[0]&&parseInt(jQuery.curCSS(elem[0],prop,true),10)||0;}var chars=jQuery.browser.safari&&parseInt(jQuery.browser.version)<417?"(?:[\\w*_-]|\\\\.)":"(?:[\\w\u0128-\uFFFF*_-]|\\\\.)",quickChild=new RegExp("^>\\s*("+chars+"+)"),quickID=new RegExp("^("+chars+"+)(#)("+chars+"+)"),quickClass=new RegExp("^([#.]?)("+chars+"*)");jQuery.extend({expr:{"":function(a,i,m){return m[2]=="*"||jQuery.nodeName(a,m[2]);},"#":function(a,i,m){return a.getAttribute("id")==m[2];},":":{lt:function(a,i,m){return i<m[3]-0;},gt:function(a,i,m){return i>m[3]-0;},nth:function(a,i,m){return m[3]-0==i;},eq:function(a,i,m){return m[3]-0==i;},first:function(a,i){return i==0;},last:function(a,i,m,r){return i==r.length-1;},even:function(a,i){return i%2==0;},odd:function(a,i){return i%2;},"first-child":function(a){return a.parentNode.getElementsByTagName("*")[0]==a;},"last-child":function(a){return jQuery.nth(a.parentNode.lastChild,1,"previousSibling")==a;},"only-child":function(a){return!jQuery.nth(a.parentNode.lastChild,2,"previousSibling");},parent:function(a){return a.firstChild;},empty:function(a){return!a.firstChild;},contains:function(a,i,m){return(a.textContent||a.innerText||jQuery(a).text()||"").indexOf(m[3])>=0;},visible:function(a){return"hidden"!=a.type&&jQuery.css(a,"display")!="none"&&jQuery.css(a,"visibility")!="hidden";},hidden:function(a){return"hidden"==a.type||jQuery.css(a,"display")=="none"||jQuery.css(a,"visibility")=="hidden";},enabled:function(a){return!a.disabled;},disabled:function(a){return a.disabled;},checked:function(a){return a.checked;},selected:function(a){return a.selected||jQuery.attr(a,"selected");},text:function(a){return"text"==a.type;},radio:function(a){return"radio"==a.type;},checkbox:function(a){return"checkbox"==a.type;},file:function(a){return"file"==a.type;},password:function(a){return"password"==a.type;},submit:function(a){return"submit"==a.type;},image:function(a){return"image"==a.type;},reset:function(a){return"reset"==a.type;},button:function(a){return"button"==a.type||jQuery.nodeName(a,"button");},input:function(a){return/input|select|textarea|button/i.test(a.nodeName);},has:function(a,i,m){return jQuery.find(m[3],a).length;},header:function(a){return/h\d/i.test(a.nodeName);},animated:function(a){return jQuery.grep(jQuery.timers,function(fn){return a==fn.elem;}).length;}}},parse:[/^(\[) *@?([\w-]+) *([!*$^~=]*) *('?"?)(.*?)\4 *\]/,/^(:)([\w-]+)\("?'?(.*?(\(.*?\))?[^(]*?)"?'?\)/,new RegExp("^([:.#]*)("+chars+"+)")],multiFilter:function(expr,elems,not){var old,cur=[];while(expr&&expr!=old){old=expr;var f=jQuery.filter(expr,elems,not);expr=f.t.replace(/^\s*,\s*/,"");cur=not?elems=f.r:jQuery.merge(cur,f.r);}return cur;},find:function(t,context){if(typeof t!="string")return[t];if(context&&context.nodeType!=1&&context.nodeType!=9)return[];context=context||document;var ret=[context],done=[],last,nodeName;while(t&&last!=t){var r=[];last=t;t=jQuery.trim(t);var foundToken=false,re=quickChild,m=re.exec(t);if(m){nodeName=m[1].toUpperCase();for(var i=0;ret[i];i++)for(var c=ret[i].firstChild;c;c=c.nextSibling)if(c.nodeType==1&&(nodeName=="*"||c.nodeName.toUpperCase()==nodeName))r.push(c);ret=r;t=t.replace(re,"");if(t.indexOf(" ")==0)continue;foundToken=true;}else{re=/^([>+~])\s*(\w*)/i;if((m=re.exec(t))!=null){r=[];var merge={};nodeName=m[2].toUpperCase();m=m[1];for(var j=0,rl=ret.length;j<rl;j++){var n=m=="~"||m=="+"?ret[j].nextSibling:ret[j].firstChild;for(;n;n=n.nextSibling)if(n.nodeType==1){var id=jQuery.data(n);if(m=="~"&&merge[id])break;if(!nodeName||n.nodeName.toUpperCase()==nodeName){if(m=="~")merge[id]=true;r.push(n);}if(m=="+")break;}}ret=r;t=jQuery.trim(t.replace(re,""));foundToken=true;}}if(t&&!foundToken){if(!t.indexOf(",")){if(context==ret[0])ret.shift();done=jQuery.merge(done,ret);r=ret=[context];t=" "+t.substr(1,t.length);}else{var re2=quickID;var m=re2.exec(t);if(m){m=[0,m[2],m[3],m[1]];}else{re2=quickClass;m=re2.exec(t);}m[2]=m[2].replace(/\\/g,"");var elem=ret[ret.length-1];if(m[1]=="#"&&elem&&elem.getElementById&&!jQuery.isXMLDoc(elem)){var oid=elem.getElementById(m[2]);if((jQuery.browser.msie||jQuery.browser.opera)&&oid&&typeof oid.id=="string"&&oid.id!=m[2])oid=jQuery('[@id="'+m[2]+'"]',elem)[0];ret=r=oid&&(!m[3]||jQuery.nodeName(oid,m[3]))?[oid]:[];}else{for(var i=0;ret[i];i++){var tag=m[1]=="#"&&m[3]?m[3]:m[1]!=""||m[0]==""?"*":m[2];if(tag=="*"&&ret[i].nodeName.toLowerCase()=="object")tag="param";r=jQuery.merge(r,ret[i].getElementsByTagName(tag));}if(m[1]==".")r=jQuery.classFilter(r,m[2]);if(m[1]=="#"){var tmp=[];for(var i=0;r[i];i++)if(r[i].getAttribute("id")==m[2]){tmp=[r[i]];break;}r=tmp;}ret=r;}t=t.replace(re2,"");}}if(t){var val=jQuery.filter(t,r);ret=r=val.r;t=jQuery.trim(val.t);}}if(t)ret=[];if(ret&&context==ret[0])ret.shift();done=jQuery.merge(done,ret);return done;},classFilter:function(r,m,not){m=" "+m+" ";var tmp=[];for(var i=0;r[i];i++){var pass=(" "+r[i].className+" ").indexOf(m)>=0;if(!not&&pass||not&&!pass)tmp.push(r[i]);}return tmp;},filter:function(t,r,not){var last;while(t&&t!=last){last=t;var p=jQuery.parse,m;for(var i=0;p[i];i++){m=p[i].exec(t);if(m){t=t.substring(m[0].length);m[2]=m[2].replace(/\\/g,"");break;}}if(!m)break;if(m[1]==":"&&m[2]=="not")r=isSimple.test(m[3])?jQuery.filter(m[3],r,true).r:jQuery(r).not(m[3]);else if(m[1]==".")r=jQuery.classFilter(r,m[2],not);else if(m[1]=="["){var tmp=[],type=m[3];for(var i=0,rl=r.length;i<rl;i++){var a=r[i],z=a[jQuery.props[m[2]]||m[2]];if(z==null||/href|src|selected/.test(m[2]))z=jQuery.attr(a,m[2])||'';if((type==""&&!!z||type=="="&&z==m[5]||type=="!="&&z!=m[5]||type=="^="&&z&&!z.indexOf(m[5])||type=="$="&&z.substr(z.length-m[5].length)==m[5]||(type=="*="||type=="~=")&&z.indexOf(m[5])>=0)^not)tmp.push(a);}r=tmp;}else if(m[1]==":"&&m[2]=="nth-child"){var merge={},tmp=[],test=/(-?)(\d*)n((?:\+|-)?\d*)/.exec(m[3]=="even"&&"2n"||m[3]=="odd"&&"2n+1"||!/\D/.test(m[3])&&"0n+"+m[3]||m[3]),first=(test[1]+(test[2]||1))-0,last=test[3]-0;for(var i=0,rl=r.length;i<rl;i++){var node=r[i],parentNode=node.parentNode,id=jQuery.data(parentNode);if(!merge[id]){var c=1;for(var n=parentNode.firstChild;n;n=n.nextSibling)if(n.nodeType==1)n.nodeIndex=c++;merge[id]=true;}var add=false;if(first==0){if(node.nodeIndex==last)add=true;}else if((node.nodeIndex-last)%first==0&&(node.nodeIndex-last)/first>=0)add=true;if(add^not)tmp.push(node);}r=tmp;}else{var fn=jQuery.expr[m[1]];if(typeof fn=="object")fn=fn[m[2]];if(typeof fn=="string")fn=eval("false||function(a,i){return "+fn+";}");r=jQuery.grep(r,function(elem,i){return fn(elem,i,m,r);},not);}}return{r:r,t:t};},dir:function(elem,dir){var matched=[],cur=elem[dir];while(cur&&cur!=document){if(cur.nodeType==1)matched.push(cur);cur=cur[dir];}return matched;},nth:function(cur,result,dir,elem){result=result||1;var num=0;for(;cur;cur=cur[dir])if(cur.nodeType==1&&++num==result)break;return cur;},sibling:function(n,elem){var r=[];for(;n;n=n.nextSibling){if(n.nodeType==1&&n!=elem)r.push(n);}return r;}});jQuery.event={add:function(elem,types,handler,data){if(elem.nodeType==3||elem.nodeType==8)return;if(jQuery.browser.msie&&elem.setInterval)elem=window;if(!handler.guid)handler.guid=this.guid++;if(data!=undefined){var fn=handler;handler=this.proxy(fn,function(){return fn.apply(this,arguments);});handler.data=data;}var events=jQuery.data(elem,"events")||jQuery.data(elem,"events",{}),handle=jQuery.data(elem,"handle")||jQuery.data(elem,"handle",function(){if(typeof jQuery!="undefined"&&!jQuery.event.triggered)return jQuery.event.handle.apply(arguments.callee.elem,arguments);});handle.elem=elem;jQuery.each(types.split(/\s+/),function(index,type){var parts=type.split(".");type=parts[0];handler.type=parts[1];var handlers=events[type];if(!handlers){handlers=events[type]={};if(!jQuery.event.special[type]||jQuery.event.special[type].setup.call(elem)===false){if(elem.addEventListener)elem.addEventListener(type,handle,false);else if(elem.attachEvent)elem.attachEvent("on"+type,handle);}}handlers[handler.guid]=handler;jQuery.event.global[type]=true;});elem=null;},guid:1,global:{},remove:function(elem,types,handler){if(elem.nodeType==3||elem.nodeType==8)return;var events=jQuery.data(elem,"events"),ret,index;if(events){if(types==undefined||(typeof types=="string"&&types.charAt(0)=="."))for(var type in events)this.remove(elem,type+(types||""));else{if(types.type){handler=types.handler;types=types.type;}jQuery.each(types.split(/\s+/),function(index,type){var parts=type.split(".");type=parts[0];if(events[type]){if(handler)delete events[type][handler.guid];else
26
+ for(handler in events[type])if(!parts[1]||events[type][handler].type==parts[1])delete events[type][handler];for(ret in events[type])break;if(!ret){if(!jQuery.event.special[type]||jQuery.event.special[type].teardown.call(elem)===false){if(elem.removeEventListener)elem.removeEventListener(type,jQuery.data(elem,"handle"),false);else if(elem.detachEvent)elem.detachEvent("on"+type,jQuery.data(elem,"handle"));}ret=null;delete events[type];}}});}for(ret in events)break;if(!ret){var handle=jQuery.data(elem,"handle");if(handle)handle.elem=null;jQuery.removeData(elem,"events");jQuery.removeData(elem,"handle");}}},trigger:function(type,data,elem,donative,extra){data=jQuery.makeArray(data);if(type.indexOf("!")>=0){type=type.slice(0,-1);var exclusive=true;}if(!elem){if(this.global[type])jQuery("*").add([window,document]).trigger(type,data);}else{if(elem.nodeType==3||elem.nodeType==8)return undefined;var val,ret,fn=jQuery.isFunction(elem[type]||null),event=!data[0]||!data[0].preventDefault;if(event){data.unshift({type:type,target:elem,preventDefault:function(){},stopPropagation:function(){},timeStamp:now()});data[0][expando]=true;}data[0].type=type;if(exclusive)data[0].exclusive=true;var handle=jQuery.data(elem,"handle");if(handle)val=handle.apply(elem,data);if((!fn||(jQuery.nodeName(elem,'a')&&type=="click"))&&elem["on"+type]&&elem["on"+type].apply(elem,data)===false)val=false;if(event)data.shift();if(extra&&jQuery.isFunction(extra)){ret=extra.apply(elem,val==null?data:data.concat(val));if(ret!==undefined)val=ret;}if(fn&&donative!==false&&val!==false&&!(jQuery.nodeName(elem,'a')&&type=="click")){this.triggered=true;try{elem[type]();}catch(e){}}this.triggered=false;}return val;},handle:function(event){var val,ret,namespace,all,handlers;event=arguments[0]=jQuery.event.fix(event||window.event);namespace=event.type.split(".");event.type=namespace[0];namespace=namespace[1];all=!namespace&&!event.exclusive;handlers=(jQuery.data(this,"events")||{})[event.type];for(var j in handlers){var handler=handlers[j];if(all||handler.type==namespace){event.handler=handler;event.data=handler.data;ret=handler.apply(this,arguments);if(val!==false)val=ret;if(ret===false){event.preventDefault();event.stopPropagation();}}}return val;},fix:function(event){if(event[expando]==true)return event;var originalEvent=event;event={originalEvent:originalEvent};var props="altKey attrChange attrName bubbles button cancelable charCode clientX clientY ctrlKey currentTarget data detail eventPhase fromElement handler keyCode metaKey newValue originalTarget pageX pageY prevValue relatedNode relatedTarget screenX screenY shiftKey srcElement target timeStamp toElement type view wheelDelta which".split(" ");for(var i=props.length;i;i--)event[props[i]]=originalEvent[props[i]];event[expando]=true;event.preventDefault=function(){if(originalEvent.preventDefault)originalEvent.preventDefault();originalEvent.returnValue=false;};event.stopPropagation=function(){if(originalEvent.stopPropagation)originalEvent.stopPropagation();originalEvent.cancelBubble=true;};event.timeStamp=event.timeStamp||now();if(!event.target)event.target=event.srcElement||document;if(event.target.nodeType==3)event.target=event.target.parentNode;if(!event.relatedTarget&&event.fromElement)event.relatedTarget=event.fromElement==event.target?event.toElement:event.fromElement;if(event.pageX==null&&event.clientX!=null){var doc=document.documentElement,body=document.body;event.pageX=event.clientX+(doc&&doc.scrollLeft||body&&body.scrollLeft||0)-(doc.clientLeft||0);event.pageY=event.clientY+(doc&&doc.scrollTop||body&&body.scrollTop||0)-(doc.clientTop||0);}if(!event.which&&((event.charCode||event.charCode===0)?event.charCode:event.keyCode))event.which=event.charCode||event.keyCode;if(!event.metaKey&&event.ctrlKey)event.metaKey=event.ctrlKey;if(!event.which&&event.button)event.which=(event.button&1?1:(event.button&2?3:(event.button&4?2:0)));return event;},proxy:function(fn,proxy){proxy.guid=fn.guid=fn.guid||proxy.guid||this.guid++;return proxy;},special:{ready:{setup:function(){bindReady();return;},teardown:function(){return;}},mouseenter:{setup:function(){if(jQuery.browser.msie)return false;jQuery(this).bind("mouseover",jQuery.event.special.mouseenter.handler);return true;},teardown:function(){if(jQuery.browser.msie)return false;jQuery(this).unbind("mouseover",jQuery.event.special.mouseenter.handler);return true;},handler:function(event){if(withinElement(event,this))return true;event.type="mouseenter";return jQuery.event.handle.apply(this,arguments);}},mouseleave:{setup:function(){if(jQuery.browser.msie)return false;jQuery(this).bind("mouseout",jQuery.event.special.mouseleave.handler);return true;},teardown:function(){if(jQuery.browser.msie)return false;jQuery(this).unbind("mouseout",jQuery.event.special.mouseleave.handler);return true;},handler:function(event){if(withinElement(event,this))return true;event.type="mouseleave";return jQuery.event.handle.apply(this,arguments);}}}};jQuery.fn.extend({bind:function(type,data,fn){return type=="unload"?this.one(type,data,fn):this.each(function(){jQuery.event.add(this,type,fn||data,fn&&data);});},one:function(type,data,fn){var one=jQuery.event.proxy(fn||data,function(event){jQuery(this).unbind(event,one);return(fn||data).apply(this,arguments);});return this.each(function(){jQuery.event.add(this,type,one,fn&&data);});},unbind:function(type,fn){return this.each(function(){jQuery.event.remove(this,type,fn);});},trigger:function(type,data,fn){return this.each(function(){jQuery.event.trigger(type,data,this,true,fn);});},triggerHandler:function(type,data,fn){return this[0]&&jQuery.event.trigger(type,data,this[0],false,fn);},toggle:function(fn){var args=arguments,i=1;while(i<args.length)jQuery.event.proxy(fn,args[i++]);return this.click(jQuery.event.proxy(fn,function(event){this.lastToggle=(this.lastToggle||0)%i;event.preventDefault();return args[this.lastToggle++].apply(this,arguments)||false;}));},hover:function(fnOver,fnOut){return this.bind('mouseenter',fnOver).bind('mouseleave',fnOut);},ready:function(fn){bindReady();if(jQuery.isReady)fn.call(document,jQuery);else
27
+ jQuery.readyList.push(function(){return fn.call(this,jQuery);});return this;}});jQuery.extend({isReady:false,readyList:[],ready:function(){if(!jQuery.isReady){jQuery.isReady=true;if(jQuery.readyList){jQuery.each(jQuery.readyList,function(){this.call(document);});jQuery.readyList=null;}jQuery(document).triggerHandler("ready");}}});var readyBound=false;function bindReady(){if(readyBound)return;readyBound=true;if(document.addEventListener&&!jQuery.browser.opera)document.addEventListener("DOMContentLoaded",jQuery.ready,false);if(jQuery.browser.msie&&window==top)(function(){if(jQuery.isReady)return;try{document.documentElement.doScroll("left");}catch(error){setTimeout(arguments.callee,0);return;}jQuery.ready();})();if(jQuery.browser.opera)document.addEventListener("DOMContentLoaded",function(){if(jQuery.isReady)return;for(var i=0;i<document.styleSheets.length;i++)if(document.styleSheets[i].disabled){setTimeout(arguments.callee,0);return;}jQuery.ready();},false);if(jQuery.browser.safari){var numStyles;(function(){if(jQuery.isReady)return;if(document.readyState!="loaded"&&document.readyState!="complete"){setTimeout(arguments.callee,0);return;}if(numStyles===undefined)numStyles=jQuery("style, link[rel=stylesheet]").length;if(document.styleSheets.length!=numStyles){setTimeout(arguments.callee,0);return;}jQuery.ready();})();}jQuery.event.add(window,"load",jQuery.ready);}jQuery.each(("blur,focus,load,resize,scroll,unload,click,dblclick,"+"mousedown,mouseup,mousemove,mouseover,mouseout,change,select,"+"submit,keydown,keypress,keyup,error").split(","),function(i,name){jQuery.fn[name]=function(fn){return fn?this.bind(name,fn):this.trigger(name);};});var withinElement=function(event,elem){var parent=event.relatedTarget;while(parent&&parent!=elem)try{parent=parent.parentNode;}catch(error){parent=elem;}return parent==elem;};jQuery(window).bind("unload",function(){jQuery("*").add(document).unbind();});jQuery.fn.extend({_load:jQuery.fn.load,load:function(url,params,callback){if(typeof url!='string')return this._load(url);var off=url.indexOf(" ");if(off>=0){var selector=url.slice(off,url.length);url=url.slice(0,off);}callback=callback||function(){};var type="GET";if(params)if(jQuery.isFunction(params)){callback=params;params=null;}else{params=jQuery.param(params);type="POST";}var self=this;jQuery.ajax({url:url,type:type,dataType:"html",data:params,complete:function(res,status){if(status=="success"||status=="notmodified")self.html(selector?jQuery("<div/>").append(res.responseText.replace(/<script(.|\s)*?\/script>/g,"")).find(selector):res.responseText);self.each(callback,[res.responseText,status,res]);}});return this;},serialize:function(){return jQuery.param(this.serializeArray());},serializeArray:function(){return this.map(function(){return jQuery.nodeName(this,"form")?jQuery.makeArray(this.elements):this;}).filter(function(){return this.name&&!this.disabled&&(this.checked||/select|textarea/i.test(this.nodeName)||/text|hidden|password/i.test(this.type));}).map(function(i,elem){var val=jQuery(this).val();return val==null?null:val.constructor==Array?jQuery.map(val,function(val,i){return{name:elem.name,value:val};}):{name:elem.name,value:val};}).get();}});jQuery.each("ajaxStart,ajaxStop,ajaxComplete,ajaxError,ajaxSuccess,ajaxSend".split(","),function(i,o){jQuery.fn[o]=function(f){return this.bind(o,f);};});var jsc=now();jQuery.extend({get:function(url,data,callback,type){if(jQuery.isFunction(data)){callback=data;data=null;}return jQuery.ajax({type:"GET",url:url,data:data,success:callback,dataType:type});},getScript:function(url,callback){return jQuery.get(url,null,callback,"script");},getJSON:function(url,data,callback){return jQuery.get(url,data,callback,"json");},post:function(url,data,callback,type){if(jQuery.isFunction(data)){callback=data;data={};}return jQuery.ajax({type:"POST",url:url,data:data,success:callback,dataType:type});},ajaxSetup:function(settings){jQuery.extend(jQuery.ajaxSettings,settings);},ajaxSettings:{url:location.href,global:true,type:"GET",timeout:0,contentType:"application/x-www-form-urlencoded",processData:true,async:true,data:null,username:null,password:null,accepts:{xml:"application/xml, text/xml",html:"text/html",script:"text/javascript, application/javascript",json:"application/json, text/javascript",text:"text/plain",_default:"*/*"}},lastModified:{},ajax:function(s){s=jQuery.extend(true,s,jQuery.extend(true,{},jQuery.ajaxSettings,s));var jsonp,jsre=/=\?(&|$)/g,status,data,type=s.type.toUpperCase();if(s.data&&s.processData&&typeof s.data!="string")s.data=jQuery.param(s.data);if(s.dataType=="jsonp"){if(type=="GET"){if(!s.url.match(jsre))s.url+=(s.url.match(/\?/)?"&":"?")+(s.jsonp||"callback")+"=?";}else if(!s.data||!s.data.match(jsre))s.data=(s.data?s.data+"&":"")+(s.jsonp||"callback")+"=?";s.dataType="json";}if(s.dataType=="json"&&(s.data&&s.data.match(jsre)||s.url.match(jsre))){jsonp="jsonp"+jsc++;if(s.data)s.data=(s.data+"").replace(jsre,"="+jsonp+"$1");s.url=s.url.replace(jsre,"="+jsonp+"$1");s.dataType="script";window[jsonp]=function(tmp){data=tmp;success();complete();window[jsonp]=undefined;try{delete window[jsonp];}catch(e){}if(head)head.removeChild(script);};}if(s.dataType=="script"&&s.cache==null)s.cache=false;if(s.cache===false&&type=="GET"){var ts=now();var ret=s.url.replace(/(\?|&)_=.*?(&|$)/,"$1_="+ts+"$2");s.url=ret+((ret==s.url)?(s.url.match(/\?/)?"&":"?")+"_="+ts:"");}if(s.data&&type=="GET"){s.url+=(s.url.match(/\?/)?"&":"?")+s.data;s.data=null;}if(s.global&&!jQuery.active++)jQuery.event.trigger("ajaxStart");var remote=/^(?:\w+:)?\/\/([^\/?#]+)/;if(s.dataType=="script"&&type=="GET"&&remote.test(s.url)&&remote.exec(s.url)[1]!=location.host){var head=document.getElementsByTagName("head")[0];var script=document.createElement("script");script.src=s.url;if(s.scriptCharset)script.charset=s.scriptCharset;if(!jsonp){var done=false;script.onload=script.onreadystatechange=function(){if(!done&&(!this.readyState||this.readyState=="loaded"||this.readyState=="complete")){done=true;success();complete();head.removeChild(script);}};}head.appendChild(script);return undefined;}var requestDone=false;var xhr=window.ActiveXObject?new ActiveXObject("Microsoft.XMLHTTP"):new XMLHttpRequest();if(s.username)xhr.open(type,s.url,s.async,s.username,s.password);else
28
+ xhr.open(type,s.url,s.async);try{if(s.data)xhr.setRequestHeader("Content-Type",s.contentType);if(s.ifModified)xhr.setRequestHeader("If-Modified-Since",jQuery.lastModified[s.url]||"Thu, 01 Jan 1970 00:00:00 GMT");xhr.setRequestHeader("X-Requested-With","XMLHttpRequest");xhr.setRequestHeader("Accept",s.dataType&&s.accepts[s.dataType]?s.accepts[s.dataType]+", */*":s.accepts._default);}catch(e){}if(s.beforeSend&&s.beforeSend(xhr,s)===false){s.global&&jQuery.active--;xhr.abort();return false;}if(s.global)jQuery.event.trigger("ajaxSend",[xhr,s]);var onreadystatechange=function(isTimeout){if(!requestDone&&xhr&&(xhr.readyState==4||isTimeout=="timeout")){requestDone=true;if(ival){clearInterval(ival);ival=null;}status=isTimeout=="timeout"&&"timeout"||!jQuery.httpSuccess(xhr)&&"error"||s.ifModified&&jQuery.httpNotModified(xhr,s.url)&&"notmodified"||"success";if(status=="success"){try{data=jQuery.httpData(xhr,s.dataType,s.dataFilter);}catch(e){status="parsererror";}}if(status=="success"){var modRes;try{modRes=xhr.getResponseHeader("Last-Modified");}catch(e){}if(s.ifModified&&modRes)jQuery.lastModified[s.url]=modRes;if(!jsonp)success();}else
29
+ jQuery.handleError(s,xhr,status);complete();if(s.async)xhr=null;}};if(s.async){var ival=setInterval(onreadystatechange,13);if(s.timeout>0)setTimeout(function(){if(xhr){xhr.abort();if(!requestDone)onreadystatechange("timeout");}},s.timeout);}try{xhr.send(s.data);}catch(e){jQuery.handleError(s,xhr,null,e);}if(!s.async)onreadystatechange();function success(){if(s.success)s.success(data,status);if(s.global)jQuery.event.trigger("ajaxSuccess",[xhr,s]);}function complete(){if(s.complete)s.complete(xhr,status);if(s.global)jQuery.event.trigger("ajaxComplete",[xhr,s]);if(s.global&&!--jQuery.active)jQuery.event.trigger("ajaxStop");}return xhr;},handleError:function(s,xhr,status,e){if(s.error)s.error(xhr,status,e);if(s.global)jQuery.event.trigger("ajaxError",[xhr,s,e]);},active:0,httpSuccess:function(xhr){try{return!xhr.status&&location.protocol=="file:"||(xhr.status>=200&&xhr.status<300)||xhr.status==304||xhr.status==1223||jQuery.browser.safari&&xhr.status==undefined;}catch(e){}return false;},httpNotModified:function(xhr,url){try{var xhrRes=xhr.getResponseHeader("Last-Modified");return xhr.status==304||xhrRes==jQuery.lastModified[url]||jQuery.browser.safari&&xhr.status==undefined;}catch(e){}return false;},httpData:function(xhr,type,filter){var ct=xhr.getResponseHeader("content-type"),xml=type=="xml"||!type&&ct&&ct.indexOf("xml")>=0,data=xml?xhr.responseXML:xhr.responseText;if(xml&&data.documentElement.tagName=="parsererror")throw"parsererror";if(filter)data=filter(data,type);if(type=="script")jQuery.globalEval(data);if(type=="json")data=eval("("+data+")");return data;},param:function(a){var s=[];if(a.constructor==Array||a.jquery)jQuery.each(a,function(){s.push(encodeURIComponent(this.name)+"="+encodeURIComponent(this.value));});else
30
+ for(var j in a)if(a[j]&&a[j].constructor==Array)jQuery.each(a[j],function(){s.push(encodeURIComponent(j)+"="+encodeURIComponent(this));});else
31
+ s.push(encodeURIComponent(j)+"="+encodeURIComponent(jQuery.isFunction(a[j])?a[j]():a[j]));return s.join("&").replace(/%20/g,"+");}});jQuery.fn.extend({show:function(speed,callback){return speed?this.animate({height:"show",width:"show",opacity:"show"},speed,callback):this.filter(":hidden").each(function(){this.style.display=this.oldblock||"";if(jQuery.css(this,"display")=="none"){var elem=jQuery("<"+this.tagName+" />").appendTo("body");this.style.display=elem.css("display");if(this.style.display=="none")this.style.display="block";elem.remove();}}).end();},hide:function(speed,callback){return speed?this.animate({height:"hide",width:"hide",opacity:"hide"},speed,callback):this.filter(":visible").each(function(){this.oldblock=this.oldblock||jQuery.css(this,"display");this.style.display="none";}).end();},_toggle:jQuery.fn.toggle,toggle:function(fn,fn2){return jQuery.isFunction(fn)&&jQuery.isFunction(fn2)?this._toggle.apply(this,arguments):fn?this.animate({height:"toggle",width:"toggle",opacity:"toggle"},fn,fn2):this.each(function(){jQuery(this)[jQuery(this).is(":hidden")?"show":"hide"]();});},slideDown:function(speed,callback){return this.animate({height:"show"},speed,callback);},slideUp:function(speed,callback){return this.animate({height:"hide"},speed,callback);},slideToggle:function(speed,callback){return this.animate({height:"toggle"},speed,callback);},fadeIn:function(speed,callback){return this.animate({opacity:"show"},speed,callback);},fadeOut:function(speed,callback){return this.animate({opacity:"hide"},speed,callback);},fadeTo:function(speed,to,callback){return this.animate({opacity:to},speed,callback);},animate:function(prop,speed,easing,callback){var optall=jQuery.speed(speed,easing,callback);return this[optall.queue===false?"each":"queue"](function(){if(this.nodeType!=1)return false;var opt=jQuery.extend({},optall),p,hidden=jQuery(this).is(":hidden"),self=this;for(p in prop){if(prop[p]=="hide"&&hidden||prop[p]=="show"&&!hidden)return opt.complete.call(this);if(p=="height"||p=="width"){opt.display=jQuery.css(this,"display");opt.overflow=this.style.overflow;}}if(opt.overflow!=null)this.style.overflow="hidden";opt.curAnim=jQuery.extend({},prop);jQuery.each(prop,function(name,val){var e=new jQuery.fx(self,opt,name);if(/toggle|show|hide/.test(val))e[val=="toggle"?hidden?"show":"hide":val](prop);else{var parts=val.toString().match(/^([+-]=)?([\d+-.]+)(.*)$/),start=e.cur(true)||0;if(parts){var end=parseFloat(parts[2]),unit=parts[3]||"px";if(unit!="px"){self.style[name]=(end||1)+unit;start=((end||1)/e.cur(true))*start;self.style[name]=start+unit;}if(parts[1])end=((parts[1]=="-="?-1:1)*end)+start;e.custom(start,end,unit);}else
32
+ e.custom(start,val,"");}});return true;});},queue:function(type,fn){if(jQuery.isFunction(type)||(type&&type.constructor==Array)){fn=type;type="fx";}if(!type||(typeof type=="string"&&!fn))return queue(this[0],type);return this.each(function(){if(fn.constructor==Array)queue(this,type,fn);else{queue(this,type).push(fn);if(queue(this,type).length==1)fn.call(this);}});},stop:function(clearQueue,gotoEnd){var timers=jQuery.timers;if(clearQueue)this.queue([]);this.each(function(){for(var i=timers.length-1;i>=0;i--)if(timers[i].elem==this){if(gotoEnd)timers[i](true);timers.splice(i,1);}});if(!gotoEnd)this.dequeue();return this;}});var queue=function(elem,type,array){if(elem){type=type||"fx";var q=jQuery.data(elem,type+"queue");if(!q||array)q=jQuery.data(elem,type+"queue",jQuery.makeArray(array));}return q;};jQuery.fn.dequeue=function(type){type=type||"fx";return this.each(function(){var q=queue(this,type);q.shift();if(q.length)q[0].call(this);});};jQuery.extend({speed:function(speed,easing,fn){var opt=speed&&speed.constructor==Object?speed:{complete:fn||!fn&&easing||jQuery.isFunction(speed)&&speed,duration:speed,easing:fn&&easing||easing&&easing.constructor!=Function&&easing};opt.duration=(opt.duration&&opt.duration.constructor==Number?opt.duration:jQuery.fx.speeds[opt.duration])||jQuery.fx.speeds.def;opt.old=opt.complete;opt.complete=function(){if(opt.queue!==false)jQuery(this).dequeue();if(jQuery.isFunction(opt.old))opt.old.call(this);};return opt;},easing:{linear:function(p,n,firstNum,diff){return firstNum+diff*p;},swing:function(p,n,firstNum,diff){return((-Math.cos(p*Math.PI)/2)+0.5)*diff+firstNum;}},timers:[],timerId:null,fx:function(elem,options,prop){this.options=options;this.elem=elem;this.prop=prop;if(!options.orig)options.orig={};}});jQuery.fx.prototype={update:function(){if(this.options.step)this.options.step.call(this.elem,this.now,this);(jQuery.fx.step[this.prop]||jQuery.fx.step._default)(this);if(this.prop=="height"||this.prop=="width")this.elem.style.display="block";},cur:function(force){if(this.elem[this.prop]!=null&&this.elem.style[this.prop]==null)return this.elem[this.prop];var r=parseFloat(jQuery.css(this.elem,this.prop,force));return r&&r>-10000?r:parseFloat(jQuery.curCSS(this.elem,this.prop))||0;},custom:function(from,to,unit){this.startTime=now();this.start=from;this.end=to;this.unit=unit||this.unit||"px";this.now=this.start;this.pos=this.state=0;this.update();var self=this;function t(gotoEnd){return self.step(gotoEnd);}t.elem=this.elem;jQuery.timers.push(t);if(jQuery.timerId==null){jQuery.timerId=setInterval(function(){var timers=jQuery.timers;for(var i=0;i<timers.length;i++)if(!timers[i]())timers.splice(i--,1);if(!timers.length){clearInterval(jQuery.timerId);jQuery.timerId=null;}},13);}},show:function(){this.options.orig[this.prop]=jQuery.attr(this.elem.style,this.prop);this.options.show=true;this.custom(0,this.cur());if(this.prop=="width"||this.prop=="height")this.elem.style[this.prop]="1px";jQuery(this.elem).show();},hide:function(){this.options.orig[this.prop]=jQuery.attr(this.elem.style,this.prop);this.options.hide=true;this.custom(this.cur(),0);},step:function(gotoEnd){var t=now();if(gotoEnd||t>this.options.duration+this.startTime){this.now=this.end;this.pos=this.state=1;this.update();this.options.curAnim[this.prop]=true;var done=true;for(var i in this.options.curAnim)if(this.options.curAnim[i]!==true)done=false;if(done){if(this.options.display!=null){this.elem.style.overflow=this.options.overflow;this.elem.style.display=this.options.display;if(jQuery.css(this.elem,"display")=="none")this.elem.style.display="block";}if(this.options.hide)this.elem.style.display="none";if(this.options.hide||this.options.show)for(var p in this.options.curAnim)jQuery.attr(this.elem.style,p,this.options.orig[p]);}if(done)this.options.complete.call(this.elem);return false;}else{var n=t-this.startTime;this.state=n/this.options.duration;this.pos=jQuery.easing[this.options.easing||(jQuery.easing.swing?"swing":"linear")](this.state,n,0,1,this.options.duration);this.now=this.start+((this.end-this.start)*this.pos);this.update();}return true;}};jQuery.extend(jQuery.fx,{speeds:{slow:600,fast:200,def:400},step:{scrollLeft:function(fx){fx.elem.scrollLeft=fx.now;},scrollTop:function(fx){fx.elem.scrollTop=fx.now;},opacity:function(fx){jQuery.attr(fx.elem.style,"opacity",fx.now);},_default:function(fx){fx.elem.style[fx.prop]=fx.now+fx.unit;}}});jQuery.fn.offset=function(){var left=0,top=0,elem=this[0],results;if(elem)with(jQuery.browser){var parent=elem.parentNode,offsetChild=elem,offsetParent=elem.offsetParent,doc=elem.ownerDocument,safari2=safari&&parseInt(version)<522&&!/adobeair/i.test(userAgent),css=jQuery.curCSS,fixed=css(elem,"position")=="fixed";if(elem.getBoundingClientRect){var box=elem.getBoundingClientRect();add(box.left+Math.max(doc.documentElement.scrollLeft,doc.body.scrollLeft),box.top+Math.max(doc.documentElement.scrollTop,doc.body.scrollTop));add(-doc.documentElement.clientLeft,-doc.documentElement.clientTop);}else{add(elem.offsetLeft,elem.offsetTop);while(offsetParent){add(offsetParent.offsetLeft,offsetParent.offsetTop);if(mozilla&&!/^t(able|d|h)$/i.test(offsetParent.tagName)||safari&&!safari2)border(offsetParent);if(!fixed&&css(offsetParent,"position")=="fixed")fixed=true;offsetChild=/^body$/i.test(offsetParent.tagName)?offsetChild:offsetParent;offsetParent=offsetParent.offsetParent;}while(parent&&parent.tagName&&!/^body|html$/i.test(parent.tagName)){if(!/^inline|table.*$/i.test(css(parent,"display")))add(-parent.scrollLeft,-parent.scrollTop);if(mozilla&&css(parent,"overflow")!="visible")border(parent);parent=parent.parentNode;}if((safari2&&(fixed||css(offsetChild,"position")=="absolute"))||(mozilla&&css(offsetChild,"position")!="absolute"))add(-doc.body.offsetLeft,-doc.body.offsetTop);if(fixed)add(Math.max(doc.documentElement.scrollLeft,doc.body.scrollLeft),Math.max(doc.documentElement.scrollTop,doc.body.scrollTop));}results={top:top,left:left};}function border(elem){add(jQuery.curCSS(elem,"borderLeftWidth",true),jQuery.curCSS(elem,"borderTopWidth",true));}function add(l,t){left+=parseInt(l,10)||0;top+=parseInt(t,10)||0;}return results;};jQuery.fn.extend({position:function(){var left=0,top=0,results;if(this[0]){var offsetParent=this.offsetParent(),offset=this.offset(),parentOffset=/^body|html$/i.test(offsetParent[0].tagName)?{top:0,left:0}:offsetParent.offset();offset.top-=num(this,'marginTop');offset.left-=num(this,'marginLeft');parentOffset.top+=num(offsetParent,'borderTopWidth');parentOffset.left+=num(offsetParent,'borderLeftWidth');results={top:offset.top-parentOffset.top,left:offset.left-parentOffset.left};}return results;},offsetParent:function(){var offsetParent=this[0].offsetParent;while(offsetParent&&(!/^body|html$/i.test(offsetParent.tagName)&&jQuery.css(offsetParent,'position')=='static'))offsetParent=offsetParent.offsetParent;return jQuery(offsetParent);}});jQuery.each(['Left','Top'],function(i,name){var method='scroll'+name;jQuery.fn[method]=function(val){if(!this[0])return;return val!=undefined?this.each(function(){this==window||this==document?window.scrollTo(!i?val:jQuery(window).scrollLeft(),i?val:jQuery(window).scrollTop()):this[method]=val;}):this[0]==window||this[0]==document?self[i?'pageYOffset':'pageXOffset']||jQuery.boxModel&&document.documentElement[method]||document.body[method]:this[0][method];};});jQuery.each(["Height","Width"],function(i,name){var tl=i?"Left":"Top",br=i?"Right":"Bottom";jQuery.fn["inner"+name]=function(){return this[name.toLowerCase()]()+num(this,"padding"+tl)+num(this,"padding"+br);};jQuery.fn["outer"+name]=function(margin){return this["inner"+name]()+num(this,"border"+tl+"Width")+num(this,"border"+br+"Width")+(margin?num(this,"margin"+tl)+num(this,"margin"+br):0);};});})();
@@ -0,0 +1,285 @@
1
+ require 'cucumber/formatters/ansicolor'
2
+
3
+ module Cucumber
4
+ module Formatters
5
+ class PrettyFormatter
6
+ include ANSIColor
7
+
8
+ INDENT = "\n "
9
+
10
+ def initialize(io, step_mother, options={})
11
+ @io = (io == STDOUT) ? Kernel : io
12
+ @options = options
13
+ @step_mother = step_mother
14
+ @pending_scenarios = []
15
+ @passed = []
16
+ @failed = []
17
+ @pending_steps = []
18
+ @skipped = []
19
+ @last_executed_was_row = false
20
+ @pending_messages = {}
21
+ @forced_pending_step_count = 0
22
+
23
+ @total_scenario_count = 0
24
+ end
25
+
26
+ def feature_executing(feature)
27
+ @feature = feature
28
+ end
29
+
30
+ def header_executing(header)
31
+ @io.puts if @feature_newline
32
+ @feature_newline = true
33
+
34
+ header_lines = header.split("\n")
35
+ header_lines.each_with_index do |line, index|
36
+ @io.print line
37
+ if @options[:source] && index==0
38
+ @io.print padding_spaces(@feature)
39
+ @io.print comment("# #{@feature.file}")
40
+ end
41
+ @io.puts
42
+ end
43
+ end
44
+
45
+ def scenario_executing(scenario)
46
+ scenario_or_scenario_outline_keyword = scenario.outline? ? Cucumber.language['scenario_outline'] : Cucumber.language['scenario']
47
+
48
+ @scenario_failed = false
49
+ @io.puts if @last_executed_was_row && !scenario.row?
50
+ if scenario.row?
51
+ @last_executed_was_row = true
52
+ @io.print " |"
53
+ else
54
+ scenario_text = "#{scenario_or_scenario_outline_keyword}: #{scenario.name}"
55
+
56
+ if scenario.pending?
57
+ @pending_scenarios << scenario
58
+ @io.print pending(" #{scenario_text}")
59
+ elsif scenario.outline?
60
+ @io.print skipped(" #{scenario_text}")
61
+ else
62
+ @io.print passed(" #{scenario_text}")
63
+ end
64
+ @last_executed_was_row = false
65
+
66
+ if @options[:source]
67
+ @io.print padding_spaces(scenario)
68
+ @io.print comment("# #{scenario.file}:#{scenario.line}")
69
+ end
70
+ @io.puts
71
+ end
72
+ end
73
+
74
+ def scenario_executed(scenario)
75
+ @io.puts
76
+ if !scenario.row? && scenario.table_header
77
+ @table_column_widths = scenario.table_column_widths
78
+ @current_column = -1
79
+ @io.print " |"
80
+ print_row(scenario.table_header)
81
+ @io.puts
82
+ elsif scenario.row? && @scenario_failed
83
+ @io.puts
84
+ output_failing_step(@failed.last)
85
+ end
86
+ @total_scenario_count += 1
87
+ end
88
+
89
+ def step_passed(step, regexp, args)
90
+ if step.row?
91
+ args = step.visible_args if step.outline?
92
+ @passed << step
93
+ print_passed_args(args)
94
+ else
95
+ @passed << step
96
+ @io.print passed(" #{step.keyword} #{step.format(regexp){|param| passed_param(param) << passed}}")
97
+ if @options[:source]
98
+ @io.print padding_spaces(step)
99
+ @io.print source_comment(step)
100
+ end
101
+ @io.puts
102
+ end
103
+ end
104
+
105
+ def step_failed(step, regexp, args)
106
+ @scenario_failed = true
107
+ if step.row?
108
+ args = step.visible_args if step.outline?
109
+ @failed << step
110
+ print_failed_args(args)
111
+ else
112
+ @failed << step
113
+ @io.print failed(" #{step.keyword} #{step.format(regexp){|param| failed_param(param) << failed}}")
114
+ if @options[:source]
115
+ @io.print padding_spaces(step)
116
+ @io.print source_comment(step)
117
+ end
118
+ @io.puts
119
+ output_failing_step(step)
120
+ end
121
+ end
122
+
123
+ def step_skipped(step, regexp, args)
124
+ @skipped << step
125
+ if step.row?
126
+ args = step.visible_args if step.outline?
127
+ print_skipped_args(args)
128
+ else
129
+ @io.print skipped(" #{step.keyword} #{step.format(regexp){|param| skipped_param(param) << skipped}}")
130
+ if @options[:source]
131
+ @io.print padding_spaces(step)
132
+ if step.outline?
133
+ @io.print comment("# #{step.file}:#{step.line}")
134
+ else
135
+ @io.print source_comment(step)
136
+ end
137
+ end
138
+ @io.puts
139
+ end
140
+ end
141
+
142
+ def step_pending(step, regexp, args)
143
+ if step.row?
144
+ args = step.visible_args if step.outline?
145
+ @pending_steps << step
146
+ print_pending_args(args)
147
+ else
148
+ @pending_steps << step
149
+ @io.print pending(" #{step.keyword} #{step.name}")
150
+ if @options[:source]
151
+ @io.print padding_spaces(step)
152
+ @io.print comment("# #{step.file}:#{step.line}")
153
+ end
154
+ @io.puts
155
+ end
156
+ if step.forced_to_pending?
157
+ @pending_messages[regexp.inspect] ||= "#{step.keyword} #{regexp.inspect} (#{step.error.message}) #{source_comment(step)}"
158
+ @forced_pending_step_count += 1
159
+ end
160
+ end
161
+
162
+ def step_traced(step, regexp, args)
163
+ @io.print skipped(" #{step.keyword} #{step.format(regexp){|param| skipped_param(param) << skipped}}")
164
+ if @options[:source]
165
+ @io.print padding_spaces(step)
166
+ @io.print comment("# #{step.file}:#{step.line}")
167
+ end
168
+ @io.puts
169
+ end
170
+
171
+ def output_failing_step(step)
172
+ @io.puts failed(" #{step.error.message.split("\n").join(INDENT)} (#{step.error.class})")
173
+ @io.puts failed(" #{step.error.cucumber_backtrace.join(INDENT)}")
174
+ end
175
+
176
+ def dump
177
+ @io.puts
178
+
179
+ print_pending_messages if @pending_messages.any?
180
+
181
+ @io.puts dump_count(@total_scenario_count, "scenario")
182
+
183
+ @io.puts pending(dump_count(@pending_scenarios.length, "scenario", "pending")) if @pending_scenarios.any?
184
+
185
+ @io.puts passed(dump_count(@passed.length, "step", "passed")) if @passed.any?
186
+ @io.puts failed(dump_count(@failed.length, "step", "failed")) if @failed.any?
187
+ @io.puts skipped(dump_count(@skipped.length, "step", "skipped")) if @skipped.any?
188
+
189
+ if @pending_steps.any?
190
+ @io.print pending(dump_count(@pending_steps.length, "step", "pending"))
191
+ @io.print pending(" (#{number_of_unimplemented_steps} with no step definition)") if number_of_unimplemented_steps > 0
192
+ @io.puts
193
+ end
194
+
195
+ @io.print reset
196
+
197
+ print_snippets if @options[:snippets]
198
+ end
199
+
200
+ def dump_count(count, what, state=nil)
201
+ return [count, "#{what}#{count == 1 ? '' : 's'}", state].compact.join(" ")
202
+ end
203
+
204
+ def print_pending_messages
205
+ @io.puts "Pending Notes:"
206
+ @pending_messages.each_value do |message|
207
+ @io.puts message
208
+ end
209
+ @io.puts
210
+ end
211
+
212
+ def print_snippets
213
+ snippets = @pending_steps
214
+ snippets.delete_if {|snippet| snippet.row? || @step_mother.has_step_definition?(snippet.name)}
215
+
216
+ unless snippets.empty?
217
+ @io.puts "\nYou can use these snippets to implement pending steps which have no step definition:\n\n"
218
+
219
+ prev_keyword = nil
220
+ snippets = snippets.map do |step|
221
+ snippet = "#{step.actual_keyword} /^#{escape_regexp_characters(step.name)}$/ do\nend\n\n"
222
+ prev_keyword = step.keyword
223
+ snippet
224
+ end.compact.uniq
225
+
226
+ snippets.each do |snippet|
227
+ @io.puts snippet
228
+ end
229
+ end
230
+ end
231
+
232
+ private
233
+
234
+ def number_of_unimplemented_steps
235
+ @pending_steps.length - @forced_pending_step_count
236
+ end
237
+
238
+ def escape_regexp_characters(string)
239
+ Regexp.escape(string).gsub('\ ', ' ').gsub('/', '\/') unless string.nil?
240
+ end
241
+
242
+ def source_comment(step)
243
+ _, _, proc = step.regexp_args_proc(@step_mother)
244
+ comment(proc.to_comment_line)
245
+ end
246
+
247
+ def padding_spaces(tree_item)
248
+ " " * tree_item.padding_length
249
+ end
250
+
251
+ def next_column_index
252
+ @current_column ||= -1
253
+ @current_column += 1
254
+ @current_column = 0 if @current_column >= @table_column_widths.size
255
+ @current_column
256
+ end
257
+
258
+ def print_row(row_args, &colorize_proc)
259
+ colorize_proc = Proc.new{|row_element| row_element} unless colorize_proc
260
+
261
+ row_args.each do |row_arg|
262
+ column_index = next_column_index
263
+ @io.print colorize_proc[row_arg.ljust(@table_column_widths[column_index])]
264
+ @io.print "|"
265
+ end
266
+ end
267
+
268
+ def print_passed_args(args)
269
+ print_row(args) {|arg| passed(arg)}
270
+ end
271
+
272
+ def print_skipped_args(args)
273
+ print_row(args) {|arg| skipped(arg)}
274
+ end
275
+
276
+ def print_failed_args(args)
277
+ print_row(args) {|arg| failed(arg)}
278
+ end
279
+
280
+ def print_pending_args(args)
281
+ print_row(args) {|arg| pending(arg)}
282
+ end
283
+ end
284
+ end
285
+ end