yard-mongoid 0.0.3 → 0.1.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.
- checksums.yaml +7 -0
- data/.gitignore +2 -0
- data/Gemfile +0 -9
- data/README.md +58 -0
- data/bin/console +7 -0
- data/bin/rake +17 -0
- data/bin/setup +6 -0
- data/lib/yard/handlers/ruby/mongoid/extensions.rb +2 -1
- data/lib/yard/handlers/ruby/mongoid/field_handler.rb +10 -10
- data/lib/yard/handlers/ruby/mongoid/helpers.rb +1 -1
- data/lib/yard/handlers/ruby/mongoid/relations/base.rb +3 -2
- data/lib/yard/handlers/ruby/mongoid/relations/belongs_to_handler.rb +1 -0
- data/lib/yard/handlers/ruby/mongoid/relations/has_and_belongs_to_many_handler.rb +1 -0
- data/lib/yard/handlers/ruby/mongoid/relations/has_many_handler.rb +1 -0
- data/lib/yard/handlers/ruby/mongoid/relations/has_one_handler.rb +1 -0
- data/lib/yard/handlers/ruby/mongoid/relations/plural_handler.rb +1 -0
- data/lib/yard/handlers/ruby/mongoid/relations/singular_handler.rb +1 -0
- data/lib/yard/mongoid/version.rb +2 -2
- data/yard-mongoid.gemspec +17 -15
- metadata +58 -17
checksums.yaml
ADDED
@@ -0,0 +1,7 @@
|
|
1
|
+
---
|
2
|
+
SHA1:
|
3
|
+
metadata.gz: d87056112075d7dbdd92fb12adeef56d88794bc2
|
4
|
+
data.tar.gz: 57b081ecc357b9acafc0de8e6c2ebc3e78fefb1e
|
5
|
+
SHA512:
|
6
|
+
metadata.gz: d12700f677cbe7e4d78d8450df5ff87a816231ee58a9d3aa552f9df00de252a1d572db78b26884661ee9ada767abb52018e116145040c83a050948b7ee84127b
|
7
|
+
data.tar.gz: 14efe78f104eccf5247bd9a4761a3c2e3caf98eeb9ba3440066ee3cd6b38ec839dc9441d9c54b0593f100fb077591a02f3f4f5114a2cb6aa825a21b52045907d
|
data/.gitignore
CHANGED
data/Gemfile
CHANGED
@@ -2,12 +2,3 @@ source 'http://rubygems.org'
|
|
2
2
|
|
3
3
|
# Specify your gem's dependencies in yard-mongoid.gemspec
|
4
4
|
gemspec
|
5
|
-
|
6
|
-
group :development do
|
7
|
-
gem 'rake'
|
8
|
-
gem 'mongoid', '~> 3.0'
|
9
|
-
gem 'yard-activerecord' # Needed for some code examples
|
10
|
-
gem 'yard-activerecord2' # Needed for some code examples
|
11
|
-
gem 'yard-rails' # Needed for some code examples
|
12
|
-
gem 'yard-delegate' # Needed for some code examples
|
13
|
-
end
|
data/README.md
ADDED
@@ -0,0 +1,58 @@
|
|
1
|
+
# YARD::Mongoid
|
2
|
+
|
3
|
+
[][gem]
|
4
|
+
[][travis]
|
5
|
+
[][gemnasium]
|
6
|
+
[][codeclimate]
|
7
|
+
[][coverage]
|
8
|
+
|
9
|
+
A [YARD](https://rubygems.org/gems/yard) plugin for documenting [Mongoid](https://rubygems.org/gems/mongoid) models.
|
10
|
+
|
11
|
+
## Installation
|
12
|
+
|
13
|
+
Add this line to your application's Gemfile:
|
14
|
+
|
15
|
+
```ruby
|
16
|
+
gem 'yard-mongoid'
|
17
|
+
```
|
18
|
+
|
19
|
+
And then execute:
|
20
|
+
|
21
|
+
$ bundle
|
22
|
+
|
23
|
+
Or install it yourself as:
|
24
|
+
|
25
|
+
$ gem install yard-mongoid
|
26
|
+
|
27
|
+
## Usage
|
28
|
+
|
29
|
+
Add following line to `.yardopts`:
|
30
|
+
|
31
|
+
```
|
32
|
+
--plugin mongoid
|
33
|
+
```
|
34
|
+
|
35
|
+
or use it as argument to `yard doc` command like `yard doc --plugin mongoid`.
|
36
|
+
|
37
|
+
## Development
|
38
|
+
|
39
|
+
After checking out the repo, run `bin/setup` to install dependencies. Then, run `rake spec` to run the tests. You can also run `bin/console` for an interactive prompt that will allow you to experiment.
|
40
|
+
|
41
|
+
To install this gem onto your local machine, run `bin/rake install`. To release a new version, update the version number in `version.rb`, and then run `bin/rake release`, which will create a git tag for the version, push git commits and tags, and push the `.gem` file to [rubygems.org](https://rubygems.org).
|
42
|
+
|
43
|
+
## Contributing
|
44
|
+
|
45
|
+
Bug reports and pull requests are welcome on GitHub at https://github.com/alsemyonov/yard-mongoid. This project is intended to be a safe, welcoming space for collaboration, and contributors are expected to adhere to the [Contributor Covenant](http://contributor-covenant.org) code of conduct.
|
46
|
+
|
47
|
+
|
48
|
+
## License
|
49
|
+
|
50
|
+
© [Alex Semyonov](https://al.semyonov.us/) <[alex@semyonov.us](mailto:alex@semyonov.us?subject=yard-mongoid)>, 2016
|
51
|
+
|
52
|
+
The gem is available as open source under the terms of the [MIT License](http://opensource.org/licenses/MIT).
|
53
|
+
|
54
|
+
[gem]: https://rubygems.org/gems/yard-mongoid
|
55
|
+
[travis]: https://travis-ci.org/alsemyonov/yard-mongoid
|
56
|
+
[gemnasium]: https://gemnasium.com/alsemyonov/yard-mongoid
|
57
|
+
[codeclimate]: https://codeclimate.com/github/alsemyonov/yard-mongoid
|
58
|
+
[coverage]: https://codeclimate.com/github/alsemyonov/yard-mongoid/coverage
|
data/bin/console
ADDED
data/bin/rake
ADDED
@@ -0,0 +1,17 @@
|
|
1
|
+
#!/usr/bin/env ruby
|
2
|
+
# frozen_string_literal: true
|
3
|
+
#
|
4
|
+
# This file was generated by Bundler.
|
5
|
+
#
|
6
|
+
# The application 'rake' is installed as part of a gem, and
|
7
|
+
# this file is here to facilitate running it.
|
8
|
+
#
|
9
|
+
|
10
|
+
require 'pathname'
|
11
|
+
ENV['BUNDLE_GEMFILE'] ||= File.expand_path('../../Gemfile',
|
12
|
+
Pathname.new(__FILE__).realpath)
|
13
|
+
|
14
|
+
require 'rubygems'
|
15
|
+
require 'bundler/setup'
|
16
|
+
|
17
|
+
load Gem.bin_path('rake', 'rake')
|
data/bin/setup
ADDED
@@ -8,7 +8,7 @@ module YARD::Handlers::Ruby
|
|
8
8
|
include Extensions
|
9
9
|
include YARD::Handlers::Ruby::Mongoid::Helpers
|
10
10
|
|
11
|
-
MONGOID_FIELDS = 'Fields'
|
11
|
+
MONGOID_FIELDS = 'Fields'.freeze
|
12
12
|
|
13
13
|
namespace_only
|
14
14
|
|
@@ -22,11 +22,11 @@ module YARD::Handlers::Ruby
|
|
22
22
|
|
23
23
|
add_field_getter(effected_namespace, name, class_name, default_value)
|
24
24
|
add_field_setter(effected_namespace, name, class_name)
|
25
|
-
#register_field_presence(effected_namespace, name, scope)
|
26
|
-
#register_field_change(effected_namespace, name, scope)
|
27
|
-
#register_field_changed(effected_namespace, name, scope)
|
28
|
-
#register_field_was(effected_namespace, name, scope)
|
29
|
-
#register_field_reset(effected_namespace, name, scope)
|
25
|
+
# register_field_presence(effected_namespace, name, scope)
|
26
|
+
# register_field_change(effected_namespace, name, scope)
|
27
|
+
# register_field_changed(effected_namespace, name, scope)
|
28
|
+
# register_field_was(effected_namespace, name, scope)
|
29
|
+
# register_field_reset(effected_namespace, name, scope)
|
30
30
|
end
|
31
31
|
end
|
32
32
|
|
@@ -38,7 +38,7 @@ module YARD::Handlers::Ruby
|
|
38
38
|
if statement.parameters.size > 2
|
39
39
|
statement.parameters[1].source.split(/,\s*/).each do |key_and_value|
|
40
40
|
if key_and_value =~ hash_args[:type]
|
41
|
-
@class_name =
|
41
|
+
@class_name = Regexp.last_match(2)
|
42
42
|
break
|
43
43
|
end
|
44
44
|
end
|
@@ -53,7 +53,7 @@ module YARD::Handlers::Ruby
|
|
53
53
|
if statement.parameters.size > 2
|
54
54
|
statement.parameters[1].source.split(/,\s*/).each do |key_and_value|
|
55
55
|
if key_and_value =~ /(:default\s*=>|default:)\s*(.+)\s*$/
|
56
|
-
@default_value =
|
56
|
+
@default_value = Regexp.last_match(2)
|
57
57
|
break
|
58
58
|
end
|
59
59
|
end
|
@@ -70,7 +70,7 @@ module YARD::Handlers::Ruby
|
|
70
70
|
end
|
71
71
|
|
72
72
|
# @yieldparam [YARD::CodeObjects::MethodObject]
|
73
|
-
def add_field_method(namespace, name
|
73
|
+
def add_field_method(namespace, name)
|
74
74
|
register YARD::CodeObjects::MethodObject.new(namespace, name, :instance) do |mo|
|
75
75
|
mo.group = MONGOID_FIELDS
|
76
76
|
mo.visibility ||= :public
|
@@ -78,7 +78,7 @@ module YARD::Handlers::Ruby
|
|
78
78
|
mo.dynamic = true
|
79
79
|
mo.signature = "def #{name}"
|
80
80
|
mo.docstring = '' if mo.docstring.empty?
|
81
|
-
|
81
|
+
yield(mo) if block_given?
|
82
82
|
end
|
83
83
|
end
|
84
84
|
|
@@ -8,7 +8,7 @@ module YARD
|
|
8
8
|
# @param [Symbol] tag
|
9
9
|
# @param [String] text
|
10
10
|
# @param [String] return_classes
|
11
|
-
def get_tag(tag, text, return_classes = [], name=nil)
|
11
|
+
def get_tag(tag, text, return_classes = [], name = nil)
|
12
12
|
YARD::Tags::Tag.new(tag, text, [return_classes].flatten, name)
|
13
13
|
end
|
14
14
|
end
|
@@ -15,7 +15,7 @@ module YARD::Handlers::Ruby::Mongoid
|
|
15
15
|
object.group = group_name
|
16
16
|
object.docstring = return_description
|
17
17
|
object.docstring.add_tag get_tag(:return, '', class_name)
|
18
|
-
object.docstring.add_tag get_tag(:see, "http://mongoid.org/en/mongoid/docs/relations.html##{statement.method_name(true)
|
18
|
+
object.docstring.add_tag get_tag(:see, "http://mongoid.org/en/mongoid/docs/relations.html##{statement.method_name(true)}")
|
19
19
|
object.dynamic = true
|
20
20
|
register object
|
21
21
|
end
|
@@ -25,6 +25,7 @@ module YARD::Handlers::Ruby::Mongoid
|
|
25
25
|
end
|
26
26
|
|
27
27
|
private
|
28
|
+
|
28
29
|
def method_name
|
29
30
|
call_params[0]
|
30
31
|
end
|
@@ -36,7 +37,7 @@ module YARD::Handlers::Ruby::Mongoid
|
|
36
37
|
while i < param_size - 1
|
37
38
|
# May want to evaluate doing it this way
|
38
39
|
statement.parameters[i].jump(:hash).source =~ /(:class_name\s*=>|class_name:)\s*["']([^"']+)["']/
|
39
|
-
return
|
40
|
+
return Regexp.last_match(2) if Regexp.last_match(2)
|
40
41
|
i += 1
|
41
42
|
end
|
42
43
|
end
|
data/lib/yard/mongoid/version.rb
CHANGED
data/yard-mongoid.gemspec
CHANGED
@@ -1,23 +1,25 @@
|
|
1
1
|
# -*- encoding: utf-8 -*-
|
2
|
-
|
2
|
+
$LOAD_PATH.push File.expand_path('../lib', __FILE__)
|
3
3
|
require 'yard/mongoid/version'
|
4
4
|
|
5
5
|
Gem::Specification.new do |s|
|
6
|
-
s.name
|
7
|
-
s.version =
|
8
|
-
s.platform
|
9
|
-
s.authors
|
10
|
-
s.email
|
11
|
-
s.homepage
|
12
|
-
s.summary
|
13
|
-
s.description =
|
6
|
+
s.name = 'yard-mongoid'
|
7
|
+
s.version = YARD::Mongoid::VERSION
|
8
|
+
s.platform = Gem::Platform::RUBY
|
9
|
+
s.authors = ['Alexander Semyonov']
|
10
|
+
s.email = %w(al@semyonov.us)
|
11
|
+
s.homepage = 'http://rubygems.org/gems/yard-mongoid'
|
12
|
+
s.summary = 'A Yard plugin for parsing Mongoid model syntax.'
|
13
|
+
s.description = 'Once yard-mongoid is installed, YARD will automatically load the plugin when ever the `yard doc` utility is ran on a project.'
|
14
14
|
|
15
|
-
s.
|
16
|
-
|
17
|
-
s.
|
18
|
-
s.
|
19
|
-
s.executables = `git ls-files -- bin/*`.split("\n").map{ |f| File.basename(f) }
|
15
|
+
s.files = `git ls-files`.split("\n")
|
16
|
+
s.test_files = `git ls-files -- {test,spec,features}/*`.split("\n")
|
17
|
+
s.bindir = 'exe'
|
18
|
+
s.executables = s.files.grep(%r{^exe/}) { |f| File.basename(f) }
|
20
19
|
s.require_paths = %w(lib)
|
21
20
|
|
22
|
-
s.
|
21
|
+
s.add_runtime_dependency 'yard', '>= 0.8.4'
|
22
|
+
s.add_development_dependency 'rake'
|
23
|
+
s.add_development_dependency 'mongoid', '>= 3.0'
|
24
|
+
s.add_development_dependency 'pry'
|
23
25
|
end
|
metadata
CHANGED
@@ -1,32 +1,71 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: yard-mongoid
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.0
|
5
|
-
prerelease:
|
4
|
+
version: 0.1.0
|
6
5
|
platform: ruby
|
7
6
|
authors:
|
8
7
|
- Alexander Semyonov
|
9
8
|
autorequire:
|
10
|
-
bindir:
|
9
|
+
bindir: exe
|
11
10
|
cert_chain: []
|
12
|
-
date:
|
11
|
+
date: 2016-11-23 00:00:00.000000000 Z
|
13
12
|
dependencies:
|
14
13
|
- !ruby/object:Gem::Dependency
|
15
14
|
name: yard
|
16
15
|
requirement: !ruby/object:Gem::Requirement
|
17
|
-
none: false
|
18
16
|
requirements:
|
19
|
-
- -
|
17
|
+
- - ">="
|
20
18
|
- !ruby/object:Gem::Version
|
21
19
|
version: 0.8.4
|
22
20
|
type: :runtime
|
23
21
|
prerelease: false
|
24
22
|
version_requirements: !ruby/object:Gem::Requirement
|
25
|
-
none: false
|
26
23
|
requirements:
|
27
|
-
- -
|
24
|
+
- - ">="
|
28
25
|
- !ruby/object:Gem::Version
|
29
26
|
version: 0.8.4
|
27
|
+
- !ruby/object:Gem::Dependency
|
28
|
+
name: rake
|
29
|
+
requirement: !ruby/object:Gem::Requirement
|
30
|
+
requirements:
|
31
|
+
- - ">="
|
32
|
+
- !ruby/object:Gem::Version
|
33
|
+
version: '0'
|
34
|
+
type: :development
|
35
|
+
prerelease: false
|
36
|
+
version_requirements: !ruby/object:Gem::Requirement
|
37
|
+
requirements:
|
38
|
+
- - ">="
|
39
|
+
- !ruby/object:Gem::Version
|
40
|
+
version: '0'
|
41
|
+
- !ruby/object:Gem::Dependency
|
42
|
+
name: mongoid
|
43
|
+
requirement: !ruby/object:Gem::Requirement
|
44
|
+
requirements:
|
45
|
+
- - ">="
|
46
|
+
- !ruby/object:Gem::Version
|
47
|
+
version: '3.0'
|
48
|
+
type: :development
|
49
|
+
prerelease: false
|
50
|
+
version_requirements: !ruby/object:Gem::Requirement
|
51
|
+
requirements:
|
52
|
+
- - ">="
|
53
|
+
- !ruby/object:Gem::Version
|
54
|
+
version: '3.0'
|
55
|
+
- !ruby/object:Gem::Dependency
|
56
|
+
name: pry
|
57
|
+
requirement: !ruby/object:Gem::Requirement
|
58
|
+
requirements:
|
59
|
+
- - ">="
|
60
|
+
- !ruby/object:Gem::Version
|
61
|
+
version: '0'
|
62
|
+
type: :development
|
63
|
+
prerelease: false
|
64
|
+
version_requirements: !ruby/object:Gem::Requirement
|
65
|
+
requirements:
|
66
|
+
- - ">="
|
67
|
+
- !ruby/object:Gem::Version
|
68
|
+
version: '0'
|
30
69
|
description: Once yard-mongoid is installed, YARD will automatically load the plugin
|
31
70
|
when ever the `yard doc` utility is ran on a project.
|
32
71
|
email:
|
@@ -35,10 +74,14 @@ executables: []
|
|
35
74
|
extensions: []
|
36
75
|
extra_rdoc_files: []
|
37
76
|
files:
|
38
|
-
- .gitignore
|
77
|
+
- ".gitignore"
|
39
78
|
- Gemfile
|
40
79
|
- MIT-LICENSE
|
80
|
+
- README.md
|
41
81
|
- Rakefile
|
82
|
+
- bin/console
|
83
|
+
- bin/rake
|
84
|
+
- bin/setup
|
42
85
|
- lib/yard-mongoid.rb
|
43
86
|
- lib/yard/handlers/ruby/mongoid/extensions.rb
|
44
87
|
- lib/yard/handlers/ruby/mongoid/field_handler.rb
|
@@ -55,27 +98,25 @@ files:
|
|
55
98
|
- yard-mongoid.gemspec
|
56
99
|
homepage: http://rubygems.org/gems/yard-mongoid
|
57
100
|
licenses: []
|
101
|
+
metadata: {}
|
58
102
|
post_install_message:
|
59
103
|
rdoc_options: []
|
60
104
|
require_paths:
|
61
105
|
- lib
|
62
106
|
required_ruby_version: !ruby/object:Gem::Requirement
|
63
|
-
none: false
|
64
107
|
requirements:
|
65
|
-
- -
|
108
|
+
- - ">="
|
66
109
|
- !ruby/object:Gem::Version
|
67
110
|
version: '0'
|
68
111
|
required_rubygems_version: !ruby/object:Gem::Requirement
|
69
|
-
none: false
|
70
112
|
requirements:
|
71
|
-
- -
|
113
|
+
- - ">="
|
72
114
|
- !ruby/object:Gem::Version
|
73
115
|
version: '0'
|
74
116
|
requirements: []
|
75
|
-
rubyforge_project:
|
76
|
-
rubygems_version:
|
117
|
+
rubyforge_project:
|
118
|
+
rubygems_version: 2.5.2
|
77
119
|
signing_key:
|
78
|
-
specification_version:
|
120
|
+
specification_version: 4
|
79
121
|
summary: A Yard plugin for parsing Mongoid model syntax.
|
80
122
|
test_files: []
|
81
|
-
has_rdoc:
|