yard 0.9.18 → 0.9.19

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 (567) hide show
  1. checksums.yaml +4 -4
  2. data/.yardopts +26 -26
  3. data/CHANGELOG.md +742 -728
  4. data/LEGAL +66 -66
  5. data/LICENSE +22 -22
  6. data/README.md +328 -328
  7. data/Rakefile +42 -53
  8. data/benchmarks/builtins_vs_eval.rb +24 -24
  9. data/benchmarks/concat_vs_join.rb +13 -13
  10. data/benchmarks/erb_vs_erubis.rb +54 -54
  11. data/benchmarks/format_args.rb +47 -47
  12. data/benchmarks/generation.rb +38 -38
  13. data/benchmarks/marshal_vs_dbm.rb +64 -64
  14. data/benchmarks/parsing.rb +46 -46
  15. data/benchmarks/pathname_vs_string.rb +50 -50
  16. data/benchmarks/rdoc_vs_yardoc.rb +11 -11
  17. data/benchmarks/registry_store_types.rb +49 -49
  18. data/benchmarks/ri_vs_yri.rb +19 -19
  19. data/benchmarks/ripper_parser.rb +13 -13
  20. data/benchmarks/splat_vs_flatten.rb +13 -13
  21. data/benchmarks/template_erb.rb +23 -23
  22. data/benchmarks/template_format.rb +7 -7
  23. data/benchmarks/template_profile.rb +18 -18
  24. data/benchmarks/yri_cache.rb +20 -20
  25. data/bin/yard +13 -13
  26. data/bin/yardoc +13 -13
  27. data/bin/yri +13 -13
  28. data/docs/CodeObjects.md +115 -115
  29. data/docs/GettingStarted.md +679 -679
  30. data/docs/Handlers.md +152 -152
  31. data/docs/Overview.md +61 -61
  32. data/docs/Parser.md +191 -191
  33. data/docs/Tags.md +283 -283
  34. data/docs/TagsArch.md +123 -123
  35. data/docs/Templates.md +496 -496
  36. data/docs/WhatsNew.md +1245 -1245
  37. data/docs/templates/default/fulldoc/html/full_list_tag.erb +8 -8
  38. data/docs/templates/default/fulldoc/html/setup.rb +6 -6
  39. data/docs/templates/default/layout/html/setup.rb +9 -9
  40. data/docs/templates/default/layout/html/tag_list.erb +11 -11
  41. data/docs/templates/default/yard_tags/html/list.erb +18 -18
  42. data/docs/templates/default/yard_tags/html/setup.rb +26 -26
  43. data/docs/templates/plugin.rb +70 -70
  44. data/lib/rubygems_plugin.rb +9 -9
  45. data/lib/yard.rb +69 -69
  46. data/lib/yard/autoload.rb +308 -303
  47. data/lib/yard/cli/command.rb +85 -85
  48. data/lib/yard/cli/command_parser.rb +93 -93
  49. data/lib/yard/cli/config.rb +198 -198
  50. data/lib/yard/cli/diff.rb +270 -270
  51. data/lib/yard/cli/display.rb +69 -69
  52. data/lib/yard/cli/gems.rb +84 -84
  53. data/lib/yard/cli/graph.rb +125 -125
  54. data/lib/yard/cli/help.rb +20 -20
  55. data/lib/yard/cli/i18n.rb +70 -70
  56. data/lib/yard/cli/list.rb +23 -23
  57. data/lib/yard/cli/markup_types.rb +32 -32
  58. data/lib/yard/cli/server.rb +257 -257
  59. data/lib/yard/cli/stats.rb +231 -231
  60. data/lib/yard/cli/yardoc.rb +789 -788
  61. data/lib/yard/cli/yardopts_command.rb +110 -110
  62. data/lib/yard/cli/yri.rb +215 -215
  63. data/lib/yard/code_objects/base.rb +615 -615
  64. data/lib/yard/code_objects/class_object.rb +146 -146
  65. data/lib/yard/code_objects/class_variable_object.rb +11 -11
  66. data/lib/yard/code_objects/constant_object.rb +16 -16
  67. data/lib/yard/code_objects/extended_method_object.rb +24 -24
  68. data/lib/yard/code_objects/extra_file_object.rb +134 -131
  69. data/lib/yard/code_objects/macro_object.rb +172 -172
  70. data/lib/yard/code_objects/method_object.rb +196 -196
  71. data/lib/yard/code_objects/module_object.rb +21 -21
  72. data/lib/yard/code_objects/namespace_mapper.rb +114 -114
  73. data/lib/yard/code_objects/namespace_object.rb +200 -200
  74. data/lib/yard/code_objects/proxy.rb +240 -240
  75. data/lib/yard/code_objects/root_object.rb +19 -19
  76. data/lib/yard/config.rb +270 -270
  77. data/lib/yard/core_ext/array.rb +16 -16
  78. data/lib/yard/core_ext/file.rb +69 -69
  79. data/lib/yard/core_ext/hash.rb +16 -16
  80. data/lib/yard/core_ext/insertion.rb +63 -63
  81. data/lib/yard/core_ext/module.rb +11 -20
  82. data/lib/yard/core_ext/string.rb +68 -68
  83. data/lib/yard/core_ext/symbol_hash.rb +75 -75
  84. data/lib/yard/docstring.rb +386 -386
  85. data/lib/yard/docstring_parser.rb +345 -345
  86. data/lib/yard/gem_index.rb +29 -29
  87. data/lib/yard/globals.rb +22 -22
  88. data/lib/yard/handlers/base.rb +595 -595
  89. data/lib/yard/handlers/c/alias_handler.rb +16 -16
  90. data/lib/yard/handlers/c/attribute_handler.rb +13 -13
  91. data/lib/yard/handlers/c/base.rb +129 -129
  92. data/lib/yard/handlers/c/class_handler.rb +27 -27
  93. data/lib/yard/handlers/c/constant_handler.rb +13 -13
  94. data/lib/yard/handlers/c/handler_methods.rb +212 -211
  95. data/lib/yard/handlers/c/init_handler.rb +20 -20
  96. data/lib/yard/handlers/c/method_handler.rb +45 -45
  97. data/lib/yard/handlers/c/mixin_handler.rb +21 -21
  98. data/lib/yard/handlers/c/module_handler.rb +17 -17
  99. data/lib/yard/handlers/c/override_comment_handler.rb +31 -31
  100. data/lib/yard/handlers/c/path_handler.rb +11 -11
  101. data/lib/yard/handlers/c/struct_handler.rb +13 -13
  102. data/lib/yard/handlers/c/symbol_handler.rb +8 -8
  103. data/lib/yard/handlers/common/method_handler.rb +19 -0
  104. data/lib/yard/handlers/processor.rb +200 -200
  105. data/lib/yard/handlers/ruby/alias_handler.rb +44 -44
  106. data/lib/yard/handlers/ruby/attribute_handler.rb +87 -87
  107. data/lib/yard/handlers/ruby/base.rb +165 -165
  108. data/lib/yard/handlers/ruby/class_condition_handler.rb +92 -92
  109. data/lib/yard/handlers/ruby/class_handler.rb +119 -119
  110. data/lib/yard/handlers/ruby/class_variable_handler.rb +17 -17
  111. data/lib/yard/handlers/ruby/comment_handler.rb +10 -10
  112. data/lib/yard/handlers/ruby/constant_handler.rb +59 -59
  113. data/lib/yard/handlers/ruby/decorator_handler_methods.rb +123 -123
  114. data/lib/yard/handlers/ruby/dsl_handler.rb +15 -15
  115. data/lib/yard/handlers/ruby/dsl_handler_methods.rb +96 -96
  116. data/lib/yard/handlers/ruby/exception_handler.rb +27 -27
  117. data/lib/yard/handlers/ruby/extend_handler.rb +22 -22
  118. data/lib/yard/handlers/ruby/legacy/alias_handler.rb +37 -37
  119. data/lib/yard/handlers/ruby/legacy/attribute_handler.rb +65 -65
  120. data/lib/yard/handlers/ruby/legacy/base.rb +245 -245
  121. data/lib/yard/handlers/ruby/legacy/class_condition_handler.rb +83 -83
  122. data/lib/yard/handlers/ruby/legacy/class_handler.rb +113 -113
  123. data/lib/yard/handlers/ruby/legacy/class_variable_handler.rb +15 -15
  124. data/lib/yard/handlers/ruby/legacy/comment_handler.rb +10 -10
  125. data/lib/yard/handlers/ruby/legacy/constant_handler.rb +29 -29
  126. data/lib/yard/handlers/ruby/legacy/dsl_handler.rb +17 -17
  127. data/lib/yard/handlers/ruby/legacy/exception_handler.rb +13 -13
  128. data/lib/yard/handlers/ruby/legacy/extend_handler.rb +21 -21
  129. data/lib/yard/handlers/ruby/legacy/method_handler.rb +90 -90
  130. data/lib/yard/handlers/ruby/legacy/mixin_handler.rb +39 -39
  131. data/lib/yard/handlers/ruby/legacy/module_function_handler.rb +19 -19
  132. data/lib/yard/handlers/ruby/legacy/module_handler.rb +12 -12
  133. data/lib/yard/handlers/ruby/legacy/private_class_method_handler.rb +22 -22
  134. data/lib/yard/handlers/ruby/legacy/private_constant_handler.rb +22 -22
  135. data/lib/yard/handlers/ruby/legacy/visibility_handler.rb +17 -17
  136. data/lib/yard/handlers/ruby/legacy/yield_handler.rb +29 -29
  137. data/lib/yard/handlers/ruby/method_condition_handler.rb +9 -9
  138. data/lib/yard/handlers/ruby/method_handler.rb +114 -118
  139. data/lib/yard/handlers/ruby/mixin_handler.rb +37 -37
  140. data/lib/yard/handlers/ruby/module_function_handler.rb +27 -27
  141. data/lib/yard/handlers/ruby/module_handler.rb +12 -12
  142. data/lib/yard/handlers/ruby/private_class_method_handler.rb +14 -14
  143. data/lib/yard/handlers/ruby/private_constant_handler.rb +43 -43
  144. data/lib/yard/handlers/ruby/public_class_method_handler.rb +14 -14
  145. data/lib/yard/handlers/ruby/struct_handler_methods.rb +143 -143
  146. data/lib/yard/handlers/ruby/visibility_handler.rb +22 -22
  147. data/lib/yard/handlers/ruby/yield_handler.rb +31 -31
  148. data/lib/yard/i18n/locale.rb +67 -67
  149. data/lib/yard/i18n/message.rb +57 -57
  150. data/lib/yard/i18n/messages.rb +56 -56
  151. data/lib/yard/i18n/po_parser.rb +61 -61
  152. data/lib/yard/i18n/pot_generator.rb +290 -290
  153. data/lib/yard/i18n/text.rb +173 -173
  154. data/lib/yard/logging.rb +205 -205
  155. data/lib/yard/options.rb +217 -217
  156. data/lib/yard/parser/base.rb +57 -57
  157. data/lib/yard/parser/c/c_parser.rb +235 -235
  158. data/lib/yard/parser/c/comment_parser.rb +134 -134
  159. data/lib/yard/parser/c/statement.rb +64 -64
  160. data/lib/yard/parser/ruby/ast_node.rb +540 -540
  161. data/lib/yard/parser/ruby/legacy/ruby_lex.rb +1354 -1354
  162. data/lib/yard/parser/ruby/legacy/ruby_parser.rb +32 -32
  163. data/lib/yard/parser/ruby/legacy/statement.rb +66 -66
  164. data/lib/yard/parser/ruby/legacy/statement_list.rb +394 -394
  165. data/lib/yard/parser/ruby/legacy/token_list.rb +74 -74
  166. data/lib/yard/parser/ruby/ruby_parser.rb +687 -687
  167. data/lib/yard/parser/ruby/token_resolver.rb +156 -156
  168. data/lib/yard/parser/source_parser.rb +526 -526
  169. data/lib/yard/rake/yardoc_task.rb +81 -81
  170. data/lib/yard/registry.rb +439 -439
  171. data/lib/yard/registry_resolver.rb +189 -189
  172. data/lib/yard/registry_store.rb +337 -337
  173. data/lib/yard/rubygems/backports.rb +10 -10
  174. data/lib/yard/rubygems/backports/LICENSE.txt +57 -57
  175. data/lib/yard/rubygems/backports/MIT.txt +20 -20
  176. data/lib/yard/rubygems/backports/gem.rb +10 -10
  177. data/lib/yard/rubygems/backports/source_index.rb +365 -365
  178. data/lib/yard/rubygems/doc_manager.rb +90 -90
  179. data/lib/yard/rubygems/hook.rb +197 -197
  180. data/lib/yard/rubygems/specification.rb +50 -50
  181. data/lib/yard/serializers/base.rb +83 -83
  182. data/lib/yard/serializers/file_system_serializer.rb +123 -123
  183. data/lib/yard/serializers/process_serializer.rb +24 -24
  184. data/lib/yard/serializers/stdout_serializer.rb +34 -34
  185. data/lib/yard/serializers/yardoc_serializer.rb +152 -152
  186. data/lib/yard/server.rb +13 -13
  187. data/lib/yard/server/adapter.rb +100 -100
  188. data/lib/yard/server/commands/base.rb +209 -209
  189. data/lib/yard/server/commands/display_file_command.rb +29 -29
  190. data/lib/yard/server/commands/display_object_command.rb +65 -65
  191. data/lib/yard/server/commands/frames_command.rb +16 -16
  192. data/lib/yard/server/commands/library_command.rb +187 -187
  193. data/lib/yard/server/commands/library_index_command.rb +28 -28
  194. data/lib/yard/server/commands/list_command.rb +25 -25
  195. data/lib/yard/server/commands/root_request_command.rb +15 -15
  196. data/lib/yard/server/commands/search_command.rb +79 -79
  197. data/lib/yard/server/commands/static_file_command.rb +23 -23
  198. data/lib/yard/server/commands/static_file_helpers.rb +62 -62
  199. data/lib/yard/server/doc_server_helper.rb +91 -91
  200. data/lib/yard/server/doc_server_serializer.rb +39 -39
  201. data/lib/yard/server/library_version.rb +277 -277
  202. data/lib/yard/server/rack_adapter.rb +89 -89
  203. data/lib/yard/server/router.rb +187 -187
  204. data/lib/yard/server/static_caching.rb +46 -46
  205. data/lib/yard/server/templates/default/fulldoc/html/css/custom.css +127 -127
  206. data/lib/yard/server/templates/default/fulldoc/html/js/autocomplete.js +11 -11
  207. data/lib/yard/server/templates/default/layout/html/breadcrumb.erb +37 -37
  208. data/lib/yard/server/templates/default/layout/html/script_setup.erb +7 -7
  209. data/lib/yard/server/templates/default/layout/html/setup.rb +8 -8
  210. data/lib/yard/server/templates/default/method_details/html/permalink.erb +4 -4
  211. data/lib/yard/server/templates/default/method_details/html/setup.rb +5 -5
  212. data/lib/yard/server/templates/doc_server/library_list/html/headers.erb +8 -8
  213. data/lib/yard/server/templates/doc_server/library_list/html/library_list.erb +14 -14
  214. data/lib/yard/server/templates/doc_server/library_list/html/listing.erb +13 -13
  215. data/lib/yard/server/templates/doc_server/library_list/html/setup.rb +6 -6
  216. data/lib/yard/server/templates/doc_server/library_list/html/title.erb +2 -2
  217. data/lib/yard/server/templates/doc_server/processing/html/processing.erb +52 -52
  218. data/lib/yard/server/templates/doc_server/processing/html/setup.rb +4 -4
  219. data/lib/yard/server/templates/doc_server/search/html/search.erb +18 -18
  220. data/lib/yard/server/templates/doc_server/search/html/setup.rb +9 -9
  221. data/lib/yard/server/webrick_adapter.rb +45 -45
  222. data/lib/yard/tags/default_factory.rb +191 -191
  223. data/lib/yard/tags/default_tag.rb +13 -13
  224. data/lib/yard/tags/directives.rb +616 -616
  225. data/lib/yard/tags/library.rb +633 -633
  226. data/lib/yard/tags/option_tag.rb +13 -13
  227. data/lib/yard/tags/overload_tag.rb +71 -71
  228. data/lib/yard/tags/ref_tag.rb +8 -8
  229. data/lib/yard/tags/ref_tag_list.rb +28 -28
  230. data/lib/yard/tags/tag.rb +71 -71
  231. data/lib/yard/tags/tag_format_error.rb +7 -7
  232. data/lib/yard/tags/types_explainer.rb +162 -162
  233. data/lib/yard/templates/engine.rb +186 -186
  234. data/lib/yard/templates/erb_cache.rb +23 -23
  235. data/lib/yard/templates/helpers/base_helper.rb +215 -215
  236. data/lib/yard/templates/helpers/filter_helper.rb +27 -27
  237. data/lib/yard/templates/helpers/html_helper.rb +646 -646
  238. data/lib/yard/templates/helpers/html_syntax_highlight_helper.rb +78 -78
  239. data/lib/yard/templates/helpers/markup/rdoc_markdown.rb +23 -23
  240. data/lib/yard/templates/helpers/markup/rdoc_markup.rb +109 -109
  241. data/lib/yard/templates/helpers/markup_helper.rb +172 -172
  242. data/lib/yard/templates/helpers/method_helper.rb +75 -75
  243. data/lib/yard/templates/helpers/module_helper.rb +21 -21
  244. data/lib/yard/templates/helpers/text_helper.rb +112 -112
  245. data/lib/yard/templates/helpers/uml_helper.rb +47 -47
  246. data/lib/yard/templates/section.rb +105 -105
  247. data/lib/yard/templates/template.rb +418 -418
  248. data/lib/yard/templates/template_options.rb +92 -92
  249. data/lib/yard/verifier.rb +151 -151
  250. data/lib/yard/version.rb +6 -6
  251. data/spec/cli/command_parser_spec.rb +43 -43
  252. data/spec/cli/command_spec.rb +36 -36
  253. data/spec/cli/config_spec.rb +148 -148
  254. data/spec/cli/diff_spec.rb +254 -254
  255. data/spec/cli/display_spec.rb +30 -30
  256. data/spec/cli/gems_spec.rb +81 -81
  257. data/spec/cli/graph_spec.rb +18 -18
  258. data/spec/cli/help_spec.rb +22 -22
  259. data/spec/cli/i18n_spec.rb +107 -107
  260. data/spec/cli/list_spec.rb +8 -8
  261. data/spec/cli/markup_types_spec.rb +22 -22
  262. data/spec/cli/server_spec.rb +324 -324
  263. data/spec/cli/stats_spec.rb +96 -96
  264. data/spec/cli/yard_on_yard_spec.rb +38 -38
  265. data/spec/cli/yardoc_spec.rb +896 -862
  266. data/spec/cli/yri_spec.rb +101 -101
  267. data/spec/code_objects/base_spec.rb +470 -470
  268. data/spec/code_objects/class_object_spec.rb +226 -226
  269. data/spec/code_objects/code_object_list_spec.rb +36 -36
  270. data/spec/code_objects/constants_spec.rb +116 -116
  271. data/spec/code_objects/extra_file_object_spec.rb +160 -160
  272. data/spec/code_objects/macro_object_spec.rb +150 -150
  273. data/spec/code_objects/method_object_spec.rb +184 -184
  274. data/spec/code_objects/module_object_spec.rb +142 -142
  275. data/spec/code_objects/namespace_object_spec.rb +171 -171
  276. data/spec/code_objects/proxy_spec.rb +141 -141
  277. data/spec/code_objects/spec_helper.rb +3 -3
  278. data/spec/config_spec.rb +171 -171
  279. data/spec/core_ext/array_spec.rb +13 -13
  280. data/spec/core_ext/file_spec.rb +72 -72
  281. data/spec/core_ext/hash_spec.rb +14 -14
  282. data/spec/core_ext/insertion_spec.rb +37 -37
  283. data/spec/core_ext/module_spec.rb +9 -15
  284. data/spec/core_ext/string_spec.rb +42 -42
  285. data/spec/core_ext/symbol_hash_spec.rb +89 -89
  286. data/spec/docstring_parser_spec.rb +280 -280
  287. data/spec/docstring_spec.rb +373 -373
  288. data/spec/examples.txt +1883 -1875
  289. data/spec/handlers/alias_handler_spec.rb +82 -82
  290. data/spec/handlers/attribute_handler_spec.rb +96 -96
  291. data/spec/handlers/base_spec.rb +216 -216
  292. data/spec/handlers/c/alias_handler_spec.rb +34 -34
  293. data/spec/handlers/c/attribute_handler_spec.rb +41 -41
  294. data/spec/handlers/c/class_handler_spec.rb +78 -78
  295. data/spec/handlers/c/constant_handler_spec.rb +71 -71
  296. data/spec/handlers/c/init_handler_spec.rb +48 -48
  297. data/spec/handlers/c/method_handler_spec.rb +327 -325
  298. data/spec/handlers/c/mixin_handler_spec.rb +44 -44
  299. data/spec/handlers/c/module_handler_spec.rb +71 -71
  300. data/spec/handlers/c/override_comment_handler_spec.rb +47 -47
  301. data/spec/handlers/c/path_handler_spec.rb +36 -36
  302. data/spec/handlers/c/spec_helper.rb +23 -23
  303. data/spec/handlers/c/struct_handler_spec.rb +16 -16
  304. data/spec/handlers/class_condition_handler_spec.rb +87 -87
  305. data/spec/handlers/class_handler_spec.rb +247 -247
  306. data/spec/handlers/class_method_handler_shared_examples.rb +133 -133
  307. data/spec/handlers/class_variable_handler_spec.rb +12 -12
  308. data/spec/handlers/constant_handler_spec.rb +112 -112
  309. data/spec/handlers/decorator_handler_methods_spec.rb +393 -393
  310. data/spec/handlers/dsl_handler_spec.rb +219 -219
  311. data/spec/handlers/examples/alias_handler_001.rb.txt +45 -45
  312. data/spec/handlers/examples/attribute_handler_001.rb.txt +31 -31
  313. data/spec/handlers/examples/class_condition_handler_001.rb.txt +68 -68
  314. data/spec/handlers/examples/class_handler_001.rb.txt +120 -120
  315. data/spec/handlers/examples/class_variable_handler_001.rb.txt +9 -9
  316. data/spec/handlers/examples/constant_handler_001.rb.txt +35 -35
  317. data/spec/handlers/examples/dsl_handler_001.rb.txt +154 -154
  318. data/spec/handlers/examples/exception_handler_001.rb.txt +58 -58
  319. data/spec/handlers/examples/extend_handler_001.rb.txt +15 -15
  320. data/spec/handlers/examples/method_condition_handler_001.rb.txt +9 -9
  321. data/spec/handlers/examples/method_handler_001.rb.txt +128 -128
  322. data/spec/handlers/examples/mixin_handler_001.rb.txt +37 -37
  323. data/spec/handlers/examples/module_handler_001.rb.txt +29 -29
  324. data/spec/handlers/examples/private_constant_handler_001.rb.txt +8 -8
  325. data/spec/handlers/examples/process_handler_001.rb.txt +11 -11
  326. data/spec/handlers/examples/visibility_handler_001.rb.txt +35 -35
  327. data/spec/handlers/examples/yield_handler_001.rb.txt +54 -54
  328. data/spec/handlers/exception_handler_spec.rb +49 -49
  329. data/spec/handlers/extend_handler_spec.rb +24 -24
  330. data/spec/handlers/legacy_base_spec.rb +128 -128
  331. data/spec/handlers/method_condition_handler_spec.rb +15 -15
  332. data/spec/handlers/method_handler_spec.rb +190 -190
  333. data/spec/handlers/mixin_handler_spec.rb +56 -56
  334. data/spec/handlers/module_function_handler_spec.rb +106 -106
  335. data/spec/handlers/module_handler_spec.rb +35 -35
  336. data/spec/handlers/private_class_method_handler_spec.rb +11 -11
  337. data/spec/handlers/private_constant_handler_spec.rb +25 -25
  338. data/spec/handlers/processor_spec.rb +35 -35
  339. data/spec/handlers/public_class_method_handler_spec.rb +11 -11
  340. data/spec/handlers/ruby/base_spec.rb +95 -95
  341. data/spec/handlers/ruby/legacy/base_spec.rb +84 -84
  342. data/spec/handlers/spec_helper.rb +33 -33
  343. data/spec/handlers/visibility_handler_spec.rb +44 -44
  344. data/spec/handlers/yield_handler_spec.rb +52 -52
  345. data/spec/i18n/locale_spec.rb +81 -81
  346. data/spec/i18n/message_spec.rb +52 -52
  347. data/spec/i18n/messages_spec.rb +67 -67
  348. data/spec/i18n/pot_generator_spec.rb +295 -295
  349. data/spec/i18n/text_spec.rb +184 -184
  350. data/spec/logging_spec.rb +44 -44
  351. data/spec/options_spec.rb +171 -171
  352. data/spec/parser/base_spec.rb +24 -24
  353. data/spec/parser/c_parser_spec.rb +236 -236
  354. data/spec/parser/examples/array.c.txt +6267 -6267
  355. data/spec/parser/examples/example1.rb.txt +7 -7
  356. data/spec/parser/examples/extrafile.c.txt +8 -8
  357. data/spec/parser/examples/file.c.txt +28 -28
  358. data/spec/parser/examples/multifile.c.txt +22 -22
  359. data/spec/parser/examples/namespace.cpp.txt +68 -68
  360. data/spec/parser/examples/override.c.txt +424 -424
  361. data/spec/parser/examples/parse_in_order_001.rb.txt +2 -2
  362. data/spec/parser/examples/parse_in_order_002.rb.txt +1 -1
  363. data/spec/parser/examples/tag_handler_001.rb.txt +7 -7
  364. data/spec/parser/ruby/ast_node_spec.rb +33 -33
  365. data/spec/parser/ruby/legacy/statement_list_spec.rb +299 -299
  366. data/spec/parser/ruby/legacy/token_list_spec.rb +79 -79
  367. data/spec/parser/ruby/ruby_parser_spec.rb +508 -508
  368. data/spec/parser/ruby/token_resolver_spec.rb +165 -165
  369. data/spec/parser/source_parser_spec.rb +727 -727
  370. data/spec/parser/tag_parsing_spec.rb +17 -17
  371. data/spec/rake/yardoc_task_spec.rb +118 -118
  372. data/spec/registry_spec.rb +463 -463
  373. data/spec/registry_store_spec.rb +316 -316
  374. data/spec/rubygems/doc_manager_spec.rb +112 -112
  375. data/spec/serializers/data/serialized_yardoc/checksums +1 -1
  376. data/spec/serializers/file_system_serializer_spec.rb +145 -145
  377. data/spec/serializers/spec_helper.rb +2 -2
  378. data/spec/serializers/yardoc_serializer_spec.rb +78 -78
  379. data/spec/server/adapter_spec.rb +39 -39
  380. data/spec/server/commands/base_spec.rb +91 -91
  381. data/spec/server/commands/library_command_spec.rb +39 -39
  382. data/spec/server/doc_server_helper_spec.rb +72 -72
  383. data/spec/server/doc_server_serializer_spec.rb +60 -60
  384. data/spec/server/rack_adapter_spec.rb +21 -21
  385. data/spec/server/router_spec.rb +123 -123
  386. data/spec/server/spec_helper.rb +22 -22
  387. data/spec/server/static_caching_spec.rb +47 -47
  388. data/spec/server/webrick_servlet_spec.rb +20 -20
  389. data/spec/server_spec.rb +19 -19
  390. data/spec/spec_helper.rb +212 -212
  391. data/spec/tags/default_factory_spec.rb +168 -168
  392. data/spec/tags/default_tag_spec.rb +11 -11
  393. data/spec/tags/directives_spec.rb +463 -463
  394. data/spec/tags/library_spec.rb +48 -48
  395. data/spec/tags/overload_tag_spec.rb +53 -53
  396. data/spec/tags/ref_tag_list_spec.rb +53 -53
  397. data/spec/tags/types_explainer_spec.rb +203 -203
  398. data/spec/templates/class_spec.rb +45 -45
  399. data/spec/templates/constant_spec.rb +41 -41
  400. data/spec/templates/engine_spec.rb +131 -131
  401. data/spec/templates/examples/class001.html +308 -308
  402. data/spec/templates/examples/class001.txt +36 -36
  403. data/spec/templates/examples/class002.html +39 -39
  404. data/spec/templates/examples/constant001.txt +24 -24
  405. data/spec/templates/examples/constant002.txt +6 -6
  406. data/spec/templates/examples/constant003.txt +10 -10
  407. data/spec/templates/examples/method001.html +137 -137
  408. data/spec/templates/examples/method001.txt +35 -35
  409. data/spec/templates/examples/method002.html +91 -91
  410. data/spec/templates/examples/method002.txt +20 -20
  411. data/spec/templates/examples/method003.html +165 -165
  412. data/spec/templates/examples/method003.txt +45 -45
  413. data/spec/templates/examples/method004.html +48 -48
  414. data/spec/templates/examples/method004.txt +10 -10
  415. data/spec/templates/examples/method005.html +105 -105
  416. data/spec/templates/examples/method005.txt +33 -33
  417. data/spec/templates/examples/method006.html +107 -107
  418. data/spec/templates/examples/method006.txt +20 -20
  419. data/spec/templates/examples/module001.dot +33 -33
  420. data/spec/templates/examples/module001.html +833 -833
  421. data/spec/templates/examples/module001.txt +33 -33
  422. data/spec/templates/examples/module002.html +341 -341
  423. data/spec/templates/examples/module003.html +202 -202
  424. data/spec/templates/examples/module004.html +394 -394
  425. data/spec/templates/examples/module005.html +81 -81
  426. data/spec/templates/examples/tag001.txt +82 -82
  427. data/spec/templates/helpers/base_helper_spec.rb +171 -171
  428. data/spec/templates/helpers/html_helper_spec.rb +687 -668
  429. data/spec/templates/helpers/html_syntax_highlight_helper_spec.rb +65 -65
  430. data/spec/templates/helpers/markup/rdoc_markup_spec.rb +84 -84
  431. data/spec/templates/helpers/markup_helper_spec.rb +136 -136
  432. data/spec/templates/helpers/method_helper_spec.rb +107 -107
  433. data/spec/templates/helpers/module_helper_spec.rb +35 -35
  434. data/spec/templates/helpers/shared_signature_examples.rb +126 -126
  435. data/spec/templates/helpers/text_helper_spec.rb +65 -65
  436. data/spec/templates/method_spec.rb +118 -118
  437. data/spec/templates/module_spec.rb +203 -203
  438. data/spec/templates/onefile_spec.rb +66 -66
  439. data/spec/templates/section_spec.rb +144 -144
  440. data/spec/templates/spec_helper.rb +76 -76
  441. data/spec/templates/tag_spec.rb +52 -52
  442. data/spec/templates/template_spec.rb +410 -410
  443. data/spec/verifier_spec.rb +106 -106
  444. data/templates/default/class/dot/setup.rb +7 -7
  445. data/templates/default/class/dot/superklass.erb +2 -2
  446. data/templates/default/class/html/constructor_details.erb +8 -8
  447. data/templates/default/class/html/setup.rb +2 -2
  448. data/templates/default/class/html/subclasses.erb +4 -4
  449. data/templates/default/class/setup.rb +36 -36
  450. data/templates/default/class/text/setup.rb +12 -12
  451. data/templates/default/class/text/subclasses.erb +5 -5
  452. data/templates/default/constant/text/header.erb +11 -11
  453. data/templates/default/constant/text/setup.rb +4 -4
  454. data/templates/default/docstring/html/abstract.erb +4 -4
  455. data/templates/default/docstring/html/deprecated.erb +1 -1
  456. data/templates/default/docstring/html/index.erb +5 -5
  457. data/templates/default/docstring/html/note.erb +6 -6
  458. data/templates/default/docstring/html/private.erb +4 -4
  459. data/templates/default/docstring/html/text.erb +1 -1
  460. data/templates/default/docstring/html/todo.erb +6 -6
  461. data/templates/default/docstring/setup.rb +52 -52
  462. data/templates/default/docstring/text/abstract.erb +2 -2
  463. data/templates/default/docstring/text/deprecated.erb +2 -2
  464. data/templates/default/docstring/text/index.erb +2 -2
  465. data/templates/default/docstring/text/note.erb +3 -3
  466. data/templates/default/docstring/text/private.erb +2 -2
  467. data/templates/default/docstring/text/text.erb +1 -1
  468. data/templates/default/docstring/text/todo.erb +3 -3
  469. data/templates/default/fulldoc/html/css/full_list.css +58 -58
  470. data/templates/default/fulldoc/html/css/style.css +496 -496
  471. data/templates/default/fulldoc/html/frames.erb +17 -17
  472. data/templates/default/fulldoc/html/full_list.erb +37 -37
  473. data/templates/default/fulldoc/html/full_list_class.erb +2 -2
  474. data/templates/default/fulldoc/html/full_list_file.erb +7 -7
  475. data/templates/default/fulldoc/html/full_list_method.erb +10 -10
  476. data/templates/default/fulldoc/html/js/app.js +303 -292
  477. data/templates/default/fulldoc/html/js/full_list.js +216 -216
  478. data/templates/default/fulldoc/html/js/jquery.js +3 -3
  479. data/templates/default/fulldoc/html/setup.rb +241 -241
  480. data/templates/default/layout/dot/header.erb +5 -5
  481. data/templates/default/layout/dot/setup.rb +15 -15
  482. data/templates/default/layout/html/breadcrumb.erb +11 -11
  483. data/templates/default/layout/html/files.erb +11 -11
  484. data/templates/default/layout/html/footer.erb +5 -5
  485. data/templates/default/layout/html/headers.erb +15 -15
  486. data/templates/default/layout/html/index.erb +2 -2
  487. data/templates/default/layout/html/layout.erb +23 -23
  488. data/templates/default/layout/html/listing.erb +4 -4
  489. data/templates/default/layout/html/objects.erb +32 -32
  490. data/templates/default/layout/html/script_setup.erb +4 -4
  491. data/templates/default/layout/html/search.erb +12 -12
  492. data/templates/default/layout/html/setup.rb +89 -89
  493. data/templates/default/method/html/header.erb +16 -16
  494. data/templates/default/method/setup.rb +4 -4
  495. data/templates/default/method_details/html/header.erb +2 -2
  496. data/templates/default/method_details/html/method_signature.erb +24 -24
  497. data/templates/default/method_details/html/source.erb +9 -9
  498. data/templates/default/method_details/setup.rb +11 -11
  499. data/templates/default/method_details/text/header.erb +10 -10
  500. data/templates/default/method_details/text/method_signature.erb +12 -12
  501. data/templates/default/method_details/text/setup.rb +11 -11
  502. data/templates/default/module/dot/child.erb +1 -1
  503. data/templates/default/module/dot/dependencies.erb +2 -2
  504. data/templates/default/module/dot/header.erb +6 -6
  505. data/templates/default/module/dot/info.erb +13 -13
  506. data/templates/default/module/dot/setup.rb +15 -15
  507. data/templates/default/module/html/attribute_details.erb +10 -10
  508. data/templates/default/module/html/attribute_summary.erb +8 -8
  509. data/templates/default/module/html/box_info.erb +43 -43
  510. data/templates/default/module/html/children.erb +8 -8
  511. data/templates/default/module/html/constant_summary.erb +17 -17
  512. data/templates/default/module/html/defines.erb +2 -2
  513. data/templates/default/module/html/header.erb +5 -5
  514. data/templates/default/module/html/inherited_attributes.erb +14 -14
  515. data/templates/default/module/html/inherited_constants.erb +8 -8
  516. data/templates/default/module/html/inherited_methods.erb +18 -18
  517. data/templates/default/module/html/item_summary.erb +40 -40
  518. data/templates/default/module/html/method_details_list.erb +9 -9
  519. data/templates/default/module/html/method_summary.erb +13 -13
  520. data/templates/default/module/html/methodmissing.erb +12 -12
  521. data/templates/default/module/setup.rb +167 -167
  522. data/templates/default/module/text/children.erb +9 -9
  523. data/templates/default/module/text/class_meths_list.erb +7 -7
  524. data/templates/default/module/text/extends.erb +7 -7
  525. data/templates/default/module/text/header.erb +7 -7
  526. data/templates/default/module/text/includes.erb +7 -7
  527. data/templates/default/module/text/instance_meths_list.erb +7 -7
  528. data/templates/default/module/text/setup.rb +13 -13
  529. data/templates/default/onefile/html/files.erb +4 -4
  530. data/templates/default/onefile/html/headers.erb +6 -6
  531. data/templates/default/onefile/html/layout.erb +17 -17
  532. data/templates/default/onefile/html/readme.erb +2 -2
  533. data/templates/default/onefile/html/setup.rb +62 -62
  534. data/templates/default/root/dot/child.erb +2 -2
  535. data/templates/default/root/dot/setup.rb +6 -6
  536. data/templates/default/root/html/setup.rb +2 -2
  537. data/templates/default/tags/html/example.erb +10 -10
  538. data/templates/default/tags/html/index.erb +2 -2
  539. data/templates/default/tags/html/option.erb +24 -24
  540. data/templates/default/tags/html/overload.erb +13 -13
  541. data/templates/default/tags/html/see.erb +7 -7
  542. data/templates/default/tags/html/tag.erb +20 -20
  543. data/templates/default/tags/setup.rb +57 -57
  544. data/templates/default/tags/text/example.erb +12 -12
  545. data/templates/default/tags/text/index.erb +1 -1
  546. data/templates/default/tags/text/option.erb +20 -20
  547. data/templates/default/tags/text/overload.erb +19 -19
  548. data/templates/default/tags/text/see.erb +11 -11
  549. data/templates/default/tags/text/tag.erb +13 -13
  550. data/templates/guide/class/html/setup.rb +2 -2
  551. data/templates/guide/docstring/html/setup.rb +2 -2
  552. data/templates/guide/fulldoc/html/css/style.css +108 -108
  553. data/templates/guide/fulldoc/html/js/app.js +33 -33
  554. data/templates/guide/fulldoc/html/setup.rb +74 -74
  555. data/templates/guide/layout/html/layout.erb +81 -81
  556. data/templates/guide/layout/html/setup.rb +25 -25
  557. data/templates/guide/method/html/header.erb +17 -17
  558. data/templates/guide/method/html/setup.rb +22 -22
  559. data/templates/guide/module/html/header.erb +6 -6
  560. data/templates/guide/module/html/method_list.erb +4 -4
  561. data/templates/guide/module/html/setup.rb +27 -27
  562. data/templates/guide/onefile/html/files.erb +4 -4
  563. data/templates/guide/onefile/html/setup.rb +6 -6
  564. data/templates/guide/onefile/html/toc.erb +3 -3
  565. data/templates/guide/tags/html/setup.rb +9 -9
  566. data/yard.gemspec +43 -43
  567. metadata +4 -3
@@ -1,168 +1,168 @@
1
- # frozen_string_literal: true
2
-
3
- RSpec.describe YARD::Tags::DefaultFactory do
4
- before { @f = YARD::Tags::DefaultFactory.new }
5
-
6
- describe "#parse_tag" do
7
- it "does not have trailing whitespace on a regular freeform tag" do
8
- expect(@f.parse_tag('api', 'private ').text).to eq "private"
9
- end
10
- end
11
-
12
- describe "#extract_types_and_name_from_text" do
13
- def parse_types(types)
14
- @f.send(:extract_types_and_name_from_text, types)
15
- end
16
-
17
- it "handles one type" do
18
- expect(parse_types('[A]')).to eq [nil, ['A'], ""]
19
- end
20
-
21
- it "handles a list of types" do
22
- expect(parse_types('[A, B, C]')).to eq [nil, ['A', 'B', 'C'], ""]
23
- end
24
-
25
- it "handles ducktypes" do
26
- expect(parse_types('[#foo]')).to eq [nil, ['#foo'], '']
27
- end
28
-
29
- %w(#foo= #<< #<=> #>> #== #=== Array<#<=>> Array<#==>).each do |meth|
30
- it "handles ducktypes with special method name #{meth}" do
31
- expect(parse_types("[#{meth}]")).to eq [nil, [meth], '']
32
- end
33
- end
34
-
35
- it "only parses #ducktypes inside brackets" do
36
- expect(parse_types("#ducktype")).to eq [nil, nil, '#ducktype']
37
- end
38
-
39
- it "returns the text before and after the type list" do
40
- expect(parse_types(' b <String> description')).to eq ['b', ['String'], 'description']
41
- expect(parse_types('b c <String> description (test)')).to eq [nil, nil, 'b c <String> description (test)']
42
- end
43
-
44
- it "does not allow types to start after a newline" do
45
- v = parse_types(" \n [X]")
46
- expect(v).to eq [nil, nil, "[X]"]
47
- end
48
-
49
- it "handles a complex list of types" do
50
- v = parse_types(' [Test, Array<String, Hash, C>, String]')
51
- expect(v).to include(["Test", "Array<String, Hash, C>", "String"])
52
- end
53
-
54
- it "handles any of the following start/end delimiting chars: (), <>, {}, []" do
55
- a = parse_types('[a,b,c]')
56
- b = parse_types('<a,b,c>')
57
- c = parse_types('(a,b,c)')
58
- d = parse_types('{a,b,c}')
59
- expect(a).to eq b
60
- expect(b).to eq c
61
- expect(c).to eq d
62
- expect(a).to include(['a', 'b', 'c'])
63
- end
64
-
65
- it "returns the text before the type list as the last element" do
66
- expect(parse_types('b[x, y, z]')).to eq ['b', ['x', 'y', 'z'], '']
67
- expect(parse_types(' ! <x>')).to eq ["!", ['x'], '']
68
- end
69
-
70
- it "returns text unparsed if there is no type list" do
71
- expect(parse_types('')).to eq [nil, nil, '']
72
- expect(parse_types('[]')).to eq [nil, nil, '[]']
73
- end
74
-
75
- it "allows A => B syntax" do
76
- v = parse_types(' [Test, Array<String, Hash{A => {B => C}}, C>, String]')
77
- expect(v).to include(["Test", "Array<String, Hash{A => {B => C}}, C>", "String"])
78
- end
79
-
80
- it "handles quoted values" do
81
- v = parse_types(' ["foo, bar", \'baz, qux\', in"them,iddle"]')
82
- expect(v).to include(["\"foo, bar\"", "'baz, qux'", 'in"them,iddle"'])
83
- end
84
- end
85
-
86
- describe "#parse_tag_with_types" do
87
- def parse_types(text)
88
- @f.send(:parse_tag_with_types, 'test', text)
89
- end
90
-
91
- it "parses given types and description" do
92
- expect(YARD::Tags::Tag).to receive(:new).with("test", "description", ["x", "y", "z"])
93
- parse_types(' [x, y, z] description')
94
- end
95
-
96
- it "parses given types only" do
97
- expect(YARD::Tags::Tag).to receive(:new).with("test", "", ["x", "y", "z"])
98
- parse_types(' [x, y, z] ')
99
- end
100
-
101
- it "allows type list to be omitted" do
102
- expect(YARD::Tags::Tag).to receive(:new).with('test', 'description', nil)
103
- parse_types(' description ')
104
- end
105
-
106
- it "raises an error if a name is specified before type list" do
107
- expect { parse_types('b<String> desc') }.to raise_error(YARD::Tags::TagFormatError, 'cannot specify a name before type list for \'@test\'')
108
- end
109
- end
110
-
111
- describe "#parse_tag_with_types_name_and_default" do
112
- def parse_types(text)
113
- @f.send(:parse_tag_with_types_name_and_default, 'test', text)
114
- end
115
-
116
- it "parses a standard type list with name before types (no default)" do
117
- expect(YARD::Tags::DefaultTag).to receive(:new).with("test", "description", ["x", "y", "z"], 'NAME', nil)
118
- parse_types('NAME [x, y, z] description')
119
- end
120
-
121
- it "parses a standard type list with name after types (no default)" do
122
- expect(YARD::Tags::DefaultTag).to receive(:new).with("test", "description", ["x", "y", "z"], 'NAME', nil)
123
- parse_types(' [x, y, z] NAME description')
124
- end
125
-
126
- it "parses a tag definition with name, typelist and default" do
127
- expect(YARD::Tags::DefaultTag).to receive(:new).with("test", "description", ["x", "y", "z"], 'NAME', ['default', 'values'])
128
- parse_types(' [x, y, z] NAME (default, values) description')
129
- end
130
-
131
- it "parses a tag definition with name, typelist and default when name is before type list" do
132
- expect(YARD::Tags::DefaultTag).to receive(:new).with("test", "description", ["x", "y", "z"], 'NAME', ['default', 'values'])
133
- parse_types(' NAME [x, y, z] (default, values) description')
134
- end
135
-
136
- it "allows typelist to be omitted" do
137
- expect(YARD::Tags::DefaultTag).to receive(:new).with("test", "description", nil, 'NAME', ['default', 'values'])
138
- parse_types(' NAME (default, values) description')
139
- end
140
- end
141
-
142
- describe "#parse_tag_with_options" do
143
- def parse_options(text)
144
- @f.parse_tag_with_options('option', text)
145
- end
146
-
147
- it "has a name before tag info" do
148
- t = parse_options("xyz key [Types] (default) description")
149
- expect(t.tag_name).to eq 'option'
150
- expect(t.name).to eq 'xyz'
151
- end
152
-
153
- it "parses the rest of the tag like DefaultTag" do
154
- t = parse_options("xyz key [Types] (default) description")
155
- expect(t.pair).to be_instance_of(Tags::DefaultTag)
156
- expect(t.pair.types).to eq ["Types"]
157
- expect(t.pair.name).to eq "key"
158
- expect(t.pair.defaults).to eq ["default"]
159
- expect(t.pair.text).to eq "description"
160
- end
161
-
162
- it "allows omitting default" do
163
- t = parse_options("xyz [Types] key")
164
- expect(t.pair).to be_instance_of(Tags::DefaultTag)
165
- expect(t.pair.name).to eq "key"
166
- end
167
- end
168
- end
1
+ # frozen_string_literal: true
2
+
3
+ RSpec.describe YARD::Tags::DefaultFactory do
4
+ before { @f = YARD::Tags::DefaultFactory.new }
5
+
6
+ describe "#parse_tag" do
7
+ it "does not have trailing whitespace on a regular freeform tag" do
8
+ expect(@f.parse_tag('api', 'private ').text).to eq "private"
9
+ end
10
+ end
11
+
12
+ describe "#extract_types_and_name_from_text" do
13
+ def parse_types(types)
14
+ @f.send(:extract_types_and_name_from_text, types)
15
+ end
16
+
17
+ it "handles one type" do
18
+ expect(parse_types('[A]')).to eq [nil, ['A'], ""]
19
+ end
20
+
21
+ it "handles a list of types" do
22
+ expect(parse_types('[A, B, C]')).to eq [nil, ['A', 'B', 'C'], ""]
23
+ end
24
+
25
+ it "handles ducktypes" do
26
+ expect(parse_types('[#foo]')).to eq [nil, ['#foo'], '']
27
+ end
28
+
29
+ %w(#foo= #<< #<=> #>> #== #=== Array<#<=>> Array<#==>).each do |meth|
30
+ it "handles ducktypes with special method name #{meth}" do
31
+ expect(parse_types("[#{meth}]")).to eq [nil, [meth], '']
32
+ end
33
+ end
34
+
35
+ it "only parses #ducktypes inside brackets" do
36
+ expect(parse_types("#ducktype")).to eq [nil, nil, '#ducktype']
37
+ end
38
+
39
+ it "returns the text before and after the type list" do
40
+ expect(parse_types(' b <String> description')).to eq ['b', ['String'], 'description']
41
+ expect(parse_types('b c <String> description (test)')).to eq [nil, nil, 'b c <String> description (test)']
42
+ end
43
+
44
+ it "does not allow types to start after a newline" do
45
+ v = parse_types(" \n [X]")
46
+ expect(v).to eq [nil, nil, "[X]"]
47
+ end
48
+
49
+ it "handles a complex list of types" do
50
+ v = parse_types(' [Test, Array<String, Hash, C>, String]')
51
+ expect(v).to include(["Test", "Array<String, Hash, C>", "String"])
52
+ end
53
+
54
+ it "handles any of the following start/end delimiting chars: (), <>, {}, []" do
55
+ a = parse_types('[a,b,c]')
56
+ b = parse_types('<a,b,c>')
57
+ c = parse_types('(a,b,c)')
58
+ d = parse_types('{a,b,c}')
59
+ expect(a).to eq b
60
+ expect(b).to eq c
61
+ expect(c).to eq d
62
+ expect(a).to include(['a', 'b', 'c'])
63
+ end
64
+
65
+ it "returns the text before the type list as the last element" do
66
+ expect(parse_types('b[x, y, z]')).to eq ['b', ['x', 'y', 'z'], '']
67
+ expect(parse_types(' ! <x>')).to eq ["!", ['x'], '']
68
+ end
69
+
70
+ it "returns text unparsed if there is no type list" do
71
+ expect(parse_types('')).to eq [nil, nil, '']
72
+ expect(parse_types('[]')).to eq [nil, nil, '[]']
73
+ end
74
+
75
+ it "allows A => B syntax" do
76
+ v = parse_types(' [Test, Array<String, Hash{A => {B => C}}, C>, String]')
77
+ expect(v).to include(["Test", "Array<String, Hash{A => {B => C}}, C>", "String"])
78
+ end
79
+
80
+ it "handles quoted values" do
81
+ v = parse_types(' ["foo, bar", \'baz, qux\', in"them,iddle"]')
82
+ expect(v).to include(["\"foo, bar\"", "'baz, qux'", 'in"them,iddle"'])
83
+ end
84
+ end
85
+
86
+ describe "#parse_tag_with_types" do
87
+ def parse_types(text)
88
+ @f.send(:parse_tag_with_types, 'test', text)
89
+ end
90
+
91
+ it "parses given types and description" do
92
+ expect(YARD::Tags::Tag).to receive(:new).with("test", "description", ["x", "y", "z"])
93
+ parse_types(' [x, y, z] description')
94
+ end
95
+
96
+ it "parses given types only" do
97
+ expect(YARD::Tags::Tag).to receive(:new).with("test", "", ["x", "y", "z"])
98
+ parse_types(' [x, y, z] ')
99
+ end
100
+
101
+ it "allows type list to be omitted" do
102
+ expect(YARD::Tags::Tag).to receive(:new).with('test', 'description', nil)
103
+ parse_types(' description ')
104
+ end
105
+
106
+ it "raises an error if a name is specified before type list" do
107
+ expect { parse_types('b<String> desc') }.to raise_error(YARD::Tags::TagFormatError, 'cannot specify a name before type list for \'@test\'')
108
+ end
109
+ end
110
+
111
+ describe "#parse_tag_with_types_name_and_default" do
112
+ def parse_types(text)
113
+ @f.send(:parse_tag_with_types_name_and_default, 'test', text)
114
+ end
115
+
116
+ it "parses a standard type list with name before types (no default)" do
117
+ expect(YARD::Tags::DefaultTag).to receive(:new).with("test", "description", ["x", "y", "z"], 'NAME', nil)
118
+ parse_types('NAME [x, y, z] description')
119
+ end
120
+
121
+ it "parses a standard type list with name after types (no default)" do
122
+ expect(YARD::Tags::DefaultTag).to receive(:new).with("test", "description", ["x", "y", "z"], 'NAME', nil)
123
+ parse_types(' [x, y, z] NAME description')
124
+ end
125
+
126
+ it "parses a tag definition with name, typelist and default" do
127
+ expect(YARD::Tags::DefaultTag).to receive(:new).with("test", "description", ["x", "y", "z"], 'NAME', ['default', 'values'])
128
+ parse_types(' [x, y, z] NAME (default, values) description')
129
+ end
130
+
131
+ it "parses a tag definition with name, typelist and default when name is before type list" do
132
+ expect(YARD::Tags::DefaultTag).to receive(:new).with("test", "description", ["x", "y", "z"], 'NAME', ['default', 'values'])
133
+ parse_types(' NAME [x, y, z] (default, values) description')
134
+ end
135
+
136
+ it "allows typelist to be omitted" do
137
+ expect(YARD::Tags::DefaultTag).to receive(:new).with("test", "description", nil, 'NAME', ['default', 'values'])
138
+ parse_types(' NAME (default, values) description')
139
+ end
140
+ end
141
+
142
+ describe "#parse_tag_with_options" do
143
+ def parse_options(text)
144
+ @f.parse_tag_with_options('option', text)
145
+ end
146
+
147
+ it "has a name before tag info" do
148
+ t = parse_options("xyz key [Types] (default) description")
149
+ expect(t.tag_name).to eq 'option'
150
+ expect(t.name).to eq 'xyz'
151
+ end
152
+
153
+ it "parses the rest of the tag like DefaultTag" do
154
+ t = parse_options("xyz key [Types] (default) description")
155
+ expect(t.pair).to be_instance_of(Tags::DefaultTag)
156
+ expect(t.pair.types).to eq ["Types"]
157
+ expect(t.pair.name).to eq "key"
158
+ expect(t.pair.defaults).to eq ["default"]
159
+ expect(t.pair.text).to eq "description"
160
+ end
161
+
162
+ it "allows omitting default" do
163
+ t = parse_options("xyz [Types] key")
164
+ expect(t.pair).to be_instance_of(Tags::DefaultTag)
165
+ expect(t.pair.name).to eq "key"
166
+ end
167
+ end
168
+ end
@@ -1,11 +1,11 @@
1
- # frozen_string_literal: true
2
-
3
- RSpec.describe YARD::Tags::DefaultTag do
4
- it "creates a tag with defaults" do
5
- o = YARD::Tags::DefaultTag.new('tagname', 'desc', ['types'], 'name', ['defaults'])
6
- expect(o.defaults).to eq ['defaults']
7
- expect(o.tag_name).to eq 'tagname'
8
- expect(o.name).to eq 'name'
9
- expect(o.types).to eq ['types']
10
- end
11
- end
1
+ # frozen_string_literal: true
2
+
3
+ RSpec.describe YARD::Tags::DefaultTag do
4
+ it "creates a tag with defaults" do
5
+ o = YARD::Tags::DefaultTag.new('tagname', 'desc', ['types'], 'name', ['defaults'])
6
+ expect(o.defaults).to eq ['defaults']
7
+ expect(o.tag_name).to eq 'tagname'
8
+ expect(o.name).to eq 'name'
9
+ expect(o.types).to eq ['types']
10
+ end
11
+ end
@@ -1,463 +1,463 @@
1
- # frozen_string_literal: true
2
-
3
- def tag_parse(content, object = nil, handler = nil)
4
- @parser = DocstringParser.new
5
- @parser.parse(content, object, handler)
6
- @parser
7
- end
8
-
9
- RSpec.describe YARD::Tags::ParseDirective do
10
- describe "#call" do
11
- after { Registry.clear }
12
-
13
- it "parses if handler=nil but use file=(stdin)" do
14
- tag_parse %(@!parse
15
- # Docstring here
16
- def foo; end
17
- )
18
- expect(Registry.at('#foo').docstring).to eq "Docstring here"
19
- expect(Registry.at('#foo').file).to eq '(stdin)'
20
- end
21
-
22
- it "allows parser type to be specified in type" do
23
- tag_parse %{@!parse [c]
24
- void Init_Foo() {
25
- rb_define_method(rb_cMyClass, "foo", foo, 1);
26
- }
27
- }
28
- expect(Registry.at('MyClass#foo')).not_to be nil
29
- end
30
-
31
- it "parses code in context of current handler" do
32
- src = <<-eof
33
- class A
34
- # @!parse
35
- # def foo; end
36
- eval "def foo; end"
37
- end
38
- eof
39
- parser = YARD::Parser::SourceParser.new
40
- parser.file = "myfile.rb"
41
- parser.parse(StringIO.new(src))
42
- expect(Registry.at('A#foo').file).to eq 'myfile.rb'
43
- end
44
- end
45
- end
46
-
47
- RSpec.describe YARD::Tags::GroupDirective do
48
- describe "#call" do
49
- it "does nothing if handler=nil" do
50
- tag_parse("@!group foo")
51
- end
52
-
53
- it "sets group value in parser state (with handler)" do
54
- handler = OpenStruct.new(:extra_state => OpenStruct.new)
55
- tag_parse("@!group foo", nil, handler)
56
- expect(handler.extra_state.group).to eq 'foo'
57
- end
58
- end
59
- end
60
-
61
- RSpec.describe YARD::Tags::EndGroupDirective do
62
- describe "#call" do
63
- it "does nothing if handler=nil" do
64
- tag_parse("@!endgroup foo")
65
- end
66
-
67
- it "sets group value in parser state (with handler)" do
68
- handler = OpenStruct.new(:extra_state => OpenStruct.new(:group => "foo"))
69
- tag_parse("@!endgroup", nil, handler)
70
- expect(handler.extra_state.group).to be nil
71
- end
72
- end
73
- end
74
-
75
- RSpec.describe YARD::Tags::MacroDirective do
76
- def handler
77
- OpenStruct.new(:call_params => %w(a b c),
78
- :caller_method => 'foo',
79
- :scope => :instance, :visibility => :public,
80
- :namespace => P('Foo::Bar'),
81
- :parser => OpenStruct.new(:file => "(stdin)", :line => 1),
82
- :statement => OpenStruct.new(:source => 'foo :a, :b, :c'))
83
- end
84
-
85
- after(:all) { Registry.clear }
86
-
87
- describe "#call" do
88
- it "defines new macro when [new] is provided" do
89
- tag_parse("@!macro [new] foo\n foo")
90
- expect(CodeObjects::MacroObject.find('foo').macro_data).to eq 'foo'
91
- end
92
-
93
- it "defines new macro if text block is provided" do
94
- tag_parse("@!macro bar\n bar")
95
- expect(CodeObjects::MacroObject.find('bar').macro_data).to eq 'bar'
96
- end
97
-
98
- it "expands macros and return #expanded_text to tag parser" do
99
- tag_parse("@!macro [new] foo\n foo")
100
- expect(tag_parse("@!macro foo").text).to eq 'foo'
101
- end
102
-
103
- it "does not expand new macro if docstring is unattached" do
104
- expect(tag_parse("@!macro [new] foo\n foo").text).not_to eq 'foo'
105
- end
106
-
107
- it "expands new anonymous macro even if docstring is unattached" do
108
- expect(tag_parse("@!macro\n foo").text).to eq 'foo'
109
- end
110
-
111
- it "allows multiple macros to be expanded" do
112
- tag_parse("@!macro [new] foo\n foo")
113
- tag_parse("@!macro bar\n bar")
114
- expect(tag_parse("@!macro foo\n@!macro bar").text).to eq "foo\nbar"
115
- end
116
-
117
- it "allows anonymous macros" do
118
- tag_parse("@!macro\n a b c", nil, handler)
119
- expect(@parser.text).to eq 'a b c'
120
- end
121
-
122
- it "expands call_params and caller_method using $N when handler is provided" do
123
- tag_parse("@!macro\n $1 $2 $3", nil, handler)
124
- expect(@parser.text).to eq 'a b c'
125
- end
126
-
127
- it "attaches macro to method if one exists" do
128
- tag_parse("@!macro [attach] attached\n $1 $2 $3", nil, handler)
129
- macro = CodeObjects::MacroObject.find('attached')
130
- expect(macro.method_object).to eq P('Foo::Bar.foo')
131
- end
132
-
133
- it "does not expand new attached macro if defined on class method" do
134
- baz = CodeObjects::MethodObject.new(P('Foo::Bar'), :baz, :class)
135
- expect(baz.visibility).to eq :public
136
- tag_parse("@!macro [attach] attached2\n @!visibility private", baz, handler)
137
- macro = CodeObjects::MacroObject.find('attached2')
138
- expect(macro.method_object).to eq P('Foo::Bar.baz')
139
- expect(baz.visibility).to eq :public
140
- end
141
-
142
- it "expands macro if defined on class method and there is no data block" do
143
- tag_parse("@!macro [new] attached3\n expanded_data")
144
- baz = CodeObjects::MethodObject.new(P('Foo::Bar'), :baz, :class)
145
- doc = DocstringParser.new.parse('@!macro attached3', baz, handler).to_docstring
146
- expect(doc).to eq 'expanded_data'
147
- end
148
-
149
- it "does not attach macros to class/modules but creates macro" do
150
- YARD::Registry.clear
151
- YARD.parse_string "module Foo; end"
152
- tag_parse("@!macro [attach] attached4\n $1 $2 $3", YARD::Registry.at('Foo'), handler)
153
- macro = CodeObjects::MacroObject.find('attached4')
154
- expect(macro.method_object).to eq nil
155
- expect(log.io.string).to match(/Attaching macros to non-methods is unsupported/)
156
- end
157
-
158
- it "does not attempt to expand macro values if handler = nil" do
159
- tag_parse("@!macro [attach] xyz\n $1 $2 $3")
160
- end
161
- end
162
- end
163
-
164
- RSpec.describe YARD::Tags::MethodDirective do
165
- describe "#call" do
166
- after { Registry.clear }
167
-
168
- it "uses entire docstring if no indented data is found" do
169
- YARD.parse_string <<-eof
170
- class Foo
171
- # @!method foo
172
- # @!method bar
173
- # @!scope class
174
- end
175
- eof
176
- expect(Registry.at('Foo.foo')).to be_a(CodeObjects::MethodObject)
177
- expect(Registry.at('Foo.bar')).to be_a(CodeObjects::MethodObject)
178
- end
179
-
180
- it "handles indented block text in @!method" do
181
- YARD.parse_string <<-eof
182
- # @!method foo(a)
183
- # Docstring here
184
- # @return [String] the foo
185
- # Ignore this
186
- # @param [String] a
187
- eof
188
- foo = Registry.at('#foo')
189
- expect(foo.docstring).to eq "Docstring here"
190
- expect(foo.docstring.tag(:return)).not_to be nil
191
- expect(foo.tag(:param)).to be nil
192
- end
193
-
194
- it "executes directives on object in indented block" do
195
- YARD.parse_string <<-eof
196
- class Foo
197
- # @!method foo(a)
198
- # @!scope class
199
- # @!visibility private
200
- # @!method bar
201
- # Hello
202
- # Ignore this
203
- end
204
- eof
205
- foo = Registry.at('Foo.foo')
206
- expect(foo.visibility).to eq :private
207
- bar = Registry.at('Foo#bar')
208
- expect(bar.visibility).to eq :public
209
- end
210
-
211
- it "is able to define multiple @methods in docstring" do
212
- YARD.parse_string <<-eof
213
- class Foo
214
- # @!method foo1
215
- # Docstring1
216
- # @!method foo2
217
- # Docstring2
218
- # @!method foo3
219
- # @!scope class
220
- # Docstring3
221
- end
222
- eof
223
- foo1 = Registry.at('Foo#foo1')
224
- foo2 = Registry.at('Foo#foo2')
225
- foo3 = Registry.at('Foo.foo3')
226
- expect(foo1.docstring).to eq 'Docstring1'
227
- expect(foo2.docstring).to eq 'Docstring2'
228
- expect(foo3.docstring).to eq 'Docstring3'
229
- end
230
-
231
- it "defines the method inside namespace if attached to namespace object" do
232
- YARD.parse_string <<-eof
233
- module Foo
234
- # @!method foo
235
- # Docstring1
236
- # @!method bar
237
- # Docstring2
238
- class Bar
239
- end
240
- end
241
- eof
242
- expect(Registry.at('Foo::Bar#foo').docstring).to eq 'Docstring1'
243
- expect(Registry.at('Foo::Bar#bar').docstring).to eq 'Docstring2'
244
- end
245
-
246
- it "sets scope to class if signature has 'self.' prefix" do
247
- YARD.parse_string <<-eof
248
- # @!method self.foo
249
- # @!method self. bar
250
- # @!method self.baz()
251
- class Foo
252
- end
253
- eof
254
- %w(foo bar baz).each do |name|
255
- expect(Registry.at("Foo.#{name}")).to be_a(CodeObjects::MethodObject)
256
- end
257
- end
258
-
259
- it "defines parameters from signature" do
260
- YARD.parse_string <<-eof
261
- # @!method foo(a, b, c = nil)
262
- eof
263
- expect(Registry.at('#foo').parameters).to eq [['a', nil], ['b', nil], ['c', 'nil']]
264
- end
265
-
266
- it "is able to define method with module scope (module function)" do
267
- YARD.parse_string <<-eof
268
- # @!method foo
269
- # @!scope module
270
- # This is a docstring
271
- # @return [Boolean] whether this is true
272
- class Foo
273
- end
274
- eof
275
- foo_c = Registry.at('Foo.foo')
276
- foo_i = Registry.at('Foo#foo')
277
- expect(foo_c).not_to be nil
278
- expect(foo_i).not_to be nil
279
- expect(foo_c).to be_module_function
280
- expect(foo_c.docstring).to eq foo_i.docstring
281
- expect(foo_c.tag(:return).text).to eq foo_i.tag(:return).text
282
- end
283
- end
284
- end
285
-
286
- RSpec.describe YARD::Tags::AttributeDirective do
287
- describe "#call" do
288
- after { Registry.clear }
289
-
290
- it "uses entire docstring if no indented data is found" do
291
- YARD.parse_string <<-eof
292
- class Foo
293
- # @!attribute foo
294
- # @!attribute bar
295
- # @!scope class
296
- end
297
- eof
298
- expect(Registry.at('Foo.foo')).to be_reader
299
- expect(Registry.at('Foo.bar')).to be_reader
300
- end
301
-
302
- it "handles indented block in @!attribute" do
303
- YARD.parse_string <<-eof
304
- # @!attribute foo
305
- # Docstring here
306
- # @return [String] the foo
307
- # Ignore this
308
- # @param [String] a
309
- eof
310
- foo = Registry.at('#foo')
311
- expect(foo.is_attribute?).to be true
312
- expect(foo.docstring).to eq "Docstring here"
313
- expect(foo.docstring.tag(:return)).not_to be nil
314
- expect(foo.tag(:param)).to be nil
315
- end
316
-
317
- it "is able to define multiple @attributes in docstring" do
318
- YARD.parse_string <<-eof
319
- class Foo
320
- # @!attribute [r] foo1
321
- # Docstring1
322
- # @!attribute [w] foo2
323
- # Docstring2
324
- # @!attribute foo3
325
- # @!scope class
326
- # Docstring3
327
- end
328
- eof
329
- foo1 = Registry.at('Foo#foo1')
330
- foo2 = Registry.at('Foo#foo2=')
331
- foo3 = Registry.at('Foo.foo3')
332
- foo4 = Registry.at('Foo.foo3=')
333
- expect(foo1).to be_reader
334
- expect(foo2).to be_writer
335
- expect(foo3).to be_reader
336
- expect(foo1.docstring).to eq 'Docstring1'
337
- expect(foo2.docstring).to eq 'Docstring2'
338
- expect(foo3.docstring).to eq 'Docstring3'
339
- expect(foo4).to be_writer
340
- expect(foo1.attr_info[:write]).to be nil
341
- expect(foo2.attr_info[:read]).to be nil
342
- end
343
-
344
- it "defines the attr inside namespace if attached to namespace object" do
345
- YARD.parse_string <<-eof
346
- module Foo
347
- # @!attribute [r] foo
348
- # @!attribute [r] bar
349
- class Bar
350
- end
351
- end
352
- eof
353
- expect(Registry.at('Foo::Bar#foo')).to be_reader
354
- expect(Registry.at('Foo::Bar#bar')).to be_reader
355
- end
356
- end
357
-
358
- it "sets scope to class if signature has 'self.' prefix" do
359
- YARD.parse_string <<-eof
360
- # @!attribute self.foo
361
- # @!attribute self. bar
362
- # @!attribute self.baz
363
- class Foo
364
- end
365
- eof
366
- %w(foo bar baz).each do |name|
367
- expect(Registry.at("Foo.#{name}")).to be_reader
368
- end
369
- end
370
- end
371
-
372
- RSpec.describe YARD::Tags::ScopeDirective do
373
- describe "#call" do
374
- after { Registry.clear }
375
-
376
- it "sets state on tag parser if object = nil" do
377
- tag_parse("@!scope class")
378
- expect(@parser.state.scope).to eq :class
379
- end
380
-
381
- it "sets state on tag parser if object is namespace" do
382
- object = CodeObjects::ClassObject.new(:root, 'Foo')
383
- tag_parse("@!scope class", object)
384
- expect(object[:scope]).to be nil
385
- expect(@parser.state.scope).to eq :class
386
- end
387
-
388
- it "sets scope on object if object is a method object" do
389
- object = CodeObjects::MethodObject.new(:root, 'foo')
390
- tag_parse("@!scope class", object)
391
- expect(object.scope).to eq :class
392
- end
393
-
394
- %w(class instance module).each do |type|
395
- it "allows #{type} as value" do
396
- tag_parse("@!scope #{type}")
397
- expect(@parser.state.scope).to eq type.to_sym
398
- end
399
- end
400
-
401
- %w(invalid foo FOO CLASS INSTANCE).each do |type|
402
- it "does not allow #{type} as value" do
403
- tag_parse("@!scope #{type}")
404
- expect(@parser.state.scope).to be nil
405
- end
406
- end
407
- end
408
- end
409
-
410
- RSpec.describe YARD::Tags::VisibilityDirective do
411
- describe "#call" do
412
- after { Registry.clear }
413
-
414
- it "sets visibility on tag parser if object = nil" do
415
- tag_parse("@!visibility private")
416
- expect(@parser.state.visibility).to eq :private
417
- end
418
-
419
- it "sets state on tag parser if object is namespace" do
420
- object = CodeObjects::ClassObject.new(:root, 'Foo')
421
- tag_parse("@!visibility protected", object)
422
- expect(object.visibility).to eq :protected
423
- expect(@parser.state.visibility).to be nil
424
- end
425
-
426
- it "sets visibility on object if object is a method object" do
427
- object = CodeObjects::MethodObject.new(:root, 'foo')
428
- tag_parse("@!visibility private", object)
429
- expect(object.visibility).to eq :private
430
- end
431
-
432
- %w(public private protected).each do |type|
433
- it "allows #{type} as value" do
434
- tag_parse("@!visibility #{type}")
435
- expect(@parser.state.visibility).to eq type.to_sym
436
- end
437
- end
438
-
439
- %w(invalid foo FOO PRIVATE INSTANCE).each do |type|
440
- it "does not allow #{type} as value" do
441
- tag_parse("@!visibility #{type}")
442
- expect(@parser.state.visibility).to be nil
443
- end
444
- end
445
-
446
- it "updates visibility on future methods" do
447
- Registry.clear
448
- YARD.parse_string <<-eof
449
- class Foo
450
- # @!visibility private
451
-
452
-
453
- def foo; end
454
- def bar; end
455
- def baz; end
456
- end
457
- eof
458
- %w(foo bar baz).each do |name|
459
- expect(Registry.at("Foo##{name}").visibility).to eq :private
460
- end
461
- end if YARD::Parser::SourceParser.parser_type == :ruby
462
- end
463
- end
1
+ # frozen_string_literal: true
2
+
3
+ def tag_parse(content, object = nil, handler = nil)
4
+ @parser = DocstringParser.new
5
+ @parser.parse(content, object, handler)
6
+ @parser
7
+ end
8
+
9
+ RSpec.describe YARD::Tags::ParseDirective do
10
+ describe "#call" do
11
+ after { Registry.clear }
12
+
13
+ it "parses if handler=nil but use file=(stdin)" do
14
+ tag_parse %(@!parse
15
+ # Docstring here
16
+ def foo; end
17
+ )
18
+ expect(Registry.at('#foo').docstring).to eq "Docstring here"
19
+ expect(Registry.at('#foo').file).to eq '(stdin)'
20
+ end
21
+
22
+ it "allows parser type to be specified in type" do
23
+ tag_parse %{@!parse [c]
24
+ void Init_Foo() {
25
+ rb_define_method(rb_cMyClass, "foo", foo, 1);
26
+ }
27
+ }
28
+ expect(Registry.at('MyClass#foo')).not_to be nil
29
+ end
30
+
31
+ it "parses code in context of current handler" do
32
+ src = <<-eof
33
+ class A
34
+ # @!parse
35
+ # def foo; end
36
+ eval "def foo; end"
37
+ end
38
+ eof
39
+ parser = YARD::Parser::SourceParser.new
40
+ parser.file = "myfile.rb"
41
+ parser.parse(StringIO.new(src))
42
+ expect(Registry.at('A#foo').file).to eq 'myfile.rb'
43
+ end
44
+ end
45
+ end
46
+
47
+ RSpec.describe YARD::Tags::GroupDirective do
48
+ describe "#call" do
49
+ it "does nothing if handler=nil" do
50
+ tag_parse("@!group foo")
51
+ end
52
+
53
+ it "sets group value in parser state (with handler)" do
54
+ handler = OpenStruct.new(:extra_state => OpenStruct.new)
55
+ tag_parse("@!group foo", nil, handler)
56
+ expect(handler.extra_state.group).to eq 'foo'
57
+ end
58
+ end
59
+ end
60
+
61
+ RSpec.describe YARD::Tags::EndGroupDirective do
62
+ describe "#call" do
63
+ it "does nothing if handler=nil" do
64
+ tag_parse("@!endgroup foo")
65
+ end
66
+
67
+ it "sets group value in parser state (with handler)" do
68
+ handler = OpenStruct.new(:extra_state => OpenStruct.new(:group => "foo"))
69
+ tag_parse("@!endgroup", nil, handler)
70
+ expect(handler.extra_state.group).to be nil
71
+ end
72
+ end
73
+ end
74
+
75
+ RSpec.describe YARD::Tags::MacroDirective do
76
+ def handler
77
+ OpenStruct.new(:call_params => %w(a b c),
78
+ :caller_method => 'foo',
79
+ :scope => :instance, :visibility => :public,
80
+ :namespace => P('Foo::Bar'),
81
+ :parser => OpenStruct.new(:file => "(stdin)", :line => 1),
82
+ :statement => OpenStruct.new(:source => 'foo :a, :b, :c'))
83
+ end
84
+
85
+ after(:all) { Registry.clear }
86
+
87
+ describe "#call" do
88
+ it "defines new macro when [new] is provided" do
89
+ tag_parse("@!macro [new] foo\n foo")
90
+ expect(CodeObjects::MacroObject.find('foo').macro_data).to eq 'foo'
91
+ end
92
+
93
+ it "defines new macro if text block is provided" do
94
+ tag_parse("@!macro bar\n bar")
95
+ expect(CodeObjects::MacroObject.find('bar').macro_data).to eq 'bar'
96
+ end
97
+
98
+ it "expands macros and return #expanded_text to tag parser" do
99
+ tag_parse("@!macro [new] foo\n foo")
100
+ expect(tag_parse("@!macro foo").text).to eq 'foo'
101
+ end
102
+
103
+ it "does not expand new macro if docstring is unattached" do
104
+ expect(tag_parse("@!macro [new] foo\n foo").text).not_to eq 'foo'
105
+ end
106
+
107
+ it "expands new anonymous macro even if docstring is unattached" do
108
+ expect(tag_parse("@!macro\n foo").text).to eq 'foo'
109
+ end
110
+
111
+ it "allows multiple macros to be expanded" do
112
+ tag_parse("@!macro [new] foo\n foo")
113
+ tag_parse("@!macro bar\n bar")
114
+ expect(tag_parse("@!macro foo\n@!macro bar").text).to eq "foo\nbar"
115
+ end
116
+
117
+ it "allows anonymous macros" do
118
+ tag_parse("@!macro\n a b c", nil, handler)
119
+ expect(@parser.text).to eq 'a b c'
120
+ end
121
+
122
+ it "expands call_params and caller_method using $N when handler is provided" do
123
+ tag_parse("@!macro\n $1 $2 $3", nil, handler)
124
+ expect(@parser.text).to eq 'a b c'
125
+ end
126
+
127
+ it "attaches macro to method if one exists" do
128
+ tag_parse("@!macro [attach] attached\n $1 $2 $3", nil, handler)
129
+ macro = CodeObjects::MacroObject.find('attached')
130
+ expect(macro.method_object).to eq P('Foo::Bar.foo')
131
+ end
132
+
133
+ it "does not expand new attached macro if defined on class method" do
134
+ baz = CodeObjects::MethodObject.new(P('Foo::Bar'), :baz, :class)
135
+ expect(baz.visibility).to eq :public
136
+ tag_parse("@!macro [attach] attached2\n @!visibility private", baz, handler)
137
+ macro = CodeObjects::MacroObject.find('attached2')
138
+ expect(macro.method_object).to eq P('Foo::Bar.baz')
139
+ expect(baz.visibility).to eq :public
140
+ end
141
+
142
+ it "expands macro if defined on class method and there is no data block" do
143
+ tag_parse("@!macro [new] attached3\n expanded_data")
144
+ baz = CodeObjects::MethodObject.new(P('Foo::Bar'), :baz, :class)
145
+ doc = DocstringParser.new.parse('@!macro attached3', baz, handler).to_docstring
146
+ expect(doc).to eq 'expanded_data'
147
+ end
148
+
149
+ it "does not attach macros to class/modules but creates macro" do
150
+ YARD::Registry.clear
151
+ YARD.parse_string "module Foo; end"
152
+ tag_parse("@!macro [attach] attached4\n $1 $2 $3", YARD::Registry.at('Foo'), handler)
153
+ macro = CodeObjects::MacroObject.find('attached4')
154
+ expect(macro.method_object).to eq nil
155
+ expect(log.io.string).to match(/Attaching macros to non-methods is unsupported/)
156
+ end
157
+
158
+ it "does not attempt to expand macro values if handler = nil" do
159
+ tag_parse("@!macro [attach] xyz\n $1 $2 $3")
160
+ end
161
+ end
162
+ end
163
+
164
+ RSpec.describe YARD::Tags::MethodDirective do
165
+ describe "#call" do
166
+ after { Registry.clear }
167
+
168
+ it "uses entire docstring if no indented data is found" do
169
+ YARD.parse_string <<-eof
170
+ class Foo
171
+ # @!method foo
172
+ # @!method bar
173
+ # @!scope class
174
+ end
175
+ eof
176
+ expect(Registry.at('Foo.foo')).to be_a(CodeObjects::MethodObject)
177
+ expect(Registry.at('Foo.bar')).to be_a(CodeObjects::MethodObject)
178
+ end
179
+
180
+ it "handles indented block text in @!method" do
181
+ YARD.parse_string <<-eof
182
+ # @!method foo(a)
183
+ # Docstring here
184
+ # @return [String] the foo
185
+ # Ignore this
186
+ # @param [String] a
187
+ eof
188
+ foo = Registry.at('#foo')
189
+ expect(foo.docstring).to eq "Docstring here"
190
+ expect(foo.docstring.tag(:return)).not_to be nil
191
+ expect(foo.tag(:param)).to be nil
192
+ end
193
+
194
+ it "executes directives on object in indented block" do
195
+ YARD.parse_string <<-eof
196
+ class Foo
197
+ # @!method foo(a)
198
+ # @!scope class
199
+ # @!visibility private
200
+ # @!method bar
201
+ # Hello
202
+ # Ignore this
203
+ end
204
+ eof
205
+ foo = Registry.at('Foo.foo')
206
+ expect(foo.visibility).to eq :private
207
+ bar = Registry.at('Foo#bar')
208
+ expect(bar.visibility).to eq :public
209
+ end
210
+
211
+ it "is able to define multiple @methods in docstring" do
212
+ YARD.parse_string <<-eof
213
+ class Foo
214
+ # @!method foo1
215
+ # Docstring1
216
+ # @!method foo2
217
+ # Docstring2
218
+ # @!method foo3
219
+ # @!scope class
220
+ # Docstring3
221
+ end
222
+ eof
223
+ foo1 = Registry.at('Foo#foo1')
224
+ foo2 = Registry.at('Foo#foo2')
225
+ foo3 = Registry.at('Foo.foo3')
226
+ expect(foo1.docstring).to eq 'Docstring1'
227
+ expect(foo2.docstring).to eq 'Docstring2'
228
+ expect(foo3.docstring).to eq 'Docstring3'
229
+ end
230
+
231
+ it "defines the method inside namespace if attached to namespace object" do
232
+ YARD.parse_string <<-eof
233
+ module Foo
234
+ # @!method foo
235
+ # Docstring1
236
+ # @!method bar
237
+ # Docstring2
238
+ class Bar
239
+ end
240
+ end
241
+ eof
242
+ expect(Registry.at('Foo::Bar#foo').docstring).to eq 'Docstring1'
243
+ expect(Registry.at('Foo::Bar#bar').docstring).to eq 'Docstring2'
244
+ end
245
+
246
+ it "sets scope to class if signature has 'self.' prefix" do
247
+ YARD.parse_string <<-eof
248
+ # @!method self.foo
249
+ # @!method self. bar
250
+ # @!method self.baz()
251
+ class Foo
252
+ end
253
+ eof
254
+ %w(foo bar baz).each do |name|
255
+ expect(Registry.at("Foo.#{name}")).to be_a(CodeObjects::MethodObject)
256
+ end
257
+ end
258
+
259
+ it "defines parameters from signature" do
260
+ YARD.parse_string <<-eof
261
+ # @!method foo(a, b, c = nil)
262
+ eof
263
+ expect(Registry.at('#foo').parameters).to eq [['a', nil], ['b', nil], ['c', 'nil']]
264
+ end
265
+
266
+ it "is able to define method with module scope (module function)" do
267
+ YARD.parse_string <<-eof
268
+ # @!method foo
269
+ # @!scope module
270
+ # This is a docstring
271
+ # @return [Boolean] whether this is true
272
+ class Foo
273
+ end
274
+ eof
275
+ foo_c = Registry.at('Foo.foo')
276
+ foo_i = Registry.at('Foo#foo')
277
+ expect(foo_c).not_to be nil
278
+ expect(foo_i).not_to be nil
279
+ expect(foo_c).to be_module_function
280
+ expect(foo_c.docstring).to eq foo_i.docstring
281
+ expect(foo_c.tag(:return).text).to eq foo_i.tag(:return).text
282
+ end
283
+ end
284
+ end
285
+
286
+ RSpec.describe YARD::Tags::AttributeDirective do
287
+ describe "#call" do
288
+ after { Registry.clear }
289
+
290
+ it "uses entire docstring if no indented data is found" do
291
+ YARD.parse_string <<-eof
292
+ class Foo
293
+ # @!attribute foo
294
+ # @!attribute bar
295
+ # @!scope class
296
+ end
297
+ eof
298
+ expect(Registry.at('Foo.foo')).to be_reader
299
+ expect(Registry.at('Foo.bar')).to be_reader
300
+ end
301
+
302
+ it "handles indented block in @!attribute" do
303
+ YARD.parse_string <<-eof
304
+ # @!attribute foo
305
+ # Docstring here
306
+ # @return [String] the foo
307
+ # Ignore this
308
+ # @param [String] a
309
+ eof
310
+ foo = Registry.at('#foo')
311
+ expect(foo.is_attribute?).to be true
312
+ expect(foo.docstring).to eq "Docstring here"
313
+ expect(foo.docstring.tag(:return)).not_to be nil
314
+ expect(foo.tag(:param)).to be nil
315
+ end
316
+
317
+ it "is able to define multiple @attributes in docstring" do
318
+ YARD.parse_string <<-eof
319
+ class Foo
320
+ # @!attribute [r] foo1
321
+ # Docstring1
322
+ # @!attribute [w] foo2
323
+ # Docstring2
324
+ # @!attribute foo3
325
+ # @!scope class
326
+ # Docstring3
327
+ end
328
+ eof
329
+ foo1 = Registry.at('Foo#foo1')
330
+ foo2 = Registry.at('Foo#foo2=')
331
+ foo3 = Registry.at('Foo.foo3')
332
+ foo4 = Registry.at('Foo.foo3=')
333
+ expect(foo1).to be_reader
334
+ expect(foo2).to be_writer
335
+ expect(foo3).to be_reader
336
+ expect(foo1.docstring).to eq 'Docstring1'
337
+ expect(foo2.docstring).to eq 'Docstring2'
338
+ expect(foo3.docstring).to eq 'Docstring3'
339
+ expect(foo4).to be_writer
340
+ expect(foo1.attr_info[:write]).to be nil
341
+ expect(foo2.attr_info[:read]).to be nil
342
+ end
343
+
344
+ it "defines the attr inside namespace if attached to namespace object" do
345
+ YARD.parse_string <<-eof
346
+ module Foo
347
+ # @!attribute [r] foo
348
+ # @!attribute [r] bar
349
+ class Bar
350
+ end
351
+ end
352
+ eof
353
+ expect(Registry.at('Foo::Bar#foo')).to be_reader
354
+ expect(Registry.at('Foo::Bar#bar')).to be_reader
355
+ end
356
+ end
357
+
358
+ it "sets scope to class if signature has 'self.' prefix" do
359
+ YARD.parse_string <<-eof
360
+ # @!attribute self.foo
361
+ # @!attribute self. bar
362
+ # @!attribute self.baz
363
+ class Foo
364
+ end
365
+ eof
366
+ %w(foo bar baz).each do |name|
367
+ expect(Registry.at("Foo.#{name}")).to be_reader
368
+ end
369
+ end
370
+ end
371
+
372
+ RSpec.describe YARD::Tags::ScopeDirective do
373
+ describe "#call" do
374
+ after { Registry.clear }
375
+
376
+ it "sets state on tag parser if object = nil" do
377
+ tag_parse("@!scope class")
378
+ expect(@parser.state.scope).to eq :class
379
+ end
380
+
381
+ it "sets state on tag parser if object is namespace" do
382
+ object = CodeObjects::ClassObject.new(:root, 'Foo')
383
+ tag_parse("@!scope class", object)
384
+ expect(object[:scope]).to be nil
385
+ expect(@parser.state.scope).to eq :class
386
+ end
387
+
388
+ it "sets scope on object if object is a method object" do
389
+ object = CodeObjects::MethodObject.new(:root, 'foo')
390
+ tag_parse("@!scope class", object)
391
+ expect(object.scope).to eq :class
392
+ end
393
+
394
+ %w(class instance module).each do |type|
395
+ it "allows #{type} as value" do
396
+ tag_parse("@!scope #{type}")
397
+ expect(@parser.state.scope).to eq type.to_sym
398
+ end
399
+ end
400
+
401
+ %w(invalid foo FOO CLASS INSTANCE).each do |type|
402
+ it "does not allow #{type} as value" do
403
+ tag_parse("@!scope #{type}")
404
+ expect(@parser.state.scope).to be nil
405
+ end
406
+ end
407
+ end
408
+ end
409
+
410
+ RSpec.describe YARD::Tags::VisibilityDirective do
411
+ describe "#call" do
412
+ after { Registry.clear }
413
+
414
+ it "sets visibility on tag parser if object = nil" do
415
+ tag_parse("@!visibility private")
416
+ expect(@parser.state.visibility).to eq :private
417
+ end
418
+
419
+ it "sets state on tag parser if object is namespace" do
420
+ object = CodeObjects::ClassObject.new(:root, 'Foo')
421
+ tag_parse("@!visibility protected", object)
422
+ expect(object.visibility).to eq :protected
423
+ expect(@parser.state.visibility).to be nil
424
+ end
425
+
426
+ it "sets visibility on object if object is a method object" do
427
+ object = CodeObjects::MethodObject.new(:root, 'foo')
428
+ tag_parse("@!visibility private", object)
429
+ expect(object.visibility).to eq :private
430
+ end
431
+
432
+ %w(public private protected).each do |type|
433
+ it "allows #{type} as value" do
434
+ tag_parse("@!visibility #{type}")
435
+ expect(@parser.state.visibility).to eq type.to_sym
436
+ end
437
+ end
438
+
439
+ %w(invalid foo FOO PRIVATE INSTANCE).each do |type|
440
+ it "does not allow #{type} as value" do
441
+ tag_parse("@!visibility #{type}")
442
+ expect(@parser.state.visibility).to be nil
443
+ end
444
+ end
445
+
446
+ it "updates visibility on future methods" do
447
+ Registry.clear
448
+ YARD.parse_string <<-eof
449
+ class Foo
450
+ # @!visibility private
451
+
452
+
453
+ def foo; end
454
+ def bar; end
455
+ def baz; end
456
+ end
457
+ eof
458
+ %w(foo bar baz).each do |name|
459
+ expect(Registry.at("Foo##{name}").visibility).to eq :private
460
+ end
461
+ end if YARD::Parser::SourceParser.parser_type == :ruby
462
+ end
463
+ end