deg-yard 0.8.7.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (558) hide show
  1. data/.travis.yml +39 -0
  2. data/.yardopts +25 -0
  3. data/.yardopts_guide +19 -0
  4. data/.yardopts_i18n +22 -0
  5. data/Gemfile +35 -0
  6. data/LEGAL +66 -0
  7. data/LICENSE +22 -0
  8. data/README.md +609 -0
  9. data/Rakefile +66 -0
  10. data/benchmarks/builtins_vs_eval.rb +23 -0
  11. data/benchmarks/concat_vs_join.rb +12 -0
  12. data/benchmarks/erb_vs_erubis.rb +53 -0
  13. data/benchmarks/format_args.rb +46 -0
  14. data/benchmarks/generation.rb +37 -0
  15. data/benchmarks/marshal_vs_dbm.rb +63 -0
  16. data/benchmarks/parsing.rb +46 -0
  17. data/benchmarks/pathname_vs_string.rb +50 -0
  18. data/benchmarks/rdoc_vs_yardoc.rb +10 -0
  19. data/benchmarks/registry_store_types.rb +48 -0
  20. data/benchmarks/ri_vs_yri.rb +18 -0
  21. data/benchmarks/ripper_parser.rb +12 -0
  22. data/benchmarks/splat_vs_flatten.rb +12 -0
  23. data/benchmarks/template_erb.rb +22 -0
  24. data/benchmarks/template_format.rb +6 -0
  25. data/benchmarks/template_profile.rb +17 -0
  26. data/benchmarks/yri_cache.rb +19 -0
  27. data/bin/yard +12 -0
  28. data/bin/yardoc +12 -0
  29. data/bin/yri +12 -0
  30. data/docs/CodeObjects.md +115 -0
  31. data/docs/GettingStarted.md +592 -0
  32. data/docs/Handlers.md +152 -0
  33. data/docs/Overview.md +61 -0
  34. data/docs/Parser.md +191 -0
  35. data/docs/Tags.md +282 -0
  36. data/docs/TagsArch.md +123 -0
  37. data/docs/Templates.md +496 -0
  38. data/docs/WhatsNew.md +1244 -0
  39. data/docs/images/code-objects-class-diagram.png +0 -0
  40. data/docs/images/handlers-class-diagram.png +0 -0
  41. data/docs/images/overview-class-diagram.png +0 -0
  42. data/docs/images/parser-class-diagram.png +0 -0
  43. data/docs/images/tags-class-diagram.png +0 -0
  44. data/docs/templates/default/fulldoc/html/full_list_tag.erb +7 -0
  45. data/docs/templates/default/fulldoc/html/setup.rb +6 -0
  46. data/docs/templates/default/layout/html/setup.rb +8 -0
  47. data/docs/templates/default/layout/html/tag_list.erb +11 -0
  48. data/docs/templates/default/yard_tags/html/list.erb +18 -0
  49. data/docs/templates/default/yard_tags/html/setup.rb +27 -0
  50. data/docs/templates/plugin.rb +65 -0
  51. data/lib/rubygems_plugin.rb +4 -0
  52. data/lib/yard/autoload.rb +290 -0
  53. data/lib/yard/cli/command.rb +84 -0
  54. data/lib/yard/cli/command_parser.rb +92 -0
  55. data/lib/yard/cli/config.rb +136 -0
  56. data/lib/yard/cli/diff.rb +270 -0
  57. data/lib/yard/cli/display.rb +68 -0
  58. data/lib/yard/cli/gems.rb +83 -0
  59. data/lib/yard/cli/graph.rb +126 -0
  60. data/lib/yard/cli/help.rb +18 -0
  61. data/lib/yard/cli/i18n.rb +69 -0
  62. data/lib/yard/cli/list.rb +22 -0
  63. data/lib/yard/cli/markup_types.rb +33 -0
  64. data/lib/yard/cli/server.rb +253 -0
  65. data/lib/yard/cli/stats.rb +213 -0
  66. data/lib/yard/cli/yardoc.rb +752 -0
  67. data/lib/yard/cli/yardopts_command.rb +109 -0
  68. data/lib/yard/cli/yri.rb +214 -0
  69. data/lib/yard/code_objects/base.rb +585 -0
  70. data/lib/yard/code_objects/class_object.rb +143 -0
  71. data/lib/yard/code_objects/class_variable_object.rb +8 -0
  72. data/lib/yard/code_objects/constant_object.rb +13 -0
  73. data/lib/yard/code_objects/extended_method_object.rb +23 -0
  74. data/lib/yard/code_objects/extra_file_object.rb +128 -0
  75. data/lib/yard/code_objects/macro_object.rb +172 -0
  76. data/lib/yard/code_objects/method_object.rb +191 -0
  77. data/lib/yard/code_objects/module_object.rb +18 -0
  78. data/lib/yard/code_objects/namespace_object.rb +200 -0
  79. data/lib/yard/code_objects/proxy.rb +258 -0
  80. data/lib/yard/code_objects/root_object.rb +17 -0
  81. data/lib/yard/config.rb +269 -0
  82. data/lib/yard/core_ext/array.rb +15 -0
  83. data/lib/yard/core_ext/file.rb +65 -0
  84. data/lib/yard/core_ext/hash.rb +15 -0
  85. data/lib/yard/core_ext/insertion.rb +60 -0
  86. data/lib/yard/core_ext/module.rb +19 -0
  87. data/lib/yard/core_ext/string.rb +67 -0
  88. data/lib/yard/core_ext/symbol_hash.rb +73 -0
  89. data/lib/yard/docstring.rb +362 -0
  90. data/lib/yard/docstring_parser.rb +321 -0
  91. data/lib/yard/globals.rb +18 -0
  92. data/lib/yard/handlers/base.rb +597 -0
  93. data/lib/yard/handlers/c/alias_handler.rb +15 -0
  94. data/lib/yard/handlers/c/attribute_handler.rb +13 -0
  95. data/lib/yard/handlers/c/base.rb +110 -0
  96. data/lib/yard/handlers/c/class_handler.rb +26 -0
  97. data/lib/yard/handlers/c/constant_handler.rb +12 -0
  98. data/lib/yard/handlers/c/handler_methods.rb +166 -0
  99. data/lib/yard/handlers/c/init_handler.rb +18 -0
  100. data/lib/yard/handlers/c/method_handler.rb +35 -0
  101. data/lib/yard/handlers/c/mixin_handler.rb +13 -0
  102. data/lib/yard/handlers/c/module_handler.rb +16 -0
  103. data/lib/yard/handlers/c/override_comment_handler.rb +30 -0
  104. data/lib/yard/handlers/c/path_handler.rb +10 -0
  105. data/lib/yard/handlers/c/struct_handler.rb +12 -0
  106. data/lib/yard/handlers/c/symbol_handler.rb +7 -0
  107. data/lib/yard/handlers/processor.rb +201 -0
  108. data/lib/yard/handlers/ruby/alias_handler.rb +41 -0
  109. data/lib/yard/handlers/ruby/attribute_handler.rb +82 -0
  110. data/lib/yard/handlers/ruby/base.rb +164 -0
  111. data/lib/yard/handlers/ruby/class_condition_handler.rb +86 -0
  112. data/lib/yard/handlers/ruby/class_handler.rb +121 -0
  113. data/lib/yard/handlers/ruby/class_variable_handler.rb +16 -0
  114. data/lib/yard/handlers/ruby/comment_handler.rb +9 -0
  115. data/lib/yard/handlers/ruby/constant_handler.rb +45 -0
  116. data/lib/yard/handlers/ruby/dsl_handler.rb +14 -0
  117. data/lib/yard/handlers/ruby/dsl_handler_methods.rb +77 -0
  118. data/lib/yard/handlers/ruby/exception_handler.rb +26 -0
  119. data/lib/yard/handlers/ruby/extend_handler.rb +21 -0
  120. data/lib/yard/handlers/ruby/legacy/alias_handler.rb +34 -0
  121. data/lib/yard/handlers/ruby/legacy/attribute_handler.rb +60 -0
  122. data/lib/yard/handlers/ruby/legacy/base.rb +250 -0
  123. data/lib/yard/handlers/ruby/legacy/class_condition_handler.rb +83 -0
  124. data/lib/yard/handlers/ruby/legacy/class_handler.rb +111 -0
  125. data/lib/yard/handlers/ruby/legacy/class_variable_handler.rb +14 -0
  126. data/lib/yard/handlers/ruby/legacy/comment_handler.rb +9 -0
  127. data/lib/yard/handlers/ruby/legacy/constant_handler.rb +28 -0
  128. data/lib/yard/handlers/ruby/legacy/dsl_handler.rb +16 -0
  129. data/lib/yard/handlers/ruby/legacy/exception_handler.rb +12 -0
  130. data/lib/yard/handlers/ruby/legacy/extend_handler.rb +20 -0
  131. data/lib/yard/handlers/ruby/legacy/method_handler.rb +85 -0
  132. data/lib/yard/handlers/ruby/legacy/mixin_handler.rb +39 -0
  133. data/lib/yard/handlers/ruby/legacy/module_function_handler.rb +18 -0
  134. data/lib/yard/handlers/ruby/legacy/module_handler.rb +11 -0
  135. data/lib/yard/handlers/ruby/legacy/private_constant_handler.rb +21 -0
  136. data/lib/yard/handlers/ruby/legacy/visibility_handler.rb +16 -0
  137. data/lib/yard/handlers/ruby/legacy/yield_handler.rb +28 -0
  138. data/lib/yard/handlers/ruby/method_condition_handler.rb +8 -0
  139. data/lib/yard/handlers/ruby/method_handler.rb +92 -0
  140. data/lib/yard/handlers/ruby/mixin_handler.rb +36 -0
  141. data/lib/yard/handlers/ruby/module_function_handler.rb +26 -0
  142. data/lib/yard/handlers/ruby/module_handler.rb +11 -0
  143. data/lib/yard/handlers/ruby/private_constant_handler.rb +36 -0
  144. data/lib/yard/handlers/ruby/struct_handler_methods.rb +141 -0
  145. data/lib/yard/handlers/ruby/visibility_handler.rb +24 -0
  146. data/lib/yard/handlers/ruby/yield_handler.rb +30 -0
  147. data/lib/yard/i18n/locale.rb +74 -0
  148. data/lib/yard/i18n/message.rb +56 -0
  149. data/lib/yard/i18n/messages.rb +55 -0
  150. data/lib/yard/i18n/pot_generator.rb +280 -0
  151. data/lib/yard/i18n/text.rb +173 -0
  152. data/lib/yard/logging.rb +190 -0
  153. data/lib/yard/options.rb +216 -0
  154. data/lib/yard/parser/base.rb +56 -0
  155. data/lib/yard/parser/c/c_parser.rb +231 -0
  156. data/lib/yard/parser/c/comment_parser.rb +131 -0
  157. data/lib/yard/parser/c/statement.rb +63 -0
  158. data/lib/yard/parser/ruby/ast_node.rb +496 -0
  159. data/lib/yard/parser/ruby/legacy/ruby_lex.rb +1378 -0
  160. data/lib/yard/parser/ruby/legacy/ruby_parser.rb +31 -0
  161. data/lib/yard/parser/ruby/legacy/statement.rb +65 -0
  162. data/lib/yard/parser/ruby/legacy/statement_list.rb +384 -0
  163. data/lib/yard/parser/ruby/legacy/token_list.rb +71 -0
  164. data/lib/yard/parser/ruby/ruby_parser.rb +625 -0
  165. data/lib/yard/parser/source_parser.rb +517 -0
  166. data/lib/yard/rake/yardoc_task.rb +74 -0
  167. data/lib/yard/registry.rb +438 -0
  168. data/lib/yard/registry_store.rb +319 -0
  169. data/lib/yard/rubygems/backports/LICENSE.txt +57 -0
  170. data/lib/yard/rubygems/backports/MIT.txt +20 -0
  171. data/lib/yard/rubygems/backports/gem.rb +9 -0
  172. data/lib/yard/rubygems/backports/source_index.rb +370 -0
  173. data/lib/yard/rubygems/backports.rb +8 -0
  174. data/lib/yard/rubygems/doc_manager.rb +88 -0
  175. data/lib/yard/rubygems/specification.rb +41 -0
  176. data/lib/yard/serializers/base.rb +80 -0
  177. data/lib/yard/serializers/file_system_serializer.rb +90 -0
  178. data/lib/yard/serializers/process_serializer.rb +24 -0
  179. data/lib/yard/serializers/stdout_serializer.rb +32 -0
  180. data/lib/yard/serializers/yardoc_serializer.rb +124 -0
  181. data/lib/yard/server/adapter.rb +100 -0
  182. data/lib/yard/server/commands/base.rb +192 -0
  183. data/lib/yard/server/commands/display_file_command.rb +24 -0
  184. data/lib/yard/server/commands/display_object_command.rb +58 -0
  185. data/lib/yard/server/commands/frames_command.rb +15 -0
  186. data/lib/yard/server/commands/library_command.rb +148 -0
  187. data/lib/yard/server/commands/library_index_command.rb +24 -0
  188. data/lib/yard/server/commands/list_command.rb +24 -0
  189. data/lib/yard/server/commands/search_command.rb +78 -0
  190. data/lib/yard/server/commands/static_file_command.rb +57 -0
  191. data/lib/yard/server/doc_server_helper.rb +76 -0
  192. data/lib/yard/server/doc_server_serializer.rb +33 -0
  193. data/lib/yard/server/library_version.rb +227 -0
  194. data/lib/yard/server/rack_adapter.rb +88 -0
  195. data/lib/yard/server/router.rb +176 -0
  196. data/lib/yard/server/static_caching.rb +45 -0
  197. data/lib/yard/server/templates/default/fulldoc/html/css/custom.css +78 -0
  198. data/lib/yard/server/templates/default/fulldoc/html/images/processing.gif +0 -0
  199. data/lib/yard/server/templates/default/fulldoc/html/js/autocomplete.js +12 -0
  200. data/lib/yard/server/templates/default/layout/html/breadcrumb.erb +46 -0
  201. data/lib/yard/server/templates/default/layout/html/script_setup.erb +8 -0
  202. data/lib/yard/server/templates/default/layout/html/setup.rb +7 -0
  203. data/lib/yard/server/templates/default/method_details/html/permalink.erb +4 -0
  204. data/lib/yard/server/templates/default/method_details/html/setup.rb +4 -0
  205. data/lib/yard/server/templates/doc_server/library_list/html/contents.erb +13 -0
  206. data/lib/yard/server/templates/doc_server/library_list/html/headers.erb +26 -0
  207. data/lib/yard/server/templates/doc_server/library_list/html/library_list.erb +12 -0
  208. data/lib/yard/server/templates/doc_server/library_list/html/setup.rb +3 -0
  209. data/lib/yard/server/templates/doc_server/library_list/html/title.erb +2 -0
  210. data/lib/yard/server/templates/doc_server/processing/html/processing.erb +51 -0
  211. data/lib/yard/server/templates/doc_server/processing/html/setup.rb +3 -0
  212. data/lib/yard/server/templates/doc_server/search/html/search.erb +18 -0
  213. data/lib/yard/server/templates/doc_server/search/html/setup.rb +8 -0
  214. data/lib/yard/server/webrick_adapter.rb +43 -0
  215. data/lib/yard/server.rb +11 -0
  216. data/lib/yard/tags/default_factory.rb +176 -0
  217. data/lib/yard/tags/default_tag.rb +12 -0
  218. data/lib/yard/tags/directives.rb +599 -0
  219. data/lib/yard/tags/library.rb +630 -0
  220. data/lib/yard/tags/option_tag.rb +12 -0
  221. data/lib/yard/tags/overload_tag.rb +66 -0
  222. data/lib/yard/tags/ref_tag.rb +7 -0
  223. data/lib/yard/tags/ref_tag_list.rb +27 -0
  224. data/lib/yard/tags/tag.rb +57 -0
  225. data/lib/yard/tags/tag_format_error.rb +6 -0
  226. data/lib/yard/templates/engine.rb +185 -0
  227. data/lib/yard/templates/erb_cache.rb +22 -0
  228. data/lib/yard/templates/helpers/base_helper.rb +212 -0
  229. data/lib/yard/templates/helpers/filter_helper.rb +26 -0
  230. data/lib/yard/templates/helpers/html_helper.rb +599 -0
  231. data/lib/yard/templates/helpers/html_syntax_highlight_helper.rb +59 -0
  232. data/lib/yard/templates/helpers/markup/rdoc_markdown.rb +22 -0
  233. data/lib/yard/templates/helpers/markup/rdoc_markup.rb +106 -0
  234. data/lib/yard/templates/helpers/markup_helper.rb +169 -0
  235. data/lib/yard/templates/helpers/method_helper.rb +74 -0
  236. data/lib/yard/templates/helpers/module_helper.rb +19 -0
  237. data/lib/yard/templates/helpers/text_helper.rb +95 -0
  238. data/lib/yard/templates/helpers/uml_helper.rb +46 -0
  239. data/lib/yard/templates/section.rb +106 -0
  240. data/lib/yard/templates/template.rb +407 -0
  241. data/lib/yard/templates/template_options.rb +88 -0
  242. data/lib/yard/verifier.rb +148 -0
  243. data/lib/yard/version.rb +3 -0
  244. data/lib/yard.rb +71 -0
  245. data/po/ja.po +31118 -0
  246. data/spec/cli/command_parser_spec.rb +43 -0
  247. data/spec/cli/command_spec.rb +36 -0
  248. data/spec/cli/config_spec.rb +92 -0
  249. data/spec/cli/diff_spec.rb +260 -0
  250. data/spec/cli/display_spec.rb +30 -0
  251. data/spec/cli/gems_spec.rb +81 -0
  252. data/spec/cli/graph_spec.rb +17 -0
  253. data/spec/cli/help_spec.rb +22 -0
  254. data/spec/cli/i18n_spec.rb +111 -0
  255. data/spec/cli/list_spec.rb +8 -0
  256. data/spec/cli/markup_types_spec.rb +22 -0
  257. data/spec/cli/server_spec.rb +327 -0
  258. data/spec/cli/stats_spec.rb +90 -0
  259. data/spec/cli/yardoc_spec.rb +804 -0
  260. data/spec/cli/yri_spec.rb +99 -0
  261. data/spec/code_objects/base_spec.rb +438 -0
  262. data/spec/code_objects/class_object_spec.rb +225 -0
  263. data/spec/code_objects/code_object_list_spec.rb +33 -0
  264. data/spec/code_objects/constants_spec.rb +82 -0
  265. data/spec/code_objects/extra_file_object_spec.rb +147 -0
  266. data/spec/code_objects/macro_object_spec.rb +148 -0
  267. data/spec/code_objects/method_object_spec.rb +175 -0
  268. data/spec/code_objects/module_object_spec.rb +141 -0
  269. data/spec/code_objects/namespace_object_spec.rb +170 -0
  270. data/spec/code_objects/proxy_spec.rb +140 -0
  271. data/spec/code_objects/spec_helper.rb +3 -0
  272. data/spec/config_spec.rb +176 -0
  273. data/spec/core_ext/array_spec.rb +14 -0
  274. data/spec/core_ext/file_spec.rb +68 -0
  275. data/spec/core_ext/hash_spec.rb +14 -0
  276. data/spec/core_ext/insertion_spec.rb +37 -0
  277. data/spec/core_ext/module_spec.rb +15 -0
  278. data/spec/core_ext/string_spec.rb +42 -0
  279. data/spec/core_ext/symbol_hash_spec.rb +86 -0
  280. data/spec/docstring_parser_spec.rb +228 -0
  281. data/spec/docstring_spec.rb +335 -0
  282. data/spec/handlers/alias_handler_spec.rb +80 -0
  283. data/spec/handlers/attribute_handler_spec.rb +94 -0
  284. data/spec/handlers/base_spec.rb +206 -0
  285. data/spec/handlers/c/alias_handler_spec.rb +33 -0
  286. data/spec/handlers/c/attribute_handler_spec.rb +40 -0
  287. data/spec/handlers/c/class_handler_spec.rb +63 -0
  288. data/spec/handlers/c/constant_handler_spec.rb +68 -0
  289. data/spec/handlers/c/init_handler_spec.rb +47 -0
  290. data/spec/handlers/c/method_handler_spec.rb +229 -0
  291. data/spec/handlers/c/mixin_handler_spec.rb +27 -0
  292. data/spec/handlers/c/module_handler_spec.rb +38 -0
  293. data/spec/handlers/c/override_comment_handler_spec.rb +46 -0
  294. data/spec/handlers/c/path_handler_spec.rb +35 -0
  295. data/spec/handlers/c/spec_helper.rb +13 -0
  296. data/spec/handlers/c/struct_handler_spec.rb +15 -0
  297. data/spec/handlers/class_condition_handler_spec.rb +67 -0
  298. data/spec/handlers/class_handler_spec.rb +246 -0
  299. data/spec/handlers/class_variable_handler_spec.rb +11 -0
  300. data/spec/handlers/constant_handler_spec.rb +64 -0
  301. data/spec/handlers/dsl_handler_spec.rb +197 -0
  302. data/spec/handlers/examples/alias_handler_001.rb.txt +44 -0
  303. data/spec/handlers/examples/attribute_handler_001.rb.txt +32 -0
  304. data/spec/handlers/examples/class_condition_handler_001.rb.txt +69 -0
  305. data/spec/handlers/examples/class_handler_001.rb.txt +120 -0
  306. data/spec/handlers/examples/class_variable_handler_001.rb.txt +10 -0
  307. data/spec/handlers/examples/constant_handler_001.rb.txt +25 -0
  308. data/spec/handlers/examples/dsl_handler_001.rb.txt +125 -0
  309. data/spec/handlers/examples/exception_handler_001.rb.txt +59 -0
  310. data/spec/handlers/examples/extend_handler_001.rb.txt +16 -0
  311. data/spec/handlers/examples/method_condition_handler_001.rb.txt +10 -0
  312. data/spec/handlers/examples/method_handler_001.rb.txt +126 -0
  313. data/spec/handlers/examples/mixin_handler_001.rb.txt +37 -0
  314. data/spec/handlers/examples/module_handler_001.rb.txt +29 -0
  315. data/spec/handlers/examples/private_constant_handler_001.rb.txt +8 -0
  316. data/spec/handlers/examples/process_handler_001.rb.txt +11 -0
  317. data/spec/handlers/examples/visibility_handler_001.rb.txt +32 -0
  318. data/spec/handlers/examples/yield_handler_001.rb.txt +54 -0
  319. data/spec/handlers/exception_handler_spec.rb +48 -0
  320. data/spec/handlers/extend_handler_spec.rb +23 -0
  321. data/spec/handlers/legacy_base_spec.rb +128 -0
  322. data/spec/handlers/method_condition_handler_spec.rb +14 -0
  323. data/spec/handlers/method_handler_spec.rb +184 -0
  324. data/spec/handlers/mixin_handler_spec.rb +55 -0
  325. data/spec/handlers/module_function_handler_spec.rb +105 -0
  326. data/spec/handlers/module_handler_spec.rb +34 -0
  327. data/spec/handlers/private_constant_handler_spec.rb +24 -0
  328. data/spec/handlers/processor_spec.rb +34 -0
  329. data/spec/handlers/ruby/base_spec.rb +94 -0
  330. data/spec/handlers/ruby/legacy/base_spec.rb +82 -0
  331. data/spec/handlers/spec_helper.rb +33 -0
  332. data/spec/handlers/visibility_handler_spec.rb +39 -0
  333. data/spec/handlers/yield_handler_spec.rb +51 -0
  334. data/spec/i18n/locale_spec.rb +68 -0
  335. data/spec/i18n/message_spec.rb +52 -0
  336. data/spec/i18n/messages_spec.rb +67 -0
  337. data/spec/i18n/pot_generator_spec.rb +262 -0
  338. data/spec/i18n/text_spec.rb +180 -0
  339. data/spec/logging_spec.rb +35 -0
  340. data/spec/options_spec.rb +171 -0
  341. data/spec/parser/base_spec.rb +24 -0
  342. data/spec/parser/c_parser_spec.rb +171 -0
  343. data/spec/parser/examples/array.c.txt +3887 -0
  344. data/spec/parser/examples/example1.rb.txt +8 -0
  345. data/spec/parser/examples/extrafile.c.txt +8 -0
  346. data/spec/parser/examples/multifile.c.txt +22 -0
  347. data/spec/parser/examples/override.c.txt +424 -0
  348. data/spec/parser/examples/parse_in_order_001.rb.txt +2 -0
  349. data/spec/parser/examples/parse_in_order_002.rb.txt +2 -0
  350. data/spec/parser/examples/tag_handler_001.rb.txt +8 -0
  351. data/spec/parser/ruby/ast_node_spec.rb +33 -0
  352. data/spec/parser/ruby/legacy/statement_list_spec.rb +299 -0
  353. data/spec/parser/ruby/legacy/token_list_spec.rb +77 -0
  354. data/spec/parser/ruby/ruby_parser_spec.rb +334 -0
  355. data/spec/parser/source_parser_spec.rb +717 -0
  356. data/spec/parser/tag_parsing_spec.rb +18 -0
  357. data/spec/rake/yardoc_task_spec.rb +101 -0
  358. data/spec/registry_spec.rb +393 -0
  359. data/spec/registry_store_spec.rb +315 -0
  360. data/spec/rubygems/doc_manager_spec.rb +112 -0
  361. data/spec/serializers/data/serialized_yardoc/checksums +1 -0
  362. data/spec/serializers/data/serialized_yardoc/objects/Foo/bar_i.dat +0 -0
  363. data/spec/serializers/data/serialized_yardoc/objects/Foo/baz_i.dat +0 -0
  364. data/spec/serializers/data/serialized_yardoc/objects/Foo.dat +0 -0
  365. data/spec/serializers/data/serialized_yardoc/objects/root.dat +0 -0
  366. data/spec/serializers/data/serialized_yardoc/proxy_types +2 -0
  367. data/spec/serializers/file_system_serializer_spec.rb +124 -0
  368. data/spec/serializers/spec_helper.rb +2 -0
  369. data/spec/serializers/yardoc_serializer_spec.rb +46 -0
  370. data/spec/server/adapter_spec.rb +38 -0
  371. data/spec/server/commands/base_spec.rb +87 -0
  372. data/spec/server/commands/library_command_spec.rb +39 -0
  373. data/spec/server/commands/static_file_command_spec.rb +84 -0
  374. data/spec/server/doc_server_helper_spec.rb +53 -0
  375. data/spec/server/doc_server_serializer_spec.rb +45 -0
  376. data/spec/server/rack_adapter_spec.rb +20 -0
  377. data/spec/server/router_spec.rb +122 -0
  378. data/spec/server/spec_helper.rb +17 -0
  379. data/spec/server/static_caching_spec.rb +39 -0
  380. data/spec/server/webrick_servlet_spec.rb +20 -0
  381. data/spec/server_spec.rb +10 -0
  382. data/spec/spec_helper.rb +128 -0
  383. data/spec/tags/default_factory_spec.rb +152 -0
  384. data/spec/tags/default_tag_spec.rb +11 -0
  385. data/spec/tags/directives_spec.rb +453 -0
  386. data/spec/tags/library_spec.rb +34 -0
  387. data/spec/tags/overload_tag_spec.rb +53 -0
  388. data/spec/tags/ref_tag_list_spec.rb +53 -0
  389. data/spec/templates/class_spec.rb +44 -0
  390. data/spec/templates/constant_spec.rb +40 -0
  391. data/spec/templates/engine_spec.rb +121 -0
  392. data/spec/templates/examples/class001.html +280 -0
  393. data/spec/templates/examples/class001.txt +36 -0
  394. data/spec/templates/examples/class002.html +35 -0
  395. data/spec/templates/examples/constant001.txt +25 -0
  396. data/spec/templates/examples/constant002.txt +7 -0
  397. data/spec/templates/examples/constant003.txt +11 -0
  398. data/spec/templates/examples/method001.html +130 -0
  399. data/spec/templates/examples/method001.txt +35 -0
  400. data/spec/templates/examples/method002.html +86 -0
  401. data/spec/templates/examples/method002.txt +20 -0
  402. data/spec/templates/examples/method003.html +159 -0
  403. data/spec/templates/examples/method003.txt +45 -0
  404. data/spec/templates/examples/method004.html +44 -0
  405. data/spec/templates/examples/method004.txt +10 -0
  406. data/spec/templates/examples/method005.html +99 -0
  407. data/spec/templates/examples/method005.txt +33 -0
  408. data/spec/templates/examples/module001.dot +33 -0
  409. data/spec/templates/examples/module001.html +825 -0
  410. data/spec/templates/examples/module001.txt +33 -0
  411. data/spec/templates/examples/module002.html +318 -0
  412. data/spec/templates/examples/module003.html +185 -0
  413. data/spec/templates/examples/module004.html +387 -0
  414. data/spec/templates/examples/tag001.txt +82 -0
  415. data/spec/templates/helpers/base_helper_spec.rb +175 -0
  416. data/spec/templates/helpers/html_helper_spec.rb +612 -0
  417. data/spec/templates/helpers/html_syntax_highlight_helper_spec.rb +48 -0
  418. data/spec/templates/helpers/markup/rdoc_markup_spec.rb +93 -0
  419. data/spec/templates/helpers/markup_helper_spec.rb +135 -0
  420. data/spec/templates/helpers/method_helper_spec.rb +82 -0
  421. data/spec/templates/helpers/shared_signature_examples.rb +123 -0
  422. data/spec/templates/helpers/text_helper_spec.rb +44 -0
  423. data/spec/templates/method_spec.rb +102 -0
  424. data/spec/templates/module_spec.rb +181 -0
  425. data/spec/templates/onefile_spec.rb +64 -0
  426. data/spec/templates/section_spec.rb +146 -0
  427. data/spec/templates/spec_helper.rb +73 -0
  428. data/spec/templates/tag_spec.rb +51 -0
  429. data/spec/templates/template_spec.rb +409 -0
  430. data/spec/verifier_spec.rb +106 -0
  431. data/templates/default/class/dot/setup.rb +6 -0
  432. data/templates/default/class/dot/superklass.erb +3 -0
  433. data/templates/default/class/html/constructor_details.erb +8 -0
  434. data/templates/default/class/html/setup.rb +1 -0
  435. data/templates/default/class/html/subclasses.erb +4 -0
  436. data/templates/default/class/setup.rb +36 -0
  437. data/templates/default/class/text/setup.rb +11 -0
  438. data/templates/default/class/text/subclasses.erb +5 -0
  439. data/templates/default/constant/text/header.erb +11 -0
  440. data/templates/default/constant/text/setup.rb +3 -0
  441. data/templates/default/docstring/html/abstract.erb +4 -0
  442. data/templates/default/docstring/html/deprecated.erb +1 -0
  443. data/templates/default/docstring/html/index.erb +5 -0
  444. data/templates/default/docstring/html/note.erb +6 -0
  445. data/templates/default/docstring/html/private.erb +4 -0
  446. data/templates/default/docstring/html/returns_void.erb +1 -0
  447. data/templates/default/docstring/html/text.erb +1 -0
  448. data/templates/default/docstring/html/todo.erb +6 -0
  449. data/templates/default/docstring/setup.rb +51 -0
  450. data/templates/default/docstring/text/abstract.erb +2 -0
  451. data/templates/default/docstring/text/deprecated.erb +2 -0
  452. data/templates/default/docstring/text/index.erb +2 -0
  453. data/templates/default/docstring/text/note.erb +4 -0
  454. data/templates/default/docstring/text/private.erb +2 -0
  455. data/templates/default/docstring/text/returns_void.erb +1 -0
  456. data/templates/default/docstring/text/text.erb +1 -0
  457. data/templates/default/docstring/text/todo.erb +4 -0
  458. data/templates/default/fulldoc/html/css/common.css +1 -0
  459. data/templates/default/fulldoc/html/css/full_list.css +57 -0
  460. data/templates/default/fulldoc/html/css/style.css +338 -0
  461. data/templates/default/fulldoc/html/frames.erb +28 -0
  462. data/templates/default/fulldoc/html/full_list.erb +40 -0
  463. data/templates/default/fulldoc/html/full_list_class.erb +2 -0
  464. data/templates/default/fulldoc/html/full_list_file.erb +5 -0
  465. data/templates/default/fulldoc/html/full_list_method.erb +8 -0
  466. data/templates/default/fulldoc/html/js/app.js +214 -0
  467. data/templates/default/fulldoc/html/js/full_list.js +178 -0
  468. data/templates/default/fulldoc/html/js/jquery.js +4 -0
  469. data/templates/default/fulldoc/html/setup.rb +199 -0
  470. data/templates/default/layout/dot/header.erb +6 -0
  471. data/templates/default/layout/dot/setup.rb +14 -0
  472. data/templates/default/layout/html/breadcrumb.erb +13 -0
  473. data/templates/default/layout/html/files.erb +11 -0
  474. data/templates/default/layout/html/footer.erb +5 -0
  475. data/templates/default/layout/html/headers.erb +14 -0
  476. data/templates/default/layout/html/index.erb +2 -0
  477. data/templates/default/layout/html/layout.erb +20 -0
  478. data/templates/default/layout/html/listing.erb +4 -0
  479. data/templates/default/layout/html/objects.erb +32 -0
  480. data/templates/default/layout/html/script_setup.erb +5 -0
  481. data/templates/default/layout/html/search.erb +8 -0
  482. data/templates/default/layout/html/setup.rb +71 -0
  483. data/templates/default/method/html/header.erb +16 -0
  484. data/templates/default/method/setup.rb +3 -0
  485. data/templates/default/method/text/header.erb +1 -0
  486. data/templates/default/method_details/html/header.erb +3 -0
  487. data/templates/default/method_details/html/method_signature.erb +25 -0
  488. data/templates/default/method_details/html/source.erb +10 -0
  489. data/templates/default/method_details/setup.rb +10 -0
  490. data/templates/default/method_details/text/header.erb +10 -0
  491. data/templates/default/method_details/text/method_signature.erb +12 -0
  492. data/templates/default/method_details/text/setup.rb +10 -0
  493. data/templates/default/module/dot/child.erb +1 -0
  494. data/templates/default/module/dot/dependencies.erb +3 -0
  495. data/templates/default/module/dot/header.erb +6 -0
  496. data/templates/default/module/dot/info.erb +14 -0
  497. data/templates/default/module/dot/setup.rb +14 -0
  498. data/templates/default/module/html/attribute_details.erb +10 -0
  499. data/templates/default/module/html/attribute_summary.erb +8 -0
  500. data/templates/default/module/html/box_info.erb +37 -0
  501. data/templates/default/module/html/children.erb +8 -0
  502. data/templates/default/module/html/constant_summary.erb +13 -0
  503. data/templates/default/module/html/defines.erb +3 -0
  504. data/templates/default/module/html/header.erb +5 -0
  505. data/templates/default/module/html/inherited_attributes.erb +14 -0
  506. data/templates/default/module/html/inherited_constants.erb +8 -0
  507. data/templates/default/module/html/inherited_methods.erb +19 -0
  508. data/templates/default/module/html/item_summary.erb +40 -0
  509. data/templates/default/module/html/method_details_list.erb +9 -0
  510. data/templates/default/module/html/method_summary.erb +14 -0
  511. data/templates/default/module/html/methodmissing.erb +12 -0
  512. data/templates/default/module/html/pre_docstring.erb +1 -0
  513. data/templates/default/module/setup.rb +164 -0
  514. data/templates/default/module/text/children.erb +10 -0
  515. data/templates/default/module/text/class_meths_list.erb +8 -0
  516. data/templates/default/module/text/extends.erb +8 -0
  517. data/templates/default/module/text/header.erb +7 -0
  518. data/templates/default/module/text/includes.erb +8 -0
  519. data/templates/default/module/text/instance_meths_list.erb +8 -0
  520. data/templates/default/module/text/setup.rb +12 -0
  521. data/templates/default/onefile/html/files.erb +5 -0
  522. data/templates/default/onefile/html/headers.erb +6 -0
  523. data/templates/default/onefile/html/layout.erb +17 -0
  524. data/templates/default/onefile/html/readme.erb +3 -0
  525. data/templates/default/onefile/html/setup.rb +61 -0
  526. data/templates/default/root/dot/child.erb +3 -0
  527. data/templates/default/root/dot/setup.rb +5 -0
  528. data/templates/default/root/html/setup.rb +1 -0
  529. data/templates/default/tags/html/example.erb +11 -0
  530. data/templates/default/tags/html/index.erb +3 -0
  531. data/templates/default/tags/html/option.erb +24 -0
  532. data/templates/default/tags/html/overload.erb +14 -0
  533. data/templates/default/tags/html/see.erb +8 -0
  534. data/templates/default/tags/html/tag.erb +20 -0
  535. data/templates/default/tags/setup.rb +55 -0
  536. data/templates/default/tags/text/example.erb +12 -0
  537. data/templates/default/tags/text/index.erb +1 -0
  538. data/templates/default/tags/text/option.erb +20 -0
  539. data/templates/default/tags/text/overload.erb +19 -0
  540. data/templates/default/tags/text/see.erb +11 -0
  541. data/templates/default/tags/text/tag.erb +13 -0
  542. data/templates/guide/class/html/setup.rb +1 -0
  543. data/templates/guide/docstring/html/setup.rb +1 -0
  544. data/templates/guide/fulldoc/html/css/style.css +108 -0
  545. data/templates/guide/fulldoc/html/js/app.js +33 -0
  546. data/templates/guide/fulldoc/html/setup.rb +73 -0
  547. data/templates/guide/layout/html/layout.erb +81 -0
  548. data/templates/guide/layout/html/setup.rb +28 -0
  549. data/templates/guide/method/html/header.erb +18 -0
  550. data/templates/guide/method/html/setup.rb +21 -0
  551. data/templates/guide/module/html/header.erb +7 -0
  552. data/templates/guide/module/html/method_list.erb +5 -0
  553. data/templates/guide/module/html/setup.rb +26 -0
  554. data/templates/guide/onefile/html/files.erb +4 -0
  555. data/templates/guide/onefile/html/setup.rb +5 -0
  556. data/templates/guide/onefile/html/toc.erb +3 -0
  557. data/templates/guide/tags/html/setup.rb +8 -0
  558. metadata +689 -0
@@ -0,0 +1,31 @@
1
+ module YARD
2
+ module Parser
3
+ module Ruby
4
+ module Legacy
5
+ # Legacy Ruby parser
6
+ # @since 0.5.6
7
+ class RubyParser < Parser::Base
8
+ def initialize(source, filename)
9
+ @source = source
10
+ end
11
+
12
+ def parse
13
+ @parse ||= StatementList.new(@source)
14
+ self
15
+ end
16
+
17
+ def tokenize
18
+ @tokenize ||= TokenList.new(@source)
19
+ end
20
+
21
+ def enumerator
22
+ @parse
23
+ end
24
+
25
+ def encoding_line; @parse.encoding_line end
26
+ def shebang_line; @parse.shebang_line end
27
+ end
28
+ end
29
+ end
30
+ end
31
+ end
@@ -0,0 +1,65 @@
1
+ module YARD
2
+ module Parser::Ruby::Legacy
3
+ class Statement
4
+ attr_reader :tokens, :comments, :block
5
+ attr_accessor :comments_range
6
+
7
+ # @deprecated Groups are now defined by directives
8
+ # @see Tags::GroupDirective
9
+ attr_accessor :group
10
+
11
+ attr_accessor :comments_hash_flag
12
+
13
+ def initialize(tokens, block = nil, comments = nil)
14
+ @tokens = tokens
15
+ @block = block
16
+ @comments = comments
17
+ @comments_hash_flag = false
18
+ end
19
+
20
+ def first_line
21
+ to_s.split(/\n/)[0]
22
+ end
23
+
24
+ def to_s(include_block = true)
25
+ tokens.map do |token|
26
+ RubyToken::TkBlockContents === token ? (include_block ? block.to_s : '') : token.text
27
+ end.join
28
+ end
29
+ alias source to_s
30
+
31
+ def inspect
32
+ l = line - 1
33
+ to_s(false).split(/\n/).map do |text|
34
+ "\t#{l += 1}: #{text}"
35
+ end.join("\n")
36
+ end
37
+
38
+ def show
39
+ "\t#{line}: #{first_line}"
40
+ end
41
+
42
+ # @return [Fixnum] the first line of Ruby source
43
+ def line
44
+ tokens.first.line_no
45
+ end
46
+
47
+ # @return [Range<Fixnum>] the first to last lines of Ruby source
48
+ # @since 0.5.4
49
+ def line_range
50
+ tokens.first.line_no..tokens.last.line_no
51
+ end
52
+
53
+ private
54
+
55
+ def clean_tokens(tokens)
56
+ last_tk = nil
57
+ tokens.reject do |tk|
58
+ tk.is_a?(RubyToken::TkNL) ||
59
+ (last_tk.is_a?(RubyToken::TkSPACE) &&
60
+ last_tk.class == tk.class) && last_tk = tk
61
+ end
62
+ end
63
+ end
64
+ end
65
+ end
@@ -0,0 +1,384 @@
1
+ module YARD
2
+ module Parser::Ruby::Legacy
3
+ class StatementList < Array
4
+ include RubyToken
5
+
6
+ attr_accessor :shebang_line, :encoding_line
7
+
8
+ # The following list of tokens will require a block to be opened
9
+ # if used at the beginning of a statement.
10
+ OPEN_BLOCK_TOKENS = [TkCLASS, TkDEF, TkMODULE, TkUNTIL,
11
+ TkIF, TkELSIF, TkUNLESS, TkWHILE, TkFOR, TkCASE]
12
+
13
+ # Creates a new statement list
14
+ #
15
+ # @param [TokenList, String] content the tokens to create the list from
16
+ def initialize(content)
17
+ @shebang_line = nil
18
+ @encoding_line = nil
19
+ if content.is_a? TokenList
20
+ @tokens = content.dup
21
+ elsif content.is_a? String
22
+ @tokens = TokenList.new(content.gsub("\r", ""))
23
+ else
24
+ raise ArgumentError, "Invalid content for StatementList: #{content.inspect}:#{content.class}"
25
+ end
26
+
27
+ parse_statements
28
+ end
29
+
30
+ private
31
+
32
+ def parse_statements
33
+ while stmt = next_statement do self << stmt end
34
+ end
35
+
36
+ # Returns the next statement in the token stream
37
+ #
38
+ # @return [Statement] the next statement
39
+ def next_statement
40
+ @state = :first_statement
41
+ @statement_stack = []
42
+ @level = 0
43
+ @block_num = 0
44
+ @done = false
45
+ @current_block = nil
46
+ @comments_line = nil
47
+ @comments_hash_flag = nil
48
+ @statement, @block, @comments = TokenList.new, nil, nil
49
+ @last_tk, @last_ns_tk, @before_last_tk, @before_last_ns_tk = nil, nil, nil, nil
50
+ @first_line = nil
51
+
52
+ while !@done && tk = @tokens.shift
53
+ process_token(tk)
54
+
55
+ @before_last_tk = @last_tk
56
+ @last_tk = tk # Save last token
57
+ unless [TkSPACE, TkNL, TkEND_OF_SCRIPT].include? tk.class
58
+ @before_last_ns_tk = @last_ns_tk
59
+ @last_ns_tk = tk
60
+ end
61
+ end
62
+
63
+ # Return the code block with starting token and initial comments
64
+ # If there is no code in the block, return nil
65
+ @comments = @comments.compact if @comments
66
+ if @block || !@statement.empty?
67
+ sanitize_statement_end
68
+ sanitize_block
69
+ @statement.pop if [TkNL, TkSPACE, TkSEMICOLON].include?(@statement.last.class)
70
+ stmt = Statement.new(@statement, @block, @comments)
71
+ if @comments && @comments_line
72
+ stmt.comments_range = (@comments_line..(@comments_line + @comments.size - 1))
73
+ stmt.comments_hash_flag = @comments_hash_flag
74
+ end
75
+ stmt
76
+ elsif @comments
77
+ @statement << TkCOMMENT.new(@comments_line, 0)
78
+ @statement.first.set_text("# " + @comments.join("\n# "))
79
+ Statement.new(@statement, nil, @comments)
80
+ else
81
+ nil
82
+ end
83
+ end
84
+
85
+ def sanitize_statement_end
86
+ extra = []
87
+ (@statement.size - 1).downto(0) do |index|
88
+ token = @statement[index]
89
+ if TkStatementEnd === token
90
+ while [TkNL, TkSPACE, TkSEMICOLON].include?(@statement[index - 1].class)
91
+ extra.unshift(@statement.delete_at(index - 1))
92
+ index -= 1
93
+ end
94
+ @statement.insert(index + 1, *extra)
95
+ return
96
+ end
97
+ end
98
+ end
99
+
100
+ def sanitize_block
101
+ return unless @block
102
+ extra = []
103
+ while [TkSPACE, TkNL, TkSEMICOLON].include?(@block.last.class)
104
+ next(@block.pop) if TkSEMICOLON === @block.last
105
+ extra.unshift(@block.pop)
106
+ end
107
+
108
+ @statement.each_with_index do |token, index|
109
+ if TkBlockContents === token
110
+ @statement[index, 1] = [token, *extra]
111
+ return
112
+ end
113
+ end
114
+ end
115
+
116
+ # Processes a single token
117
+ #
118
+ # @param [RubyToken::Token] tk the token to process
119
+ def process_token(tk)
120
+ # p tk.class, tk.text, @state, @level, @current_block, "<br/>"
121
+ case @state
122
+ when :first_statement
123
+ return if process_initial_comment(tk)
124
+ return if @statement.empty? && [TkSPACE, TkNL, TkCOMMENT].include?(tk.class)
125
+ @comments_last_line = nil
126
+ if @statement.empty? && tk.class == TkALIAS
127
+ @state = :alias_statement
128
+ @alias_values = []
129
+ push_token(tk)
130
+ return
131
+ end
132
+ return if process_simple_block_opener(tk)
133
+ push_token(tk)
134
+ return if process_complex_block_opener(tk)
135
+
136
+ if balances?(tk)
137
+ process_statement_end(tk)
138
+ else
139
+ @state = :balance
140
+ end
141
+ when :alias_statement
142
+ push_token(tk)
143
+ @alias_values << tk unless [TkSPACE, TkNL, TkCOMMENT].include?(tk.class)
144
+ if @alias_values.size == 2
145
+ @state = :first_statement
146
+ if [NilClass, TkNL, TkEND_OF_SCRIPT, TkSEMICOLON].include?(peek_no_space.class)
147
+ @done = true
148
+ end
149
+ end
150
+ when :balance
151
+ @statement << tk
152
+ return unless balances?(tk)
153
+ @state = :first_statement
154
+ process_statement_end(tk)
155
+ when :block_statement
156
+ push_token(tk)
157
+ return unless balances?(tk)
158
+ process_statement_end(tk)
159
+ when :pre_block
160
+ @current_block = nil
161
+ process_block_token(tk) unless tk.class == TkSEMICOLON
162
+ @state = :block
163
+ when :block
164
+ process_block_token(tk)
165
+ when :post_block
166
+ if tk.class == TkSPACE
167
+ @statement << tk
168
+ return
169
+ end
170
+
171
+ process_statement_end(tk)
172
+ @state = :block
173
+ end
174
+
175
+ if @first_line == tk.line_no && !@statement.empty? && TkCOMMENT === tk
176
+ process_initial_comment(tk)
177
+ end
178
+ end
179
+
180
+ # Processes a token in a block
181
+ #
182
+ # @param [RubyToken::Token] tk the token to process
183
+ def process_block_token(tk)
184
+ if balances?(tk)
185
+ @statement << tk
186
+ @state = :first_statement
187
+ process_statement_end(tk)
188
+ elsif @block_num > 1 || (@block.empty? && [TkSPACE, TkNL].include?(tk.class))
189
+ @statement << tk
190
+ else
191
+ if @block.empty?
192
+ @statement << TkBlockContents.new(tk.line_no, tk.char_no)
193
+ end
194
+ @block << tk
195
+ end
196
+ end
197
+
198
+ # Processes a comment token that comes before a statement
199
+ #
200
+ # @param [RubyToken::Token] tk the token to process
201
+ # @return [Boolean] whether or not +tk+ was processed as an initial comment
202
+ def process_initial_comment(tk)
203
+ if @statement.empty? && (@comments_last_line || 0) < tk.line_no - 2
204
+ @comments = nil
205
+ end
206
+
207
+ return unless tk.class == TkCOMMENT
208
+
209
+ case tk.text
210
+ when Parser::SourceParser::SHEBANG_LINE
211
+ if !@last_ns_tk && !@encoding_line
212
+ @shebang_line = tk.text
213
+ return
214
+ end
215
+ when Parser::SourceParser::ENCODING_LINE
216
+ if (@last_ns_tk.class == TkCOMMENT && @last_ns_tk.text == @shebang_line) ||
217
+ !@last_ns_tk
218
+ @encoding_line = tk.text
219
+ return
220
+ end
221
+ end
222
+
223
+ return if !@statement.empty? && @comments
224
+ return if @first_line && tk.line_no > @first_line
225
+
226
+ if @comments_last_line && @comments_last_line < tk.line_no - 1
227
+ if @comments && @statement.empty?
228
+ @tokens.unshift(tk)
229
+ return @done = true
230
+ end
231
+ @comments = nil
232
+ end
233
+ @comments_line = tk.line_no unless @comments
234
+
235
+ # Remove the "#" and up to 1 space before the text
236
+ # Since, of course, the convention is to have "# text"
237
+ # and not "#text", which I deem ugly (you heard it here first)
238
+ @comments ||= []
239
+ if tk.text =~ /\A=begin/
240
+ lines = tk.text.count("\n")
241
+ @comments += tk.text.gsub(/\A=begin.*\r?\n|\r?\n=end.*\r?\n?\Z/, '').split(/\r?\n/)
242
+ @comments_last_line = tk.line_no + lines
243
+ else
244
+ @comments << tk.text.gsub(/^(#+)\s{0,1}/, '')
245
+ @comments_hash_flag = $1 == '##' if @comments_hash_flag == nil
246
+ @comments_last_line = tk.line_no
247
+ end
248
+ @comments.pop if @comments.size == 1 && @comments.first =~ /^\s*$/
249
+ true
250
+ end
251
+
252
+ # Processes a simple block-opening token;
253
+ # that is, a block opener such as +begin+ or +do+
254
+ # that isn't followed by an expression
255
+ #
256
+ # @param [RubyToken::Token] tk the token to process
257
+ def process_simple_block_opener(tk)
258
+ return unless [TkLBRACE, TkDO, TkBEGIN, TkELSE].include?(tk.class) &&
259
+ # Make sure hashes are parsed as hashes, not as blocks
260
+ (@last_ns_tk.nil? || @last_ns_tk.lex_state != EXPR_BEG)
261
+
262
+ @level += 1
263
+ @state = :block
264
+ @block_num += 1
265
+ unless @block
266
+ @block = TokenList.new
267
+ tokens = [tk, TkStatementEnd.new(tk.line_no, tk.char_no)]
268
+ tokens = tokens.reverse if TkBEGIN === tk.class
269
+ @statement.push(*tokens)
270
+ else
271
+ @statement << tk
272
+ end
273
+
274
+ true
275
+ end
276
+
277
+ # Processes a complex block-opening token;
278
+ # that is, a block opener such as +while+ or +for+
279
+ # that is followed by an expression
280
+ #
281
+ # @param [RubyToken::Token] tk the token to process
282
+ def process_complex_block_opener(tk)
283
+ return unless OPEN_BLOCK_TOKENS.include?(tk.class)
284
+
285
+ @current_block = tk.class
286
+ @state = :block_statement
287
+
288
+ true
289
+ end
290
+
291
+ # Processes a token that closes a statement
292
+ #
293
+ # @param [RubyToken::Token] tk the token to process
294
+ def process_statement_end(tk)
295
+ # Whitespace means that we keep the same value of @new_statement as last token
296
+ return if tk.class == TkSPACE
297
+
298
+ return unless
299
+ # We might be coming after a statement-ending token...
300
+ ((@last_tk && [TkSEMICOLON, TkNL, TkEND_OF_SCRIPT].include?(tk.class)) ||
301
+ # Or we might be at the beginning of an argument list
302
+ (@current_block == TkDEF && tk.class == TkRPAREN))
303
+
304
+ # Continue line ending on . or ::
305
+ return if @last_tk && [EXPR_DOT].include?(@last_tk.lex_state)
306
+
307
+ # Continue a possible existing new statement unless we just finished an expression...
308
+ return unless (@last_tk && [EXPR_END, EXPR_ARG].include?(@last_tk.lex_state)) ||
309
+ # Or we've opened a block and are ready to move into the body
310
+ (@current_block && [TkNL, TkSEMICOLON].include?(tk.class) &&
311
+ # Handle the case where the block statement's expression is on the next line
312
+ #
313
+ # while
314
+ # foo
315
+ # end
316
+ @last_ns_tk.class != @current_block &&
317
+ # And the case where part of the expression is on the next line
318
+ #
319
+ # while foo ||
320
+ # bar
321
+ # end
322
+ @last_tk.lex_state != EXPR_BEG)
323
+
324
+ # Continue with the statement if we've hit a comma in a def
325
+ return if @current_block == TkDEF && peek_no_space.class == TkCOMMA
326
+
327
+
328
+ if [TkEND_OF_SCRIPT, TkNL, TkSEMICOLON].include?(tk.class) && @state == :block_statement &&
329
+ [TkRBRACE, TkEND].include?(@last_ns_tk.class) && @level == 0
330
+ @current_block = nil
331
+ end
332
+
333
+ unless @current_block
334
+ @done = true
335
+ return
336
+ end
337
+
338
+ @state = :pre_block
339
+ @level += 1
340
+ @block_num += 1
341
+ unless @block
342
+ @block = TokenList.new
343
+ @statement << TkStatementEnd.new(tk.line_no, tk.char_no)
344
+ end
345
+ end
346
+
347
+ # Handles the balancing of parentheses and blocks
348
+ #
349
+ # @param [RubyToken::Token] tk the token to process
350
+ # @return [Boolean] whether or not the current statement's parentheses and blocks
351
+ # are balanced after +tk+
352
+ def balances?(tk)
353
+ unless [TkALIAS, TkDEF].include?(@last_ns_tk.class) || @before_last_ns_tk.class == TkALIAS
354
+ if [TkLPAREN, TkLBRACK, TkLBRACE, TkDO, TkBEGIN].include?(tk.class)
355
+ @level += 1
356
+ elsif OPEN_BLOCK_TOKENS.include?(tk.class)
357
+ @level += 1 unless tk.class == TkELSIF
358
+ elsif [TkRPAREN, TkRBRACK, TkRBRACE, TkEND].include?(tk.class) && @level > 0
359
+ @level -= 1
360
+ end
361
+ end
362
+
363
+ @level == 0
364
+ end
365
+
366
+ # Adds a token to the current statement,
367
+ # unless it's a newline, semicolon, or comment
368
+ #
369
+ # @param [RubyToken::Token] tk the token to process
370
+ def push_token(tk)
371
+ @first_line = tk.line_no if @statement.empty?
372
+ @statement << tk unless @level == 0 && [TkCOMMENT].include?(tk.class)
373
+ end
374
+
375
+ # Returns the next token in the stream that's not a space
376
+ #
377
+ # @return [RubyToken::Token] the next non-space token
378
+ def peek_no_space
379
+ return @tokens.first unless @tokens.first.class == TkSPACE
380
+ return @tokens[1]
381
+ end
382
+ end
383
+ end
384
+ end
@@ -0,0 +1,71 @@
1
+ module YARD
2
+ module Parser::Ruby::Legacy
3
+ class TokenList < Array
4
+ include RubyToken
5
+
6
+ def initialize(content = nil)
7
+ self << content if content
8
+ end
9
+
10
+ def to_s(full_statement = false, show_block = true)
11
+ inject([]) do |acc, token|
12
+ break acc if !full_statement && TkStatementEnd === token
13
+ if !show_block && TkBlockContents === token
14
+ acc << ""
15
+ else
16
+ acc << token.text
17
+ end
18
+ acc
19
+ end.join
20
+ end
21
+
22
+ # @param [TokenList, Token, String] tokens
23
+ # A list of tokens. If the token is a string, it
24
+ # is parsed with {RubyLex}.
25
+ def push(*tokens)
26
+ tokens.each do |tok|
27
+ if tok.is_a?(TokenList) || tok.is_a?(Array)
28
+ concat tok
29
+ elsif tok.is_a?(Token)
30
+ super tok
31
+ elsif tok.is_a?(String)
32
+ parse_content(tok)
33
+ else
34
+ raise ArgumentError, "Expecting token, list of tokens or string of code to be tokenized. Got #{tok.class}"
35
+ end
36
+ end
37
+ self
38
+ end
39
+ alias_method :<<, :push
40
+
41
+ def squeeze(type = TkSPACE)
42
+ last = nil
43
+ TokenList.new(map {|t| x = t.is_a?(type) && last.is_a?(type) ? nil : t; last = t; x })
44
+ end
45
+
46
+ private
47
+
48
+ def parse_content(content)
49
+ lex = RubyLex.new(content)
50
+ while tk = lex.token do
51
+ self << convert_token(lex, tk)
52
+ end
53
+ end
54
+
55
+ def convert_token(lex, tk)
56
+ if TkIDENTIFIER === tk && lex.peek == ':'
57
+ next_tk = lex.token
58
+ sym = TkLABEL.new(tk.line_no, tk.char_no, nil)
59
+ sym.lex_state = lex.lex_state
60
+ sym.set_text(tk.text + next_tk.text)
61
+ elsif TkSYMBEG === tk && next_tk = lex.token
62
+ sym = TkSYMBOL.new(tk.line_no, tk.char_no, nil)
63
+ sym.lex_state = lex.lex_state
64
+ sym.set_text(tk.text + next_tk.text)
65
+ else
66
+ tk
67
+ end
68
+ end
69
+ end
70
+ end
71
+ end