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.
Files changed (259) hide show
  1. checksums.yaml +4 -4
  2. data/.rubocop.yml +15 -0
  3. data/.rubocop_todo.yml +94 -0
  4. data/CHANGELOG.md +26 -2
  5. data/Gemfile +5 -2
  6. data/README.md +3 -3
  7. data/Rakefile +6 -2
  8. data/bin/inch +3 -3
  9. data/config/{example.yml → .inch.yml.sample} +1 -0
  10. data/config/base.rb +53 -0
  11. data/config/elixir.rb +43 -0
  12. data/config/nodejs.rb +10 -0
  13. data/config/{defaults.rb → ruby.rb} +5 -54
  14. data/inch.gemspec +7 -7
  15. data/lib/inch.rb +14 -9
  16. data/lib/inch/api.rb +10 -10
  17. data/lib/inch/api/compare.rb +2 -2
  18. data/lib/inch/api/compare/code_objects.rb +2 -3
  19. data/lib/inch/api/compare/codebases.rb +1 -1
  20. data/lib/inch/api/diff.rb +13 -16
  21. data/lib/inch/api/filter.rb +1 -1
  22. data/lib/inch/api/get.rb +2 -2
  23. data/lib/inch/api/options/base.rb +4 -4
  24. data/lib/inch/api/options/filter.rb +0 -4
  25. data/lib/inch/api/options/suggest.rb +2 -6
  26. data/lib/inch/api/stats.rb +0 -1
  27. data/lib/inch/api/suggest.rb +9 -10
  28. data/lib/inch/cli.rb +6 -6
  29. data/lib/inch/cli/arguments.rb +2 -2
  30. data/lib/inch/cli/command.rb +15 -15
  31. data/lib/inch/cli/command/base.rb +30 -9
  32. data/lib/inch/cli/command/base_list.rb +2 -2
  33. data/lib/inch/cli/command/console.rb +5 -5
  34. data/lib/inch/cli/command/diff.rb +9 -9
  35. data/lib/inch/cli/command/inspect.rb +5 -4
  36. data/lib/inch/cli/command/list.rb +4 -4
  37. data/lib/inch/cli/command/options/base.rb +17 -16
  38. data/lib/inch/cli/command/options/base_list.rb +9 -5
  39. data/lib/inch/cli/command/options/console.rb +4 -3
  40. data/lib/inch/cli/command/options/diff.rb +8 -6
  41. data/lib/inch/cli/command/options/inspect.rb +2 -2
  42. data/lib/inch/cli/command/options/list.rb +3 -2
  43. data/lib/inch/cli/command/options/show.rb +2 -2
  44. data/lib/inch/cli/command/options/stats.rb +2 -1
  45. data/lib/inch/cli/command/options/suggest.rb +6 -3
  46. data/lib/inch/cli/command/output/base.rb +4 -6
  47. data/lib/inch/cli/command/output/console.rb +6 -7
  48. data/lib/inch/cli/command/output/diff.rb +6 -6
  49. data/lib/inch/cli/command/output/inspect.rb +6 -8
  50. data/lib/inch/cli/command/output/list.rb +0 -1
  51. data/lib/inch/cli/command/output/show.rb +4 -5
  52. data/lib/inch/cli/command/output/stats.rb +21 -21
  53. data/lib/inch/cli/command/output/suggest.rb +31 -28
  54. data/lib/inch/cli/command/show.rb +4 -4
  55. data/lib/inch/cli/command/stats.rb +4 -4
  56. data/lib/inch/cli/command/suggest.rb +6 -6
  57. data/lib/inch/cli/command_parser.rb +6 -5
  58. data/lib/inch/cli/sparkline_helper.rb +6 -6
  59. data/lib/inch/cli/trace_helper.rb +1 -1
  60. data/lib/inch/cli/yardopts_helper.rb +4 -3
  61. data/lib/inch/code_object.rb +3 -3
  62. data/lib/inch/code_object/converter.rb +6 -8
  63. data/lib/inch/code_object/provider.rb +11 -11
  64. data/lib/inch/code_object/proxy.rb +61 -30
  65. data/lib/inch/codebase.rb +7 -8
  66. data/lib/inch/codebase/object.rb +60 -0
  67. data/lib/inch/codebase/objects.rb +8 -10
  68. data/lib/inch/codebase/objects_filter.rb +7 -5
  69. data/lib/inch/codebase/proxy.rb +4 -4
  70. data/lib/inch/codebase/serializer.rb +3 -3
  71. data/lib/inch/config.rb +42 -11
  72. data/lib/inch/config/base.rb +8 -29
  73. data/lib/inch/config/codebase.rb +32 -7
  74. data/lib/inch/config/evaluation.rb +61 -0
  75. data/lib/inch/core_ext.rb +1 -1
  76. data/lib/inch/core_ext/string.rb +1 -1
  77. data/lib/inch/evaluation.rb +13 -21
  78. data/lib/inch/evaluation/file.rb +4 -2
  79. data/lib/inch/evaluation/grade_list.rb +4 -4
  80. data/lib/inch/evaluation/priority_range.rb +3 -0
  81. data/lib/inch/evaluation/proxy.rb +139 -14
  82. data/lib/inch/evaluation/role.rb +99 -0
  83. data/lib/inch/language.rb +3 -0
  84. data/lib/inch/language/elixir/code_object/base.rb +197 -0
  85. data/lib/inch/language/elixir/code_object/function_object.rb +74 -0
  86. data/lib/inch/language/elixir/code_object/module_object.rb +23 -0
  87. data/lib/inch/language/elixir/code_object/type_object.rb +11 -0
  88. data/lib/inch/language/elixir/evaluation/base.rb +28 -0
  89. data/lib/inch/language/elixir/evaluation/function_object.rb +31 -0
  90. data/lib/inch/language/elixir/evaluation/module_object.rb +27 -0
  91. data/lib/inch/language/elixir/evaluation/type_object.rb +11 -0
  92. data/lib/inch/language/elixir/import.rb +24 -0
  93. data/lib/inch/language/elixir/provider/reader.rb +19 -0
  94. data/lib/inch/language/elixir/provider/reader/object.rb +63 -0
  95. data/lib/inch/language/elixir/provider/reader/object/base.rb +191 -0
  96. data/lib/inch/language/elixir/provider/reader/object/function_object.rb +26 -0
  97. data/lib/inch/language/elixir/provider/reader/object/module_object.rb +22 -0
  98. data/lib/inch/language/elixir/provider/reader/object/type_object.rb +15 -0
  99. data/lib/inch/language/elixir/provider/reader/parser.rb +55 -0
  100. data/lib/inch/language/elixir/roles/base.rb +32 -0
  101. data/lib/inch/language/elixir/roles/function.rb +112 -0
  102. data/lib/inch/language/elixir/roles/module.rb +64 -0
  103. data/lib/inch/language/elixir/roles/object.rb +76 -0
  104. data/lib/inch/language/elixir/roles/type.rb +13 -0
  105. data/lib/inch/language/nodejs/import.rb +8 -0
  106. data/lib/inch/language/nodejs/provider/jsdoc.rb +19 -0
  107. data/lib/inch/language/nodejs/provider/jsdoc/object.rb +55 -0
  108. data/lib/inch/language/nodejs/provider/jsdoc/object/base.rb +191 -0
  109. data/lib/inch/language/nodejs/provider/jsdoc/parser.rb +59 -0
  110. data/lib/inch/language/ruby/code_object/base.rb +197 -0
  111. data/lib/inch/language/ruby/code_object/class_object.rb +10 -0
  112. data/lib/inch/language/ruby/code_object/class_variable_object.rb +10 -0
  113. data/lib/inch/language/ruby/code_object/constant_object.rb +10 -0
  114. data/lib/inch/language/ruby/code_object/method_object.rb +85 -0
  115. data/lib/inch/language/ruby/code_object/method_parameter_object.rb +64 -0
  116. data/lib/inch/language/ruby/code_object/module_object.rb +10 -0
  117. data/lib/inch/language/ruby/code_object/namespace_object.rb +35 -0
  118. data/lib/inch/language/ruby/evaluation/base.rb +45 -0
  119. data/lib/inch/language/ruby/evaluation/class_object.rb +10 -0
  120. data/lib/inch/language/ruby/evaluation/class_variable_object.rb +21 -0
  121. data/lib/inch/language/ruby/evaluation/constant_object.rb +21 -0
  122. data/lib/inch/language/ruby/evaluation/method_object.rb +74 -0
  123. data/lib/inch/language/ruby/evaluation/module_object.rb +10 -0
  124. data/lib/inch/language/ruby/evaluation/namespace_object.rb +30 -0
  125. data/lib/inch/language/ruby/import.rb +34 -0
  126. data/lib/inch/language/ruby/provider/yard.rb +58 -0
  127. data/lib/inch/language/ruby/provider/yard/docstring.rb +162 -0
  128. data/lib/inch/language/ruby/provider/yard/nodoc_helper.rb +97 -0
  129. data/lib/inch/language/ruby/provider/yard/object.rb +63 -0
  130. data/lib/inch/language/ruby/provider/yard/object/base.rb +325 -0
  131. data/lib/inch/language/ruby/provider/yard/object/class_object.rb +14 -0
  132. data/lib/inch/language/ruby/provider/yard/object/class_variable_object.rb +14 -0
  133. data/lib/inch/language/ruby/provider/yard/object/constant_object.rb +14 -0
  134. data/lib/inch/language/ruby/provider/yard/object/method_object.rb +170 -0
  135. data/lib/inch/language/ruby/provider/yard/object/method_parameter_object.rb +94 -0
  136. data/lib/inch/language/ruby/provider/yard/object/method_signature.rb +120 -0
  137. data/lib/inch/language/ruby/provider/yard/object/module_object.rb +14 -0
  138. data/lib/inch/language/ruby/provider/yard/object/namespace_object.rb +46 -0
  139. data/lib/inch/language/ruby/provider/yard/object/root_object.rb +14 -0
  140. data/lib/inch/language/ruby/provider/yard/parser.rb +71 -0
  141. data/lib/inch/language/ruby/roles/base.rb +17 -0
  142. data/lib/inch/language/ruby/roles/class_variable.rb +53 -0
  143. data/lib/inch/language/ruby/roles/constant.rb +53 -0
  144. data/lib/inch/language/ruby/roles/method.rb +112 -0
  145. data/lib/inch/language/ruby/roles/method_parameter.rb +84 -0
  146. data/lib/inch/language/ruby/roles/missing.rb +24 -0
  147. data/lib/inch/language/ruby/roles/namespace.rb +89 -0
  148. data/lib/inch/language/ruby/roles/object.rb +120 -0
  149. data/lib/inch/rake.rb +2 -2
  150. data/lib/inch/rake/suggest.rb +7 -2
  151. data/lib/inch/utils/buffered_ui.rb +16 -0
  152. data/lib/inch/utils/shell_helper.rb +1 -1
  153. data/lib/inch/utils/ui.rb +5 -5
  154. data/lib/inch/utils/weighted_list.rb +2 -3
  155. data/lib/inch/version.rb +1 -1
  156. data/test/fixtures/{code_examples → ruby/code_examples}/lib/foo.rb +0 -0
  157. data/test/fixtures/{diff1 → ruby/diff1}/lib/diff1.rb +0 -0
  158. data/test/fixtures/{diff2 → ruby/diff2}/lib/diff2.rb +0 -0
  159. data/test/fixtures/{inch-yml → ruby/inch-yml}/.inch.yml +0 -0
  160. data/test/fixtures/{inch-yml → ruby/inch-yml}/foo/bar.rb +0 -0
  161. data/test/fixtures/{inch-yml → ruby/inch-yml}/foo/vendor/base.rb +0 -0
  162. data/test/fixtures/{parameters → ruby/parameters}/lib/foo.rb +0 -0
  163. data/test/fixtures/{readme → ruby/readme}/lib/foo.rb +0 -0
  164. data/test/fixtures/{really_good → ruby/really_good}/lib/foo.rb +0 -0
  165. data/test/fixtures/{really_good_pedantic → ruby/really_good_pedantic}/lib/foo.rb +0 -0
  166. data/test/fixtures/{simple → ruby/simple}/README +0 -0
  167. data/test/fixtures/{simple → ruby/simple}/lib/broken.rb +11 -19
  168. data/test/fixtures/ruby/simple/lib/broken_ruby_2_0_features.rb +7 -0
  169. data/test/fixtures/ruby/simple/lib/directives.rb +8 -0
  170. data/test/fixtures/{simple → ruby/simple}/lib/foo.rb +22 -1
  171. data/test/fixtures/{simple → ruby/simple}/lib/nodoc.rb +0 -0
  172. data/test/fixtures/{simple → ruby/simple}/lib/role_methods.rb +0 -0
  173. data/test/fixtures/{simple → ruby/simple}/lib/role_namespaces.rb +0 -0
  174. data/test/fixtures/{visibility → ruby/visibility}/lib/foo.rb +0 -0
  175. data/test/fixtures/{yardopts → ruby/yardopts}/.yardopts +0 -0
  176. data/test/fixtures/{yardopts → ruby/yardopts}/foo/bar.rb +0 -0
  177. data/test/integration/api/compare/codebases.rb +3 -3
  178. data/test/integration/cli/command/console_test.rb +6 -6
  179. data/test/integration/cli/command/diff_test.rb +62 -0
  180. data/test/integration/cli/command/inspect_test.rb +5 -6
  181. data/test/integration/cli/command/list_test.rb +4 -5
  182. data/test/integration/cli/command/show_test.rb +5 -5
  183. data/test/integration/cli/command/stats_test.rb +3 -3
  184. data/test/integration/cli/command/suggest_test.rb +13 -13
  185. data/test/integration/stats_options_test.rb +4 -4
  186. data/test/integration/visibility_options_test.rb +14 -14
  187. data/test/shared/base_list.rb +4 -3
  188. data/test/test_helper.rb +13 -13
  189. data/test/unit/api/filter_test.rb +7 -7
  190. data/test/unit/api/get_test.rb +1 -1
  191. data/test/unit/api/list_test.rb +1 -1
  192. data/test/unit/api/options/base_test.rb +3 -3
  193. data/test/unit/api/stats_test.rb +1 -1
  194. data/test/unit/api/suggest_test.rb +3 -3
  195. data/test/unit/cli/arguments_test.rb +2 -2
  196. data/test/unit/cli/command/base_test.rb +1 -1
  197. data/test/unit/cli/command/options/base_list_test.rb +2 -2
  198. data/test/unit/cli/command/options/base_object_test.rb +1 -1
  199. data/test/unit/cli/command/options/base_test.rb +1 -1
  200. data/test/unit/cli/command_parser_test.rb +3 -3
  201. data/test/unit/cli/trace_helper_test.rb +1 -1
  202. data/test/unit/cli/yardopts_helper_test.rb +6 -5
  203. data/test/unit/code_object/converter_test.rb +1 -1
  204. data/test/unit/code_object/provider_test.rb +2 -2
  205. data/test/unit/code_object/proxy_test.rb +2 -2
  206. data/test/unit/codebase/objects_test.rb +2 -2
  207. data/test/unit/codebase/proxy_test.rb +7 -5
  208. data/test/unit/config/codebase_test.rb +4 -4
  209. data/test/unit/config_test.rb +28 -0
  210. data/test/unit/evaluation/{role/base_test.rb → role_test.rb} +7 -7
  211. data/test/unit/{code_object/proxy → language/ruby/code_object}/method_object_test.rb +66 -21
  212. data/test/unit/{code_object → language/ruby}/provider/yard/docstring_test.rb +74 -38
  213. data/test/unit/{code_object → language/ruby}/provider/yard/nodoc_helper_test.rb +9 -7
  214. data/test/unit/{code_object → language/ruby}/provider/yard/object/method_object_test.rb +21 -11
  215. data/test/unit/language/ruby/provider/yard_test.rb +25 -0
  216. data/test/unit/utils/buffered_ui_test.rb +48 -0
  217. data/test/unit/utils/ui_test.rb +7 -7
  218. data/test/unit/utils/weighted_list_test.rb +7 -4
  219. metadata +139 -93
  220. data/lib/inch/code_object/provider/yard.rb +0 -57
  221. data/lib/inch/code_object/provider/yard/docstring.rb +0 -133
  222. data/lib/inch/code_object/provider/yard/nodoc_helper.rb +0 -93
  223. data/lib/inch/code_object/provider/yard/object.rb +0 -60
  224. data/lib/inch/code_object/provider/yard/object/base.rb +0 -302
  225. data/lib/inch/code_object/provider/yard/object/class_object.rb +0 -12
  226. data/lib/inch/code_object/provider/yard/object/class_variable_object.rb +0 -12
  227. data/lib/inch/code_object/provider/yard/object/constant_object.rb +0 -12
  228. data/lib/inch/code_object/provider/yard/object/method_object.rb +0 -153
  229. data/lib/inch/code_object/provider/yard/object/method_parameter_object.rb +0 -88
  230. data/lib/inch/code_object/provider/yard/object/method_signature.rb +0 -114
  231. data/lib/inch/code_object/provider/yard/object/module_object.rb +0 -12
  232. data/lib/inch/code_object/provider/yard/object/namespace_object.rb +0 -47
  233. data/lib/inch/code_object/provider/yard/object/root_object.rb +0 -12
  234. data/lib/inch/code_object/provider/yard/parser.rb +0 -62
  235. data/lib/inch/code_object/proxy/base.rb +0 -241
  236. data/lib/inch/code_object/proxy/class_object.rb +0 -8
  237. data/lib/inch/code_object/proxy/class_variable_object.rb +0 -8
  238. data/lib/inch/code_object/proxy/constant_object.rb +0 -8
  239. data/lib/inch/code_object/proxy/method_object.rb +0 -82
  240. data/lib/inch/code_object/proxy/method_parameter_object.rb +0 -60
  241. data/lib/inch/code_object/proxy/module_object.rb +0 -8
  242. data/lib/inch/code_object/proxy/namespace_object.rb +0 -33
  243. data/lib/inch/evaluation/object_schema.rb +0 -30
  244. data/lib/inch/evaluation/proxy/base.rb +0 -164
  245. data/lib/inch/evaluation/proxy/class_object.rb +0 -8
  246. data/lib/inch/evaluation/proxy/class_variable_object.rb +0 -19
  247. data/lib/inch/evaluation/proxy/constant_object.rb +0 -19
  248. data/lib/inch/evaluation/proxy/method_object.rb +0 -65
  249. data/lib/inch/evaluation/proxy/module_object.rb +0 -8
  250. data/lib/inch/evaluation/proxy/namespace_object.rb +0 -27
  251. data/lib/inch/evaluation/role/base.rb +0 -92
  252. data/lib/inch/evaluation/role/class_variable.rb +0 -55
  253. data/lib/inch/evaluation/role/constant.rb +0 -55
  254. data/lib/inch/evaluation/role/method.rb +0 -126
  255. data/lib/inch/evaluation/role/method_parameter.rb +0 -91
  256. data/lib/inch/evaluation/role/missing.rb +0 -20
  257. data/lib/inch/evaluation/role/namespace.rb +0 -85
  258. data/lib/inch/evaluation/role/object.rb +0 -143
  259. data/test/unit/code_object/provider/yard_test.rb +0 -25
@@ -0,0 +1,14 @@
1
+ module Inch
2
+ module Language
3
+ module Ruby
4
+ module Provider
5
+ module YARD
6
+ module Object
7
+ class ClassObject < NamespaceObject
8
+ end
9
+ end
10
+ end
11
+ end
12
+ end
13
+ end
14
+ end
@@ -0,0 +1,14 @@
1
+ module Inch
2
+ module Language
3
+ module Ruby
4
+ module Provider
5
+ module YARD
6
+ module Object
7
+ class ClassVariableObject < Base
8
+ end
9
+ end
10
+ end
11
+ end
12
+ end
13
+ end
14
+ end
@@ -0,0 +1,14 @@
1
+ module Inch
2
+ module Language
3
+ module Ruby
4
+ module Provider
5
+ module YARD
6
+ module Object
7
+ class ConstantObject < Base
8
+ end
9
+ end
10
+ end
11
+ end
12
+ end
13
+ end
14
+ end
@@ -0,0 +1,170 @@
1
+ require "inch/language/ruby/provider/yard/object/method_signature"
2
+
3
+ module Inch
4
+ module Language
5
+ module Ruby
6
+ module Provider
7
+ module YARD
8
+ module Object
9
+ # Proxy class for methods
10
+ class MethodObject < Base
11
+ UNUSABLE_RETURN_VALUES = %w(nil nothing undefined void)
12
+
13
+ def aliases_fullnames
14
+ object.aliases.map(&:path)
15
+ end
16
+
17
+ def bang_name?
18
+ name =~ /\!$/
19
+ end
20
+
21
+ def constructor?
22
+ name == :initialize
23
+ end
24
+
25
+ def getter?
26
+ attr_info = object.attr_info || {}
27
+ read_info = attr_info[:read]
28
+ if read_info
29
+ read_info.path == fullname
30
+ else
31
+ parent.child(:"#{name}=")
32
+ end
33
+ end
34
+
35
+ def has_code_example?
36
+ signatures.any? { |s| s.has_code_example? }
37
+ end
38
+
39
+ def has_doc?
40
+ signatures.any? { |s| s.has_doc? }
41
+ end
42
+
43
+ def method?
44
+ true
45
+ end
46
+
47
+ def parameters
48
+ @parameters ||= signatures.map(&:parameters).flatten
49
+ end
50
+
51
+ def parameter(name)
52
+ parameters.find { |p| p.name == name.to_s }
53
+ end
54
+
55
+ def overridden?
56
+ !!object.overridden_method
57
+ end
58
+
59
+ def overridden_method
60
+ return unless overridden?
61
+ @overridden_method ||= YARD::Object.for(object.overridden_method)
62
+ end
63
+
64
+ def overridden_method_fullname
65
+ return unless overridden?
66
+ overridden_method.fullname
67
+ end
68
+
69
+ # Returns +true+ if a return value is described by it's type or
70
+ # mentioned in the docstring (e.g. "Returns a String").
71
+ def return_mentioned?
72
+ return_tags.any? do |t|
73
+ !t.types.nil? && !t.types.empty? && !YARD.implicit_tag?(t, self)
74
+ end || docstring.mentions_return? && !implicit_docstring?
75
+ end
76
+
77
+ # Returns +true+ if a return value is described by words.
78
+ def return_described?
79
+ return_described_via_tag? ||
80
+ docstring.describes_return? && !implicit_docstring?
81
+ end
82
+
83
+ def return_typed?
84
+ return_mentioned?
85
+ end
86
+
87
+ def setter?
88
+ name =~ /\=$/ && parameters.size == 1
89
+ end
90
+
91
+ def signatures
92
+ base = MethodSignature.new(self, nil)
93
+ overloaded = overload_tags.map do |tag|
94
+ MethodSignature.new(self, tag)
95
+ end
96
+ if overloaded.any? { |s| s.same?(base) }
97
+ overloaded
98
+ else
99
+ [base] + overloaded
100
+ end
101
+ end
102
+
103
+ def questioning_name?
104
+ name =~ /\?$/
105
+ end
106
+
107
+ private
108
+
109
+ # Returns @return tags that are assigned to the getter
110
+ # corresponding to this setter.
111
+ #
112
+ # @return [Array<::YARD::Tag>]
113
+ def attributed_return_tags
114
+ if setter? && object.tags(:return).empty?
115
+ method = corresponding_getter
116
+ return method.object.tags(:return) if method
117
+ end
118
+ []
119
+ end
120
+
121
+ # @return [MethodObject,nil]
122
+ def corresponding_getter
123
+ clean_name = name.to_s.gsub(/(\=)$/, "")
124
+ parent.child(clean_name.to_sym)
125
+ end
126
+
127
+ # Returns +true+ if the docstring was generated by YARD.
128
+ def implicit_docstring?
129
+ YARD.implicit_docstring?(docstring, self)
130
+ end
131
+
132
+ # @return [Array<::YARD::Tag>]
133
+ def overload_tags
134
+ object.tags(:overload)
135
+ end
136
+
137
+ # @return [Array<::YARD::Tag>]
138
+ def overloaded_return_tags
139
+ overload_tags.map do |overload_tag|
140
+ overload_tag.tag(:return)
141
+ end.compact
142
+ end
143
+
144
+ # @return [Array<::YARD::Tag>]
145
+ def return_tags
146
+ object.tags(:return) +
147
+ overloaded_return_tags +
148
+ attributed_return_tags
149
+ end
150
+
151
+ # Returns +true+ if a return value is described by words.
152
+ def return_described_via_tag?
153
+ return_tags.any? do |t|
154
+ return_tag_describes_unusable_value?(t) ||
155
+ !t.text.empty? && !YARD.implicit_tag?(t, self)
156
+ end
157
+ end
158
+
159
+ def return_tag_describes_unusable_value?(t)
160
+ return false if t.types.nil?
161
+ t.types.size == 1 &&
162
+ UNUSABLE_RETURN_VALUES.include?(t.types.first)
163
+ end
164
+ end
165
+ end
166
+ end
167
+ end
168
+ end
169
+ end
170
+ end
@@ -0,0 +1,94 @@
1
+ module Inch
2
+ module Language
3
+ module Ruby
4
+ module Provider
5
+ module YARD
6
+ module Object
7
+ # Proxy class for method parameters
8
+ class MethodParameterObject
9
+ attr_reader :name # @return [String]
10
+
11
+ # @param method [YARD::Object::MethodObject] the method the
12
+ # parameter belongs to
13
+ # @param name [String] the name of the parameter
14
+ # @param in_signature [String] how the parameter is noted in the
15
+ # method's signature
16
+ # @param tag [YARD::Tags::Tag] the Tag object for the parameter
17
+ def initialize(method, name, in_signature, tag)
18
+ @method = method
19
+ @name = name
20
+ @tag = tag
21
+ @in_signature = in_signature
22
+ end
23
+
24
+ BAD_NAME_EXCEPTIONS = %w(id)
25
+ BAD_NAME_THRESHOLD = 3
26
+
27
+ # @return [Boolean] +true+ if the name of the parameter is
28
+ # uncommunicative
29
+ def bad_name?
30
+ return false if BAD_NAME_EXCEPTIONS.include?(name)
31
+ name.size < BAD_NAME_THRESHOLD || name =~ /[0-9]$/
32
+ end
33
+
34
+ # @return [Boolean] +true+ if the parameter is a block
35
+ def block?
36
+ @in_signature.to_s =~ /^\&/
37
+ end
38
+
39
+ # @return [Boolean] +true+ if an additional description given?
40
+ def described?
41
+ described_by_tag? || described_by_docstring?
42
+ end
43
+
44
+ # @return [Boolean] +true+ if the parameter is mentioned in the docs
45
+ def mentioned?
46
+ !!@tag || mentioned_by_docstring?
47
+ end
48
+
49
+ # @return [Boolean] +true+ if the parameter is a splat argument
50
+ def splat?
51
+ @in_signature.to_s =~ /^\*/
52
+ end
53
+
54
+ # @return [Boolean] +true+ if the type of the parameter is defined
55
+ def typed?
56
+ @tag && @tag.types && !@tag.types.empty?
57
+ end
58
+
59
+ # @return [Boolean] +true+ if the parameter is mentioned in the
60
+ # docs, but not present in the method's signature
61
+ def wrongly_mentioned?
62
+ mentioned? && !@in_signature
63
+ end
64
+
65
+ private
66
+
67
+ def described_by_tag?
68
+ @tag && @tag.text && !@tag.text.empty?
69
+ end
70
+
71
+ def described_by_docstring?
72
+ if @method.docstring.describes_parameter?(name)
73
+ true
74
+ else
75
+ unsplatted = name.gsub(/^[\&\*]/, "")
76
+ @method.docstring.describes_parameter?(unsplatted)
77
+ end
78
+ end
79
+
80
+ def mentioned_by_docstring?
81
+ if @method.docstring.mentions_parameter?(name)
82
+ true
83
+ else
84
+ unsplatted = name.gsub(/^[\&\*]/, "")
85
+ @method.docstring.mentions_parameter?(unsplatted)
86
+ end
87
+ end
88
+ end
89
+ end
90
+ end
91
+ end
92
+ end
93
+ end
94
+ end
@@ -0,0 +1,120 @@
1
+ module Inch
2
+ module Language
3
+ module Ruby
4
+ module Provider
5
+ module YARD
6
+ module Object
7
+ # Utility class to describe (overloaded) method signatures
8
+ class MethodSignature < Struct.new(:method, :yard_tag)
9
+ attr_reader :method, :docstring
10
+
11
+ # @param method [Provider::YARD::Object::MethodObject]
12
+ # @param yard_tag [::YARD::Tags::Tag,nil] if nil, the method's
13
+ # normal signature is used
14
+ def initialize(method, yard_tag = nil)
15
+ @method = method
16
+ @yard_tag = yard_tag
17
+ @docstring =
18
+ Provider::YARD::Docstring.new(relevant_object.docstring)
19
+ end
20
+
21
+ def all_signature_parameter_names
22
+ relevant_object.parameters.map(&:first)
23
+ end
24
+
25
+ def has_code_example?
26
+ if docstring.contains_code_example?
27
+ true
28
+ else
29
+ !relevant_object.tags(:example).empty?
30
+ end
31
+ end
32
+
33
+ def has_doc?
34
+ !docstring.empty? && !implicit_docstring?
35
+ end
36
+
37
+ def parameters
38
+ @parameters ||= all_parameter_names.map do |name|
39
+ signature_name = in_signature(name)
40
+ tag = parameter_tag(name) || parameter_tag(signature_name)
41
+ MethodParameterObject.new(method, name, signature_name, tag)
42
+ end
43
+ end
44
+
45
+ # Returns the parameter with the given +name+.
46
+ # @param name [String,Symbol]
47
+ # @return [MethodParameterObject]
48
+ def parameter(name)
49
+ parameters.find { |p| p.name == name.to_s }
50
+ end
51
+
52
+ # Returns +true+ if the other signature is identical to self
53
+ # @param other [MethodSignature]
54
+ # @return [Boolean]
55
+ def same?(other)
56
+ all_signature_parameter_names ==
57
+ other.all_signature_parameter_names
58
+ end
59
+
60
+ # Returns the actual signature of the method.
61
+ # @return [String]
62
+ def signature
63
+ relevant_object.signature.gsub(/^(def\ )/, "")
64
+ end
65
+
66
+ private
67
+
68
+ def all_parameter_names
69
+ all_names = all_signature_parameter_names +
70
+ parameter_tags.map(&:name)
71
+ all_names.map do |name|
72
+ normalize_parameter_name(name) if name
73
+ end.compact.uniq
74
+ end
75
+
76
+ # Returns +true+ if the docstring was generated by YARD
77
+ def implicit_docstring?
78
+ YARD.implicit_docstring?(docstring, method)
79
+ end
80
+
81
+ # Returns how the given parameter is noted in the method's
82
+ # signature.
83
+ #
84
+ # @param name [String] parameter name
85
+ # @return [String]
86
+ def in_signature(name)
87
+ possible_names = [name, "*#{name}", "&#{name}"]
88
+ (all_signature_parameter_names & possible_names).first
89
+ end
90
+
91
+ # Removes block, splat symbols, dollar sign,
92
+ # leading and trailing brackets from a given +name+
93
+ # (sometimes used to indicate optional parameters in overload
94
+ # signatures).
95
+ # @param name [String] parameter name
96
+ # @return [String]
97
+ def normalize_parameter_name(name)
98
+ name.gsub(/[\&\*\$\[\]]/, "")
99
+ end
100
+
101
+ def parameter_tag(param_name)
102
+ parameter_tags.find do |tag|
103
+ tag.name == param_name
104
+ end
105
+ end
106
+
107
+ def parameter_tags
108
+ relevant_object.tags(:param)
109
+ end
110
+
111
+ def relevant_object
112
+ @yard_tag || method.object
113
+ end
114
+ end
115
+ end
116
+ end
117
+ end
118
+ end
119
+ end
120
+ end
@@ -0,0 +1,14 @@
1
+ module Inch
2
+ module Language
3
+ module Ruby
4
+ module Provider
5
+ module YARD
6
+ module Object
7
+ class ModuleObject < NamespaceObject
8
+ end
9
+ end
10
+ end
11
+ end
12
+ end
13
+ end
14
+ end