redcar 0.2.9dev

Sign up to get free protection for your applications and to get access to all the features.
Files changed (600) hide show
  1. data/CHANGES +64 -0
  2. data/LICENSE +32 -0
  3. data/README.md +64 -0
  4. data/ROADMAP.md +69 -0
  5. data/Rakefile +223 -0
  6. data/bin/redcar +6 -0
  7. data/config/default.yaml +15 -0
  8. data/ext/extconf.rb +18 -0
  9. data/lib/freebase2/README.txt +47 -0
  10. data/lib/freebase2/bin/default.yaml +15 -0
  11. data/lib/freebase2/bin/install.rb +42 -0
  12. data/lib/freebase2/bin/run.rb +48 -0
  13. data/lib/freebase2/lib/freebase/configuration.rb +535 -0
  14. data/lib/freebase2/lib/freebase/core.rb +197 -0
  15. data/lib/freebase2/lib/freebase/databus.rb +1128 -0
  16. data/lib/freebase2/lib/freebase/freebase.rb +60 -0
  17. data/lib/freebase2/lib/freebase/logger.rb +117 -0
  18. data/lib/freebase2/lib/freebase/plugin.rb +384 -0
  19. data/lib/freebase2/lib/freebase/properties.rb +130 -0
  20. data/lib/freebase2/lib/freebase/readers.rb +321 -0
  21. data/lib/freebase2/notes +61 -0
  22. data/lib/freebase2/plugins/raa_webrick/httpd.rb +125 -0
  23. data/lib/freebase2/plugins/raa_webrick/plugin.yaml +7 -0
  24. data/lib/freebase2/plugins/raa_webrick/web_root/test.html +5 -0
  25. data/lib/freebase2/plugins/raa_webrick/webserver.yaml +6 -0
  26. data/lib/freebase2/plugins/raa_xmlrpc4r/plugin.xml +8 -0
  27. data/lib/freebase2/plugins/raa_xmlrpc4r/rpcd.rb +54 -0
  28. data/lib/freebase2/regress/README +1 -0
  29. data/lib/little_plugger/History.txt +20 -0
  30. data/lib/little_plugger/Rakefile +34 -0
  31. data/lib/little_plugger/lib/little-plugger.rb +323 -0
  32. data/lib/little_plugger/spec/little-plugger_spec.rb +26 -0
  33. data/lib/little_plugger/spec/spec_helper.rb +16 -0
  34. data/lib/logging/History.txt +240 -0
  35. data/lib/logging/Rakefile +37 -0
  36. data/lib/logging/data/bad_logging_1.rb +13 -0
  37. data/lib/logging/data/bad_logging_2.rb +21 -0
  38. data/lib/logging/data/logging.rb +42 -0
  39. data/lib/logging/data/logging.yaml +63 -0
  40. data/lib/logging/data/simple_logging.rb +13 -0
  41. data/lib/logging/examples/appenders.rb +47 -0
  42. data/lib/logging/examples/classes.rb +41 -0
  43. data/lib/logging/examples/consolidation.rb +83 -0
  44. data/lib/logging/examples/formatting.rb +51 -0
  45. data/lib/logging/examples/hierarchies.rb +73 -0
  46. data/lib/logging/examples/layouts.rb +48 -0
  47. data/lib/logging/examples/loggers.rb +29 -0
  48. data/lib/logging/examples/names.rb +43 -0
  49. data/lib/logging/examples/simple.rb +17 -0
  50. data/lib/logging/lib/logging.rb +501 -0
  51. data/lib/logging/lib/logging/appender.rb +251 -0
  52. data/lib/logging/lib/logging/appenders.rb +131 -0
  53. data/lib/logging/lib/logging/appenders/buffering.rb +168 -0
  54. data/lib/logging/lib/logging/appenders/console.rb +60 -0
  55. data/lib/logging/lib/logging/appenders/email.rb +75 -0
  56. data/lib/logging/lib/logging/appenders/file.rb +58 -0
  57. data/lib/logging/lib/logging/appenders/growl.rb +197 -0
  58. data/lib/logging/lib/logging/appenders/io.rb +69 -0
  59. data/lib/logging/lib/logging/appenders/rolling_file.rb +293 -0
  60. data/lib/logging/lib/logging/appenders/string_io.rb +68 -0
  61. data/lib/logging/lib/logging/appenders/syslog.rb +194 -0
  62. data/lib/logging/lib/logging/config/configurator.rb +188 -0
  63. data/lib/logging/lib/logging/config/yaml_configurator.rb +191 -0
  64. data/lib/logging/lib/logging/layout.rb +117 -0
  65. data/lib/logging/lib/logging/layouts.rb +47 -0
  66. data/lib/logging/lib/logging/layouts/basic.rb +32 -0
  67. data/lib/logging/lib/logging/layouts/parseable.rb +211 -0
  68. data/lib/logging/lib/logging/layouts/pattern.rb +311 -0
  69. data/lib/logging/lib/logging/log_event.rb +45 -0
  70. data/lib/logging/lib/logging/logger.rb +503 -0
  71. data/lib/logging/lib/logging/repository.rb +232 -0
  72. data/lib/logging/lib/logging/root_logger.rb +61 -0
  73. data/lib/logging/lib/logging/stats.rb +278 -0
  74. data/lib/logging/lib/logging/utils.rb +153 -0
  75. data/lib/logging/lib/spec/logging_helper.rb +34 -0
  76. data/lib/logging/test/appenders/test_buffered_io.rb +176 -0
  77. data/lib/logging/test/appenders/test_console.rb +66 -0
  78. data/lib/logging/test/appenders/test_email.rb +170 -0
  79. data/lib/logging/test/appenders/test_file.rb +95 -0
  80. data/lib/logging/test/appenders/test_growl.rb +127 -0
  81. data/lib/logging/test/appenders/test_io.rb +129 -0
  82. data/lib/logging/test/appenders/test_rolling_file.rb +200 -0
  83. data/lib/logging/test/appenders/test_syslog.rb +194 -0
  84. data/lib/logging/test/benchmark.rb +86 -0
  85. data/lib/logging/test/config/test_configurator.rb +70 -0
  86. data/lib/logging/test/config/test_yaml_configurator.rb +40 -0
  87. data/lib/logging/test/layouts/test_basic.rb +42 -0
  88. data/lib/logging/test/layouts/test_json.rb +112 -0
  89. data/lib/logging/test/layouts/test_pattern.rb +198 -0
  90. data/lib/logging/test/layouts/test_yaml.rb +121 -0
  91. data/lib/logging/test/setup.rb +44 -0
  92. data/lib/logging/test/test_appender.rb +152 -0
  93. data/lib/logging/test/test_consolidate.rb +46 -0
  94. data/lib/logging/test/test_layout.rb +110 -0
  95. data/lib/logging/test/test_log_event.rb +80 -0
  96. data/lib/logging/test/test_logger.rb +699 -0
  97. data/lib/logging/test/test_logging.rb +267 -0
  98. data/lib/logging/test/test_repository.rb +158 -0
  99. data/lib/logging/test/test_root_logger.rb +81 -0
  100. data/lib/logging/test/test_stats.rb +274 -0
  101. data/lib/logging/test/test_utils.rb +116 -0
  102. data/lib/redcar.rb +12 -0
  103. data/lib/redcar/boot.rb +105 -0
  104. data/lib/redcar/install.rb +97 -0
  105. data/lib/redcar/plist.rb +83 -0
  106. data/lib/redcar/ruby_extensions.rb +14 -0
  107. data/lib/redcar/runner.rb +32 -0
  108. data/lib/redcar/usage.rb +24 -0
  109. data/lib/regex_replace.rb +220 -0
  110. data/plugins/application/features/main_menu.feature +9 -0
  111. data/plugins/application/features/main_window.feature +8 -0
  112. data/plugins/application/features/step_definitions/dialog_steps.rb +5 -0
  113. data/plugins/application/features/step_definitions/menu_steps.rb +21 -0
  114. data/plugins/application/features/step_definitions/window_steps.rb +4 -0
  115. data/plugins/application/features/support/env.rb +32 -0
  116. data/plugins/application/lib/application.rb +128 -0
  117. data/plugins/application/lib/application/assets/file.png +0 -0
  118. data/plugins/application/lib/application/command.rb +70 -0
  119. data/plugins/application/lib/application/command/executor.rb +46 -0
  120. data/plugins/application/lib/application/command/history.rb +49 -0
  121. data/plugins/application/lib/application/dialog.rb +15 -0
  122. data/plugins/application/lib/application/menu.rb +27 -0
  123. data/plugins/application/lib/application/menu/builder.rb +51 -0
  124. data/plugins/application/lib/application/menu/item.rb +26 -0
  125. data/plugins/application/lib/application/notebook.rb +77 -0
  126. data/plugins/application/lib/application/sensitive.rb +57 -0
  127. data/plugins/application/lib/application/sensitivity.rb +78 -0
  128. data/plugins/application/lib/application/tab.rb +47 -0
  129. data/plugins/application/lib/application/tab/command.rb +5 -0
  130. data/plugins/application/lib/application/window.rb +139 -0
  131. data/plugins/application/plugin.yaml +11 -0
  132. data/plugins/application/spec/application/application_spec.rb +23 -0
  133. data/plugins/application/spec/application/command/executor_spec.rb +67 -0
  134. data/plugins/application/spec/application/command/history_spec.rb +49 -0
  135. data/plugins/application/spec/application/command_spec.rb +59 -0
  136. data/plugins/application/spec/application/controllers/application_controller.rb +4 -0
  137. data/plugins/application/spec/application/controllers/notebook_controller.rb +4 -0
  138. data/plugins/application/spec/application/controllers/window_controller.rb +5 -0
  139. data/plugins/application/spec/application/menu/builder_spec.rb +57 -0
  140. data/plugins/application/spec/application/menu/menu_item_spec.rb +17 -0
  141. data/plugins/application/spec/application/menu_spec.rb +36 -0
  142. data/plugins/application/spec/application/notebook_spec.rb +26 -0
  143. data/plugins/application/spec/application/sensitive_spec.rb +156 -0
  144. data/plugins/application/spec/application/window_spec.rb +24 -0
  145. data/plugins/application/spec/spec_helper.rb +7 -0
  146. data/plugins/application_swt/lib/application_swt.rb +70 -0
  147. data/plugins/application_swt/lib/application_swt/cucumber_patches.rb +118 -0
  148. data/plugins/application_swt/lib/application_swt/cucumber_runner.rb +25 -0
  149. data/plugins/application_swt/lib/application_swt/dialog_adapter.rb +23 -0
  150. data/plugins/application_swt/lib/application_swt/event_loop.rb +27 -0
  151. data/plugins/application_swt/lib/application_swt/menu.rb +59 -0
  152. data/plugins/application_swt/lib/application_swt/menu/binding_translator.rb +39 -0
  153. data/plugins/application_swt/lib/application_swt/notebook.rb +129 -0
  154. data/plugins/application_swt/lib/application_swt/notebook/drag_and_drop_listener.rb +71 -0
  155. data/plugins/application_swt/lib/application_swt/swt/grid_data.rb +11 -0
  156. data/plugins/application_swt/lib/application_swt/swt_wrapper.rb +106 -0
  157. data/plugins/application_swt/lib/application_swt/tab.rb +58 -0
  158. data/plugins/application_swt/lib/application_swt/window.rb +142 -0
  159. data/plugins/application_swt/plugin.yaml +11 -0
  160. data/plugins/application_swt/spec/application_swt/menu/binding_translator_spec.rb +45 -0
  161. data/plugins/application_swt/spec/application_swt/menu_spec.rb +7 -0
  162. data/plugins/application_swt/spec/spec_helper.rb +18 -0
  163. data/plugins/application_swt/vendor/swt/linux/dummy +1 -0
  164. data/plugins/application_swt/vendor/swt/osx/dummy +1 -0
  165. data/plugins/application_swt/vendor/swt/osx64/dummy +1 -0
  166. data/plugins/application_swt/vendor/swt/win32/dummy +1 -0
  167. data/plugins/core/lib/core.rb +29 -0
  168. data/plugins/core/lib/core/controller.rb +5 -0
  169. data/plugins/core/lib/core/gui.rb +87 -0
  170. data/plugins/core/lib/core/logger.rb +25 -0
  171. data/plugins/core/lib/core/model.rb +9 -0
  172. data/plugins/core/lib/core/observable.rb +111 -0
  173. data/plugins/core/lib/core/plugin.rb +5 -0
  174. data/plugins/core/plugin.yaml +7 -0
  175. data/plugins/core/spec/core/gui_spec.rb +27 -0
  176. data/plugins/core/spec/core/observable_spec.rb +104 -0
  177. data/plugins/core/spec/spec_helper.rb +4 -0
  178. data/plugins/edit_view/features/multiple_notebooks.feature +77 -0
  179. data/plugins/edit_view/features/multiple_windows.feature +48 -0
  180. data/plugins/edit_view/features/new_tab.feature +12 -0
  181. data/plugins/edit_view/features/step_definitions/key_steps.rb +48 -0
  182. data/plugins/edit_view/features/step_definitions/notebook_steps.rb +60 -0
  183. data/plugins/edit_view/features/step_definitions/tab_steps.rb +55 -0
  184. data/plugins/edit_view/features/step_definitions/window_steps.rb +80 -0
  185. data/plugins/edit_view/features/support/env.rb +66 -0
  186. data/plugins/edit_view/lib/edit_view.rb +76 -0
  187. data/plugins/edit_view/lib/edit_view/command.rb +6 -0
  188. data/plugins/edit_view/lib/edit_view/document.rb +63 -0
  189. data/plugins/edit_view/lib/edit_view/edit_tab.rb +29 -0
  190. data/plugins/edit_view/lib/edit_view/mirror.rb +42 -0
  191. data/plugins/edit_view/plugin.yaml +14 -0
  192. data/plugins/edit_view/spec/edit_view/document_spec.rb +77 -0
  193. data/plugins/edit_view/spec/spec_helper.rb +4 -0
  194. data/plugins/edit_view_swt/lib/edit_view_swt.rb +170 -0
  195. data/plugins/edit_view_swt/lib/edit_view_swt/document.rb +31 -0
  196. data/plugins/edit_view_swt/lib/edit_view_swt/edit_tab.rb +33 -0
  197. data/plugins/edit_view_swt/plugin.yaml +14 -0
  198. data/plugins/edit_view_swt/vendor/dummy +1 -0
  199. data/plugins/edit_view_swt/vendor/java-mateview.rb +12 -0
  200. data/plugins/project/features/fixtures/winter.txt +1 -0
  201. data/plugins/project/features/open_and_save_files.feature +22 -0
  202. data/plugins/project/features/step_definitions/file_steps.rb +24 -0
  203. data/plugins/project/features/support/env.rb +15 -0
  204. data/plugins/project/lib/project.rb +79 -0
  205. data/plugins/project/lib/project/dir_mirror.rb +53 -0
  206. data/plugins/project/lib/project/file_mirror.rb +70 -0
  207. data/plugins/project/plugin.yaml +12 -0
  208. data/plugins/project/spec/project/dir_mirror_spec.rb +76 -0
  209. data/plugins/project/spec/project/file_mirror_spec.rb +78 -0
  210. data/plugins/project/spec/spec_helper.rb +4 -0
  211. data/plugins/redcar/plugin.yaml +20 -0
  212. data/plugins/redcar/redcar.rb +166 -0
  213. data/plugins/repl/lib/repl.rb +44 -0
  214. data/plugins/repl/lib/repl/internal_mirror.rb +98 -0
  215. data/plugins/repl/plugin.yaml +12 -0
  216. data/plugins/repl/spec/repl/internal_mirror_spec.rb +147 -0
  217. data/plugins/repl/spec/spec_helper.rb +4 -0
  218. data/plugins/tree_view/lib/tree_view.rb +7 -0
  219. data/plugins/tree_view/lib/tree_view/mirror.rb +74 -0
  220. data/plugins/tree_view/plugin.yaml +14 -0
  221. data/plugins/tree_view/spec/spec_helper.rb +4 -0
  222. data/plugins/tree_view_swt/lib/tree_view_swt.rb +5 -0
  223. data/plugins/tree_view_swt/plugin.yaml +14 -0
  224. data/textmate/Bundles/C.tmbundle/Snippets/010_main_______main__.plist +20 -0
  225. data/textmate/Bundles/C.tmbundle/Snippets/030_for_int_loop___fori__.plist +19 -0
  226. data/textmate/Bundles/C.tmbundle/Snippets/Include_header_once_only_guard.plist +28 -0
  227. data/textmate/Bundles/C.tmbundle/Snippets/Typedef.tmSnippet +16 -0
  228. data/textmate/Bundles/C.tmbundle/Snippets/__1_begin_________1_end_______beginend__.plist +16 -0
  229. data/textmate/Bundles/C.tmbundle/Snippets/__endif.plist +17 -0
  230. data/textmate/Bundles/C.tmbundle/Snippets/__ifndef__________define__________endif.tmSnippet +18 -0
  231. data/textmate/Bundles/C.tmbundle/Snippets/__include________inc__.plist +16 -0
  232. data/textmate/Bundles/C.tmbundle/Snippets/__pragma_mark___mark__.plist +21 -0
  233. data/textmate/Bundles/C.tmbundle/Snippets/class______class__.plist +24 -0
  234. data/textmate/Bundles/C.tmbundle/Snippets/do___while_loop___do__.plist +18 -0
  235. data/textmate/Bundles/C.tmbundle/Snippets/fprintf_______.tmSnippet +16 -0
  236. data/textmate/Bundles/C.tmbundle/Snippets/if______if__.plist +19 -0
  237. data/textmate/Bundles/C.tmbundle/Snippets/namespace______namespace__.plist +20 -0
  238. data/textmate/Bundles/C.tmbundle/Snippets/next___include________Inc__.plist +16 -0
  239. data/textmate/Bundles/C.tmbundle/Snippets/printf______printf__.plist +16 -0
  240. data/textmate/Bundles/C.tmbundle/Snippets/read_file___readF__.plist +23 -0
  241. data/textmate/Bundles/C.tmbundle/Snippets/std____map___map__.plist +16 -0
  242. data/textmate/Bundles/C.tmbundle/Snippets/std____vector___v__.plist +16 -0
  243. data/textmate/Bundles/C.tmbundle/Snippets/struct.plist +19 -0
  244. data/textmate/Bundles/C.tmbundle/Snippets/template___typename________template__.plist +16 -0
  245. data/textmate/Bundles/C.tmbundle/Syntaxes/C.plist +1084 -0
  246. data/textmate/Bundles/C.tmbundle/Syntaxes/C____.plist +521 -0
  247. data/textmate/Bundles/CSS.tmbundle/Snippets/Fixed_Position_Bottom_100___wide_IE6.tmSnippet +18 -0
  248. data/textmate/Bundles/CSS.tmbundle/Snippets/__important_CSS_______.plist +18 -0
  249. data/textmate/Bundles/CSS.tmbundle/Snippets/background____color_image_repeat_attachment_position___background__.plist +16 -0
  250. data/textmate/Bundles/CSS.tmbundle/Snippets/background__attachment___scroll__fixed___background__.plist +16 -0
  251. data/textmate/Bundles/CSS.tmbundle/Snippets/background__color____color__hex___background__.plist +16 -0
  252. data/textmate/Bundles/CSS.tmbundle/Snippets/background__color____color__name___background__.plist +16 -0
  253. data/textmate/Bundles/CSS.tmbundle/Snippets/background__color____color__rgb___background__.plist +16 -0
  254. data/textmate/Bundles/CSS.tmbundle/Snippets/background__color____transparent___background__.plist +16 -0
  255. data/textmate/Bundles/CSS.tmbundle/Snippets/background__image____none___background__.plist +16 -0
  256. data/textmate/Bundles/CSS.tmbundle/Snippets/background__image____url___background__.plist +16 -0
  257. data/textmate/Bundles/CSS.tmbundle/Snippets/background__position____position___background__.plist +16 -0
  258. data/textmate/Bundles/CSS.tmbundle/Snippets/background__repeat____r__r__x__r__y__n__r___background__.plist +16 -0
  259. data/textmate/Bundles/CSS.tmbundle/Snippets/border_____size_style_color___border__.plist +16 -0
  260. data/textmate/Bundles/CSS.tmbundle/Snippets/border__bottom___size_style_color___border__.plist +16 -0
  261. data/textmate/Bundles/CSS.tmbundle/Snippets/border__bottom__color___size_style_color___border__.plist +16 -0
  262. data/textmate/Bundles/CSS.tmbundle/Snippets/border__bottom__style___size_style_color___border__.plist +16 -0
  263. data/textmate/Bundles/CSS.tmbundle/Snippets/border__bottom__width___size_style_color___border__.plist +16 -0
  264. data/textmate/Bundles/CSS.tmbundle/Snippets/border__color___color___border__.plist +16 -0
  265. data/textmate/Bundles/CSS.tmbundle/Snippets/border__left___size_style_color___border__.plist +16 -0
  266. data/textmate/Bundles/CSS.tmbundle/Snippets/border__left__color___color___border__.plist +16 -0
  267. data/textmate/Bundles/CSS.tmbundle/Snippets/border__left__style___style___border__.plist +16 -0
  268. data/textmate/Bundles/CSS.tmbundle/Snippets/border__left__width___size___border__.plist +16 -0
  269. data/textmate/Bundles/CSS.tmbundle/Snippets/border__right___size_style_color___border__.plist +16 -0
  270. data/textmate/Bundles/CSS.tmbundle/Snippets/border__right__color___color___border__.plist +16 -0
  271. data/textmate/Bundles/CSS.tmbundle/Snippets/border__right__style___style___border__.plist +16 -0
  272. data/textmate/Bundles/CSS.tmbundle/Snippets/border__right__width___size___border__.plist +16 -0
  273. data/textmate/Bundles/CSS.tmbundle/Snippets/border__style___style___border__.plist +16 -0
  274. data/textmate/Bundles/CSS.tmbundle/Snippets/border__top___size_style_color___border__.plist +16 -0
  275. data/textmate/Bundles/CSS.tmbundle/Snippets/border__top__color___color___border__.plist +16 -0
  276. data/textmate/Bundles/CSS.tmbundle/Snippets/border__top__style___style___border__.plist +16 -0
  277. data/textmate/Bundles/CSS.tmbundle/Snippets/border__top__width___size___border__.plist +16 -0
  278. data/textmate/Bundles/CSS.tmbundle/Snippets/border__width___width___border__.plist +16 -0
  279. data/textmate/Bundles/CSS.tmbundle/Snippets/clear___value___clear__.plist +16 -0
  280. data/textmate/Bundles/CSS.tmbundle/Snippets/color____color__hex___color__.plist +16 -0
  281. data/textmate/Bundles/CSS.tmbundle/Snippets/color____color__name___color__.plist +16 -0
  282. data/textmate/Bundles/CSS.tmbundle/Snippets/color____color__rgb___color__.plist +16 -0
  283. data/textmate/Bundles/CSS.tmbundle/Snippets/cursor___type___cursor__.plist +16 -0
  284. data/textmate/Bundles/CSS.tmbundle/Snippets/cursor___url___cursor__.plist +16 -0
  285. data/textmate/Bundles/CSS.tmbundle/Snippets/direction___ltr__rtl___direction__.plist +16 -0
  286. data/textmate/Bundles/CSS.tmbundle/Snippets/display___block___display__.plist +16 -0
  287. data/textmate/Bundles/CSS.tmbundle/Snippets/display___common__types___display__.plist +16 -0
  288. data/textmate/Bundles/CSS.tmbundle/Snippets/display___inline___display__.plist +16 -0
  289. data/textmate/Bundles/CSS.tmbundle/Snippets/display___table__types___display__.plist +16 -0
  290. data/textmate/Bundles/CSS.tmbundle/Snippets/filter___AlphaImageLoader___for_IE_PNGs_____background__.plist +19 -0
  291. data/textmate/Bundles/CSS.tmbundle/Snippets/float___left__right__none___float__.plist +16 -0
  292. data/textmate/Bundles/CSS.tmbundle/Snippets/font_____style_variant_weight_size__line__height_font___family___font__.plist +16 -0
  293. data/textmate/Bundles/CSS.tmbundle/Snippets/font___size_font___font__.plist +16 -0
  294. data/textmate/Bundles/CSS.tmbundle/Snippets/font__family_____family___font__.plist +16 -0
  295. data/textmate/Bundles/CSS.tmbundle/Snippets/font__size___size___font__.plist +16 -0
  296. data/textmate/Bundles/CSS.tmbundle/Snippets/font__style_____normal__italic__oblique___font__.plist +16 -0
  297. data/textmate/Bundles/CSS.tmbundle/Snippets/font__variant_____normal__small__caps___font__.plist +16 -0
  298. data/textmate/Bundles/CSS.tmbundle/Snippets/font__weight___weight___font__.plist +16 -0
  299. data/textmate/Bundles/CSS.tmbundle/Snippets/letter__spacing_____length__em___letter__.plist +16 -0
  300. data/textmate/Bundles/CSS.tmbundle/Snippets/letter__spacing_____length__px___letter__.plist +16 -0
  301. data/textmate/Bundles/CSS.tmbundle/Snippets/list__style___type_position_image___list__.plist +16 -0
  302. data/textmate/Bundles/CSS.tmbundle/Snippets/list__style__image___url___list__.plist +16 -0
  303. data/textmate/Bundles/CSS.tmbundle/Snippets/list__style__position___pos___list__.plist +16 -0
  304. data/textmate/Bundles/CSS.tmbundle/Snippets/list__style__type___asian___list__.plist +16 -0
  305. data/textmate/Bundles/CSS.tmbundle/Snippets/list__style__type___marker__list__.plist +16 -0
  306. data/textmate/Bundles/CSS.tmbundle/Snippets/list__style__type___numeric___list__.plist +16 -0
  307. data/textmate/Bundles/CSS.tmbundle/Snippets/list__style__type___other___list__.plist +16 -0
  308. data/textmate/Bundles/CSS.tmbundle/Snippets/list__style__type___roman__alpha__greek___list__.plist +16 -0
  309. data/textmate/Bundles/CSS.tmbundle/Snippets/margin___T_R_B_L___margin__.plist +16 -0
  310. data/textmate/Bundles/CSS.tmbundle/Snippets/margin___V_H___margin__.plist +16 -0
  311. data/textmate/Bundles/CSS.tmbundle/Snippets/margin_____all___margin__.plist +16 -0
  312. data/textmate/Bundles/CSS.tmbundle/Snippets/margin__bottom___length___margin__.plist +16 -0
  313. data/textmate/Bundles/CSS.tmbundle/Snippets/margin__left___length___margin__.plist +16 -0
  314. data/textmate/Bundles/CSS.tmbundle/Snippets/margin__right___length___margin__.plist +16 -0
  315. data/textmate/Bundles/CSS.tmbundle/Snippets/margin__top___length___margin__.plist +16 -0
  316. data/textmate/Bundles/CSS.tmbundle/Snippets/marker__offset___auto___marker__.plist +16 -0
  317. data/textmate/Bundles/CSS.tmbundle/Snippets/marker__offset___length___marker__.plist +16 -0
  318. data/textmate/Bundles/CSS.tmbundle/Snippets/opacity_____for_Safari___FF_and_IE_____opacity__.plist +18 -0
  319. data/textmate/Bundles/CSS.tmbundle/Snippets/overflow___type___overflow__.plist +16 -0
  320. data/textmate/Bundles/CSS.tmbundle/Snippets/padding_____T_R_B_L___padding__.plist +16 -0
  321. data/textmate/Bundles/CSS.tmbundle/Snippets/padding_____V_H___padding__.plist +16 -0
  322. data/textmate/Bundles/CSS.tmbundle/Snippets/padding_____all___padding__.plist +16 -0
  323. data/textmate/Bundles/CSS.tmbundle/Snippets/padding__bottom___length___margin__.plist +16 -0
  324. data/textmate/Bundles/CSS.tmbundle/Snippets/padding__left___length___margin__.plist +16 -0
  325. data/textmate/Bundles/CSS.tmbundle/Snippets/padding__right___length___margin__.plist +16 -0
  326. data/textmate/Bundles/CSS.tmbundle/Snippets/padding__top___length___margin__.plist +16 -0
  327. data/textmate/Bundles/CSS.tmbundle/Snippets/position___type___position__.plist +16 -0
  328. data/textmate/Bundles/CSS.tmbundle/Snippets/properties_______________.plist +19 -0
  329. data/textmate/Bundles/CSS.tmbundle/Snippets/scrollbar.tmSnippet +23 -0
  330. data/textmate/Bundles/CSS.tmbundle/Snippets/selection.tmSnippet +20 -0
  331. data/textmate/Bundles/CSS.tmbundle/Snippets/text__align___left__center__right___txt__.plist +16 -0
  332. data/textmate/Bundles/CSS.tmbundle/Snippets/text__decoration___none__underline__overline__line__through__blink___text__.plist +16 -0
  333. data/textmate/Bundles/CSS.tmbundle/Snippets/text__indent___length___text__.plist +16 -0
  334. data/textmate/Bundles/CSS.tmbundle/Snippets/text__shadow___color__hex_x_y_blur___text__.plist +16 -0
  335. data/textmate/Bundles/CSS.tmbundle/Snippets/text__shadow___color__rgb_x_y_blur___text__.plist +16 -0
  336. data/textmate/Bundles/CSS.tmbundle/Snippets/text__shadow___none___text__.plist +16 -0
  337. data/textmate/Bundles/CSS.tmbundle/Snippets/text__transform___capitalize__upper__lower___text__.plist +16 -0
  338. data/textmate/Bundles/CSS.tmbundle/Snippets/text__transform___none___text__.plist +16 -0
  339. data/textmate/Bundles/CSS.tmbundle/Snippets/vertical__align___type___vertical__.plist +16 -0
  340. data/textmate/Bundles/CSS.tmbundle/Snippets/visibility___type___visibility__.plist +16 -0
  341. data/textmate/Bundles/CSS.tmbundle/Snippets/white__space____normal__pre__nowrap___white__.plist +16 -0
  342. data/textmate/Bundles/CSS.tmbundle/Snippets/word__spacing____length___word__.plist +16 -0
  343. data/textmate/Bundles/CSS.tmbundle/Snippets/word__spacing____normal___word__.plist +16 -0
  344. data/textmate/Bundles/CSS.tmbundle/Snippets/z__index___index___z__.plist +16 -0
  345. data/textmate/Bundles/CSS.tmbundle/Syntaxes/CSS.plist +543 -0
  346. data/textmate/Bundles/HTML.tmbundle/Snippets/Arrow___arrow__.plist +16 -0
  347. data/textmate/Bundles/HTML.tmbundle/Snippets/Backspace___backspace__.plist +16 -0
  348. data/textmate/Bundles/HTML.tmbundle/Snippets/Backtab___backtab__.plist +16 -0
  349. data/textmate/Bundles/HTML.tmbundle/Snippets/Command___command__.plist +16 -0
  350. data/textmate/Bundles/HTML.tmbundle/Snippets/Control___control__.plist +16 -0
  351. data/textmate/Bundles/HTML.tmbundle/Snippets/Delete___delete__.plist +16 -0
  352. data/textmate/Bundles/HTML.tmbundle/Snippets/DocType_HTML_4_0_Strict.plist +18 -0
  353. data/textmate/Bundles/HTML.tmbundle/Snippets/DocType_XHTL_1_0_Frameset.plist +18 -0
  354. data/textmate/Bundles/HTML.tmbundle/Snippets/DocType_XHTML_1_0_Strict.plist +18 -0
  355. data/textmate/Bundles/HTML.tmbundle/Snippets/DocType_XHTML_1_0_Transitional.plist +18 -0
  356. data/textmate/Bundles/HTML.tmbundle/Snippets/DocType_XHTML_1_1.plist +18 -0
  357. data/textmate/Bundles/HTML.tmbundle/Snippets/Down___down__.plist +16 -0
  358. data/textmate/Bundles/HTML.tmbundle/Snippets/Embed_QT_movie___movie__.plist +26 -0
  359. data/textmate/Bundles/HTML.tmbundle/Snippets/Emphasize.tmSnippet +16 -0
  360. data/textmate/Bundles/HTML.tmbundle/Snippets/Enter___enter__.plist +16 -0
  361. data/textmate/Bundles/HTML.tmbundle/Snippets/Escape___escape__.plist +16 -0
  362. data/textmate/Bundles/HTML.tmbundle/Snippets/Fieldset.tmSnippet +22 -0
  363. data/textmate/Bundles/HTML.tmbundle/Snippets/HTML________4_0_Transitional___doctype__.plist +18 -0
  364. data/textmate/Bundles/HTML.tmbundle/Snippets/IE_Conditional_Comment___Internet_Explorer.tmSnippet +16 -0
  365. data/textmate/Bundles/HTML.tmbundle/Snippets/IE_Conditional_Comment___Internet_Explorer_5_0_only.tmSnippet +16 -0
  366. data/textmate/Bundles/HTML.tmbundle/Snippets/IE_Conditional_Comment___Internet_Explorer_5_5_only.tmSnippet +16 -0
  367. data/textmate/Bundles/HTML.tmbundle/Snippets/IE_Conditional_Comment___Internet_Explorer_5_x.tmSnippet +16 -0
  368. data/textmate/Bundles/HTML.tmbundle/Snippets/IE_Conditional_Comment___Internet_Explorer_6_and_below.tmSnippet +16 -0
  369. data/textmate/Bundles/HTML.tmbundle/Snippets/IE_Conditional_Comment___Internet_Explorer_6_only.tmSnippet +16 -0
  370. data/textmate/Bundles/HTML.tmbundle/Snippets/IE_Conditional_Comment___Internet_Explorer_7__.tmSnippet +16 -0
  371. data/textmate/Bundles/HTML.tmbundle/Snippets/IE_Conditional_Comment___NOT_Internet_Explorer.tmSnippet +16 -0
  372. data/textmate/Bundles/HTML.tmbundle/Snippets/Input_with_Label.tmSnippet +19 -0
  373. data/textmate/Bundles/HTML.tmbundle/Snippets/Left___left__.plist +16 -0
  374. data/textmate/Bundles/HTML.tmbundle/Snippets/Option.tmSnippet +18 -0
  375. data/textmate/Bundles/HTML.tmbundle/Snippets/Option___option__.plist +16 -0
  376. data/textmate/Bundles/HTML.tmbundle/Snippets/Return___return__.plist +16 -0
  377. data/textmate/Bundles/HTML.tmbundle/Snippets/Right___right__.plist +16 -0
  378. data/textmate/Bundles/HTML.tmbundle/Snippets/Select_Box.tmSnippet +22 -0
  379. data/textmate/Bundles/HTML.tmbundle/Snippets/Shift___shift__.plist +16 -0
  380. data/textmate/Bundles/HTML.tmbundle/Snippets/Smart_return__indent_for_tag_pairs.plist +18 -0
  381. data/textmate/Bundles/HTML.tmbundle/Snippets/Strong.tmSnippet +16 -0
  382. data/textmate/Bundles/HTML.tmbundle/Snippets/Tab___tab__.plist +16 -0
  383. data/textmate/Bundles/HTML.tmbundle/Snippets/Up___up__.plist +16 -0
  384. data/textmate/Bundles/HTML.tmbundle/Snippets/Wrap_Selection_In_Tag.plist +16 -0
  385. data/textmate/Bundles/HTML.tmbundle/Snippets/Wrap_in___________________.plist +14 -0
  386. data/textmate/Bundles/HTML.tmbundle/Snippets/XHTML_____input__.plist +16 -0
  387. data/textmate/Bundles/HTML.tmbundle/Snippets/XHTML_____textarea__.plist +16 -0
  388. data/textmate/Bundles/HTML.tmbundle/Snippets/XHTML___a_mailto_____.plist +16 -0
  389. data/textmate/Bundles/HTML.tmbundle/Snippets/XHTML___base__.plist +16 -0
  390. data/textmate/Bundles/HTML.tmbundle/Snippets/XHTML___body__.plist +18 -0
  391. data/textmate/Bundles/HTML.tmbundle/Snippets/XHTML___br_____.plist +16 -0
  392. data/textmate/Bundles/HTML.tmbundle/Snippets/XHTML___div__.plist +18 -0
  393. data/textmate/Bundles/HTML.tmbundle/Snippets/XHTML___form__.plist +20 -0
  394. data/textmate/Bundles/HTML.tmbundle/Snippets/XHTML___h1__.plist +16 -0
  395. data/textmate/Bundles/HTML.tmbundle/Snippets/XHTML___head__.plist +20 -0
  396. data/textmate/Bundles/HTML.tmbundle/Snippets/XHTML___link__.plist +16 -0
  397. data/textmate/Bundles/HTML.tmbundle/Snippets/XHTML___meta__.plist +16 -0
  398. data/textmate/Bundles/HTML.tmbundle/Snippets/XHTML___nbsp___NonBreakingSpace.plist +16 -0
  399. data/textmate/Bundles/HTML.tmbundle/Snippets/XHTML___script__.plist +18 -0
  400. data/textmate/Bundles/HTML.tmbundle/Snippets/XHTML___script_src_____.plist +16 -0
  401. data/textmate/Bundles/HTML.tmbundle/Snippets/XHTML___style__.plist +18 -0
  402. data/textmate/Bundles/HTML.tmbundle/Snippets/XHTML___table__.plist +19 -0
  403. data/textmate/Bundles/HTML.tmbundle/Snippets/XHTML___title__.plist +16 -0
  404. data/textmate/Bundles/HTML.tmbundle/Syntaxes/HTML.plist +962 -0
  405. data/textmate/Bundles/HTML.tmbundle/Templates/HTML /342/200/223 4.0 Strict/index.html" +15 -0
  406. data/textmate/Bundles/HTML.tmbundle/Templates/HTML /342/200/223 4.0 Strict/info.plist" +20 -0
  407. data/textmate/Bundles/HTML.tmbundle/Templates/HTML /342/200/224 4.0 Transitional/index.html" +15 -0
  408. data/textmate/Bundles/HTML.tmbundle/Templates/HTML /342/200/224 4.0 Transitional/info.plist" +20 -0
  409. data/textmate/Bundles/HTML.tmbundle/Templates/XHTML /342/200/223 1.0 Frameset/index.html" +16 -0
  410. data/textmate/Bundles/HTML.tmbundle/Templates/XHTML /342/200/223 1.0 Frameset/info.plist" +16 -0
  411. data/textmate/Bundles/HTML.tmbundle/Templates/XHTML /342/200/223 1.0 Strict/index.html" +16 -0
  412. data/textmate/Bundles/HTML.tmbundle/Templates/XHTML /342/200/223 1.0 Strict/info.plist" +16 -0
  413. data/textmate/Bundles/HTML.tmbundle/Templates/XHTML /342/200/223 1.0 Transitional/index.html" +16 -0
  414. data/textmate/Bundles/HTML.tmbundle/Templates/XHTML /342/200/223 1.0 Transitional/info.plist" +16 -0
  415. data/textmate/Bundles/HTML.tmbundle/Templates/XHTML /342/200/223 1.1/index.html" +15 -0
  416. data/textmate/Bundles/HTML.tmbundle/Templates/XHTML /342/200/223 1.1/info.plist" +16 -0
  417. data/textmate/Bundles/RedcarRepl.tmbundle/Syntaxes/InternalRuby.plist +54 -0
  418. data/textmate/Bundles/Ruby.tmbundle/Snippets/060_ruby_if_else.plist +20 -0
  419. data/textmate/Bundles/Ruby.tmbundle/Snippets/070_ruby_if.plist +18 -0
  420. data/textmate/Bundles/Ruby.tmbundle/Snippets/080_ruby_case.plist +19 -0
  421. data/textmate/Bundles/Ruby.tmbundle/Snippets/Add_____________Marker.tmSnippet +16 -0
  422. data/textmate/Bundles/Ruby.tmbundle/Snippets/Array_new__10________i____________Arr__.plist +16 -0
  423. data/textmate/Bundles/Ruby.tmbundle/Snippets/Benchmark_bmbm_______do____end.tmSnippet +19 -0
  424. data/textmate/Bundles/Ruby.tmbundle/Snippets/Dir__________.tmSnippet +16 -0
  425. data/textmate/Bundles/Ruby.tmbundle/Snippets/Dir_glob___________do___file______end____Dir__.plist +16 -0
  426. data/textmate/Bundles/Ruby.tmbundle/Snippets/File_foreach____________do___line______end____File__.plist +16 -0
  427. data/textmate/Bundles/Ruby.tmbundle/Snippets/File_open________________file________.tmSnippet +16 -0
  428. data/textmate/Bundles/Ruby.tmbundle/Snippets/File_read__________.tmSnippet +16 -0
  429. data/textmate/Bundles/Ruby.tmbundle/Snippets/Hash_new______hash___key___hash__key_______________Has__.plist +16 -0
  430. data/textmate/Bundles/Ruby.tmbundle/Snippets/Insert_ERb__s______________or_______________.tmSnippet +16 -0
  431. data/textmate/Bundles/Ruby.tmbundle/Snippets/Marshal_dump__obj___file______Md__.plist +16 -0
  432. data/textmate/Bundles/Ruby.tmbundle/Snippets/Marshal_load__obj______Ml__.plist +16 -0
  433. data/textmate/Bundles/Ruby.tmbundle/Snippets/PStore_new________.tmSnippet +16 -0
  434. data/textmate/Bundles/Ruby.tmbundle/Snippets/RDoc_documentation_block.tmSnippet +20 -0
  435. data/textmate/Bundles/Ruby.tmbundle/Snippets/Wrap_in_Begin________Rescue________End.plist +23 -0
  436. data/textmate/Bundles/Ruby.tmbundle/Snippets/YAML_dump_______file______Yd____.plist +16 -0
  437. data/textmate/Bundles/Ruby.tmbundle/Snippets/YAML_load__file______Yl____.plist +16 -0
  438. data/textmate/Bundles/Ruby.tmbundle/Snippets/__END__.tmSnippet +17 -0
  439. data/textmate/Bundles/Ruby.tmbundle/Snippets/______usr__local__bin__ruby___w.plist +17 -0
  440. data/textmate/Bundles/Ruby.tmbundle/Snippets/__yields___RDoc_comment.tmSnippet +16 -0
  441. data/textmate/Bundles/Ruby.tmbundle/Snippets/alias_method_______am__.plist +16 -0
  442. data/textmate/Bundles/Ruby.tmbundle/Snippets/all________e____________all__.plist +16 -0
  443. data/textmate/Bundles/Ruby.tmbundle/Snippets/any________e____________any__.plist +16 -0
  444. data/textmate/Bundles/Ruby.tmbundle/Snippets/application_code_______app__.plist +18 -0
  445. data/textmate/Bundles/Ruby.tmbundle/Snippets/assert__________as__.plist +16 -0
  446. data/textmate/Bundles/Ruby.tmbundle/Snippets/assert_equal.tmSnippet +16 -0
  447. data/textmate/Bundles/Ruby.tmbundle/Snippets/assert_in_delta__________asid__.plist +16 -0
  448. data/textmate/Bundles/Ruby.tmbundle/Snippets/assert_instance_of__________asio__.plist +16 -0
  449. data/textmate/Bundles/Ruby.tmbundle/Snippets/assert_kind_of__________asko__.plist +16 -0
  450. data/textmate/Bundles/Ruby.tmbundle/Snippets/assert_match__________asm__.plist +16 -0
  451. data/textmate/Bundles/Ruby.tmbundle/Snippets/assert_nil__________asn__.plist +16 -0
  452. data/textmate/Bundles/Ruby.tmbundle/Snippets/assert_no_match__________asnm__.plist +16 -0
  453. data/textmate/Bundles/Ruby.tmbundle/Snippets/assert_not_equal__________asne__.plist +16 -0
  454. data/textmate/Bundles/Ruby.tmbundle/Snippets/assert_not_nil__________asnn__.plist +16 -0
  455. data/textmate/Bundles/Ruby.tmbundle/Snippets/assert_not_same__________asns__.plist +16 -0
  456. data/textmate/Bundles/Ruby.tmbundle/Snippets/assert_nothing_raised___________________asnr__.plist +16 -0
  457. data/textmate/Bundles/Ruby.tmbundle/Snippets/assert_nothing_thrown_____________asnt__.plist +16 -0
  458. data/textmate/Bundles/Ruby.tmbundle/Snippets/assert_operator__________aso__.plist +16 -0
  459. data/textmate/Bundles/Ruby.tmbundle/Snippets/assert_raise___________________asr__.plist +16 -0
  460. data/textmate/Bundles/Ruby.tmbundle/Snippets/assert_respond_to__________asrt__.plist +16 -0
  461. data/textmate/Bundles/Ruby.tmbundle/Snippets/assert_same__________ass__.plist +16 -0
  462. data/textmate/Bundles/Ruby.tmbundle/Snippets/assert_send__________ass__.plist +16 -0
  463. data/textmate/Bundles/Ruby.tmbundle/Snippets/assert_throws___________________ast__.plist +16 -0
  464. data/textmate/Bundles/Ruby.tmbundle/Snippets/attr_accessor_______rw__.plist +16 -0
  465. data/textmate/Bundles/Ruby.tmbundle/Snippets/attr_reader_______r__.plist +16 -0
  466. data/textmate/Bundles/Ruby.tmbundle/Snippets/attr_writer_______w__.plist +16 -0
  467. data/textmate/Bundles/Ruby.tmbundle/Snippets/class_______DelegateClass____initialize____end____class__.plist +24 -0
  468. data/textmate/Bundles/Ruby.tmbundle/Snippets/class_______ParentClass____initialize____end.plist +22 -0
  469. data/textmate/Bundles/Ruby.tmbundle/Snippets/class_______Struct____initialize____end.plist +22 -0
  470. data/textmate/Bundles/Ruby.tmbundle/Snippets/class_______Test____Unit____TestCase____end____tc__.plist +24 -0
  471. data/textmate/Bundles/Ruby.tmbundle/Snippets/class______self____end.tmSnippet +18 -0
  472. data/textmate/Bundles/Ruby.tmbundle/Snippets/class____end____cla__.plist +18 -0
  473. data/textmate/Bundles/Ruby.tmbundle/Snippets/class____initialize____end.plist +22 -0
  474. data/textmate/Bundles/Ruby.tmbundle/Snippets/class____instance_methods____undef____initialize____end____class__.plist +30 -0
  475. data/textmate/Bundles/Ruby.tmbundle/Snippets/class_from_name________clafn__.plist +16 -0
  476. data/textmate/Bundles/Ruby.tmbundle/Snippets/classify______e____________clas__.plist +16 -0
  477. data/textmate/Bundles/Ruby.tmbundle/Snippets/collect______e____________col__.plist +16 -0
  478. data/textmate/Bundles/Ruby.tmbundle/Snippets/deep_copy__________dee__.plist +16 -0
  479. data/textmate/Bundles/Ruby.tmbundle/Snippets/def_delegator______defd__.plist +16 -0
  480. data/textmate/Bundles/Ruby.tmbundle/Snippets/def_delegators______defds__.plist +16 -0
  481. data/textmate/Bundles/Ruby.tmbundle/Snippets/def_end.plist +18 -0
  482. data/textmate/Bundles/Ruby.tmbundle/Snippets/def_method_missing____end____mm__.plist +18 -0
  483. data/textmate/Bundles/Ruby.tmbundle/Snippets/def_self____end____defs__.plist +18 -0
  484. data/textmate/Bundles/Ruby.tmbundle/Snippets/def_test_____end____t__.plist +18 -0
  485. data/textmate/Bundles/Ruby.tmbundle/Snippets/delete_if______e____________deli__.plist +16 -0
  486. data/textmate/Bundles/Ruby.tmbundle/Snippets/detect______e____________det__.plist +16 -0
  487. data/textmate/Bundles/Ruby.tmbundle/Snippets/directory____.tmSnippet +16 -0
  488. data/textmate/Bundles/Ruby.tmbundle/Snippets/do___obj______end___doo__.plist +18 -0
  489. data/textmate/Bundles/Ruby.tmbundle/Snippets/downto__0________n____________dow__.plist +16 -0
  490. data/textmate/Bundles/Ruby.tmbundle/Snippets/each______e____________ea__.plist +16 -0
  491. data/textmate/Bundles/Ruby.tmbundle/Snippets/each_byte______byte____________eab__.plist +16 -0
  492. data/textmate/Bundles/Ruby.tmbundle/Snippets/each_char______chr____________eac____.plist +16 -0
  493. data/textmate/Bundles/Ruby.tmbundle/Snippets/each_cons____________group____________eac____.plist +16 -0
  494. data/textmate/Bundles/Ruby.tmbundle/Snippets/each_index______i____________eai__.plist +16 -0
  495. data/textmate/Bundles/Ruby.tmbundle/Snippets/each_key______key____________eak__.plist +16 -0
  496. data/textmate/Bundles/Ruby.tmbundle/Snippets/each_line______line____________eal__.plist +16 -0
  497. data/textmate/Bundles/Ruby.tmbundle/Snippets/each_pair______name___val____________eap__.plist +16 -0
  498. data/textmate/Bundles/Ruby.tmbundle/Snippets/each_slice______group____________eas__.plist +16 -0
  499. data/textmate/Bundles/Ruby.tmbundle/Snippets/each_value______val____________eav__.plist +16 -0
  500. data/textmate/Bundles/Ruby.tmbundle/Snippets/each_with_index______e___i____________eawi__.plist +16 -0
  501. data/textmate/Bundles/Ruby.tmbundle/Snippets/elsif____.tmSnippet +17 -0
  502. data/textmate/Bundles/Ruby.tmbundle/Snippets/embed_string_variable.plist +16 -0
  503. data/textmate/Bundles/Ruby.tmbundle/Snippets/extend_Forwardable____Forw__.plist +16 -0
  504. data/textmate/Bundles/Ruby.tmbundle/Snippets/fetch__name________key____________fet__.plist +16 -0
  505. data/textmate/Bundles/Ruby.tmbundle/Snippets/fill__range________i____________fil__.plist +16 -0
  506. data/textmate/Bundles/Ruby.tmbundle/Snippets/find______e____________fin__.plist +16 -0
  507. data/textmate/Bundles/Ruby.tmbundle/Snippets/find_all______e____________fina__.plist +16 -0
  508. data/textmate/Bundles/Ruby.tmbundle/Snippets/flatten_once____fla__.plist +16 -0
  509. data/textmate/Bundles/Ruby.tmbundle/Snippets/flunk__________fl__.plist +16 -0
  510. data/textmate/Bundles/Ruby.tmbundle/Snippets/grep____pattern__________match____________gre__.plist +16 -0
  511. data/textmate/Bundles/Ruby.tmbundle/Snippets/gsub________________match____________gsu__.plist +16 -0
  512. data/textmate/Bundles/Ruby.tmbundle/Snippets/hash_pair_______.plist +16 -0
  513. data/textmate/Bundles/Ruby.tmbundle/Snippets/hash_pointer.plist +16 -0
  514. data/textmate/Bundles/Ruby.tmbundle/Snippets/include_Comparable_______Comp__.plist +20 -0
  515. data/textmate/Bundles/Ruby.tmbundle/Snippets/include_Enumerable_______Enum__.plist +20 -0
  516. data/textmate/Bundles/Ruby.tmbundle/Snippets/inject__init________mem___var____________inj__.plist +16 -0
  517. data/textmate/Bundles/Ruby.tmbundle/Snippets/lambda______args____________lam__.plist +16 -0
  518. data/textmate/Bundles/Ruby.tmbundle/Snippets/loop_________.tmSnippet +16 -0
  519. data/textmate/Bundles/Ruby.tmbundle/Snippets/map______e____________map__.plist +16 -0
  520. data/textmate/Bundles/Ruby.tmbundle/Snippets/map_with_index______e___i____________mapwi__.plist +16 -0
  521. data/textmate/Bundles/Ruby.tmbundle/Snippets/max______a___b____________max__.plist +16 -0
  522. data/textmate/Bundles/Ruby.tmbundle/Snippets/min______a___b____________min__.plist +16 -0
  523. data/textmate/Bundles/Ruby.tmbundle/Snippets/module____ClassMethods____end.plist +29 -0
  524. data/textmate/Bundles/Ruby.tmbundle/Snippets/module____end.plist +18 -0
  525. data/textmate/Bundles/Ruby.tmbundle/Snippets/module____module_function____end.plist +20 -0
  526. data/textmate/Bundles/Ruby.tmbundle/Snippets/namespace______do____end.tmSnippet +18 -0
  527. data/textmate/Bundles/Ruby.tmbundle/Snippets/open____path__or__url_______w_____do___doc______end___ope__.plist +16 -0
  528. data/textmate/Bundles/Ruby.tmbundle/Snippets/open_yield_block_______.plist +16 -0
  529. data/textmate/Bundles/Ruby.tmbundle/Snippets/option_parse_____________optp__.plist +43 -0
  530. data/textmate/Bundles/Ruby.tmbundle/Snippets/partition______e____________par__.plist +16 -0
  531. data/textmate/Bundles/Ruby.tmbundle/Snippets/path_from_here________.tmSnippet +16 -0
  532. data/textmate/Bundles/Ruby.tmbundle/Snippets/randomize____ran__.plist +16 -0
  533. data/textmate/Bundles/Ruby.tmbundle/Snippets/reject______e____________rej__.plist +16 -0
  534. data/textmate/Bundles/Ruby.tmbundle/Snippets/require___________req__.plist +16 -0
  535. data/textmate/Bundles/Ruby.tmbundle/Snippets/require___tc____________ts__.plist +20 -0
  536. data/textmate/Bundles/Ruby.tmbundle/Snippets/require_gem_______.tmSnippet +16 -0
  537. data/textmate/Bundles/Ruby.tmbundle/Snippets/results_report_______________.tmSnippet +16 -0
  538. data/textmate/Bundles/Ruby.tmbundle/Snippets/reverse_each______e____________rea__.plist +16 -0
  539. data/textmate/Bundles/Ruby.tmbundle/Snippets/scan________________match____________sca__.plist +16 -0
  540. data/textmate/Bundles/Ruby.tmbundle/Snippets/select______e____________sel__.plist +16 -0
  541. data/textmate/Bundles/Ruby.tmbundle/Snippets/singleton_class____.tmSnippet +16 -0
  542. data/textmate/Bundles/Ruby.tmbundle/Snippets/sort______a___b____________sor__.plist +16 -0
  543. data/textmate/Bundles/Ruby.tmbundle/Snippets/sort_by______e____________sorb__.plist +16 -0
  544. data/textmate/Bundles/Ruby.tmbundle/Snippets/step__2________e____________ste__.plist +16 -0
  545. data/textmate/Bundles/Ruby.tmbundle/Snippets/sub________________match____________sub__.plist +16 -0
  546. data/textmate/Bundles/Ruby.tmbundle/Snippets/task___task_name__________dependent_____tasks___do____end.tmSnippet +19 -0
  547. data/textmate/Bundles/Ruby.tmbundle/Snippets/times______n____________tim__.plist +16 -0
  548. data/textmate/Bundles/Ruby.tmbundle/Snippets/transaction_________do____end.tmSnippet +16 -0
  549. data/textmate/Bundles/Ruby.tmbundle/Snippets/unix_filter______uni__.plist +18 -0
  550. data/textmate/Bundles/Ruby.tmbundle/Snippets/unless___unless__.plist +18 -0
  551. data/textmate/Bundles/Ruby.tmbundle/Snippets/until_____end.tmSnippet +18 -0
  552. data/textmate/Bundles/Ruby.tmbundle/Snippets/untitled.plist +19 -0
  553. data/textmate/Bundles/Ruby.tmbundle/Snippets/upto__1_0__0_0________n____________upt__.plist +16 -0
  554. data/textmate/Bundles/Ruby.tmbundle/Snippets/usage_if________usai__.plist +18 -0
  555. data/textmate/Bundles/Ruby.tmbundle/Snippets/usage_unless________usau__.plist +18 -0
  556. data/textmate/Bundles/Ruby.tmbundle/Snippets/when.plist +17 -0
  557. data/textmate/Bundles/Ruby.tmbundle/Snippets/while_____end.tmSnippet +18 -0
  558. data/textmate/Bundles/Ruby.tmbundle/Snippets/xmlread______.tmSnippet +16 -0
  559. data/textmate/Bundles/Ruby.tmbundle/Snippets/xpath_______________.tmSnippet +18 -0
  560. data/textmate/Bundles/Ruby.tmbundle/Snippets/zip__enums________row____________zip__.plist +16 -0
  561. data/textmate/Bundles/Ruby.tmbundle/Syntaxes/Ruby.plist +2763 -0
  562. data/textmate/Bundles/Source.tmbundle/Snippets/Continue_line_comment.plist +35 -0
  563. data/textmate/Bundles/Source.tmbundle/Snippets/Escaped_Quote_Pair_____________.plist +14 -0
  564. data/textmate/Bundles/Source.tmbundle/Snippets/Escaped_Single_Quote_Pair_____________.plist +14 -0
  565. data/textmate/Bundles/Source.tmbundle/Snippets/Frame_text.plist +16 -0
  566. data/textmate/Bundles/Source.tmbundle/Snippets/__n.plist +16 -0
  567. data/textmate/Bundles/Text.tmbundle/Snippets/010_Copyright.plist +14 -0
  568. data/textmate/Bundles/Text.tmbundle/Snippets/Conitnue_bullet.plist +17 -0
  569. data/textmate/Bundles/Text.tmbundle/Snippets/Conitnue_light_bullet.plist +17 -0
  570. data/textmate/Bundles/Text.tmbundle/Snippets/Conitnue_star_bullet.plist +17 -0
  571. data/textmate/Bundles/Text.tmbundle/Snippets/Insert_ISO_date.plist +14 -0
  572. data/textmate/Bundles/Text.tmbundle/Snippets/Lorem_ipsum.plist +14 -0
  573. data/textmate/Bundles/Text.tmbundle/Syntaxes/Plain_text.plist +83 -0
  574. data/textmate/Bundles/Text.tmbundle/Templates/Empty file/info.plist +14 -0
  575. data/textmate/Bundles/Text.tmbundle/Templates/From Clipboard/info.plist +17 -0
  576. data/textmate/Themes/Active4D.tmTheme +407 -0
  577. data/textmate/Themes/All Hallow's Eve.tmTheme +277 -0
  578. data/textmate/Themes/Amy.tmTheme +557 -0
  579. data/textmate/Themes/Blackboard.tmTheme +350 -0
  580. data/textmate/Themes/Brilliance Black.tmTheme +2619 -0
  581. data/textmate/Themes/Brilliance Dull.tmTheme +2243 -0
  582. data/textmate/Themes/Cobalt.tmTheme +559 -0
  583. data/textmate/Themes/Dawn.tmTheme +437 -0
  584. data/textmate/Themes/Eiffel.tmTheme +439 -0
  585. data/textmate/Themes/Espresso Libre.tmTheme +402 -0
  586. data/textmate/Themes/IDLE.tmTheme +235 -0
  587. data/textmate/Themes/LAZY.tmTheme +291 -0
  588. data/textmate/Themes/Mac Classic.tmTheme +450 -0
  589. data/textmate/Themes/MagicWB (Amiga).tmTheme +376 -0
  590. data/textmate/Themes/Pastels on Dark.tmTheme +701 -0
  591. data/textmate/Themes/Railscasts.tmTheme +278 -0
  592. data/textmate/Themes/Slush & Poppies.tmTheme +336 -0
  593. data/textmate/Themes/SpaceCadet.tmTheme +212 -0
  594. data/textmate/Themes/Sunburst.tmTheme +665 -0
  595. data/textmate/Themes/Twilight.tmTheme +514 -0
  596. data/textmate/Themes/Vibrant Ink.tmTheme +447 -0
  597. data/textmate/Themes/Zenburnesque.tmTheme +343 -0
  598. data/textmate/Themes/choco.tmTheme +542 -0
  599. data/textmate/Themes/iPlastic.tmTheme +286 -0
  600. metadata +673 -0
@@ -0,0 +1,46 @@
1
+
2
+ require File.join(File.dirname(__FILE__), %w[setup])
3
+
4
+ module TestLogging
5
+
6
+ class TestConsolidate < Test::Unit::TestCase
7
+ include LoggingTestCase
8
+
9
+ def test_root
10
+ Logging.consolidate :root
11
+ root = Logging.logger.root
12
+
13
+ assert_same root, Logging.logger['Foo']
14
+ assert_same root, Logging.logger['Foo::Bar']
15
+ assert_same root, Logging.logger[Array]
16
+ end
17
+
18
+ def test_foo
19
+ Logging.consolidate 'Foo'
20
+ logger = Logging.logger['Foo::Bar::Baz']
21
+
22
+ assert_same Logging.logger['Foo'], logger
23
+ assert_not_same Logging.logger.root, logger
24
+ end
25
+
26
+ def test_many
27
+ Logging.consolidate 'Foo', 'root', 'Foo::Bar::Baz'
28
+
29
+ root = Logging.logger.root
30
+ foo = Logging.logger['Foo']
31
+ fbb = Logging.logger['Foo::Bar::Baz']
32
+
33
+ assert_not_same root, foo
34
+ assert_not_same root, fbb
35
+ assert_not_same foo, fbb
36
+
37
+ assert_same root, Logging.logger[Hash]
38
+ assert_same root, Logging.logger['ActiveRecord::Base']
39
+ assert_same foo, Logging.logger['Foo::Bar']
40
+ assert_same fbb, Logging.logger['Foo::Bar::Baz::Buz']
41
+ end
42
+
43
+ end # class TestConsolidate
44
+ end # module TestLogging
45
+
46
+ # EOF
@@ -0,0 +1,110 @@
1
+
2
+ require File.join(File.dirname(__FILE__), %w[setup])
3
+
4
+ module TestLogging
5
+
6
+ class TestLayout < Test::Unit::TestCase
7
+ include LoggingTestCase
8
+
9
+ def setup
10
+ super
11
+ @layout = ::Logging::Layout.new
12
+ end
13
+
14
+ def test_header
15
+ assert_equal '', @layout.header
16
+ end
17
+
18
+ def test_initialize
19
+ obj_format = lambda {|l| l.instance_variable_get :@obj_format}
20
+
21
+ assert_equal :string, obj_format[@layout]
22
+
23
+ @layout = ::Logging::Layout.new 'format_as' => 'blah'
24
+ assert_equal :string, obj_format[@layout]
25
+
26
+ @layout = ::Logging::Layout.new :format_as => :inspect
27
+ assert_equal :inspect, obj_format[@layout]
28
+
29
+ @layout = ::Logging::Layout.new 'format_as' => :yaml
30
+ assert_equal :yaml, obj_format[@layout]
31
+
32
+ @layout = ::Logging::Layout.new
33
+ assert_equal :string, obj_format[@layout]
34
+
35
+ ::Logging.format_as :yaml
36
+ @layout = ::Logging::Layout.new
37
+ assert_equal :yaml, obj_format[@layout]
38
+ end
39
+
40
+ def test_footer
41
+ assert_equal '', @layout.footer
42
+ end
43
+
44
+ def test_format
45
+ assert_nil @layout.format(::Logging::LogEvent.new('a','b','c',false))
46
+ end
47
+
48
+ def test_format_obj
49
+ obj = 'test string'
50
+ r = @layout.format_obj obj
51
+ assert_same obj, r
52
+
53
+ obj = RuntimeError.new
54
+ r = @layout.format_obj obj
55
+ assert_equal '<RuntimeError> RuntimeError', r
56
+
57
+ obj = TypeError.new 'only works with Integers'
58
+ r = @layout.format_obj obj
59
+ assert_equal '<TypeError> only works with Integers', r
60
+
61
+ obj = Exception.new 'some exception'
62
+ obj.set_backtrace %w( this is the backtrace )
63
+ r = @layout.format_obj obj
64
+ obj = "<Exception> some exception\n\tthis\n\tis\n\tthe\n\tbacktrace"
65
+ assert_equal obj, r
66
+
67
+ obj = [1, 2, 3, 4]
68
+ r = @layout.format_obj obj
69
+ assert_equal "<Array> #{[1,2,3,4]}", r
70
+
71
+ obj = %w( one two three four )
72
+ @layout = ::Logging::Layout.new :format_as => :inspect
73
+ r = @layout.format_obj obj
74
+ assert_equal '<Array> ["one", "two", "three", "four"]', r
75
+
76
+ @layout = ::Logging::Layout.new :format_as => :yaml
77
+ r = @layout.format_obj obj
78
+ assert_equal "<Array> \n--- \n- one\n- two\n- three\n- four\n", r
79
+
80
+ r = @layout.format_obj Class
81
+ assert_equal "<Class> Class", r
82
+ end
83
+
84
+ def test_format_obj_without_backtrace
85
+ @layout = ::Logging::Layout.new :backtrace => 'off'
86
+
87
+ obj = Exception.new 'some exception'
88
+ obj.set_backtrace %w( this is the backtrace )
89
+ r = @layout.format_obj obj
90
+ obj = "<Exception> some exception"
91
+ assert_equal obj, r
92
+
93
+ ::Logging.backtrace :off
94
+ @layout = ::Logging::Layout.new
95
+
96
+ obj = ArgumentError.new 'wrong type of argument'
97
+ obj.set_backtrace %w( this is the backtrace )
98
+ r = @layout.format_obj obj
99
+ obj = "<ArgumentError> wrong type of argument"
100
+ assert_equal obj, r
101
+ end
102
+
103
+ def test_initializer
104
+ assert_raise(ArgumentError) {::Logging::Layout.new :backtrace => 'foo'}
105
+ end
106
+
107
+ end # class TestLayout
108
+ end # module TestLogging
109
+
110
+ # EOF
@@ -0,0 +1,80 @@
1
+
2
+ require File.join(File.dirname(__FILE__), %w[setup])
3
+
4
+ module TestLogging
5
+
6
+ class TestLogEvent < Test::Unit::TestCase
7
+ include LoggingTestCase
8
+
9
+ def setup
10
+ super
11
+
12
+ @appender = EventAppender.new('test')
13
+ @logger = ::Logging::Logger['TestLogger']
14
+ @logger.add_appenders @appender
15
+
16
+ @logger.info 'message 1'
17
+ @event = @appender.event
18
+ end
19
+
20
+ def test_data
21
+ assert_equal 'message 1', @event.data
22
+ end
23
+
24
+ def test_data_eq
25
+ @event.data = 'message 2'
26
+ assert_equal 'message 2', @event.data
27
+ end
28
+
29
+ def test_file
30
+ assert_equal '', @event.file
31
+
32
+ @logger.trace = true
33
+ @logger.warn 'warning message'
34
+ assert_match %r/test_log_event.rb\z/, @appender.event.file
35
+ end
36
+
37
+ def test_level
38
+ assert_equal 1, @event.level
39
+ end
40
+
41
+ def test_level_eq
42
+ @event.level = 3
43
+ assert_equal 3, @event.level
44
+ end
45
+
46
+ def test_line
47
+ assert_equal '', @event.file
48
+
49
+ @logger.trace = true
50
+ @logger.error 'error message'
51
+ assert_equal 50, @appender.event.line
52
+ end
53
+
54
+ def test_logger
55
+ assert_equal 'TestLogger', @event.logger
56
+ end
57
+
58
+ def test_logger_eq
59
+ @event.logger = 'MyLogger'
60
+ assert_equal 'MyLogger', @event.logger
61
+ end
62
+
63
+ def test_method
64
+ assert_equal '', @event.file
65
+
66
+ @logger.trace = true
67
+ @logger.debug 'debug message'
68
+ assert_equal 'test_method', @appender.event.method
69
+ end
70
+
71
+ end # class TestLogEvent
72
+
73
+ class EventAppender < ::Logging::Appender
74
+ attr_reader :event
75
+ def append( event ) @event = event end
76
+ end
77
+
78
+ end # module TestLogging
79
+
80
+ # EOF
@@ -0,0 +1,699 @@
1
+
2
+ require File.join(File.dirname(__FILE__), %w[setup])
3
+
4
+ module TestLogging
5
+
6
+ class TestLogger < Test::Unit::TestCase
7
+ include LoggingTestCase
8
+
9
+ def test_initialize
10
+ assert_nothing_raised {::Logging::Logger[:test]}
11
+ assert_equal ::Logging::Logger[:test], ::Logging::Logger['test']
12
+ assert_nothing_raised {::Logging::Logger.new(Object)}
13
+ end
14
+
15
+ def test_add
16
+ root = ::Logging::Logger[:root]
17
+ root.level = 'info'
18
+
19
+ a1 = ::Logging::Appenders::StringIo.new 'a1'
20
+ a2 = ::Logging::Appenders::StringIo.new 'a2'
21
+ log = ::Logging::Logger.new 'A Logger'
22
+
23
+ root.add_appenders a1
24
+ assert_nil a1.readline
25
+ assert_nil a2.readline
26
+
27
+ log.add(0, 'this should NOT be logged')
28
+ assert_nil a1.readline
29
+ assert_nil a2.readline
30
+
31
+ log.add(1, 'this should be logged')
32
+ assert_equal " INFO A Logger : this should be logged\n", a1.readline
33
+ assert_nil a1.readline
34
+ assert_nil a2.readline
35
+
36
+ log.add(2,[1,2,3,4])
37
+ assert_equal " WARN A Logger : <Array> #{[1,2,3,4]}\n", a1.readline
38
+ assert_nil a1.readline
39
+ assert_nil a2.readline
40
+
41
+ log.add_appenders a2
42
+ log.add(3, 'an error has occurred')
43
+ assert_equal "ERROR A Logger : an error has occurred\n", a1.readline
44
+ assert_equal "ERROR A Logger : an error has occurred\n", a2.readline
45
+ assert_nil a1.readline
46
+ assert_nil a2.readline
47
+
48
+ log.additive = false
49
+ log.add(3, 'another error has occurred')
50
+ assert_equal "ERROR A Logger : another error has occurred\n", a2.readline
51
+ assert_nil a1.readline
52
+ assert_nil a2.readline
53
+
54
+ log.add_appenders a1
55
+ log.add(4, 'fatal exception')
56
+ assert_equal "FATAL A Logger : fatal exception\n", a1.readline
57
+ assert_equal "FATAL A Logger : fatal exception\n", a2.readline
58
+ assert_nil a1.readline
59
+ assert_nil a2.readline
60
+
61
+
62
+ log.level = :warn
63
+ log.add(2) do
64
+ str = 'a string of data'
65
+ str
66
+ end
67
+ assert_equal " WARN A Logger : a string of data\n", a1.readline
68
+ assert_equal " WARN A Logger : a string of data\n", a2.readline
69
+ assert_nil a1.readline
70
+ assert_nil a2.readline
71
+
72
+ log.add(1) do
73
+ rb_raise(RuntimeError, "this block should not be executed")
74
+ end
75
+ assert_nil a1.readline
76
+ assert_nil a2.readline
77
+ end
78
+
79
+ def test_add_appenders
80
+ log = ::Logging::Logger.new 'A'
81
+
82
+ appenders = lambda {log.instance_variable_get :@appenders}
83
+ assert_equal [], appenders[]
84
+
85
+ assert_raise(ArgumentError) {log.add_appenders Object.new}
86
+ assert_raise(ArgumentError) {log.add_appenders 'not an appender'}
87
+
88
+ a = ::Logging::Appender.new 'test_appender_1'
89
+ b = ::Logging::Appender.new 'test_appender_2'
90
+ c = ::Logging::Appender.new 'test_appender_3'
91
+
92
+ log.add_appenders a
93
+ assert_equal [a], appenders[]
94
+
95
+ log.add_appenders a
96
+ assert_equal [a], appenders[]
97
+
98
+ log.add_appenders b
99
+ assert_equal [a,b], appenders[]
100
+
101
+ log.add_appenders c
102
+ assert_equal [a,b,c], appenders[]
103
+
104
+ log.add_appenders a, c
105
+ assert_equal [a,b,c], appenders[]
106
+
107
+ log.clear_appenders
108
+ assert_equal [], appenders[]
109
+
110
+ log.add_appenders a, c
111
+ assert_equal [a,c], appenders[]
112
+ end
113
+
114
+ def test_additive
115
+ root = ::Logging::Logger.new :root
116
+ log = ::Logging::Logger.new 'A'
117
+
118
+ assert_raise(NoMethodError) {root.additive}
119
+ assert_equal true, log.additive
120
+ end
121
+
122
+ def test_additive_eq
123
+ root = ::Logging::Logger.new :root
124
+ log = ::Logging::Logger.new 'A'
125
+
126
+ assert_raise(NoMethodError) {root.additive = false}
127
+ assert_equal true, log.additive
128
+
129
+ log.additive = false
130
+ assert_equal false, log.additive
131
+
132
+ log.additive = true
133
+ assert_equal true, log.additive
134
+
135
+ log.additive = 'false'
136
+ assert_equal false, log.additive
137
+
138
+ log.additive = 'true'
139
+ assert_equal true, log.additive
140
+
141
+ log.additive = nil
142
+ assert_equal true, log.additive
143
+
144
+ assert_raise(ArgumentError) {log.additive = Object}
145
+ end
146
+
147
+ def test_appenders_eq
148
+ log = ::Logging::Logger.new '42'
149
+
150
+ appenders = lambda {log.instance_variable_get :@appenders}
151
+ assert_equal [], appenders[]
152
+
153
+ assert_raise(ArgumentError) {log.appenders = Object.new}
154
+ assert_raise(ArgumentError) {log.appenders = 'not an appender'}
155
+
156
+ a = ::Logging::Appender.new 'test_appender_1'
157
+ b = ::Logging::Appender.new 'test_appender_2'
158
+ c = ::Logging::Appender.new 'test_appender_3'
159
+
160
+ log.appenders = a, b, c
161
+ assert_equal [a, b, c], appenders[]
162
+
163
+ log.appenders = b
164
+ assert_equal [b], appenders[]
165
+
166
+ log.appenders = c, a, b
167
+ assert_equal [c,a,b], appenders[]
168
+
169
+ log.appenders = nil
170
+ assert_equal [], appenders[]
171
+
172
+ log.appenders = %w[test_appender_1 test_appender_3]
173
+ assert_equal [a,c], appenders[]
174
+
175
+ assert_raise(ArgumentError) {log.appenders = 'unknown'}
176
+ end
177
+
178
+ def test_class_aref
179
+ root = ::Logging::Logger[:root]
180
+ assert_same root, ::Logging::Logger[:root]
181
+
182
+ a = []
183
+ assert_same ::Logging::Logger['Array'], ::Logging::Logger[Array]
184
+ assert_same ::Logging::Logger['Array'], ::Logging::Logger[a]
185
+
186
+ assert_not_same ::Logging::Logger['Array'], ::Logging::Logger[:root]
187
+ assert_not_same ::Logging::Logger['A'], ::Logging::Logger['A::B']
188
+ end
189
+
190
+ def test_class_root
191
+ root = ::Logging::Logger[:root]
192
+ assert_same root, ::Logging::Logger.root
193
+ end
194
+
195
+ def test_clear_appenders
196
+ log = ::Logging::Logger.new 'Elliott'
197
+
198
+ appenders = lambda {log.instance_variable_get :@appenders}
199
+ assert_equal [], appenders[]
200
+
201
+ a = ::Logging::Appender.new 'test_appender_1'
202
+ b = ::Logging::Appender.new 'test_appender_2'
203
+ c = ::Logging::Appender.new 'test_appender_3'
204
+
205
+ log.add_appenders a, b, c
206
+ assert_equal [a,b,c], appenders[]
207
+
208
+ log.clear_appenders
209
+ assert_equal [], appenders[]
210
+ end
211
+
212
+ def test_concat
213
+ a1 = ::Logging::Appenders::StringIo.new 'a1'
214
+ a2 = ::Logging::Appenders::StringIo.new 'a2'
215
+ log = ::Logging::Logger.new 'A'
216
+
217
+ ::Logging::Logger[:root].add_appenders a1
218
+ assert_nil a1.readline
219
+ assert_nil a2.readline
220
+
221
+ log << "this is line one of the log file\n"
222
+ assert_equal "this is line one of the log file\n", a1.readline
223
+ assert_nil a1.readline
224
+ assert_nil a2.readline
225
+
226
+ log << "this is line two of the log file\n"
227
+ log << "this is line three of the log file\n"
228
+ assert_equal "this is line two of the log file\n", a1.readline
229
+ assert_equal "this is line three of the log file\n", a1.readline
230
+ assert_nil a1.readline
231
+ assert_nil a2.readline
232
+
233
+ log.add_appenders a2
234
+ log << "this is line four of the log file\n"
235
+ assert_equal "this is line four of the log file\n", a1.readline
236
+ assert_equal "this is line four of the log file\n", a2.readline
237
+ assert_nil a1.readline
238
+ assert_nil a2.readline
239
+
240
+ log.additive = false
241
+ log << "this is line five of the log file\n"
242
+ assert_equal "this is line five of the log file\n", a2.readline
243
+ assert_nil a1.readline
244
+ assert_nil a2.readline
245
+
246
+ log.add_appenders a1
247
+ log << "this is line six of the log file\n"
248
+ assert_equal "this is line six of the log file\n", a1.readline
249
+ assert_equal "this is line six of the log file\n", a2.readline
250
+ assert_nil a1.readline
251
+ assert_nil a2.readline
252
+ end
253
+
254
+ def test_inspect
255
+ root = ::Logging::Logger.new :root
256
+
257
+ str = "<#{root.class.name}:0x%x name=\"#{root.name}\">" % root.object_id
258
+ assert_equal str, root.inspect
259
+ end
260
+
261
+ def test_level
262
+ root = ::Logging::Logger.new :root
263
+ log = ::Logging::Logger.new 'A'
264
+
265
+ assert_equal 0, root.level
266
+ assert_equal 0, log.level
267
+
268
+ root.level = :warn
269
+ assert_equal 2, root.level
270
+ assert_equal 2, log.level
271
+
272
+ log.level = nil
273
+ assert_equal 2, root.level
274
+ assert_equal 2, log.level
275
+
276
+ log.level = :error
277
+ assert_equal 2, root.level
278
+ assert_equal 3, log.level
279
+ end
280
+
281
+ def test_level_eq
282
+ root = ::Logging::Logger.new :root
283
+ log = ::Logging::Logger.new 'A'
284
+ logb = ::Logging::Logger.new 'A::B'
285
+
286
+ assert_equal 0, root.level
287
+ assert_equal 0, log.level
288
+ assert_equal 0, logb.level
289
+ assert_equal true, root.debug?
290
+ assert_equal true, log.debug?
291
+ assert_equal true, logb.debug?
292
+
293
+ assert_raise(ArgumentError) {root.level = -1}
294
+ assert_raise(ArgumentError) {root.level = 6}
295
+ assert_raise(ArgumentError) {root.level = Object}
296
+ assert_raise(ArgumentError) {root.level = 'bob'}
297
+ assert_raise(ArgumentError) {root.level = :wtf}
298
+
299
+ root.level = 'INFO'
300
+ assert_equal 1, root.level
301
+ assert_equal 1, log.level
302
+ assert_equal 1, logb.level
303
+ assert_equal false, root.debug?
304
+ assert_equal true, root.info?
305
+ assert_equal false, log.debug?
306
+ assert_equal true , log.info?
307
+ assert_equal false, logb.debug?
308
+ assert_equal true , logb.info?
309
+
310
+ root.level = :warn
311
+ assert_equal 2, root.level
312
+ assert_equal 2, log.level
313
+ assert_equal 2, logb.level
314
+ assert_equal false, root.info?
315
+ assert_equal true, root.warn?
316
+ assert_equal false, log.info?
317
+ assert_equal true , log.warn?
318
+ assert_equal false, logb.info?
319
+ assert_equal true , logb.warn?
320
+
321
+ root.level = 'error'
322
+ assert_equal 3, root.level
323
+ assert_equal 3, log.level
324
+ assert_equal 3, logb.level
325
+ assert_equal false, root.warn?
326
+ assert_equal true, root.error?
327
+ assert_equal false, log.warn?
328
+ assert_equal true , log.error?
329
+ assert_equal false, logb.warn?
330
+ assert_equal true , logb.error?
331
+
332
+ root.level = 4
333
+ assert_equal 4, root.level
334
+ assert_equal 4, log.level
335
+ assert_equal 4, logb.level
336
+ assert_equal false, root.error?
337
+ assert_equal true, root.fatal?
338
+ assert_equal false, log.error?
339
+ assert_equal true , log.fatal?
340
+ assert_equal false, logb.error?
341
+ assert_equal true , logb.fatal?
342
+
343
+ log.level = nil
344
+ assert_equal 4, root.level
345
+ assert_equal 4, log.level
346
+ assert_equal 4, logb.level
347
+ assert_equal false, root.error?
348
+ assert_equal true, root.fatal?
349
+ assert_equal false, log.error?
350
+ assert_equal true , log.fatal?
351
+ assert_equal false, logb.error?
352
+ assert_equal true , logb.fatal?
353
+
354
+ log.level = :DEBUG
355
+ assert_equal 4, root.level
356
+ assert_equal 0, log.level
357
+ assert_equal 0, logb.level
358
+ assert_equal false, root.error?
359
+ assert_equal true, root.fatal?
360
+ assert_equal true, log.debug?
361
+ assert_equal true, logb.debug?
362
+
363
+ log.level = :off
364
+ assert_equal 4, root.level
365
+ assert_equal 5, log.level
366
+ assert_equal 5, logb.level
367
+ assert_equal false, root.error?
368
+ assert_equal true, root.fatal?
369
+ assert_equal false, log.fatal?
370
+ assert_equal false, logb.fatal?
371
+
372
+ root.level = :all
373
+ assert_equal 0, root.level
374
+ assert_equal 5, log.level
375
+ assert_equal 5, logb.level
376
+ assert_equal true, root.debug?
377
+ assert_equal false, log.fatal?
378
+ assert_equal false, logb.fatal?
379
+
380
+ log.level = nil
381
+ assert_equal 0, root.level
382
+ assert_equal 0, log.level
383
+ assert_equal 0, logb.level
384
+ assert_equal true, root.debug?
385
+ assert_equal true, log.debug?
386
+ assert_equal true, logb.debug?
387
+
388
+ logb.level = :warn
389
+ assert_equal 0, root.level
390
+ assert_equal 0, log.level
391
+ assert_equal 2, logb.level
392
+ assert_equal true, root.debug?
393
+ assert_equal true, log.debug?
394
+ assert_equal false, logb.info?
395
+ assert_equal true, logb.warn?
396
+
397
+ log.level = :info
398
+ logb.level = nil
399
+ assert_equal 0, root.level
400
+ assert_equal 1, log.level
401
+ assert_equal 1, logb.level
402
+ assert_equal true, root.debug?
403
+ assert_equal false, logb.debug?
404
+ assert_equal true, log.info?
405
+ assert_equal false, logb.debug?
406
+ assert_equal true, logb.info?
407
+ end
408
+
409
+ def test_log
410
+ root = ::Logging::Logger[:root]
411
+ root.level = 'info'
412
+
413
+ a1 = ::Logging::Appenders::StringIo.new 'a1'
414
+ a2 = ::Logging::Appenders::StringIo.new 'a2'
415
+ log = ::Logging::Logger.new 'A Logger'
416
+
417
+ root.add_appenders a1
418
+ assert_nil a1.readline
419
+ assert_nil a2.readline
420
+
421
+ log.debug 'this should NOT be logged'
422
+ assert_nil a1.readline
423
+ assert_nil a2.readline
424
+
425
+ log.info 'this should be logged'
426
+ assert_equal " INFO A Logger : this should be logged\n", a1.readline
427
+ assert_nil a1.readline
428
+ assert_nil a2.readline
429
+
430
+ log.warn [1,2,3,4]
431
+ assert_equal " WARN A Logger : <Array> #{[1,2,3,4]}\n", a1.readline
432
+ assert_nil a1.readline
433
+ assert_nil a2.readline
434
+
435
+ log.add_appenders a2
436
+ log.error 'an error has occurred'
437
+ assert_equal "ERROR A Logger : an error has occurred\n", a1.readline
438
+ assert_equal "ERROR A Logger : an error has occurred\n", a2.readline
439
+ assert_nil a1.readline
440
+ assert_nil a2.readline
441
+
442
+ log.additive = false
443
+ log.error 'another error has occurred'
444
+ assert_equal "ERROR A Logger : another error has occurred\n", a2.readline
445
+ assert_nil a1.readline
446
+ assert_nil a2.readline
447
+
448
+ log.add_appenders a1
449
+ log.fatal 'fatal exception'
450
+ assert_equal "FATAL A Logger : fatal exception\n", a1.readline
451
+ assert_equal "FATAL A Logger : fatal exception\n", a2.readline
452
+ assert_nil a1.readline
453
+ assert_nil a2.readline
454
+
455
+ assert_equal false, log.debug
456
+ assert_equal true, log.info
457
+ assert_equal " INFO A Logger : <NilClass> nil\n", a1.readline
458
+ assert_equal " INFO A Logger : <NilClass> nil\n", a2.readline
459
+ assert_equal true, log.warn
460
+ assert_equal " WARN A Logger : <NilClass> nil\n", a1.readline
461
+ assert_equal " WARN A Logger : <NilClass> nil\n", a2.readline
462
+ assert_equal true, log.error
463
+ assert_equal "ERROR A Logger : <NilClass> nil\n", a1.readline
464
+ assert_equal "ERROR A Logger : <NilClass> nil\n", a2.readline
465
+ assert_equal true, log.fatal
466
+ assert_equal "FATAL A Logger : <NilClass> nil\n", a1.readline
467
+ assert_equal "FATAL A Logger : <NilClass> nil\n", a2.readline
468
+
469
+ log.level = :warn
470
+ assert_equal false, log.debug
471
+ assert_equal false, log.info
472
+ assert_equal true, log.warn
473
+ assert_equal " WARN A Logger : <NilClass> nil\n", a1.readline
474
+ assert_equal " WARN A Logger : <NilClass> nil\n", a2.readline
475
+ assert_equal true, log.error
476
+ assert_equal "ERROR A Logger : <NilClass> nil\n", a1.readline
477
+ assert_equal "ERROR A Logger : <NilClass> nil\n", a2.readline
478
+ assert_equal true, log.fatal
479
+ assert_equal "FATAL A Logger : <NilClass> nil\n", a1.readline
480
+ assert_equal "FATAL A Logger : <NilClass> nil\n", a2.readline
481
+
482
+ assert_raise(NoMethodError) {log.critical 'this log level does not exist'}
483
+
484
+ log.warn do
485
+ str = 'a string of data'
486
+ str
487
+ end
488
+ assert_equal " WARN A Logger : a string of data\n", a1.readline
489
+ assert_equal " WARN A Logger : a string of data\n", a2.readline
490
+ assert_nil a1.readline
491
+ assert_nil a2.readline
492
+
493
+ log.info do
494
+ rb_raise(RuntimeError, "this block should not be executed")
495
+ end
496
+ assert_nil a1.readline
497
+ assert_nil a2.readline
498
+ end
499
+
500
+ def test_log_eh
501
+ ::Logging::Logger[:root].level = 'info'
502
+ log = ::Logging::Logger['A Logger']
503
+
504
+ assert_equal false, log.debug?
505
+ assert_equal true, log.info?
506
+ assert_equal true, log.warn?
507
+ assert_equal true, log.error?
508
+ assert_equal true, log.fatal?
509
+
510
+ log.level = :warn
511
+ assert_equal false, log.debug?
512
+ assert_equal false, log.info?
513
+ assert_equal true, log.warn?
514
+ assert_equal true, log.error?
515
+ assert_equal true, log.fatal?
516
+
517
+ assert_raise(NoMethodError) do
518
+ log.critical? 'this log level does not exist'
519
+ end
520
+ end
521
+
522
+ def test_name
523
+ root = ::Logging::Logger.new :root
524
+ log = ::Logging::Logger.new 'A'
525
+
526
+ assert_equal 'root', root.name
527
+ assert_equal 'A', log.name
528
+ end
529
+
530
+ def test_parent
531
+ logger = ::Logging::Logger
532
+ root = logger.new :root
533
+
534
+ assert_raise(NoMethodError) {root.parent}
535
+
536
+ assert_same root, logger['A'].parent
537
+ assert_same logger['A'], logger['A::B'].parent
538
+ assert_same logger['A::B'], logger['A::B::C::D'].parent
539
+ assert_same logger['A::B'], logger['A::B::C::E'].parent
540
+ assert_same logger['A::B'], logger['A::B::C::F'].parent
541
+
542
+ assert_same logger['A::B'], logger['A::B::C'].parent
543
+ assert_same logger['A::B::C'], logger['A::B::C::D'].parent
544
+ assert_same logger['A::B::C'], logger['A::B::C::E'].parent
545
+ assert_same logger['A::B::C'], logger['A::B::C::F'].parent
546
+
547
+ assert_same logger['A::B::C::E'], logger['A::B::C::E::G'].parent
548
+ end
549
+
550
+ def test_remove_appenders
551
+ log = ::Logging::Logger['X']
552
+
553
+ appenders = lambda {log.instance_variable_get :@appenders}
554
+ assert_equal [], appenders[]
555
+
556
+ a = ::Logging::Appender.new 'test_appender_1'
557
+ b = ::Logging::Appender.new 'test_appender_2'
558
+ c = ::Logging::Appender.new 'test_appender_3'
559
+
560
+ log.add_appenders a, b, c
561
+ assert_equal [a,b,c], appenders[]
562
+
563
+ assert_raise(ArgumentError) {log.remove_appenders Object.new}
564
+ assert_raise(ArgumentError) {log.remove_appenders 10}
565
+
566
+ log.remove_appenders b
567
+ assert_equal [a,c], appenders[]
568
+
569
+ log.remove_appenders 'test_appender_1'
570
+ assert_equal [c], appenders[]
571
+
572
+ log.remove_appenders c
573
+ assert_equal [], appenders[]
574
+
575
+ log.remove_appenders a, b, c
576
+ assert_equal [], appenders[]
577
+
578
+ log.add_appenders a, b, c
579
+ assert_equal [a,b,c], appenders[]
580
+
581
+ log.remove_appenders a, c
582
+ assert_equal [b], appenders[]
583
+ end
584
+
585
+ def test_spaceship
586
+ logs = %w(
587
+ A A::B A::B::C A::B::C::D A::B::C::E A::B::C::E::G A::B::C::F
588
+ ).map {|x| ::Logging::Logger[x]}
589
+ logs.unshift ::Logging::Logger[:root]
590
+
591
+ logs.inject do |a,b|
592
+ assert_equal(-1, a <=> b, "'#{a.name}' <=> '#{b.name}'")
593
+ b
594
+ end
595
+
596
+ assert_equal 1, logs[1] <=> ::Logging::Logger[:root]
597
+ assert_raise(ArgumentError) {logs[1] <=> Object.new}
598
+ assert_raise(ArgumentError) {::Logging::Logger[:root] <=> 'string'}
599
+ end
600
+
601
+ def test_trace
602
+ log = ::Logging::Logger[:root]
603
+ assert_equal false, log.trace
604
+
605
+ log.trace = true
606
+ assert_equal true, log.trace
607
+
608
+ log = ::Logging::Logger['A']
609
+ assert_equal false, log.trace
610
+
611
+ log.trace = true
612
+ assert_equal true, log.trace
613
+ end
614
+
615
+ def test_trace_eq
616
+ log = ::Logging::Logger.new 'A'
617
+ assert_equal false, log.trace
618
+
619
+ log.trace = true
620
+ assert_equal true, log.trace
621
+
622
+ log.trace = false
623
+ assert_equal false, log.trace
624
+
625
+ log.trace = 'true'
626
+ assert_equal true, log.trace
627
+
628
+ log.trace = 'false'
629
+ assert_equal false, log.trace
630
+
631
+ log.trace = nil
632
+ assert_equal false, log.trace
633
+
634
+ assert_raise(ArgumentError) {log.trace = Object}
635
+ end
636
+
637
+ def test_dump_configuration
638
+ log_a = ::Logging::Logger['A-logger']
639
+ log_b = ::Logging::Logger['A-logger::B-logger']
640
+ log_c = ::Logging::Logger['A-logger::B-logger::C-logger']
641
+ log_d = ::Logging::Logger['A-logger::D-logger']
642
+
643
+ sio = StringIO.new
644
+ sio.extend ::Logging::Appenders::StringIo::IoToS
645
+
646
+ log_a._dump_configuration( sio )
647
+ assert_equal(
648
+ "A-logger ........................................ debug +A -T\n", sio.to_s)
649
+
650
+ log_b._dump_configuration( sio )
651
+ assert_equal(
652
+ "A-logger::B-logger .............................. debug +A -T\n", sio.to_s)
653
+
654
+ log_c._dump_configuration( sio )
655
+ assert_equal(
656
+ "A-logger::B-logger::C-logger .................... debug +A -T\n", sio.to_s)
657
+
658
+ log_d._dump_configuration( sio )
659
+ assert_equal(
660
+ "A-logger::D-logger .............................. debug +A -T\n", sio.to_s)
661
+
662
+ log_b.level = :warn
663
+ log_b.trace = true
664
+ log_b._dump_configuration( sio )
665
+ assert_equal(
666
+ "A-logger::B-logger .............................. *warn +A +T\n", sio.to_s)
667
+
668
+ log_c.additive = false
669
+ log_c._dump_configuration( sio )
670
+ assert_equal(
671
+ "A-logger::B-logger::C-logger .................... warn -A -T\n", sio.to_s)
672
+
673
+ # with an indent specified
674
+ log_a._dump_configuration( sio, 4 )
675
+ assert_equal(
676
+ " A-logger .................................... debug +A -T\n", sio.to_s)
677
+
678
+ log_b._dump_configuration( sio, 8 )
679
+ assert_equal(
680
+ " A-logger::B-logger ...................... *warn +A +T\n", sio.to_s)
681
+
682
+ log_c._dump_configuration( sio, 10 )
683
+ assert_equal(
684
+ " A-logger::B-logger::C-logger .......... warn -A -T\n", sio.to_s)
685
+
686
+ log_d._dump_configuration( sio, 22 )
687
+ assert_equal(
688
+ " A-logger::D-logger ........ debug +A -T\n", sio.to_s)
689
+
690
+ log_c.level = 0
691
+ log_c._dump_configuration( sio, 26 )
692
+ assert_equal(
693
+ " A-logger::B...::C-logger *debug -A -T\n", sio.to_s)
694
+ end
695
+
696
+ end # class TestLogger
697
+ end # module TestLogging
698
+
699
+ # EOF