to_reference 0.0.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/lib/to_reference.rb +46 -0
- metadata +62 -0
data/lib/to_reference.rb
ADDED
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
require 'active_support/concern'
|
|
2
|
+
|
|
3
|
+
module ToReference
|
|
4
|
+
extend ActiveSupport::Concern
|
|
5
|
+
|
|
6
|
+
included do
|
|
7
|
+
class_eval do
|
|
8
|
+
def self.defining_method(dup_method, method, i_method)
|
|
9
|
+
define_any_method(dup_method, method, i_method)
|
|
10
|
+
end
|
|
11
|
+
|
|
12
|
+
def self.define_any_method(dup_method, method, i_method)
|
|
13
|
+
if i_method
|
|
14
|
+
define_method(dup_method, instance_method(method)) {|*params|}
|
|
15
|
+
else
|
|
16
|
+
define_singleton_method(dup_method, method(method)) {|*params|}
|
|
17
|
+
end
|
|
18
|
+
end
|
|
19
|
+
end
|
|
20
|
+
end
|
|
21
|
+
|
|
22
|
+
module ClassMethods
|
|
23
|
+
def reference(*methods)
|
|
24
|
+
methods.each do |method|
|
|
25
|
+
dup_method = get_dup_method(method)
|
|
26
|
+
i_method = self.instance_methods.include?(method)
|
|
27
|
+
defining_method(dup_method, method, i_method)
|
|
28
|
+
redefine_method(method, i_method) { |*params| method(dup_method) }
|
|
29
|
+
end
|
|
30
|
+
end
|
|
31
|
+
|
|
32
|
+
def redefine_method(method, i_method, &block)
|
|
33
|
+
remove_possible_method(method)
|
|
34
|
+
i_method ? define_method(method, &block) : define_singleton_method(method, &block)
|
|
35
|
+
end
|
|
36
|
+
|
|
37
|
+
def get_dup_method(method)
|
|
38
|
+
(method.to_s + rand.to_s).gsub(".","").to_sym
|
|
39
|
+
end
|
|
40
|
+
|
|
41
|
+
def remove_possible_method(method)
|
|
42
|
+
remove_method(method)
|
|
43
|
+
rescue NameError
|
|
44
|
+
end
|
|
45
|
+
end
|
|
46
|
+
end
|
metadata
ADDED
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
--- !ruby/object:Gem::Specification
|
|
2
|
+
name: to_reference
|
|
3
|
+
version: !ruby/object:Gem::Version
|
|
4
|
+
version: 0.0.0
|
|
5
|
+
prerelease:
|
|
6
|
+
platform: ruby
|
|
7
|
+
authors:
|
|
8
|
+
- Soorya Eswaran
|
|
9
|
+
autorequire:
|
|
10
|
+
bindir: bin
|
|
11
|
+
cert_chain: []
|
|
12
|
+
date: 2015-03-18 00:00:00.000000000 Z
|
|
13
|
+
dependencies:
|
|
14
|
+
- !ruby/object:Gem::Dependency
|
|
15
|
+
name: activesupport
|
|
16
|
+
requirement: !ruby/object:Gem::Requirement
|
|
17
|
+
none: false
|
|
18
|
+
requirements:
|
|
19
|
+
- - ~>
|
|
20
|
+
- !ruby/object:Gem::Version
|
|
21
|
+
version: '3.2'
|
|
22
|
+
type: :runtime
|
|
23
|
+
prerelease: false
|
|
24
|
+
version_requirements: !ruby/object:Gem::Requirement
|
|
25
|
+
none: false
|
|
26
|
+
requirements:
|
|
27
|
+
- - ~>
|
|
28
|
+
- !ruby/object:Gem::Version
|
|
29
|
+
version: '3.2'
|
|
30
|
+
description: Just like in Javascript, convert ruby methods to references that you
|
|
31
|
+
can pass around and call at a later time.
|
|
32
|
+
email: sooryazeal@gmail.com
|
|
33
|
+
executables: []
|
|
34
|
+
extensions: []
|
|
35
|
+
extra_rdoc_files: []
|
|
36
|
+
files:
|
|
37
|
+
- lib/to_reference.rb
|
|
38
|
+
homepage: http://rubygems.org/gems/to_reference
|
|
39
|
+
licenses: []
|
|
40
|
+
post_install_message:
|
|
41
|
+
rdoc_options: []
|
|
42
|
+
require_paths:
|
|
43
|
+
- lib
|
|
44
|
+
required_ruby_version: !ruby/object:Gem::Requirement
|
|
45
|
+
none: false
|
|
46
|
+
requirements:
|
|
47
|
+
- - ! '>='
|
|
48
|
+
- !ruby/object:Gem::Version
|
|
49
|
+
version: '0'
|
|
50
|
+
required_rubygems_version: !ruby/object:Gem::Requirement
|
|
51
|
+
none: false
|
|
52
|
+
requirements:
|
|
53
|
+
- - ! '>='
|
|
54
|
+
- !ruby/object:Gem::Version
|
|
55
|
+
version: '0'
|
|
56
|
+
requirements: []
|
|
57
|
+
rubyforge_project:
|
|
58
|
+
rubygems_version: 1.8.30
|
|
59
|
+
signing_key:
|
|
60
|
+
specification_version: 3
|
|
61
|
+
summary: Convert any method to a reference.
|
|
62
|
+
test_files: []
|