yard-value 1.2.0
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.
- data/README +5 -0
- data/Rakefile +17 -0
- data/lib/yard-value-1.0.rb +57 -0
- data/lib/yard-value/version.rb +16 -0
- data/test/unit/yard-value-1.0.rb +164 -0
- data/test/unit/yard-value/version.rb +4 -0
- metadata +106 -0
data/README
ADDED
data/Rakefile
ADDED
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
# -*- coding: utf-8 -*-
|
|
2
|
+
|
|
3
|
+
require 'inventory/rake-1.0'
|
|
4
|
+
|
|
5
|
+
load File.expand_path('../lib/yard-value/version.rb', __FILE__)
|
|
6
|
+
|
|
7
|
+
Inventory::Rake::Tasks.define YARDValue::Version, :gem => proc{ |_, s|
|
|
8
|
+
s.author = 'Nikolai Weibull'
|
|
9
|
+
s.email = 'now@bitwi.se'
|
|
10
|
+
s.homepage = 'https://github.com/now/yard-value'
|
|
11
|
+
}
|
|
12
|
+
|
|
13
|
+
Inventory::Rake::Tasks.unless_installing_dependencies do
|
|
14
|
+
require 'lookout/rake-3.0'
|
|
15
|
+
# TODO: Silence warnings generated from YARD (remove this once we plug them)
|
|
16
|
+
Lookout::Rake::Tasks::Test.new :options => []
|
|
17
|
+
end
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
# -*- coding: utf-8 -*-
|
|
2
|
+
|
|
3
|
+
# Namespace for YARD extensions for Value.
|
|
4
|
+
module YARDValue
|
|
5
|
+
load File.expand_path('../yard-value/version.rb', __FILE__)
|
|
6
|
+
Version.load
|
|
7
|
+
end
|
|
8
|
+
|
|
9
|
+
class YARD::Handlers::Ruby::ValuesHandler < YARD::Handlers::Ruby::Base
|
|
10
|
+
handles method_call('Value')
|
|
11
|
+
namespace_only
|
|
12
|
+
|
|
13
|
+
process do
|
|
14
|
+
parameters = statement.parameters(false)
|
|
15
|
+
if YARD::Parser::Ruby::AstNode === parameters[-1][0] and
|
|
16
|
+
parameters[-1][0].type == :assoc and
|
|
17
|
+
comparable = parameters[-1].find{ |e| e.jump(:ident).source == 'comparable' }
|
|
18
|
+
parameters.pop
|
|
19
|
+
comparables = (comparable[1].type == :array and comparable[1][0].map{ |e| e.jump(:ident).source })
|
|
20
|
+
ancestor 'Comparable'
|
|
21
|
+
ancestor 'Value::Comparable'
|
|
22
|
+
end
|
|
23
|
+
ancestor 'Value'
|
|
24
|
+
initialize = define('initialize', parameters.map{ |e| [e.jump(:ident).source, e.type == :array ? e[0][1].source : nil] })
|
|
25
|
+
initialize.docstring.tags(:param).select{ |e| e.text and not e.text.empty? }.each do |e|
|
|
26
|
+
define e.name.sub(/\A[&*]/, ''), [],
|
|
27
|
+
'@return [%s] %s' % [e.types ? e.types.join(', ') : '', e.text], :protected
|
|
28
|
+
e.text = ''
|
|
29
|
+
end
|
|
30
|
+
initialize.docstring.add_tag(YARD::Tags::Tag.new(:note, 'Comparisons between instances are made between %s.' % join(comparables))) if comparables
|
|
31
|
+
end
|
|
32
|
+
|
|
33
|
+
def ancestor(name)
|
|
34
|
+
modul = Proxy.new(:root, name).tap{ |m| m.type = :module }
|
|
35
|
+
namespace.mixins(scope).unshift(modul) unless namespace.mixins(scope).include? modul
|
|
36
|
+
end
|
|
37
|
+
|
|
38
|
+
def define(name, parameters, docstring = nil, visibility = :public)
|
|
39
|
+
YARD::CodeObjects::MethodObject.new(namespace, name).tap{ |m|
|
|
40
|
+
register(m)
|
|
41
|
+
m.signature = 'def %s%s' %
|
|
42
|
+
[name,
|
|
43
|
+
parameters.empty? ?
|
|
44
|
+
'' :
|
|
45
|
+
'(%s)' % parameters.map{ |n, d| d ? '%s = %s' % [n, d] : n }.join(', ')]
|
|
46
|
+
m.parameters = parameters
|
|
47
|
+
m.docstring = docstring if docstring
|
|
48
|
+
m.visibility = visibility
|
|
49
|
+
}
|
|
50
|
+
end
|
|
51
|
+
|
|
52
|
+
def join(items)
|
|
53
|
+
return items.join('') if items.size < 2
|
|
54
|
+
return items.join(' and ') if items.size < 3
|
|
55
|
+
return '%s, and %s' % [items[0..-2].join(', '), items[-1]]
|
|
56
|
+
end
|
|
57
|
+
end
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
# -*- coding: utf-8 -*-
|
|
2
|
+
|
|
3
|
+
require 'inventory-1.0'
|
|
4
|
+
|
|
5
|
+
module YARDValue
|
|
6
|
+
Version = Inventory.new(1, 2, 0){
|
|
7
|
+
def dependencies
|
|
8
|
+
super + Inventory::Dependencies.new{
|
|
9
|
+
development 'inventory-rake', 1, 3, 0
|
|
10
|
+
development 'lookout', 3, 0, 0
|
|
11
|
+
development 'lookout-rake', 3, 0, 0
|
|
12
|
+
runtime 'yard', 0, 8, 0, :feature => 'yard'
|
|
13
|
+
}
|
|
14
|
+
end
|
|
15
|
+
}
|
|
16
|
+
end
|
|
@@ -0,0 +1,164 @@
|
|
|
1
|
+
# -*- coding: utf-8 -*-
|
|
2
|
+
|
|
3
|
+
Expectations do
|
|
4
|
+
expect [YARD::CodeObjects::Proxy.new(:root, 'Value')] do
|
|
5
|
+
YARD::Registry.clear
|
|
6
|
+
YARD::Parser::SourceParser.parse_string(<<EOS)
|
|
7
|
+
class A
|
|
8
|
+
# @param [String] a
|
|
9
|
+
# @param [Integer] b The b
|
|
10
|
+
Value(:a, :b)
|
|
11
|
+
end
|
|
12
|
+
EOS
|
|
13
|
+
YARD::Registry.at('A').mixins(:instance)
|
|
14
|
+
end
|
|
15
|
+
|
|
16
|
+
expect 'Represents As.' do
|
|
17
|
+
YARD::Registry.clear
|
|
18
|
+
YARD::Parser::SourceParser.parse_string(<<EOS)
|
|
19
|
+
class A
|
|
20
|
+
# Represents As.
|
|
21
|
+
Value(:a, :b)
|
|
22
|
+
end
|
|
23
|
+
EOS
|
|
24
|
+
YARD::Registry.at('A#initialize').docstring
|
|
25
|
+
end
|
|
26
|
+
|
|
27
|
+
expect [['a', nil], ['b', '3']] do
|
|
28
|
+
YARD::Registry.clear
|
|
29
|
+
YARD::Parser::SourceParser.parse_string(<<EOS)
|
|
30
|
+
class A
|
|
31
|
+
Value(:a, [:b, 3])
|
|
32
|
+
end
|
|
33
|
+
EOS
|
|
34
|
+
YARD::Registry.at('A#initialize').parameters
|
|
35
|
+
end
|
|
36
|
+
|
|
37
|
+
expect [:b, :initialize] do
|
|
38
|
+
YARD::Registry.clear
|
|
39
|
+
YARD::Parser::SourceParser.parse_string(<<EOS)
|
|
40
|
+
class A
|
|
41
|
+
# @param [String] a
|
|
42
|
+
# @param [Integer] b The b
|
|
43
|
+
Value(:a, :b)
|
|
44
|
+
end
|
|
45
|
+
EOS
|
|
46
|
+
YARD::Registry.all(:method).map(&:name).sort
|
|
47
|
+
end
|
|
48
|
+
|
|
49
|
+
expect [:b, :initialize] do
|
|
50
|
+
YARD::Registry.clear
|
|
51
|
+
YARD::Parser::SourceParser.parse_string(<<EOS)
|
|
52
|
+
class A
|
|
53
|
+
# @param [String] a
|
|
54
|
+
# @param [Integer] *b The b
|
|
55
|
+
Value(:a, :'*b')
|
|
56
|
+
end
|
|
57
|
+
EOS
|
|
58
|
+
YARD::Registry.all(:method).map(&:name).sort
|
|
59
|
+
end
|
|
60
|
+
|
|
61
|
+
expect [:b, :initialize] do
|
|
62
|
+
YARD::Registry.clear
|
|
63
|
+
YARD::Parser::SourceParser.parse_string(<<EOS)
|
|
64
|
+
class A
|
|
65
|
+
# @param [String] a
|
|
66
|
+
# @param [Integer] &b The b
|
|
67
|
+
Value(:a, :'&b')
|
|
68
|
+
end
|
|
69
|
+
EOS
|
|
70
|
+
YARD::Registry.all(:method).map(&:name).sort
|
|
71
|
+
end
|
|
72
|
+
|
|
73
|
+
expect nil do
|
|
74
|
+
YARD::Registry.clear
|
|
75
|
+
YARD::Parser::SourceParser.parse_string(<<EOS)
|
|
76
|
+
class A
|
|
77
|
+
# @param [String] a
|
|
78
|
+
# @param [Integer] b The b
|
|
79
|
+
Value(:a, :b)
|
|
80
|
+
end
|
|
81
|
+
EOS
|
|
82
|
+
YARD::Registry.at('A#a')
|
|
83
|
+
end
|
|
84
|
+
|
|
85
|
+
expect '@return [Integer] The b' do
|
|
86
|
+
YARD::Registry.clear
|
|
87
|
+
YARD::Parser::SourceParser.parse_string(<<EOS)
|
|
88
|
+
class A
|
|
89
|
+
# @param [String] a
|
|
90
|
+
# @param [Integer] b The b
|
|
91
|
+
Value(:a, :b)
|
|
92
|
+
end
|
|
93
|
+
EOS
|
|
94
|
+
YARD::Registry.at('A#b').docstring.to_raw
|
|
95
|
+
end
|
|
96
|
+
|
|
97
|
+
expect %w'Value Value::Comparable Comparable' do
|
|
98
|
+
YARD::Registry.clear
|
|
99
|
+
YARD::Parser::SourceParser.parse_string(<<EOS)
|
|
100
|
+
class A
|
|
101
|
+
# @param [String] a
|
|
102
|
+
Value(:a, :comparable => true)
|
|
103
|
+
end
|
|
104
|
+
EOS
|
|
105
|
+
YARD::Registry.at('A').inheritance_tree(true)[1..3].map(&:path)
|
|
106
|
+
end
|
|
107
|
+
|
|
108
|
+
expect %w'Value Value::Comparable Comparable' do
|
|
109
|
+
YARD::Registry.clear
|
|
110
|
+
YARD::Parser::SourceParser.parse_string(<<EOS)
|
|
111
|
+
module A
|
|
112
|
+
# @param [String] a
|
|
113
|
+
Value(:a, :comparable => true)
|
|
114
|
+
end
|
|
115
|
+
class B
|
|
116
|
+
include A
|
|
117
|
+
# @param [String] a
|
|
118
|
+
# @param [String] b
|
|
119
|
+
Value(:a, :b, :comparable => true)
|
|
120
|
+
end
|
|
121
|
+
EOS
|
|
122
|
+
YARD::Registry.at('B').inheritance_tree(true)[1..3].map(&:path)
|
|
123
|
+
end
|
|
124
|
+
|
|
125
|
+
expect 'Comparisons between instances are made between a.' do
|
|
126
|
+
YARD::Registry.clear
|
|
127
|
+
YARD::Parser::SourceParser.parse_string(<<EOS)
|
|
128
|
+
class A
|
|
129
|
+
# This is A.
|
|
130
|
+
# @param [String] a
|
|
131
|
+
# @param [String] b
|
|
132
|
+
Value(:a, :b, :other => true, :comparable => [:a])
|
|
133
|
+
end
|
|
134
|
+
EOS
|
|
135
|
+
YARD::Registry.at('A#initialize').docstring.tag(:note).text
|
|
136
|
+
end
|
|
137
|
+
|
|
138
|
+
expect 'Comparisons between instances are made between a and b.' do
|
|
139
|
+
YARD::Registry.clear
|
|
140
|
+
YARD::Parser::SourceParser.parse_string(<<EOS)
|
|
141
|
+
class A
|
|
142
|
+
# @param [String] a
|
|
143
|
+
# @param [String] b
|
|
144
|
+
# @param [String] c
|
|
145
|
+
Value(:a, :b, :c, :comparable => [:a, :b])
|
|
146
|
+
end
|
|
147
|
+
EOS
|
|
148
|
+
YARD::Registry.at('A#initialize').docstring.tag(:note).text
|
|
149
|
+
end
|
|
150
|
+
|
|
151
|
+
expect 'Comparisons between instances are made between a, b, and c.' do
|
|
152
|
+
YARD::Registry.clear
|
|
153
|
+
YARD::Parser::SourceParser.parse_string(<<EOS)
|
|
154
|
+
class A
|
|
155
|
+
# @param [String] a
|
|
156
|
+
# @param [String] b
|
|
157
|
+
# @param [String] c
|
|
158
|
+
# @param [String] d
|
|
159
|
+
Value(:a, :b, :c, :d, :comparable => [:a, :b, :c])
|
|
160
|
+
end
|
|
161
|
+
EOS
|
|
162
|
+
YARD::Registry.at('A#initialize').docstring.tag(:note).text
|
|
163
|
+
end
|
|
164
|
+
end
|
metadata
ADDED
|
@@ -0,0 +1,106 @@
|
|
|
1
|
+
--- !ruby/object:Gem::Specification
|
|
2
|
+
name: yard-value
|
|
3
|
+
version: !ruby/object:Gem::Version
|
|
4
|
+
version: 1.2.0
|
|
5
|
+
prerelease:
|
|
6
|
+
platform: ruby
|
|
7
|
+
authors:
|
|
8
|
+
- Nikolai Weibull
|
|
9
|
+
autorequire:
|
|
10
|
+
bindir: bin
|
|
11
|
+
cert_chain: []
|
|
12
|
+
date: 2012-05-01 00:00:00.000000000 Z
|
|
13
|
+
dependencies:
|
|
14
|
+
- !ruby/object:Gem::Dependency
|
|
15
|
+
name: inventory
|
|
16
|
+
requirement: &2152770480 !ruby/object:Gem::Requirement
|
|
17
|
+
none: false
|
|
18
|
+
requirements:
|
|
19
|
+
- - ~>
|
|
20
|
+
- !ruby/object:Gem::Version
|
|
21
|
+
version: '1.3'
|
|
22
|
+
type: :runtime
|
|
23
|
+
prerelease: false
|
|
24
|
+
version_requirements: *2152770480
|
|
25
|
+
- !ruby/object:Gem::Dependency
|
|
26
|
+
name: inventory-rake
|
|
27
|
+
requirement: &2152769900 !ruby/object:Gem::Requirement
|
|
28
|
+
none: false
|
|
29
|
+
requirements:
|
|
30
|
+
- - ~>
|
|
31
|
+
- !ruby/object:Gem::Version
|
|
32
|
+
version: '1.3'
|
|
33
|
+
type: :development
|
|
34
|
+
prerelease: false
|
|
35
|
+
version_requirements: *2152769900
|
|
36
|
+
- !ruby/object:Gem::Dependency
|
|
37
|
+
name: lookout
|
|
38
|
+
requirement: &2152769300 !ruby/object:Gem::Requirement
|
|
39
|
+
none: false
|
|
40
|
+
requirements:
|
|
41
|
+
- - ~>
|
|
42
|
+
- !ruby/object:Gem::Version
|
|
43
|
+
version: '3.0'
|
|
44
|
+
type: :development
|
|
45
|
+
prerelease: false
|
|
46
|
+
version_requirements: *2152769300
|
|
47
|
+
- !ruby/object:Gem::Dependency
|
|
48
|
+
name: lookout-rake
|
|
49
|
+
requirement: &2152768740 !ruby/object:Gem::Requirement
|
|
50
|
+
none: false
|
|
51
|
+
requirements:
|
|
52
|
+
- - ~>
|
|
53
|
+
- !ruby/object:Gem::Version
|
|
54
|
+
version: '3.0'
|
|
55
|
+
type: :development
|
|
56
|
+
prerelease: false
|
|
57
|
+
version_requirements: *2152768740
|
|
58
|
+
- !ruby/object:Gem::Dependency
|
|
59
|
+
name: yard
|
|
60
|
+
requirement: &2152768060 !ruby/object:Gem::Requirement
|
|
61
|
+
none: false
|
|
62
|
+
requirements:
|
|
63
|
+
- - ~>
|
|
64
|
+
- !ruby/object:Gem::Version
|
|
65
|
+
version: 0.8.0
|
|
66
|
+
type: :runtime
|
|
67
|
+
prerelease: false
|
|
68
|
+
version_requirements: *2152768060
|
|
69
|
+
description: ! " YARD-Value\n\n YARD-Value provides
|
|
70
|
+
YARD handlers for Value¹ objects.\n\n¹ Check out the Value library at http://disu.se/software/value\n"
|
|
71
|
+
email: now@bitwi.se
|
|
72
|
+
executables: []
|
|
73
|
+
extensions: []
|
|
74
|
+
extra_rdoc_files: []
|
|
75
|
+
files:
|
|
76
|
+
- lib/yard-value-1.0.rb
|
|
77
|
+
- lib/yard-value/version.rb
|
|
78
|
+
- test/unit/yard-value-1.0.rb
|
|
79
|
+
- test/unit/yard-value/version.rb
|
|
80
|
+
- README
|
|
81
|
+
- Rakefile
|
|
82
|
+
homepage: https://github.com/now/yard-value
|
|
83
|
+
licenses: []
|
|
84
|
+
post_install_message:
|
|
85
|
+
rdoc_options: []
|
|
86
|
+
require_paths:
|
|
87
|
+
- lib
|
|
88
|
+
required_ruby_version: !ruby/object:Gem::Requirement
|
|
89
|
+
none: false
|
|
90
|
+
requirements:
|
|
91
|
+
- - ! '>='
|
|
92
|
+
- !ruby/object:Gem::Version
|
|
93
|
+
version: '0'
|
|
94
|
+
required_rubygems_version: !ruby/object:Gem::Requirement
|
|
95
|
+
none: false
|
|
96
|
+
requirements:
|
|
97
|
+
- - ! '>='
|
|
98
|
+
- !ruby/object:Gem::Version
|
|
99
|
+
version: '0'
|
|
100
|
+
requirements: []
|
|
101
|
+
rubyforge_project:
|
|
102
|
+
rubygems_version: 1.8.11
|
|
103
|
+
signing_key:
|
|
104
|
+
specification_version: 3
|
|
105
|
+
summary: YARD-Value provides YARD handlers for Value¹ objects.
|
|
106
|
+
test_files: []
|