inch 0.5.0.rc3 → 0.5.0.rc4
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.
- checksums.yaml +4 -4
- data/.rubocop.yml +15 -0
- data/.rubocop_todo.yml +94 -0
- data/CHANGELOG.md +26 -2
- data/Gemfile +5 -2
- data/README.md +3 -3
- data/Rakefile +6 -2
- data/bin/inch +3 -3
- data/config/{example.yml → .inch.yml.sample} +1 -0
- data/config/base.rb +53 -0
- data/config/elixir.rb +43 -0
- data/config/nodejs.rb +10 -0
- data/config/{defaults.rb → ruby.rb} +5 -54
- data/inch.gemspec +7 -7
- data/lib/inch.rb +14 -9
- data/lib/inch/api.rb +10 -10
- data/lib/inch/api/compare.rb +2 -2
- data/lib/inch/api/compare/code_objects.rb +2 -3
- data/lib/inch/api/compare/codebases.rb +1 -1
- data/lib/inch/api/diff.rb +13 -16
- data/lib/inch/api/filter.rb +1 -1
- data/lib/inch/api/get.rb +2 -2
- data/lib/inch/api/options/base.rb +4 -4
- data/lib/inch/api/options/filter.rb +0 -4
- data/lib/inch/api/options/suggest.rb +2 -6
- data/lib/inch/api/stats.rb +0 -1
- data/lib/inch/api/suggest.rb +9 -10
- data/lib/inch/cli.rb +6 -6
- data/lib/inch/cli/arguments.rb +2 -2
- data/lib/inch/cli/command.rb +15 -15
- data/lib/inch/cli/command/base.rb +30 -9
- data/lib/inch/cli/command/base_list.rb +2 -2
- data/lib/inch/cli/command/console.rb +5 -5
- data/lib/inch/cli/command/diff.rb +9 -9
- data/lib/inch/cli/command/inspect.rb +5 -4
- data/lib/inch/cli/command/list.rb +4 -4
- data/lib/inch/cli/command/options/base.rb +17 -16
- data/lib/inch/cli/command/options/base_list.rb +9 -5
- data/lib/inch/cli/command/options/console.rb +4 -3
- data/lib/inch/cli/command/options/diff.rb +8 -6
- data/lib/inch/cli/command/options/inspect.rb +2 -2
- data/lib/inch/cli/command/options/list.rb +3 -2
- data/lib/inch/cli/command/options/show.rb +2 -2
- data/lib/inch/cli/command/options/stats.rb +2 -1
- data/lib/inch/cli/command/options/suggest.rb +6 -3
- data/lib/inch/cli/command/output/base.rb +4 -6
- data/lib/inch/cli/command/output/console.rb +6 -7
- data/lib/inch/cli/command/output/diff.rb +6 -6
- data/lib/inch/cli/command/output/inspect.rb +6 -8
- data/lib/inch/cli/command/output/list.rb +0 -1
- data/lib/inch/cli/command/output/show.rb +4 -5
- data/lib/inch/cli/command/output/stats.rb +21 -21
- data/lib/inch/cli/command/output/suggest.rb +31 -28
- data/lib/inch/cli/command/show.rb +4 -4
- data/lib/inch/cli/command/stats.rb +4 -4
- data/lib/inch/cli/command/suggest.rb +6 -6
- data/lib/inch/cli/command_parser.rb +6 -5
- data/lib/inch/cli/sparkline_helper.rb +6 -6
- data/lib/inch/cli/trace_helper.rb +1 -1
- data/lib/inch/cli/yardopts_helper.rb +4 -3
- data/lib/inch/code_object.rb +3 -3
- data/lib/inch/code_object/converter.rb +6 -8
- data/lib/inch/code_object/provider.rb +11 -11
- data/lib/inch/code_object/proxy.rb +61 -30
- data/lib/inch/codebase.rb +7 -8
- data/lib/inch/codebase/object.rb +60 -0
- data/lib/inch/codebase/objects.rb +8 -10
- data/lib/inch/codebase/objects_filter.rb +7 -5
- data/lib/inch/codebase/proxy.rb +4 -4
- data/lib/inch/codebase/serializer.rb +3 -3
- data/lib/inch/config.rb +42 -11
- data/lib/inch/config/base.rb +8 -29
- data/lib/inch/config/codebase.rb +32 -7
- data/lib/inch/config/evaluation.rb +61 -0
- data/lib/inch/core_ext.rb +1 -1
- data/lib/inch/core_ext/string.rb +1 -1
- data/lib/inch/evaluation.rb +13 -21
- data/lib/inch/evaluation/file.rb +4 -2
- data/lib/inch/evaluation/grade_list.rb +4 -4
- data/lib/inch/evaluation/priority_range.rb +3 -0
- data/lib/inch/evaluation/proxy.rb +139 -14
- data/lib/inch/evaluation/role.rb +99 -0
- data/lib/inch/language.rb +3 -0
- data/lib/inch/language/elixir/code_object/base.rb +197 -0
- data/lib/inch/language/elixir/code_object/function_object.rb +74 -0
- data/lib/inch/language/elixir/code_object/module_object.rb +23 -0
- data/lib/inch/language/elixir/code_object/type_object.rb +11 -0
- data/lib/inch/language/elixir/evaluation/base.rb +28 -0
- data/lib/inch/language/elixir/evaluation/function_object.rb +31 -0
- data/lib/inch/language/elixir/evaluation/module_object.rb +27 -0
- data/lib/inch/language/elixir/evaluation/type_object.rb +11 -0
- data/lib/inch/language/elixir/import.rb +24 -0
- data/lib/inch/language/elixir/provider/reader.rb +19 -0
- data/lib/inch/language/elixir/provider/reader/object.rb +63 -0
- data/lib/inch/language/elixir/provider/reader/object/base.rb +191 -0
- data/lib/inch/language/elixir/provider/reader/object/function_object.rb +26 -0
- data/lib/inch/language/elixir/provider/reader/object/module_object.rb +22 -0
- data/lib/inch/language/elixir/provider/reader/object/type_object.rb +15 -0
- data/lib/inch/language/elixir/provider/reader/parser.rb +55 -0
- data/lib/inch/language/elixir/roles/base.rb +32 -0
- data/lib/inch/language/elixir/roles/function.rb +112 -0
- data/lib/inch/language/elixir/roles/module.rb +64 -0
- data/lib/inch/language/elixir/roles/object.rb +76 -0
- data/lib/inch/language/elixir/roles/type.rb +13 -0
- data/lib/inch/language/nodejs/import.rb +8 -0
- data/lib/inch/language/nodejs/provider/jsdoc.rb +19 -0
- data/lib/inch/language/nodejs/provider/jsdoc/object.rb +55 -0
- data/lib/inch/language/nodejs/provider/jsdoc/object/base.rb +191 -0
- data/lib/inch/language/nodejs/provider/jsdoc/parser.rb +59 -0
- data/lib/inch/language/ruby/code_object/base.rb +197 -0
- data/lib/inch/language/ruby/code_object/class_object.rb +10 -0
- data/lib/inch/language/ruby/code_object/class_variable_object.rb +10 -0
- data/lib/inch/language/ruby/code_object/constant_object.rb +10 -0
- data/lib/inch/language/ruby/code_object/method_object.rb +85 -0
- data/lib/inch/language/ruby/code_object/method_parameter_object.rb +64 -0
- data/lib/inch/language/ruby/code_object/module_object.rb +10 -0
- data/lib/inch/language/ruby/code_object/namespace_object.rb +35 -0
- data/lib/inch/language/ruby/evaluation/base.rb +45 -0
- data/lib/inch/language/ruby/evaluation/class_object.rb +10 -0
- data/lib/inch/language/ruby/evaluation/class_variable_object.rb +21 -0
- data/lib/inch/language/ruby/evaluation/constant_object.rb +21 -0
- data/lib/inch/language/ruby/evaluation/method_object.rb +74 -0
- data/lib/inch/language/ruby/evaluation/module_object.rb +10 -0
- data/lib/inch/language/ruby/evaluation/namespace_object.rb +30 -0
- data/lib/inch/language/ruby/import.rb +34 -0
- data/lib/inch/language/ruby/provider/yard.rb +58 -0
- data/lib/inch/language/ruby/provider/yard/docstring.rb +162 -0
- data/lib/inch/language/ruby/provider/yard/nodoc_helper.rb +97 -0
- data/lib/inch/language/ruby/provider/yard/object.rb +63 -0
- data/lib/inch/language/ruby/provider/yard/object/base.rb +325 -0
- data/lib/inch/language/ruby/provider/yard/object/class_object.rb +14 -0
- data/lib/inch/language/ruby/provider/yard/object/class_variable_object.rb +14 -0
- data/lib/inch/language/ruby/provider/yard/object/constant_object.rb +14 -0
- data/lib/inch/language/ruby/provider/yard/object/method_object.rb +170 -0
- data/lib/inch/language/ruby/provider/yard/object/method_parameter_object.rb +94 -0
- data/lib/inch/language/ruby/provider/yard/object/method_signature.rb +120 -0
- data/lib/inch/language/ruby/provider/yard/object/module_object.rb +14 -0
- data/lib/inch/language/ruby/provider/yard/object/namespace_object.rb +46 -0
- data/lib/inch/language/ruby/provider/yard/object/root_object.rb +14 -0
- data/lib/inch/language/ruby/provider/yard/parser.rb +71 -0
- data/lib/inch/language/ruby/roles/base.rb +17 -0
- data/lib/inch/language/ruby/roles/class_variable.rb +53 -0
- data/lib/inch/language/ruby/roles/constant.rb +53 -0
- data/lib/inch/language/ruby/roles/method.rb +112 -0
- data/lib/inch/language/ruby/roles/method_parameter.rb +84 -0
- data/lib/inch/language/ruby/roles/missing.rb +24 -0
- data/lib/inch/language/ruby/roles/namespace.rb +89 -0
- data/lib/inch/language/ruby/roles/object.rb +120 -0
- data/lib/inch/rake.rb +2 -2
- data/lib/inch/rake/suggest.rb +7 -2
- data/lib/inch/utils/buffered_ui.rb +16 -0
- data/lib/inch/utils/shell_helper.rb +1 -1
- data/lib/inch/utils/ui.rb +5 -5
- data/lib/inch/utils/weighted_list.rb +2 -3
- data/lib/inch/version.rb +1 -1
- data/test/fixtures/{code_examples → ruby/code_examples}/lib/foo.rb +0 -0
- data/test/fixtures/{diff1 → ruby/diff1}/lib/diff1.rb +0 -0
- data/test/fixtures/{diff2 → ruby/diff2}/lib/diff2.rb +0 -0
- data/test/fixtures/{inch-yml → ruby/inch-yml}/.inch.yml +0 -0
- data/test/fixtures/{inch-yml → ruby/inch-yml}/foo/bar.rb +0 -0
- data/test/fixtures/{inch-yml → ruby/inch-yml}/foo/vendor/base.rb +0 -0
- data/test/fixtures/{parameters → ruby/parameters}/lib/foo.rb +0 -0
- data/test/fixtures/{readme → ruby/readme}/lib/foo.rb +0 -0
- data/test/fixtures/{really_good → ruby/really_good}/lib/foo.rb +0 -0
- data/test/fixtures/{really_good_pedantic → ruby/really_good_pedantic}/lib/foo.rb +0 -0
- data/test/fixtures/{simple → ruby/simple}/README +0 -0
- data/test/fixtures/{simple → ruby/simple}/lib/broken.rb +11 -19
- data/test/fixtures/ruby/simple/lib/broken_ruby_2_0_features.rb +7 -0
- data/test/fixtures/ruby/simple/lib/directives.rb +8 -0
- data/test/fixtures/{simple → ruby/simple}/lib/foo.rb +22 -1
- data/test/fixtures/{simple → ruby/simple}/lib/nodoc.rb +0 -0
- data/test/fixtures/{simple → ruby/simple}/lib/role_methods.rb +0 -0
- data/test/fixtures/{simple → ruby/simple}/lib/role_namespaces.rb +0 -0
- data/test/fixtures/{visibility → ruby/visibility}/lib/foo.rb +0 -0
- data/test/fixtures/{yardopts → ruby/yardopts}/.yardopts +0 -0
- data/test/fixtures/{yardopts → ruby/yardopts}/foo/bar.rb +0 -0
- data/test/integration/api/compare/codebases.rb +3 -3
- data/test/integration/cli/command/console_test.rb +6 -6
- data/test/integration/cli/command/diff_test.rb +62 -0
- data/test/integration/cli/command/inspect_test.rb +5 -6
- data/test/integration/cli/command/list_test.rb +4 -5
- data/test/integration/cli/command/show_test.rb +5 -5
- data/test/integration/cli/command/stats_test.rb +3 -3
- data/test/integration/cli/command/suggest_test.rb +13 -13
- data/test/integration/stats_options_test.rb +4 -4
- data/test/integration/visibility_options_test.rb +14 -14
- data/test/shared/base_list.rb +4 -3
- data/test/test_helper.rb +13 -13
- data/test/unit/api/filter_test.rb +7 -7
- data/test/unit/api/get_test.rb +1 -1
- data/test/unit/api/list_test.rb +1 -1
- data/test/unit/api/options/base_test.rb +3 -3
- data/test/unit/api/stats_test.rb +1 -1
- data/test/unit/api/suggest_test.rb +3 -3
- data/test/unit/cli/arguments_test.rb +2 -2
- data/test/unit/cli/command/base_test.rb +1 -1
- data/test/unit/cli/command/options/base_list_test.rb +2 -2
- data/test/unit/cli/command/options/base_object_test.rb +1 -1
- data/test/unit/cli/command/options/base_test.rb +1 -1
- data/test/unit/cli/command_parser_test.rb +3 -3
- data/test/unit/cli/trace_helper_test.rb +1 -1
- data/test/unit/cli/yardopts_helper_test.rb +6 -5
- data/test/unit/code_object/converter_test.rb +1 -1
- data/test/unit/code_object/provider_test.rb +2 -2
- data/test/unit/code_object/proxy_test.rb +2 -2
- data/test/unit/codebase/objects_test.rb +2 -2
- data/test/unit/codebase/proxy_test.rb +7 -5
- data/test/unit/config/codebase_test.rb +4 -4
- data/test/unit/config_test.rb +28 -0
- data/test/unit/evaluation/{role/base_test.rb → role_test.rb} +7 -7
- data/test/unit/{code_object/proxy → language/ruby/code_object}/method_object_test.rb +66 -21
- data/test/unit/{code_object → language/ruby}/provider/yard/docstring_test.rb +74 -38
- data/test/unit/{code_object → language/ruby}/provider/yard/nodoc_helper_test.rb +9 -7
- data/test/unit/{code_object → language/ruby}/provider/yard/object/method_object_test.rb +21 -11
- data/test/unit/language/ruby/provider/yard_test.rb +25 -0
- data/test/unit/utils/buffered_ui_test.rb +48 -0
- data/test/unit/utils/ui_test.rb +7 -7
- data/test/unit/utils/weighted_list_test.rb +7 -4
- metadata +139 -93
- data/lib/inch/code_object/provider/yard.rb +0 -57
- data/lib/inch/code_object/provider/yard/docstring.rb +0 -133
- data/lib/inch/code_object/provider/yard/nodoc_helper.rb +0 -93
- data/lib/inch/code_object/provider/yard/object.rb +0 -60
- data/lib/inch/code_object/provider/yard/object/base.rb +0 -302
- data/lib/inch/code_object/provider/yard/object/class_object.rb +0 -12
- data/lib/inch/code_object/provider/yard/object/class_variable_object.rb +0 -12
- data/lib/inch/code_object/provider/yard/object/constant_object.rb +0 -12
- data/lib/inch/code_object/provider/yard/object/method_object.rb +0 -153
- data/lib/inch/code_object/provider/yard/object/method_parameter_object.rb +0 -88
- data/lib/inch/code_object/provider/yard/object/method_signature.rb +0 -114
- data/lib/inch/code_object/provider/yard/object/module_object.rb +0 -12
- data/lib/inch/code_object/provider/yard/object/namespace_object.rb +0 -47
- data/lib/inch/code_object/provider/yard/object/root_object.rb +0 -12
- data/lib/inch/code_object/provider/yard/parser.rb +0 -62
- data/lib/inch/code_object/proxy/base.rb +0 -241
- data/lib/inch/code_object/proxy/class_object.rb +0 -8
- data/lib/inch/code_object/proxy/class_variable_object.rb +0 -8
- data/lib/inch/code_object/proxy/constant_object.rb +0 -8
- data/lib/inch/code_object/proxy/method_object.rb +0 -82
- data/lib/inch/code_object/proxy/method_parameter_object.rb +0 -60
- data/lib/inch/code_object/proxy/module_object.rb +0 -8
- data/lib/inch/code_object/proxy/namespace_object.rb +0 -33
- data/lib/inch/evaluation/object_schema.rb +0 -30
- data/lib/inch/evaluation/proxy/base.rb +0 -164
- data/lib/inch/evaluation/proxy/class_object.rb +0 -8
- data/lib/inch/evaluation/proxy/class_variable_object.rb +0 -19
- data/lib/inch/evaluation/proxy/constant_object.rb +0 -19
- data/lib/inch/evaluation/proxy/method_object.rb +0 -65
- data/lib/inch/evaluation/proxy/module_object.rb +0 -8
- data/lib/inch/evaluation/proxy/namespace_object.rb +0 -27
- data/lib/inch/evaluation/role/base.rb +0 -92
- data/lib/inch/evaluation/role/class_variable.rb +0 -55
- data/lib/inch/evaluation/role/constant.rb +0 -55
- data/lib/inch/evaluation/role/method.rb +0 -126
- data/lib/inch/evaluation/role/method_parameter.rb +0 -91
- data/lib/inch/evaluation/role/missing.rb +0 -20
- data/lib/inch/evaluation/role/namespace.rb +0 -85
- data/lib/inch/evaluation/role/object.rb +0 -143
- data/test/unit/code_object/provider/yard_test.rb +0 -25
@@ -1,133 +0,0 @@
|
|
1
|
-
module Inch
|
2
|
-
module CodeObject
|
3
|
-
module Provider
|
4
|
-
module YARD
|
5
|
-
class Docstring
|
6
|
-
def initialize(text)
|
7
|
-
@text = text.to_s
|
8
|
-
end
|
9
|
-
|
10
|
-
def describes_internal_api?
|
11
|
-
first_line =~ /^Internal\:\ .+/
|
12
|
-
end
|
13
|
-
|
14
|
-
def describes_private_object?
|
15
|
-
first_line =~ /^Private\:\ .+/
|
16
|
-
end
|
17
|
-
|
18
|
-
def empty?
|
19
|
-
@text.strip.empty?
|
20
|
-
end
|
21
|
-
|
22
|
-
def contains_code_example?
|
23
|
-
!code_examples.empty?
|
24
|
-
end
|
25
|
-
|
26
|
-
def code_examples
|
27
|
-
@code_examples ||= parse_code_examples
|
28
|
-
end
|
29
|
-
|
30
|
-
def describes_parameter?(name)
|
31
|
-
return false if name.nil?
|
32
|
-
describe_parameter_regexps(name).any? do |pattern|
|
33
|
-
@text.index(pattern)
|
34
|
-
end
|
35
|
-
end
|
36
|
-
|
37
|
-
def mentions_parameter?(name)
|
38
|
-
return false if name.nil?
|
39
|
-
mention_parameter_regexps(name).any? do |pattern|
|
40
|
-
@text.index(pattern)
|
41
|
-
end
|
42
|
-
end
|
43
|
-
|
44
|
-
def mentions_return?
|
45
|
-
last_line =~ /^#{tomdoc_modifiers}Returns\ /
|
46
|
-
end
|
47
|
-
|
48
|
-
def describes_return?
|
49
|
-
last_line =~ /^#{tomdoc_modifiers}Returns\ (\w+\s){2,}/i ||
|
50
|
-
last_line =~ /^#{tomdoc_modifiers}Returns\ (nil|nothing)\.*/i
|
51
|
-
end
|
52
|
-
|
53
|
-
def to_s
|
54
|
-
@text
|
55
|
-
end
|
56
|
-
|
57
|
-
private
|
58
|
-
|
59
|
-
def first_line
|
60
|
-
@first_line ||= @text.lines.to_a.first
|
61
|
-
end
|
62
|
-
|
63
|
-
def last_line
|
64
|
-
@last_line ||= @text.lines.to_a.last
|
65
|
-
end
|
66
|
-
|
67
|
-
def parse_code_examples
|
68
|
-
code_examples = []
|
69
|
-
example = nil
|
70
|
-
@text.lines.each_with_index do |line, index|
|
71
|
-
if line =~/^\s*+$/
|
72
|
-
code_examples << example if example
|
73
|
-
example = []
|
74
|
-
elsif line =~/^\ {2,}\S+/
|
75
|
-
example << line if example
|
76
|
-
else
|
77
|
-
code_examples << example if example
|
78
|
-
example = nil
|
79
|
-
end
|
80
|
-
end
|
81
|
-
code_examples << example if example
|
82
|
-
code_examples.delete_if(&:empty?).map(&:join)
|
83
|
-
end
|
84
|
-
|
85
|
-
def mention_parameter_patterns(name)
|
86
|
-
[
|
87
|
-
"+#{name}+",
|
88
|
-
"+#{name}+::",
|
89
|
-
"<tt>#{name}</tt>",
|
90
|
-
"<tt>#{name}</tt>::",
|
91
|
-
"#{name}::",
|
92
|
-
/^#{Regexp.escape(name)}\ \-\ /
|
93
|
-
]
|
94
|
-
end
|
95
|
-
|
96
|
-
def describe_parameter_extra_regexps(name)
|
97
|
-
[
|
98
|
-
"#{name}::",
|
99
|
-
"+#{name}+::",
|
100
|
-
"<tt>#{name}</tt>::",
|
101
|
-
].map do |pattern|
|
102
|
-
r = pattern.is_a?(Regexp) ? pattern : Regexp.escape(pattern)
|
103
|
-
/#{r}\n\ {2,}.+/m
|
104
|
-
end
|
105
|
-
end
|
106
|
-
|
107
|
-
def describe_parameter_regexps(name)
|
108
|
-
same_line_regexps = mention_parameter_patterns(name).map do |pattern|
|
109
|
-
r = pattern.is_a?(Regexp) ? pattern : Regexp.escape(pattern)
|
110
|
-
/^#{r}\s?\S+/
|
111
|
-
end
|
112
|
-
same_line_regexps + describe_parameter_extra_regexps(name)
|
113
|
-
end
|
114
|
-
|
115
|
-
def mention_parameter_regexps(name)
|
116
|
-
mention_parameter_patterns(name).map do |pattern|
|
117
|
-
if pattern.is_a?(Regexp)
|
118
|
-
pattern
|
119
|
-
else
|
120
|
-
r = Regexp.escape(pattern)
|
121
|
-
/\W#{r}\W/
|
122
|
-
end
|
123
|
-
end
|
124
|
-
end
|
125
|
-
|
126
|
-
def tomdoc_modifiers
|
127
|
-
/((Public|Private|Internal)\:\ )*/
|
128
|
-
end
|
129
|
-
end
|
130
|
-
end
|
131
|
-
end
|
132
|
-
end
|
133
|
-
end
|
@@ -1,93 +0,0 @@
|
|
1
|
-
module Inch
|
2
|
-
module CodeObject
|
3
|
-
module Provider
|
4
|
-
module YARD
|
5
|
-
module NodocHelper
|
6
|
-
|
7
|
-
# Returns true if the code object is somehow marked not to be
|
8
|
-
# documented.
|
9
|
-
#
|
10
|
-
# @note Doesnot recognize ":startdoc:" and ":stopdoc:"
|
11
|
-
#
|
12
|
-
def nodoc?
|
13
|
-
tagged_as_private? || nodoc_comment?
|
14
|
-
end
|
15
|
-
|
16
|
-
NO_DOC_REGEX = /#\s*\:nodoc\:/
|
17
|
-
NO_DOC_ALL_REGEX = /#\s*\:nodoc\:\s*all/
|
18
|
-
DOC_REGEX = /#\s*\:doc\:/
|
19
|
-
|
20
|
-
def nodoc_comment?
|
21
|
-
explicit_nodoc_comment? || implicit_nodoc_comment?
|
22
|
-
end
|
23
|
-
|
24
|
-
def explicit_nodoc_comment?
|
25
|
-
declarations.any? { |str| str =~ NO_DOC_REGEX }
|
26
|
-
end
|
27
|
-
|
28
|
-
def explicit_nodoc_all_comment?
|
29
|
-
declarations.any? { |str| str =~ NO_DOC_ALL_REGEX }
|
30
|
-
end
|
31
|
-
|
32
|
-
def explicit_doc_comment?
|
33
|
-
declarations.any? { |str| str =~ DOC_REGEX }
|
34
|
-
end
|
35
|
-
|
36
|
-
def implicit_nodoc_all_comment?
|
37
|
-
if parent
|
38
|
-
parent.explicit_nodoc_all_comment? ||
|
39
|
-
parent.implicit_nodoc_all_comment?
|
40
|
-
end
|
41
|
-
end
|
42
|
-
|
43
|
-
def implicit_nodoc_comment?
|
44
|
-
return false if explicit_doc_comment?
|
45
|
-
|
46
|
-
if parent
|
47
|
-
return false if parent.explicit_doc_comment?
|
48
|
-
|
49
|
-
if namespace?
|
50
|
-
if parent.explicit_nodoc_all_comment?
|
51
|
-
return true
|
52
|
-
else
|
53
|
-
return parent.implicit_nodoc_all_comment?
|
54
|
-
end
|
55
|
-
else
|
56
|
-
if parent.explicit_nodoc_comment?
|
57
|
-
return true
|
58
|
-
else
|
59
|
-
return parent.implicit_nodoc_all_comment?
|
60
|
-
end
|
61
|
-
end
|
62
|
-
end
|
63
|
-
end
|
64
|
-
|
65
|
-
# Returns all lines in all files declaring the object
|
66
|
-
#
|
67
|
-
# @example
|
68
|
-
# declarations # => ["class Base # :nodoc:", "class Foo < Base"]
|
69
|
-
#
|
70
|
-
# @return [Array<String>]
|
71
|
-
def declarations
|
72
|
-
@declarations ||= files.map do |f|
|
73
|
-
get_line_no(f.filename, f.line_no)
|
74
|
-
end
|
75
|
-
end
|
76
|
-
|
77
|
-
# Returns a +line_number+ from a file
|
78
|
-
#
|
79
|
-
# @param filename [String]
|
80
|
-
# @param line_number [Fixnum]
|
81
|
-
# @return [String]
|
82
|
-
def get_line_no(filename, line_number)
|
83
|
-
f = File.open(filename)
|
84
|
-
line_number.times{f.gets}
|
85
|
-
result = $_
|
86
|
-
f.close
|
87
|
-
result.encode('UTF-8', 'binary', invalid: :replace, undef: :replace, replace: '')
|
88
|
-
end
|
89
|
-
end
|
90
|
-
end
|
91
|
-
end
|
92
|
-
end
|
93
|
-
end
|
@@ -1,60 +0,0 @@
|
|
1
|
-
module Inch
|
2
|
-
module CodeObject
|
3
|
-
module Provider
|
4
|
-
module YARD
|
5
|
-
# CodeObject::Provider::YARD::Object object represent code objects.
|
6
|
-
#
|
7
|
-
module Object
|
8
|
-
class << self
|
9
|
-
def clear_cache
|
10
|
-
@cache = {}
|
11
|
-
end
|
12
|
-
|
13
|
-
# Returns a Proxy object for the given +yard_object+
|
14
|
-
#
|
15
|
-
# @param yard_object [YARD::CodeObject]
|
16
|
-
# @return [Provider::YARD::Object]
|
17
|
-
def for(yard_object)
|
18
|
-
@cache ||= {}
|
19
|
-
if proxy_object = @cache[cache_key(yard_object)]
|
20
|
-
proxy_object
|
21
|
-
else
|
22
|
-
@cache[cache_key(yard_object)] = class_for(yard_object).new(yard_object)
|
23
|
-
end
|
24
|
-
end
|
25
|
-
|
26
|
-
private
|
27
|
-
|
28
|
-
# Returns a Proxy class for the given +yard_object+
|
29
|
-
#
|
30
|
-
# @param yard_object [YARD::CodeObject]
|
31
|
-
# @return [Class]
|
32
|
-
def class_for(yard_object)
|
33
|
-
class_name = yard_object.class.to_s.split('::').last
|
34
|
-
const_get(class_name)
|
35
|
-
rescue NameError
|
36
|
-
Base
|
37
|
-
end
|
38
|
-
|
39
|
-
# Returns a cache key for the given +yard_object+
|
40
|
-
#
|
41
|
-
# @param yard_object [YARD::CodeObject]
|
42
|
-
# @return [String]
|
43
|
-
def cache_key(yard_object)
|
44
|
-
yard_object.path
|
45
|
-
end
|
46
|
-
end
|
47
|
-
end
|
48
|
-
end
|
49
|
-
end
|
50
|
-
end
|
51
|
-
end
|
52
|
-
|
53
|
-
require 'inch/code_object/provider/yard/object/base'
|
54
|
-
require 'inch/code_object/provider/yard/object/namespace_object'
|
55
|
-
require 'inch/code_object/provider/yard/object/class_object'
|
56
|
-
require 'inch/code_object/provider/yard/object/class_variable_object'
|
57
|
-
require 'inch/code_object/provider/yard/object/constant_object'
|
58
|
-
require 'inch/code_object/provider/yard/object/method_object'
|
59
|
-
require 'inch/code_object/provider/yard/object/method_parameter_object'
|
60
|
-
require 'inch/code_object/provider/yard/object/module_object'
|
@@ -1,302 +0,0 @@
|
|
1
|
-
require 'forwardable'
|
2
|
-
|
3
|
-
module Inch
|
4
|
-
module CodeObject
|
5
|
-
module Provider
|
6
|
-
module YARD
|
7
|
-
module Object
|
8
|
-
# @abstract
|
9
|
-
class Base
|
10
|
-
extend Forwardable
|
11
|
-
include YARD::NodocHelper
|
12
|
-
|
13
|
-
# @return [YARD::CodeObjects::Base] the actual (YARD) code object
|
14
|
-
attr_reader :object
|
15
|
-
|
16
|
-
# @return [String] the codebase's directory
|
17
|
-
attr_accessor :base_dir
|
18
|
-
|
19
|
-
# Tags considered by wrapper methods like {#has_code_example?}
|
20
|
-
CONSIDERED_YARD_TAGS = %w(api example param private return since)
|
21
|
-
AUTO_GENERATED_TAG_NAMES = %w(raise yield)
|
22
|
-
|
23
|
-
# convenient shortcuts to (YARD) code object
|
24
|
-
def_delegators :object, :type, :namespace, :source, :source_type, :group, :dynamic, :visibility
|
25
|
-
|
26
|
-
# @param object [YARD::CodeObjects::Base] the actual (YARD) code object
|
27
|
-
def initialize(object)
|
28
|
-
@object = object
|
29
|
-
@__api_tag = __api_tag
|
30
|
-
@__parent = __parent
|
31
|
-
@__private_tag = __private_tag
|
32
|
-
end
|
33
|
-
|
34
|
-
# Returns the fullname of the object that the current object
|
35
|
-
# is an alias for
|
36
|
-
attr_accessor :aliased_object_fullname
|
37
|
-
|
38
|
-
# Returns the fullnames of the objects that are aliases
|
39
|
-
# for the current object
|
40
|
-
def aliases_fullnames
|
41
|
-
[]
|
42
|
-
end
|
43
|
-
|
44
|
-
def api_tag?
|
45
|
-
!api_tag.nil?
|
46
|
-
end
|
47
|
-
|
48
|
-
def api_tag
|
49
|
-
@__api_tag
|
50
|
-
end
|
51
|
-
|
52
|
-
# To be overridden
|
53
|
-
# @see Proxy::NamespaceObject
|
54
|
-
# @return [CodeObject::Proxy::Base,nil] the child inside the current object or +nil+
|
55
|
-
def child(name)
|
56
|
-
nil
|
57
|
-
end
|
58
|
-
|
59
|
-
# @return [Array,nil] the full names of the children of the current object
|
60
|
-
def children_fullnames
|
61
|
-
[]
|
62
|
-
end
|
63
|
-
|
64
|
-
# To be overridden
|
65
|
-
# @see Proxy::NamespaceObject
|
66
|
-
def children
|
67
|
-
[]
|
68
|
-
end
|
69
|
-
|
70
|
-
RUBY_CORE = %w(Array Bignum BasicObject Object Module Class Complex NilClass Numeric String Float Fiber FiberError Continuation Dir File Encoding Enumerator StopIteration Enumerator::Generator Enumerator::Yielder Exception SystemExit SignalException Interrupt StandardError TypeError ArgumentError IndexError KeyError RangeError ScriptError SyntaxError LoadError NotImplementedError NameError NoMethodError RuntimeError SecurityError NoMemoryError EncodingError SystemCallError Encoding::CompatibilityError File::Stat IO Hash ENV IOError EOFError ARGF RubyVM RubyVM::InstructionSequence Math::DomainError ZeroDivisionError FloatDomainError Integer Fixnum Data TrueClass FalseClass Mutex Thread Proc LocalJumpError SystemStackError Method UnboundMethod Binding Process::Status Random Range Rational RegexpError Regexp MatchData Symbol Struct ThreadGroup ThreadError Time Encoding::UndefinedConversionError Encoding::InvalidByteSequenceError Encoding::ConverterNotFoundError Encoding::Converter RubyVM::Env) +
|
71
|
-
%w(Comparable Kernel File::Constants Enumerable Errno FileTest GC ObjectSpace GC::Profiler IO::WaitReadable IO::WaitWritable Marshal Math Process Process::UID Process::GID Process::Sys Signal)
|
72
|
-
def core?
|
73
|
-
RUBY_CORE.include?(name.to_s)
|
74
|
-
end
|
75
|
-
|
76
|
-
# @return [Docstring]
|
77
|
-
def docstring
|
78
|
-
@docstring ||= Docstring.new(object.docstring)
|
79
|
-
end
|
80
|
-
|
81
|
-
# Returns all files declaring the object in the form of an Array of
|
82
|
-
# Arrays containing the location of their declaration.
|
83
|
-
#
|
84
|
-
# @return [Array<CodeLocation>]
|
85
|
-
def files
|
86
|
-
object.files.map do |(filename, line_no)|
|
87
|
-
CodeLocation.new(base_dir, filename, line_no)
|
88
|
-
end
|
89
|
-
rescue ::YARD::CodeObjects::ProxyMethodError
|
90
|
-
# this error is raised by YARD
|
91
|
-
# see broken.rb in test fixtures
|
92
|
-
[]
|
93
|
-
end
|
94
|
-
|
95
|
-
# CodeLocation is a utility class to find declarations of objects in files
|
96
|
-
class CodeLocation < Struct.new(:base_dir, :relative_path, :line_no)
|
97
|
-
def filename
|
98
|
-
File.join(base_dir, relative_path)
|
99
|
-
end
|
100
|
-
end
|
101
|
-
|
102
|
-
# Returns the name of the file where the object is declared first
|
103
|
-
# @return [String] a filename
|
104
|
-
def filename
|
105
|
-
# just checking the first file (which is the file where an object
|
106
|
-
# is first declared)
|
107
|
-
files.first && files.first.filename
|
108
|
-
end
|
109
|
-
|
110
|
-
def fullname
|
111
|
-
@fullname ||= object.path
|
112
|
-
end
|
113
|
-
|
114
|
-
def name
|
115
|
-
@name ||= object.name
|
116
|
-
end
|
117
|
-
|
118
|
-
def has_children?
|
119
|
-
!children.empty?
|
120
|
-
end
|
121
|
-
|
122
|
-
def has_code_example?
|
123
|
-
!tags(:example).empty? ||
|
124
|
-
docstring.contains_code_example?
|
125
|
-
end
|
126
|
-
|
127
|
-
def has_doc?
|
128
|
-
!docstring.empty?
|
129
|
-
end
|
130
|
-
|
131
|
-
def has_multiple_code_examples?
|
132
|
-
if tags(:example).size > 1 || docstring.code_examples.size > 1
|
133
|
-
true
|
134
|
-
else
|
135
|
-
if tag = tag(:example)
|
136
|
-
multi_code_examples?(tag.text)
|
137
|
-
elsif text = docstring.code_examples.first
|
138
|
-
multi_code_examples?(text)
|
139
|
-
else
|
140
|
-
false
|
141
|
-
end
|
142
|
-
end
|
143
|
-
end
|
144
|
-
|
145
|
-
def has_unconsidered_tags?
|
146
|
-
!unconsidered_tags.empty?
|
147
|
-
end
|
148
|
-
|
149
|
-
def in_in_root?
|
150
|
-
depth == 1
|
151
|
-
end
|
152
|
-
|
153
|
-
# The depth of the following is 4:
|
154
|
-
#
|
155
|
-
# Foo::Bar::Baz#initialize
|
156
|
-
# ^ ^ ^ ^
|
157
|
-
# 1 << 2 << 3 << 4
|
158
|
-
#
|
159
|
-
# +depth+ answers the question "how many layers of code objects are
|
160
|
-
# above this one?"
|
161
|
-
#
|
162
|
-
# @note top-level counts, that's why Foo has depth 1!
|
163
|
-
#
|
164
|
-
# @return [Fixnum] the depth of the object in terms of namespace
|
165
|
-
def depth
|
166
|
-
@__depth ||= __depth
|
167
|
-
end
|
168
|
-
|
169
|
-
# @return [Boolean] +true+ if the object represents a method
|
170
|
-
def method?
|
171
|
-
false
|
172
|
-
end
|
173
|
-
|
174
|
-
# @return [Boolean] +true+ if the object represents a namespace
|
175
|
-
def namespace?
|
176
|
-
false
|
177
|
-
end
|
178
|
-
|
179
|
-
# @return [String] the documentation comments
|
180
|
-
def original_docstring
|
181
|
-
object.docstring.all.to_s
|
182
|
-
end
|
183
|
-
|
184
|
-
def parameters
|
185
|
-
[]
|
186
|
-
end
|
187
|
-
|
188
|
-
# @return [Array,nil] the parent of the current object or +nil+
|
189
|
-
def parent
|
190
|
-
@__parent
|
191
|
-
end
|
192
|
-
|
193
|
-
def __parent
|
194
|
-
YARD::Object.for(object.parent) if object.parent
|
195
|
-
end
|
196
|
-
|
197
|
-
def private?
|
198
|
-
visibility == :private
|
199
|
-
end
|
200
|
-
|
201
|
-
def tagged_as_internal_api?
|
202
|
-
private_api_tag? || docstring.describes_internal_api?
|
203
|
-
end
|
204
|
-
|
205
|
-
def tagged_as_private?
|
206
|
-
private_tag? || docstring.describes_private_object?
|
207
|
-
end
|
208
|
-
|
209
|
-
def protected?
|
210
|
-
visibility == :protected
|
211
|
-
end
|
212
|
-
|
213
|
-
def public?
|
214
|
-
visibility == :public
|
215
|
-
end
|
216
|
-
|
217
|
-
def in_root?
|
218
|
-
depth == 1
|
219
|
-
end
|
220
|
-
|
221
|
-
# @return [Boolean] +true+ if the object has no documentation at all
|
222
|
-
def undocumented?
|
223
|
-
original_docstring.empty?
|
224
|
-
end
|
225
|
-
|
226
|
-
def unconsidered_tag_count
|
227
|
-
unconsidered_tags.size
|
228
|
-
end
|
229
|
-
|
230
|
-
def inspect
|
231
|
-
"#<#{self.class.to_s}: #{fullname}>"
|
232
|
-
end
|
233
|
-
|
234
|
-
protected
|
235
|
-
|
236
|
-
def multi_code_examples?(text)
|
237
|
-
text.scan(/\b(#{Regexp.escape(name)})[^_0-9\!\?]/m).size > 1
|
238
|
-
end
|
239
|
-
|
240
|
-
# @return [Boolean]
|
241
|
-
# +true+ if the object or its parent is tagged as @private
|
242
|
-
def private_tag?
|
243
|
-
!private_tag.nil?
|
244
|
-
end
|
245
|
-
|
246
|
-
def private_tag
|
247
|
-
@__private_tag
|
248
|
-
end
|
249
|
-
|
250
|
-
def private_api_tag?
|
251
|
-
api_tag && api_tag.text == 'private'
|
252
|
-
end
|
253
|
-
|
254
|
-
def tag(name)
|
255
|
-
tags(name).first
|
256
|
-
end
|
257
|
-
|
258
|
-
def tags(name = nil)
|
259
|
-
object.tags(name)
|
260
|
-
rescue ::YARD::CodeObjects::ProxyMethodError
|
261
|
-
# this error is raised by YARD
|
262
|
-
# see broken.rb in test fixtures
|
263
|
-
[]
|
264
|
-
end
|
265
|
-
|
266
|
-
# @return [Array]
|
267
|
-
# YARD tags that are not already covered by other wrapper methods
|
268
|
-
def unconsidered_tags
|
269
|
-
@unconsidered_tags ||= tags.reject do |tag|
|
270
|
-
auto_generated_tag?(tag) ||
|
271
|
-
CONSIDERED_YARD_TAGS.include?(tag.tag_name)
|
272
|
-
end
|
273
|
-
end
|
274
|
-
|
275
|
-
def __depth(i = 0)
|
276
|
-
if parent
|
277
|
-
parent.__depth(i+1)
|
278
|
-
else
|
279
|
-
i
|
280
|
-
end
|
281
|
-
end
|
282
|
-
|
283
|
-
private
|
284
|
-
|
285
|
-
def __api_tag
|
286
|
-
tag(:api) || (parent && parent.api_tag)
|
287
|
-
end
|
288
|
-
|
289
|
-
def __private_tag
|
290
|
-
tag(:private) || (parent && parent.private_tag)
|
291
|
-
end
|
292
|
-
|
293
|
-
def auto_generated_tag?(tag)
|
294
|
-
tag.text.to_s.empty? &&
|
295
|
-
AUTO_GENERATED_TAG_NAMES.include?(tag.tag_name)
|
296
|
-
end
|
297
|
-
end
|
298
|
-
end
|
299
|
-
end
|
300
|
-
end
|
301
|
-
end
|
302
|
-
end
|