yard 0.9.5 → 0.9.6
Sign up to get free protection for your applications and to get access to all the features.
Potentially problematic release.
This version of yard might be problematic. Click here for more details.
- checksums.yaml +4 -4
- data/.yardopts +0 -0
- data/CHANGELOG.md +20 -0
- data/LEGAL +0 -0
- data/LICENSE +0 -0
- data/README.md +70 -35
- data/Rakefile +10 -39
- data/benchmarks/builtins_vs_eval.rb +9 -8
- data/benchmarks/concat_vs_join.rb +1 -0
- data/benchmarks/erb_vs_erubis.rb +3 -2
- data/benchmarks/format_args.rb +1 -0
- data/benchmarks/generation.rb +2 -1
- data/benchmarks/marshal_vs_dbm.rb +2 -1
- data/benchmarks/parsing.rb +1 -1
- data/benchmarks/pathname_vs_string.rb +1 -0
- data/benchmarks/rdoc_vs_yardoc.rb +2 -1
- data/benchmarks/registry_store_types.rb +1 -0
- data/benchmarks/ri_vs_yri.rb +1 -0
- data/benchmarks/ripper_parser.rb +2 -1
- data/benchmarks/splat_vs_flatten.rb +4 -3
- data/benchmarks/template_erb.rb +2 -1
- data/benchmarks/template_format.rb +1 -0
- data/benchmarks/template_profile.rb +4 -3
- data/benchmarks/yri_cache.rb +2 -1
- data/bin/yard +2 -1
- data/bin/yardoc +2 -1
- data/bin/yri +2 -1
- data/docs/CodeObjects.md +0 -0
- data/docs/GettingStarted.md +0 -0
- data/docs/Handlers.md +0 -0
- data/docs/Overview.md +0 -0
- data/docs/Parser.md +0 -0
- data/docs/Tags.md +0 -0
- data/docs/TagsArch.md +0 -0
- data/docs/Templates.md +0 -0
- data/docs/WhatsNew.md +0 -0
- data/docs/images/code-objects-class-diagram.png +0 -0
- data/docs/images/tags-class-diagram.png +0 -0
- data/docs/templates/default/fulldoc/html/full_list_tag.erb +0 -0
- data/docs/templates/default/fulldoc/html/setup.rb +1 -1
- data/docs/templates/default/layout/html/setup.rb +1 -0
- data/docs/templates/default/layout/html/tag_list.erb +0 -0
- data/docs/templates/default/yard_tags/html/list.erb +0 -0
- data/docs/templates/default/yard_tags/html/setup.rb +18 -19
- data/docs/templates/plugin.rb +18 -13
- data/lib/rubygems_plugin.rb +1 -0
- data/lib/yard.rb +5 -6
- data/lib/yard/autoload.rb +4 -0
- data/lib/yard/cli/command.rb +3 -2
- data/lib/yard/cli/command_parser.rb +4 -3
- data/lib/yard/cli/config.rb +5 -4
- data/lib/yard/cli/diff.rb +39 -39
- data/lib/yard/cli/display.rb +2 -1
- data/lib/yard/cli/gems.rb +6 -5
- data/lib/yard/cli/graph.rb +4 -5
- data/lib/yard/cli/help.rb +4 -2
- data/lib/yard/cli/i18n.rb +2 -1
- data/lib/yard/cli/list.rb +2 -1
- data/lib/yard/cli/markup_types.rb +4 -5
- data/lib/yard/cli/server.rb +27 -24
- data/lib/yard/cli/stats.rb +20 -16
- data/lib/yard/cli/yardoc.rb +22 -19
- data/lib/yard/cli/yardopts_command.rb +3 -2
- data/lib/yard/cli/yri.rb +26 -25
- data/lib/yard/code_objects/base.rb +41 -37
- data/lib/yard/code_objects/class_object.rb +3 -2
- data/lib/yard/code_objects/class_variable_object.rb +2 -1
- data/lib/yard/code_objects/constant_object.rb +2 -1
- data/lib/yard/code_objects/extended_method_object.rb +2 -1
- data/lib/yard/code_objects/extra_file_object.rb +1 -0
- data/lib/yard/code_objects/macro_object.rb +10 -10
- data/lib/yard/code_objects/method_object.rb +15 -13
- data/lib/yard/code_objects/module_object.rb +1 -0
- data/lib/yard/code_objects/namespace_mapper.rb +1 -0
- data/lib/yard/code_objects/namespace_object.rb +2 -5
- data/lib/yard/code_objects/proxy.rb +35 -53
- data/lib/yard/code_objects/root_object.rb +3 -1
- data/lib/yard/config.rb +8 -9
- data/lib/yard/core_ext/array.rb +1 -0
- data/lib/yard/core_ext/file.rb +4 -3
- data/lib/yard/core_ext/hash.rb +3 -2
- data/lib/yard/core_ext/insertion.rb +7 -4
- data/lib/yard/core_ext/module.rb +2 -1
- data/lib/yard/core_ext/string.rb +5 -4
- data/lib/yard/core_ext/symbol_hash.rb +8 -6
- data/lib/yard/docstring.rb +26 -15
- data/lib/yard/docstring_parser.rb +61 -61
- data/lib/yard/gem_index.rb +17 -0
- data/lib/yard/globals.rb +6 -2
- data/lib/yard/handlers/base.rb +22 -23
- data/lib/yard/handlers/c/alias_handler.rb +3 -2
- data/lib/yard/handlers/c/attribute_handler.rb +2 -2
- data/lib/yard/handlers/c/base.rb +13 -13
- data/lib/yard/handlers/c/class_handler.rb +1 -0
- data/lib/yard/handlers/c/constant_handler.rb +3 -2
- data/lib/yard/handlers/c/handler_methods.rb +24 -25
- data/lib/yard/handlers/c/init_handler.rb +4 -2
- data/lib/yard/handlers/c/method_handler.rb +7 -6
- data/lib/yard/handlers/c/mixin_handler.rb +3 -1
- data/lib/yard/handlers/c/module_handler.rb +1 -0
- data/lib/yard/handlers/c/override_comment_handler.rb +2 -1
- data/lib/yard/handlers/c/path_handler.rb +1 -0
- data/lib/yard/handlers/c/struct_handler.rb +1 -0
- data/lib/yard/handlers/c/symbol_handler.rb +2 -1
- data/lib/yard/handlers/processor.rb +14 -15
- data/lib/yard/handlers/ruby/alias_handler.rb +4 -2
- data/lib/yard/handlers/ruby/attribute_handler.rb +11 -6
- data/lib/yard/handlers/ruby/base.rb +5 -4
- data/lib/yard/handlers/ruby/class_condition_handler.rb +4 -3
- data/lib/yard/handlers/ruby/class_handler.rb +7 -9
- data/lib/yard/handlers/ruby/class_variable_handler.rb +2 -1
- data/lib/yard/handlers/ruby/comment_handler.rb +1 -0
- data/lib/yard/handlers/ruby/constant_handler.rb +9 -5
- data/lib/yard/handlers/ruby/decorator_handler_methods.rb +15 -28
- data/lib/yard/handlers/ruby/dsl_handler.rb +1 -0
- data/lib/yard/handlers/ruby/dsl_handler_methods.rb +7 -6
- data/lib/yard/handlers/ruby/exception_handler.rb +1 -0
- data/lib/yard/handlers/ruby/extend_handler.rb +1 -0
- data/lib/yard/handlers/ruby/legacy/alias_handler.rb +6 -4
- data/lib/yard/handlers/ruby/legacy/attribute_handler.rb +12 -7
- data/lib/yard/handlers/ruby/legacy/base.rb +21 -26
- data/lib/yard/handlers/ruby/legacy/class_condition_handler.rb +7 -7
- data/lib/yard/handlers/ruby/legacy/class_handler.rb +7 -5
- data/lib/yard/handlers/ruby/legacy/class_variable_handler.rb +2 -1
- data/lib/yard/handlers/ruby/legacy/comment_handler.rb +1 -0
- data/lib/yard/handlers/ruby/legacy/constant_handler.rb +2 -1
- data/lib/yard/handlers/ruby/legacy/dsl_handler.rb +1 -0
- data/lib/yard/handlers/ruby/legacy/exception_handler.rb +2 -1
- data/lib/yard/handlers/ruby/legacy/extend_handler.rb +2 -1
- data/lib/yard/handlers/ruby/legacy/method_handler.rb +11 -6
- data/lib/yard/handlers/ruby/legacy/mixin_handler.rb +5 -5
- data/lib/yard/handlers/ruby/legacy/module_function_handler.rb +2 -1
- data/lib/yard/handlers/ruby/legacy/module_handler.rb +2 -1
- data/lib/yard/handlers/ruby/legacy/private_class_method_handler.rb +2 -1
- data/lib/yard/handlers/ruby/legacy/private_constant_handler.rb +2 -1
- data/lib/yard/handlers/ruby/legacy/visibility_handler.rb +3 -2
- data/lib/yard/handlers/ruby/legacy/yield_handler.rb +1 -0
- data/lib/yard/handlers/ruby/method_condition_handler.rb +2 -1
- data/lib/yard/handlers/ruby/method_handler.rb +9 -11
- data/lib/yard/handlers/ruby/mixin_handler.rb +2 -1
- data/lib/yard/handlers/ruby/module_function_handler.rb +2 -1
- data/lib/yard/handlers/ruby/module_handler.rb +2 -1
- data/lib/yard/handlers/ruby/private_class_method_handler.rb +1 -0
- data/lib/yard/handlers/ruby/private_constant_handler.rb +2 -2
- data/lib/yard/handlers/ruby/public_class_method_handler.rb +1 -0
- data/lib/yard/handlers/ruby/struct_handler_methods.rb +5 -4
- data/lib/yard/handlers/ruby/visibility_handler.rb +1 -0
- data/lib/yard/handlers/ruby/yield_handler.rb +1 -0
- data/lib/yard/i18n/locale.rb +1 -0
- data/lib/yard/i18n/message.rb +5 -4
- data/lib/yard/i18n/messages.rb +2 -1
- data/lib/yard/i18n/po_parser.rb +5 -4
- data/lib/yard/i18n/pot_generator.rb +8 -8
- data/lib/yard/i18n/text.rb +9 -9
- data/lib/yard/logging.rb +9 -6
- data/lib/yard/options.rb +8 -7
- data/lib/yard/parser/base.rb +3 -2
- data/lib/yard/parser/c/c_parser.rb +22 -21
- data/lib/yard/parser/c/comment_parser.rb +9 -6
- data/lib/yard/parser/c/statement.rb +1 -0
- data/lib/yard/parser/ruby/ast_node.rb +20 -18
- data/lib/yard/parser/ruby/legacy/ruby_lex.rb +99 -122
- data/lib/yard/parser/ruby/legacy/ruby_parser.rb +3 -2
- data/lib/yard/parser/ruby/legacy/statement.rb +4 -3
- data/lib/yard/parser/ruby/legacy/statement_list.rb +52 -42
- data/lib/yard/parser/ruby/legacy/token_list.rb +16 -13
- data/lib/yard/parser/ruby/ruby_parser.rb +87 -63
- data/lib/yard/parser/ruby/token_resolver.rb +156 -0
- data/lib/yard/parser/source_parser.rb +28 -20
- data/lib/yard/rake/yardoc_task.rb +3 -3
- data/lib/yard/registry.rb +14 -16
- data/lib/yard/registry_resolver.rb +36 -20
- data/lib/yard/registry_store.rb +19 -15
- data/lib/yard/rubygems/backports.rb +2 -0
- data/lib/yard/rubygems/backports/LICENSE.txt +0 -0
- data/lib/yard/rubygems/backports/MIT.txt +0 -0
- data/lib/yard/rubygems/backports/gem.rb +1 -0
- data/lib/yard/rubygems/backports/source_index.rb +25 -30
- data/lib/yard/rubygems/doc_manager.rb +10 -8
- data/lib/yard/rubygems/hook.rb +11 -18
- data/lib/yard/rubygems/specification.rb +1 -0
- data/lib/yard/serializers/base.rb +5 -2
- data/lib/yard/serializers/file_system_serializer.rb +7 -6
- data/lib/yard/serializers/process_serializer.rb +2 -2
- data/lib/yard/serializers/stdout_serializer.rb +8 -6
- data/lib/yard/serializers/yardoc_serializer.rb +31 -26
- data/lib/yard/server.rb +2 -1
- data/lib/yard/server/adapter.rb +1 -1
- data/lib/yard/server/commands/base.rb +15 -2
- data/lib/yard/server/commands/display_file_command.rb +2 -2
- data/lib/yard/server/commands/display_object_command.rb +6 -3
- data/lib/yard/server/commands/frames_command.rb +1 -0
- data/lib/yard/server/commands/library_command.rb +50 -14
- data/lib/yard/server/commands/library_index_command.rb +5 -4
- data/lib/yard/server/commands/list_command.rb +1 -0
- data/lib/yard/server/commands/root_request_command.rb +1 -0
- data/lib/yard/server/commands/search_command.rb +17 -16
- data/lib/yard/server/commands/static_file_command.rb +2 -1
- data/lib/yard/server/commands/static_file_helpers.rb +23 -14
- data/lib/yard/server/doc_server_helper.rb +15 -1
- data/lib/yard/server/doc_server_serializer.rb +3 -5
- data/lib/yard/server/library_version.rb +44 -22
- data/lib/yard/server/rack_adapter.rb +2 -1
- data/lib/yard/server/router.rb +15 -14
- data/lib/yard/server/static_caching.rb +1 -0
- data/lib/yard/server/templates/default/fulldoc/html/css/custom.css +0 -0
- data/lib/yard/server/templates/default/fulldoc/html/images/processing.gif +0 -0
- data/lib/yard/server/templates/default/fulldoc/html/js/autocomplete.js +0 -0
- data/lib/yard/server/templates/default/layout/html/breadcrumb.erb +0 -0
- data/lib/yard/server/templates/default/layout/html/script_setup.erb +0 -0
- data/lib/yard/server/templates/default/layout/html/setup.rb +2 -1
- data/lib/yard/server/templates/default/method_details/html/permalink.erb +0 -0
- data/lib/yard/server/templates/default/method_details/html/setup.rb +1 -0
- data/lib/yard/server/templates/doc_server/library_list/html/headers.erb +2 -2
- data/lib/yard/server/templates/doc_server/library_list/html/library_list.erb +0 -0
- data/lib/yard/server/templates/doc_server/library_list/html/listing.erb +1 -1
- data/lib/yard/server/templates/doc_server/library_list/html/setup.rb +2 -1
- data/lib/yard/server/templates/doc_server/library_list/html/title.erb +0 -0
- data/lib/yard/server/templates/doc_server/processing/html/processing.erb +4 -4
- data/lib/yard/server/templates/doc_server/processing/html/setup.rb +2 -1
- data/lib/yard/server/templates/doc_server/search/html/search.erb +0 -0
- data/lib/yard/server/templates/doc_server/search/html/setup.rb +2 -1
- data/lib/yard/server/webrick_adapter.rb +4 -2
- data/lib/yard/tags/default_factory.rb +19 -13
- data/lib/yard/tags/default_tag.rb +2 -1
- data/lib/yard/tags/directives.rb +17 -19
- data/lib/yard/tags/library.rb +9 -6
- data/lib/yard/tags/option_tag.rb +1 -0
- data/lib/yard/tags/overload_tag.rb +6 -4
- data/lib/yard/tags/ref_tag.rb +1 -0
- data/lib/yard/tags/ref_tag_list.rb +2 -1
- data/lib/yard/tags/tag.rb +16 -2
- data/lib/yard/tags/tag_format_error.rb +3 -2
- data/lib/yard/tags/types_explainer.rb +160 -0
- data/lib/yard/templates/engine.rb +3 -2
- data/lib/yard/templates/erb_cache.rb +3 -2
- data/lib/yard/templates/helpers/base_helper.rb +9 -6
- data/lib/yard/templates/helpers/filter_helper.rb +1 -0
- data/lib/yard/templates/helpers/html_helper.rb +65 -37
- data/lib/yard/templates/helpers/html_syntax_highlight_helper.rb +25 -7
- data/lib/yard/templates/helpers/markup/rdoc_markdown.rb +2 -1
- data/lib/yard/templates/helpers/markup/rdoc_markup.rb +10 -7
- data/lib/yard/templates/helpers/markup_helper.rb +12 -13
- data/lib/yard/templates/helpers/method_helper.rb +8 -7
- data/lib/yard/templates/helpers/module_helper.rb +1 -0
- data/lib/yard/templates/helpers/text_helper.rb +16 -11
- data/lib/yard/templates/helpers/uml_helper.rb +2 -1
- data/lib/yard/templates/section.rb +3 -4
- data/lib/yard/templates/template.rb +18 -11
- data/lib/yard/templates/template_options.rb +1 -0
- data/lib/yard/verifier.rb +2 -0
- data/lib/yard/version.rb +2 -1
- data/spec/cli/command_parser_spec.rb +7 -7
- data/spec/cli/command_spec.rb +2 -2
- data/spec/cli/config_spec.rb +3 -4
- data/spec/cli/diff_spec.rb +7 -9
- data/spec/cli/display_spec.rb +2 -2
- data/spec/cli/gems_spec.rb +11 -11
- data/spec/cli/graph_spec.rb +4 -3
- data/spec/cli/help_spec.rb +3 -3
- data/spec/cli/i18n_spec.rb +3 -3
- data/spec/cli/list_spec.rb +2 -2
- data/spec/cli/markup_types_spec.rb +2 -2
- data/spec/cli/server_spec.rb +21 -18
- data/spec/cli/stats_spec.rb +23 -22
- data/spec/cli/yardoc_spec.rb +49 -47
- data/spec/cli/yri_spec.rb +6 -6
- data/spec/code_objects/base_spec.rb +6 -4
- data/spec/code_objects/class_object_spec.rb +10 -9
- data/spec/code_objects/code_object_list_spec.rb +3 -2
- data/spec/code_objects/constants_spec.rb +17 -6
- data/spec/code_objects/extra_file_object_spec.rb +6 -5
- data/spec/code_objects/macro_object_spec.rb +5 -3
- data/spec/code_objects/method_object_spec.rb +6 -5
- data/spec/code_objects/module_object_spec.rb +3 -2
- data/spec/code_objects/namespace_object_spec.rb +10 -9
- data/spec/code_objects/proxy_spec.rb +9 -8
- data/spec/code_objects/spec_helper.rb +2 -2
- data/spec/config_spec.rb +9 -14
- data/spec/core_ext/array_spec.rb +2 -3
- data/spec/core_ext/file_spec.rb +3 -3
- data/spec/core_ext/hash_spec.rb +5 -5
- data/spec/core_ext/insertion_spec.rb +2 -2
- data/spec/core_ext/module_spec.rb +3 -3
- data/spec/core_ext/string_spec.rb +5 -5
- data/spec/core_ext/symbol_hash_spec.rb +8 -8
- data/spec/docstring_parser_spec.rb +6 -7
- data/spec/docstring_spec.rb +30 -3
- data/spec/examples.txt +1848 -0
- data/spec/handlers/alias_handler_spec.rb +2 -1
- data/spec/handlers/attribute_handler_spec.rb +7 -5
- data/spec/handlers/base_spec.rb +9 -8
- data/spec/handlers/c/alias_handler_spec.rb +2 -1
- data/spec/handlers/c/attribute_handler_spec.rb +2 -1
- data/spec/handlers/c/class_handler_spec.rb +2 -1
- data/spec/handlers/c/constant_handler_spec.rb +5 -4
- data/spec/handlers/c/init_handler_spec.rb +2 -1
- data/spec/handlers/c/method_handler_spec.rb +2 -1
- data/spec/handlers/c/mixin_handler_spec.rb +2 -1
- data/spec/handlers/c/module_handler_spec.rb +2 -1
- data/spec/handlers/c/override_comment_handler_spec.rb +2 -1
- data/spec/handlers/c/path_handler_spec.rb +2 -1
- data/spec/handlers/c/spec_helper.rb +1 -1
- data/spec/handlers/c/struct_handler_spec.rb +3 -2
- data/spec/handlers/class_condition_handler_spec.rb +3 -2
- data/spec/handlers/class_handler_spec.rb +3 -2
- data/spec/handlers/class_method_handler_shared_examples.rb +9 -8
- data/spec/handlers/class_variable_handler_spec.rb +3 -2
- data/spec/handlers/constant_handler_spec.rb +28 -3
- data/spec/handlers/decorator_handler_methods_spec.rb +47 -59
- data/spec/handlers/dsl_handler_spec.rb +3 -2
- data/spec/handlers/examples/alias_handler_001.rb.txt +0 -0
- data/spec/handlers/examples/attribute_handler_001.rb.txt +0 -0
- data/spec/handlers/examples/class_condition_handler_001.rb.txt +0 -0
- data/spec/handlers/examples/class_handler_001.rb.txt +0 -0
- data/spec/handlers/examples/class_variable_handler_001.rb.txt +0 -0
- data/spec/handlers/examples/constant_handler_001.rb.txt +0 -0
- data/spec/handlers/examples/dsl_handler_001.rb.txt +0 -0
- data/spec/handlers/examples/exception_handler_001.rb.txt +0 -0
- data/spec/handlers/examples/extend_handler_001.rb.txt +0 -0
- data/spec/handlers/examples/method_condition_handler_001.rb.txt +0 -0
- data/spec/handlers/examples/method_handler_001.rb.txt +2 -0
- data/spec/handlers/examples/mixin_handler_001.rb.txt +0 -0
- data/spec/handlers/examples/module_handler_001.rb.txt +0 -0
- data/spec/handlers/examples/private_constant_handler_001.rb.txt +0 -0
- data/spec/handlers/examples/process_handler_001.rb.txt +0 -0
- data/spec/handlers/examples/visibility_handler_001.rb.txt +0 -0
- data/spec/handlers/examples/yield_handler_001.rb.txt +0 -0
- data/spec/handlers/exception_handler_spec.rb +3 -2
- data/spec/handlers/extend_handler_spec.rb +2 -1
- data/spec/handlers/legacy_base_spec.rb +5 -5
- data/spec/handlers/method_condition_handler_spec.rb +3 -2
- data/spec/handlers/method_handler_spec.rb +7 -1
- data/spec/handlers/mixin_handler_spec.rb +3 -2
- data/spec/handlers/module_function_handler_spec.rb +2 -1
- data/spec/handlers/module_handler_spec.rb +3 -2
- data/spec/handlers/private_class_method_handler_spec.rb +2 -1
- data/spec/handlers/private_constant_handler_spec.rb +2 -1
- data/spec/handlers/processor_spec.rb +2 -1
- data/spec/handlers/public_class_method_handler_spec.rb +2 -1
- data/spec/handlers/ruby/base_spec.rb +6 -5
- data/spec/handlers/ruby/legacy/base_spec.rb +4 -4
- data/spec/handlers/spec_helper.rb +3 -3
- data/spec/handlers/visibility_handler_spec.rb +3 -2
- data/spec/handlers/yield_handler_spec.rb +3 -2
- data/spec/i18n/locale_spec.rb +3 -3
- data/spec/i18n/message_spec.rb +2 -2
- data/spec/i18n/messages_spec.rb +3 -3
- data/spec/i18n/pot_generator_spec.rb +34 -34
- data/spec/i18n/text_spec.rb +16 -12
- data/spec/logging_spec.rb +2 -2
- data/spec/options_spec.rb +9 -9
- data/spec/parser/base_spec.rb +2 -2
- data/spec/parser/c_parser_spec.rb +5 -4
- data/spec/parser/examples/array.c.txt +0 -0
- data/spec/parser/examples/example1.rb.txt +0 -0
- data/spec/parser/examples/extrafile.c.txt +0 -0
- data/spec/parser/examples/multifile.c.txt +0 -0
- data/spec/parser/examples/override.c.txt +0 -0
- data/spec/parser/examples/parse_in_order_001.rb.txt +0 -0
- data/spec/parser/examples/parse_in_order_002.rb.txt +0 -0
- data/spec/parser/examples/tag_handler_001.rb.txt +0 -0
- data/spec/parser/ruby/ast_node_spec.rb +7 -7
- data/spec/parser/ruby/legacy/statement_list_spec.rb +7 -7
- data/spec/parser/ruby/legacy/token_list_spec.rb +4 -4
- data/spec/parser/ruby/ruby_parser_spec.rb +42 -20
- data/spec/parser/ruby/token_resolver_spec.rb +165 -0
- data/spec/parser/source_parser_spec.rb +18 -18
- data/spec/parser/tag_parsing_spec.rb +2 -2
- data/spec/rake/yardoc_task_spec.rb +4 -4
- data/spec/registry_spec.rb +62 -56
- data/spec/registry_store_spec.rb +7 -7
- data/spec/rubygems/doc_manager_spec.rb +2 -2
- data/spec/serializers/data/serialized_yardoc/checksums +0 -0
- data/spec/serializers/data/serialized_yardoc/objects/Foo.dat +0 -0
- data/spec/serializers/data/serialized_yardoc/objects/Foo/bar_i.dat +0 -0
- data/spec/serializers/data/serialized_yardoc/objects/Foo/baz_i.dat +0 -0
- data/spec/serializers/data/serialized_yardoc/objects/root.dat +0 -0
- data/spec/serializers/data/serialized_yardoc/proxy_types +0 -0
- data/spec/serializers/file_system_serializer_spec.rb +8 -7
- data/spec/serializers/spec_helper.rb +2 -2
- data/spec/serializers/yardoc_serializer_spec.rb +5 -4
- data/spec/server/adapter_spec.rb +3 -2
- data/spec/server/commands/base_spec.rb +15 -11
- data/spec/server/commands/library_command_spec.rb +2 -2
- data/spec/server/doc_server_helper_spec.rb +4 -3
- data/spec/server/doc_server_serializer_spec.rb +3 -2
- data/spec/server/rack_adapter_spec.rb +3 -2
- data/spec/server/router_spec.rb +3 -2
- data/spec/server/spec_helper.rb +2 -2
- data/spec/server/static_caching_spec.rb +4 -3
- data/spec/server/webrick_servlet_spec.rb +5 -4
- data/spec/server_spec.rb +3 -3
- data/spec/spec_helper.rb +94 -21
- data/spec/tags/default_factory_spec.rb +10 -4
- data/spec/tags/default_tag_spec.rb +3 -3
- data/spec/tags/directives_spec.rb +12 -12
- data/spec/tags/library_spec.rb +16 -2
- data/spec/tags/overload_tag_spec.rb +4 -4
- data/spec/tags/ref_tag_list_spec.rb +3 -3
- data/spec/tags/types_explainer_spec.rb +200 -0
- data/spec/templates/class_spec.rb +2 -1
- data/spec/templates/constant_spec.rb +3 -2
- data/spec/templates/engine_spec.rb +4 -3
- data/spec/templates/examples/class001.html +0 -0
- data/spec/templates/examples/class001.txt +0 -0
- data/spec/templates/examples/class002.html +0 -0
- data/spec/templates/examples/constant001.txt +0 -0
- data/spec/templates/examples/constant002.txt +0 -0
- data/spec/templates/examples/constant003.txt +0 -0
- data/spec/templates/examples/method001.html +0 -0
- data/spec/templates/examples/method001.txt +0 -0
- data/spec/templates/examples/method002.html +0 -0
- data/spec/templates/examples/method002.txt +0 -0
- data/spec/templates/examples/method003.html +0 -0
- data/spec/templates/examples/method003.txt +0 -0
- data/spec/templates/examples/method004.html +0 -0
- data/spec/templates/examples/method004.txt +0 -0
- data/spec/templates/examples/method005.html +0 -0
- data/spec/templates/examples/method005.txt +0 -0
- data/spec/templates/examples/method006.html +108 -0
- data/spec/templates/examples/method006.txt +20 -0
- data/spec/templates/examples/module001.dot +0 -0
- data/spec/templates/examples/module001.html +0 -0
- data/spec/templates/examples/module001.txt +0 -0
- data/spec/templates/examples/module002.html +0 -0
- data/spec/templates/examples/module003.html +0 -0
- data/spec/templates/examples/module004.html +0 -0
- data/spec/templates/examples/tag001.txt +0 -0
- data/spec/templates/helpers/base_helper_spec.rb +5 -5
- data/spec/templates/helpers/html_helper_spec.rb +64 -60
- data/spec/templates/helpers/html_syntax_highlight_helper_spec.rb +17 -6
- data/spec/templates/helpers/markup/rdoc_markup_spec.rb +11 -13
- data/spec/templates/helpers/markup_helper_spec.rb +2 -2
- data/spec/templates/helpers/method_helper_spec.rb +3 -3
- data/spec/templates/helpers/module_helper_spec.rb +2 -2
- data/spec/templates/helpers/shared_signature_examples.rb +2 -1
- data/spec/templates/helpers/text_helper_spec.rb +7 -6
- data/spec/templates/method_spec.rb +18 -2
- data/spec/templates/module_spec.rb +4 -3
- data/spec/templates/onefile_spec.rb +8 -6
- data/spec/templates/section_spec.rb +3 -2
- data/spec/templates/spec_helper.rb +5 -2
- data/spec/templates/tag_spec.rb +3 -2
- data/spec/templates/template_spec.rb +15 -14
- data/spec/verifier_spec.rb +3 -3
- data/templates/default/class/dot/setup.rb +2 -1
- data/templates/default/class/dot/superklass.erb +0 -0
- data/templates/default/class/html/constructor_details.erb +0 -0
- data/templates/default/class/html/setup.rb +2 -1
- data/templates/default/class/html/subclasses.erb +0 -0
- data/templates/default/class/setup.rb +6 -6
- data/templates/default/class/text/setup.rb +2 -1
- data/templates/default/class/text/subclasses.erb +0 -0
- data/templates/default/constant/text/header.erb +0 -0
- data/templates/default/constant/text/setup.rb +1 -0
- data/templates/default/docstring/html/abstract.erb +0 -0
- data/templates/default/docstring/html/deprecated.erb +0 -0
- data/templates/default/docstring/html/index.erb +0 -0
- data/templates/default/docstring/html/note.erb +0 -0
- data/templates/default/docstring/html/private.erb +0 -0
- data/templates/default/docstring/html/returns_void.erb +0 -0
- data/templates/default/docstring/html/text.erb +0 -0
- data/templates/default/docstring/html/todo.erb +0 -0
- data/templates/default/docstring/setup.rb +4 -3
- data/templates/default/docstring/text/abstract.erb +0 -0
- data/templates/default/docstring/text/deprecated.erb +0 -0
- data/templates/default/docstring/text/index.erb +0 -0
- data/templates/default/docstring/text/note.erb +0 -0
- data/templates/default/docstring/text/private.erb +0 -0
- data/templates/default/docstring/text/returns_void.erb +0 -0
- data/templates/default/docstring/text/text.erb +0 -0
- data/templates/default/docstring/text/todo.erb +0 -0
- data/templates/default/fulldoc/html/css/common.css +0 -0
- data/templates/default/fulldoc/html/css/full_list.css +0 -0
- data/templates/default/fulldoc/html/css/style.css +31 -20
- data/templates/default/fulldoc/html/frames.erb +0 -0
- data/templates/default/fulldoc/html/full_list.erb +2 -2
- data/templates/default/fulldoc/html/full_list_class.erb +0 -0
- data/templates/default/fulldoc/html/full_list_file.erb +0 -0
- data/templates/default/fulldoc/html/full_list_method.erb +0 -0
- data/templates/default/fulldoc/html/js/app.js +3 -3
- data/templates/default/fulldoc/html/js/full_list.js +0 -0
- data/templates/default/fulldoc/html/js/jquery.js +0 -0
- data/templates/default/fulldoc/html/setup.rb +22 -23
- data/templates/default/layout/dot/header.erb +0 -0
- data/templates/default/layout/dot/setup.rb +1 -0
- data/templates/default/layout/html/breadcrumb.erb +0 -0
- data/templates/default/layout/html/files.erb +0 -0
- data/templates/default/layout/html/footer.erb +0 -0
- data/templates/default/layout/html/headers.erb +2 -2
- data/templates/default/layout/html/index.erb +0 -0
- data/templates/default/layout/html/layout.erb +1 -3
- data/templates/default/layout/html/listing.erb +0 -0
- data/templates/default/layout/html/objects.erb +0 -0
- data/templates/default/layout/html/script_setup.erb +0 -0
- data/templates/default/layout/html/search.erb +0 -0
- data/templates/default/layout/html/setup.rb +21 -19
- data/templates/default/method/html/header.erb +0 -0
- data/templates/default/method/setup.rb +2 -1
- data/templates/default/method/text/header.erb +0 -0
- data/templates/default/method_details/html/header.erb +0 -0
- data/templates/default/method_details/html/method_signature.erb +0 -0
- data/templates/default/method_details/html/source.erb +0 -0
- data/templates/default/method_details/setup.rb +1 -0
- data/templates/default/method_details/text/header.erb +0 -0
- data/templates/default/method_details/text/method_signature.erb +0 -0
- data/templates/default/method_details/text/setup.rb +3 -2
- data/templates/default/module/dot/child.erb +0 -0
- data/templates/default/module/dot/dependencies.erb +0 -0
- data/templates/default/module/dot/header.erb +0 -0
- data/templates/default/module/dot/info.erb +0 -0
- data/templates/default/module/dot/setup.rb +2 -1
- data/templates/default/module/html/attribute_details.erb +0 -0
- data/templates/default/module/html/attribute_summary.erb +0 -0
- data/templates/default/module/html/box_info.erb +0 -0
- data/templates/default/module/html/children.erb +0 -0
- data/templates/default/module/html/constant_summary.erb +0 -0
- data/templates/default/module/html/defines.erb +0 -0
- data/templates/default/module/html/header.erb +0 -0
- data/templates/default/module/html/inherited_attributes.erb +0 -0
- data/templates/default/module/html/inherited_constants.erb +0 -0
- data/templates/default/module/html/inherited_methods.erb +0 -0
- data/templates/default/module/html/item_summary.erb +0 -0
- data/templates/default/module/html/method_details_list.erb +0 -0
- data/templates/default/module/html/method_summary.erb +0 -0
- data/templates/default/module/html/methodmissing.erb +0 -0
- data/templates/default/module/html/pre_docstring.erb +0 -0
- data/templates/default/module/setup.rb +24 -26
- data/templates/default/module/text/children.erb +0 -0
- data/templates/default/module/text/class_meths_list.erb +0 -0
- data/templates/default/module/text/extends.erb +0 -0
- data/templates/default/module/text/header.erb +0 -0
- data/templates/default/module/text/includes.erb +0 -0
- data/templates/default/module/text/instance_meths_list.erb +0 -0
- data/templates/default/module/text/setup.rb +2 -1
- data/templates/default/onefile/html/files.erb +0 -0
- data/templates/default/onefile/html/headers.erb +0 -0
- data/templates/default/onefile/html/layout.erb +3 -3
- data/templates/default/onefile/html/readme.erb +0 -0
- data/templates/default/onefile/html/setup.rb +9 -8
- data/templates/default/root/dot/child.erb +0 -0
- data/templates/default/root/dot/setup.rb +3 -2
- data/templates/default/root/html/setup.rb +2 -1
- data/templates/default/tags/html/example.erb +0 -0
- data/templates/default/tags/html/index.erb +0 -0
- data/templates/default/tags/html/option.erb +1 -1
- data/templates/default/tags/html/overload.erb +0 -0
- data/templates/default/tags/html/see.erb +0 -0
- data/templates/default/tags/html/tag.erb +1 -1
- data/templates/default/tags/setup.rb +7 -5
- data/templates/default/tags/text/example.erb +0 -0
- data/templates/default/tags/text/index.erb +0 -0
- data/templates/default/tags/text/option.erb +1 -1
- data/templates/default/tags/text/overload.erb +0 -0
- data/templates/default/tags/text/see.erb +0 -0
- data/templates/default/tags/text/tag.erb +2 -2
- data/templates/guide/class/html/setup.rb +1 -0
- data/templates/guide/docstring/html/setup.rb +1 -0
- data/templates/guide/fulldoc/html/css/style.css +0 -0
- data/templates/guide/fulldoc/html/js/app.js +0 -0
- data/templates/guide/fulldoc/html/setup.rb +7 -6
- data/templates/guide/layout/html/layout.erb +0 -0
- data/templates/guide/layout/html/setup.rb +2 -5
- data/templates/guide/method/html/header.erb +0 -0
- data/templates/guide/method/html/setup.rb +5 -4
- data/templates/guide/module/html/header.erb +0 -0
- data/templates/guide/module/html/method_list.erb +0 -0
- data/templates/guide/module/html/setup.rb +2 -1
- data/templates/guide/onefile/html/files.erb +0 -0
- data/templates/guide/onefile/html/setup.rb +1 -0
- data/templates/guide/onefile/html/toc.erb +0 -0
- data/templates/guide/tags/html/setup.rb +1 -0
- data/yard.gemspec +2 -1
- metadata +10 -2
data/lib/yard/cli/diff.rb
CHANGED
@@ -1,3 +1,4 @@
|
|
1
|
+
# frozen_string_literal: true
|
1
2
|
require 'tmpdir'
|
2
3
|
require 'fileutils'
|
3
4
|
require 'open-uri'
|
@@ -29,21 +30,19 @@ module YARD
|
|
29
30
|
if @use_git
|
30
31
|
load_git_commit(gemfile)
|
31
32
|
all_objects
|
33
|
+
elsif load_gem_data(gemfile)
|
34
|
+
log.info "Found #{gemfile}"
|
35
|
+
all_objects
|
32
36
|
else
|
33
|
-
|
34
|
-
|
35
|
-
all_objects
|
36
|
-
else
|
37
|
-
log.error "Cannot find gem #{gemfile}"
|
38
|
-
nil
|
39
|
-
end
|
37
|
+
log.error "Cannot find gem #{gemfile}"
|
38
|
+
nil
|
40
39
|
end
|
41
40
|
end.compact
|
42
41
|
|
43
42
|
return if registry.size != 2
|
44
43
|
|
45
44
|
first_object = nil
|
46
|
-
[
|
45
|
+
[["Added objects", "A", added_objects(*registry)],
|
47
46
|
["Modified objects", "M", modified_objects(*registry)],
|
48
47
|
["Removed objects", "D", removed_objects(*registry)]].each do |name, short, objects|
|
49
48
|
next if short == "M" && @modified == false
|
@@ -51,7 +50,7 @@ module YARD
|
|
51
50
|
last_object = nil
|
52
51
|
all_objects_notice = false
|
53
52
|
log.puts name + ":" unless @compact
|
54
|
-
objects.sort_by
|
53
|
+
objects.sort_by(&:path).each do |object|
|
55
54
|
if !@list_all && last_object && object.parent == last_object
|
56
55
|
log.print " (...)" unless all_objects_notice
|
57
56
|
all_objects_notice = true
|
@@ -63,7 +62,7 @@ module YARD
|
|
63
62
|
end
|
64
63
|
all_objects_notice = false
|
65
64
|
log.print "" + (@compact ? "#{short} " : " ") +
|
66
|
-
|
65
|
+
object.path + " (#{object.file}:#{object.line})"
|
67
66
|
last_object = object
|
68
67
|
first_object = true
|
69
68
|
end
|
@@ -123,30 +122,29 @@ module YARD
|
|
123
122
|
# First check for argument as .yardoc file
|
124
123
|
[File.join(gemfile, '.yardoc'), gemfile].each do |yardoc|
|
125
124
|
log.info "Searching for .yardoc db at #{yardoc}"
|
126
|
-
|
127
|
-
|
128
|
-
|
129
|
-
|
130
|
-
end
|
125
|
+
next unless File.directory?(yardoc)
|
126
|
+
Registry.load_yardoc(yardoc)
|
127
|
+
Registry.load_all
|
128
|
+
return true
|
131
129
|
end
|
132
130
|
|
133
131
|
# Next check installed RubyGems
|
134
132
|
gemfile_without_ext = gemfile.sub(/\.gem$/, '')
|
135
133
|
log.info "Searching for installed gem #{gemfile_without_ext}"
|
136
|
-
|
137
|
-
|
138
|
-
|
139
|
-
|
140
|
-
|
141
|
-
|
142
|
-
|
143
|
-
|
144
|
-
|
145
|
-
|
146
|
-
|
134
|
+
YARD::GemIndex.find_all_by_name('').find do |spec|
|
135
|
+
next unless spec.full_name == gemfile_without_ext
|
136
|
+
yardoc = Registry.yardoc_file_for_gem(spec.name, "= #{spec.version}")
|
137
|
+
if yardoc
|
138
|
+
Registry.load_yardoc(yardoc)
|
139
|
+
Registry.load_all
|
140
|
+
else
|
141
|
+
log.enter_level(Logger::ERROR) do
|
142
|
+
olddir = Dir.pwd
|
143
|
+
Gems.run(spec.name, spec.version.to_s)
|
144
|
+
Dir.chdir(olddir)
|
147
145
|
end
|
148
|
-
return true
|
149
146
|
end
|
147
|
+
return true
|
150
148
|
end
|
151
149
|
|
152
150
|
# Look for local .gem file
|
@@ -166,6 +164,7 @@ module YARD
|
|
166
164
|
open(url) {|io| expand_and_parse(gemfile, io) }
|
167
165
|
return true
|
168
166
|
rescue OpenURI::HTTPError
|
167
|
+
nil # noop
|
169
168
|
end
|
170
169
|
false
|
171
170
|
end
|
@@ -177,7 +176,6 @@ module YARD
|
|
177
176
|
end
|
178
177
|
|
179
178
|
def generate_yardoc(dir)
|
180
|
-
olddir = Dir.pwd
|
181
179
|
Dir.chdir(dir) do
|
182
180
|
log.enter_level(Logger::ERROR) { Yardoc.run('-n', '--no-save') }
|
183
181
|
end
|
@@ -192,21 +190,23 @@ module YARD
|
|
192
190
|
require 'rubygems/package/tar_reader'
|
193
191
|
reader = Gem::Package::TarReader.new(io)
|
194
192
|
reader.each do |pkg|
|
195
|
-
|
196
|
-
|
197
|
-
|
198
|
-
|
199
|
-
|
200
|
-
|
201
|
-
|
202
|
-
|
203
|
-
|
204
|
-
out.fsync
|
193
|
+
next unless pkg.full_name == 'data.tar.gz'
|
194
|
+
Zlib::GzipReader.wrap(pkg) do |gzio|
|
195
|
+
tar = Gem::Package::TarReader.new(gzio)
|
196
|
+
tar.each do |entry|
|
197
|
+
file = File.join(tmpdir, entry.full_name)
|
198
|
+
FileUtils.mkdir_p(File.dirname(file))
|
199
|
+
File.open(file, 'wb') do |out|
|
200
|
+
out.write(entry.read)
|
201
|
+
begin
|
202
|
+
out.fsync
|
203
|
+
rescue NotImplementedError
|
204
|
+
nil # noop
|
205
205
|
end
|
206
206
|
end
|
207
207
|
end
|
208
|
-
break
|
209
208
|
end
|
209
|
+
break
|
210
210
|
end
|
211
211
|
else
|
212
212
|
Gem::Package.open(io) do |pkg|
|
data/lib/yard/cli/display.rb
CHANGED
@@ -1,3 +1,4 @@
|
|
1
|
+
# frozen_string_literal: true
|
1
2
|
module YARD
|
2
3
|
module CLI
|
3
4
|
# Display one object
|
@@ -53,7 +54,7 @@ module YARD
|
|
53
54
|
@objects = args.map {|o| Registry.at(o) }
|
54
55
|
|
55
56
|
# validation
|
56
|
-
return false if @objects.any?
|
57
|
+
return false if @objects.any?(&:nil?)
|
57
58
|
verify_markup_options
|
58
59
|
end
|
59
60
|
|
data/lib/yard/cli/gems.rb
CHANGED
@@ -1,3 +1,4 @@
|
|
1
|
+
# frozen_string_literal: true
|
1
2
|
module YARD
|
2
3
|
module CLI
|
3
4
|
# @since 0.6.0
|
@@ -45,8 +46,9 @@ module YARD
|
|
45
46
|
|
46
47
|
def add_gems(gems)
|
47
48
|
0.step(gems.size - 1, 2) do |index|
|
48
|
-
gem
|
49
|
-
|
49
|
+
gem = gems[index]
|
50
|
+
ver_require = gems[index + 1] || ">= 0"
|
51
|
+
specs = YARD::GemIndex.find_all_by_name(gem, ver_require)
|
50
52
|
if specs.empty?
|
51
53
|
log.warn "#{gem} #{ver_require} could not be found in RubyGems index"
|
52
54
|
else
|
@@ -71,13 +73,12 @@ module YARD
|
|
71
73
|
parse_options(opts, args)
|
72
74
|
add_gems(args)
|
73
75
|
|
74
|
-
|
75
76
|
if !args.empty? && @gems.empty?
|
76
77
|
log.error "No specified gems could be found for command"
|
77
78
|
elsif @gems.empty?
|
78
|
-
@gems +=
|
79
|
+
@gems += YARD::GemIndex.find_all_by_name('') if @gems.empty?
|
79
80
|
end
|
80
81
|
end
|
81
82
|
end
|
82
83
|
end
|
83
|
-
end
|
84
|
+
end
|
data/lib/yard/cli/graph.rb
CHANGED
@@ -1,3 +1,4 @@
|
|
1
|
+
# frozen_string_literal: true
|
1
2
|
module YARD
|
2
3
|
module CLI
|
3
4
|
# Options to pass to the {Graph} CLI.
|
@@ -115,11 +116,9 @@ module YARD
|
|
115
116
|
|
116
117
|
expression = "#{visibilities.uniq.inspect}.include?(object.visibility)"
|
117
118
|
options.verifier = Verifier.new(expression)
|
118
|
-
|
119
|
-
|
120
|
-
|
121
|
-
@objects = [Registry.root]
|
122
|
-
end
|
119
|
+
@objects = args.first ?
|
120
|
+
args.map {|o| Registry.at(o) }.compact :
|
121
|
+
[Registry.root]
|
123
122
|
end
|
124
123
|
end
|
125
124
|
end
|
data/lib/yard/cli/help.rb
CHANGED
@@ -1,3 +1,4 @@
|
|
1
|
+
# frozen_string_literal: true
|
1
2
|
module YARD
|
2
3
|
module CLI
|
3
4
|
# Handles help for commands
|
@@ -6,7 +7,8 @@ module YARD
|
|
6
7
|
def description; "Retrieves help for a command" end
|
7
8
|
|
8
9
|
def run(*args)
|
9
|
-
|
10
|
+
cmd = args.first && CommandParser.commands[args.first.to_sym]
|
11
|
+
if cmd
|
10
12
|
cmd.run('--help')
|
11
13
|
else
|
12
14
|
log.puts "Command #{args.first} not found." if args.first
|
@@ -15,4 +17,4 @@ module YARD
|
|
15
17
|
end
|
16
18
|
end
|
17
19
|
end
|
18
|
-
end
|
20
|
+
end
|
data/lib/yard/cli/i18n.rb
CHANGED
@@ -1,3 +1,4 @@
|
|
1
|
+
# frozen_string_literal: true
|
1
2
|
require "pathname"
|
2
3
|
|
3
4
|
module YARD
|
@@ -20,7 +21,7 @@ module YARD
|
|
20
21
|
end
|
21
22
|
|
22
23
|
def run(*args)
|
23
|
-
if args.
|
24
|
+
if args.empty? || !args.first.nil?
|
24
25
|
# fail early if arguments are not valid
|
25
26
|
return unless parse_arguments(*args)
|
26
27
|
end
|
data/lib/yard/cli/list.rb
CHANGED
@@ -1,3 +1,4 @@
|
|
1
|
+
# frozen_string_literal: true
|
1
2
|
module YARD
|
2
3
|
module CLI
|
3
4
|
# Lists all markup types
|
@@ -10,7 +11,7 @@ module YARD
|
|
10
11
|
#
|
11
12
|
# @param [Array<String>] args the list of arguments.
|
12
13
|
# @return [void]
|
13
|
-
def run(*args)
|
14
|
+
def run(*args) # rubocop:disable Lint/UnusedMethodArgument
|
14
15
|
log.puts "Available markup types for `doc' command:"
|
15
16
|
log.puts
|
16
17
|
types = Templates::Helpers::MarkupHelper::MARKUP_PROVIDERS
|
@@ -18,11 +19,9 @@ module YARD
|
|
18
19
|
types.sort_by {|name, _| name.to_s }.each do |name, providers|
|
19
20
|
log.puts "[#{name}]"
|
20
21
|
libs = providers.map {|p| p[:lib] }.compact
|
21
|
-
|
22
|
-
log.puts " Providers: #{libs.join(" ")}"
|
23
|
-
end
|
22
|
+
log.puts " Providers: #{libs.join(" ")}" unless libs.empty?
|
24
23
|
if exts[name]
|
25
|
-
log.puts " Extensions: #{exts[name].map {|e| ".#{e}"}.join(" ")}"
|
24
|
+
log.puts " Extensions: #{exts[name].map {|e| ".#{e}" }.join(" ")}"
|
26
25
|
end
|
27
26
|
|
28
27
|
log.puts
|
data/lib/yard/cli/server.rb
CHANGED
@@ -1,3 +1,4 @@
|
|
1
|
+
# frozen_string_literal: true
|
1
2
|
module YARD
|
2
3
|
module CLI
|
3
4
|
# A local documentation server
|
@@ -71,7 +72,8 @@ module YARD
|
|
71
72
|
|
72
73
|
def add_libraries(args)
|
73
74
|
(0...args.size).step(2) do |index|
|
74
|
-
library
|
75
|
+
library = args[index]
|
76
|
+
dir = args[index + 1]
|
75
77
|
|
76
78
|
libver = nil
|
77
79
|
if dir
|
@@ -109,23 +111,23 @@ module YARD
|
|
109
111
|
# @return [LibraryVersion, nil]
|
110
112
|
def create_library_version_if_yardopts_exist(library, dir)
|
111
113
|
if dir
|
112
|
-
|
113
|
-
|
114
|
-
|
115
|
-
|
116
|
-
|
117
|
-
|
118
|
-
|
119
|
-
|
120
|
-
|
121
|
-
|
122
|
-
|
114
|
+
options_file = File.join(dir, Yardoc::DEFAULT_YARDOPTS_FILE)
|
115
|
+
if File.exist?(options_file)
|
116
|
+
# Found yardopts, extract db path
|
117
|
+
yfile = extract_db_from_options_file(options_file)
|
118
|
+
db = File.expand_path(yfile, dir)
|
119
|
+
|
120
|
+
# Create libver
|
121
|
+
libver = YARD::Server::LibraryVersion.new(library, nil, db)
|
122
|
+
libver.source_path = dir
|
123
|
+
libver
|
124
|
+
end
|
123
125
|
end
|
124
126
|
end
|
125
127
|
|
126
128
|
def add_gems
|
127
129
|
require 'rubygems'
|
128
|
-
|
130
|
+
YARD::GemIndex.find_all_by_name('').each do |spec|
|
129
131
|
libraries[spec.name] ||= []
|
130
132
|
libraries[spec.name] |= [YARD::Server::LibraryVersion.new(spec.name, spec.version.to_s, nil, :gem)]
|
131
133
|
end
|
@@ -174,7 +176,7 @@ module YARD
|
|
174
176
|
end
|
175
177
|
opts.on('-t', '--template-path PATH',
|
176
178
|
'The template path to look for templates in. (used with -t).') do |path|
|
177
|
-
|
179
|
+
template_paths << path
|
178
180
|
end
|
179
181
|
opts.separator ''
|
180
182
|
opts.separator "Web Server Options:"
|
@@ -183,7 +185,7 @@ module YARD
|
|
183
185
|
end
|
184
186
|
opts.on('-B HOST', '--bind', 'The host address to bind to') do |host|
|
185
187
|
server_options[:Host] = host.to_s
|
186
|
-
end
|
188
|
+
end
|
187
189
|
opts.on('-p PORT', '--port', 'Serves documentation on PORT') do |port|
|
188
190
|
server_options[:Port] = port.to_i
|
189
191
|
end
|
@@ -191,20 +193,23 @@ module YARD
|
|
191
193
|
server_options[:DocumentRoot] = File.expand_path(docroot)
|
192
194
|
end
|
193
195
|
opts.on('-a', '--adapter ADAPTER', 'Use the ADAPTER (full Ruby class) for web server') do |adapter|
|
194
|
-
if adapter.
|
196
|
+
if adapter.casecmp('webrick') == 0
|
195
197
|
self.adapter = YARD::Server::WebrickAdapter
|
196
|
-
elsif adapter.
|
198
|
+
elsif adapter.casecmp('rack') == 0
|
197
199
|
self.adapter = YARD::Server::RackAdapter
|
198
200
|
else
|
199
|
-
self.adapter = eval(adapter)
|
201
|
+
self.adapter = eval(adapter) # rubocop:disable Lint/Eval
|
200
202
|
end
|
201
203
|
end
|
202
204
|
opts.on('-s', '--server TYPE', 'Use a specific server type eg. thin,mongrel,cgi (Rack specific)') do |type|
|
203
205
|
server_options[:server] = type
|
204
206
|
end
|
207
|
+
opts.on('--fork', 'Use process forking when serving requests') do
|
208
|
+
options[:use_fork] = true
|
209
|
+
end
|
205
210
|
common_options(opts)
|
206
211
|
opts.on('-e', '--load FILE', 'A Ruby script to load before the source tree is parsed.') do |file|
|
207
|
-
|
212
|
+
scripts << file
|
208
213
|
end
|
209
214
|
parse_options(opts, args)
|
210
215
|
|
@@ -215,9 +220,7 @@ module YARD
|
|
215
220
|
# Generate doc for first time
|
216
221
|
# This is not necessary but makes for a better first-run experience
|
217
222
|
libver = libraries.empty? ? nil : libraries.values.first.first
|
218
|
-
if libver
|
219
|
-
generate_doc_for_first_time(libver)
|
220
|
-
end
|
223
|
+
generate_doc_for_first_time(libver) if libver && !libver.ready?
|
221
224
|
else
|
222
225
|
add_libraries(args)
|
223
226
|
options[:single_library] = false if libraries.size > 1
|
@@ -226,7 +229,7 @@ module YARD
|
|
226
229
|
|
227
230
|
def generate_doc_for_first_time(libver)
|
228
231
|
log.enter_level(Logger::INFO) do
|
229
|
-
yardoc_file = libver.yardoc_file.sub
|
232
|
+
yardoc_file = libver.yardoc_file.sub(%r{^#{Regexp.quote Dir.pwd}[\\/]+}, '')
|
230
233
|
log.info "No yardoc db found in #{yardoc_file}, parsing source before starting server..."
|
231
234
|
end
|
232
235
|
Dir.chdir(libver.source_path) do
|
@@ -243,7 +246,7 @@ module YARD
|
|
243
246
|
begin
|
244
247
|
opts.parse!(args)
|
245
248
|
rescue OptionParser::ParseError
|
246
|
-
args.shift if args.first && args.first[0,1] != '-'
|
249
|
+
args.shift if args.first && args.first[0, 1] != '-'
|
247
250
|
retry
|
248
251
|
end
|
249
252
|
|
data/lib/yard/cli/stats.rb
CHANGED
@@ -1,3 +1,4 @@
|
|
1
|
+
# frozen_string_literal: true
|
1
2
|
module YARD
|
2
3
|
module CLI
|
3
4
|
# @since 0.6.0
|
@@ -49,8 +50,9 @@ module YARD
|
|
49
50
|
# To add statistics for a specific type, add a method +#stats_for_TYPE+
|
50
51
|
# to this class that calls {#output}.
|
51
52
|
def print_statistics
|
52
|
-
@total
|
53
|
-
|
53
|
+
@total = 0
|
54
|
+
@undocumented = 0
|
55
|
+
meths = methods.map(&:to_s).grep(/^stats_for_/)
|
54
56
|
STATS_ORDER.each do |meth|
|
55
57
|
mname = "stats_for_#{meth}"
|
56
58
|
if meths.include?(mname)
|
@@ -60,13 +62,14 @@ module YARD
|
|
60
62
|
end
|
61
63
|
meths.each {|m| send(m) }
|
62
64
|
|
63
|
-
|
64
|
-
|
65
|
-
|
66
|
-
total
|
67
|
-
|
68
|
-
|
69
|
-
|
65
|
+
total =
|
66
|
+
if @undocumented == 0
|
67
|
+
100
|
68
|
+
elsif @total == 0
|
69
|
+
0
|
70
|
+
else
|
71
|
+
(@total - @undocumented).to_f / @total.to_f * 100
|
72
|
+
end
|
70
73
|
log.puts("% 3.2f%% documented" % total)
|
71
74
|
end
|
72
75
|
|
@@ -137,8 +140,8 @@ module YARD
|
|
137
140
|
# Statistics for methods
|
138
141
|
def stats_for_methods
|
139
142
|
objs = all_objects.select {|m| m.type == :method }
|
140
|
-
objs.reject!
|
141
|
-
objs.reject!
|
143
|
+
objs.reject!(&:is_alias?)
|
144
|
+
objs.reject!(&:is_attribute?)
|
142
145
|
undoc = objs.select {|m| m.docstring.blank? }
|
143
146
|
@undoc_list |= undoc if @undoc_list
|
144
147
|
output "Methods", objs.size, undoc.size
|
@@ -156,11 +159,12 @@ module YARD
|
|
156
159
|
def output(name, data, undoc = nil)
|
157
160
|
@total += data if data.is_a?(Integer) && undoc
|
158
161
|
@undocumented += undoc if undoc.is_a?(Integer)
|
159
|
-
|
160
|
-
|
161
|
-
|
162
|
-
|
163
|
-
|
162
|
+
data =
|
163
|
+
if undoc
|
164
|
+
("%5s (% 5d undocumented)" % [data, undoc])
|
165
|
+
else
|
166
|
+
"%5s" % data
|
167
|
+
end
|
164
168
|
log.puts("%-12s %s" % [name + ":", data])
|
165
169
|
end
|
166
170
|
|