rshade 0.1.2 → 0.1.7
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/Gemfile.lock +4 -4
- data/README.md +23 -16
- data/lib/rshade.rb +24 -4
- data/lib/rshade/base.rb +13 -0
- data/lib/rshade/configuration.rb +39 -0
- data/lib/rshade/event.rb +35 -0
- data/lib/rshade/event_serializer.rb +29 -0
- data/lib/rshade/event_store.rb +23 -0
- data/lib/rshade/filter/app_filter.rb +20 -0
- data/lib/rshade/formatter/http.rb +8 -0
- data/lib/rshade/formatter/json.rb +70 -0
- data/lib/rshade/formatter/stdout.rb +10 -0
- data/lib/rshade/formatter/string.rb +30 -0
- data/lib/rshade/rails/rails.rb +0 -0
- data/lib/rshade/{rspec.rb → rspec/rspec.rb} +4 -6
- data/lib/rshade/storage.rb +4 -0
- data/lib/rshade/trace.rb +27 -36
- data/lib/rshade/version.rb +1 -1
- data/rshade.gemspec +1 -1
- data/todo.md +8 -0
- metadata +21 -12
- data/lib/rshade/source.rb +0 -53
- data/lib/rshade/source_node.rb +0 -23
- data/lib/rshade/tree.rb +0 -30
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 5594d3ba4348f6f4c4b73a74c223a7b30f3b7eda7216c72d0d122079cae63bf7
|
4
|
+
data.tar.gz: b071916008465bed00ff107b8b88fe778235a333e1a24c74af5ea62631ec4b75
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: b4a81694ecce4e7063a8a8d4cd5ed758ea93ca151aa0b09cd785e281d206c4cdcdfa389237523fe05f57441c6f4ad648f5cd60e1abb46793162b2ff182965555
|
7
|
+
data.tar.gz: 756a618370faa424864563640ac0389124201bc5c49eb47fdb6cae0fe8f535dadc7c97c366b6c5dfaa330700a39d9e2eaa6e9caad9538209319a7da9587c142f
|
data/Gemfile.lock
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
PATH
|
2
2
|
remote: .
|
3
3
|
specs:
|
4
|
-
rshade (0.1.
|
4
|
+
rshade (0.1.6)
|
5
5
|
colorize
|
6
6
|
|
7
7
|
GEM
|
@@ -14,7 +14,7 @@ GEM
|
|
14
14
|
pry (0.12.2)
|
15
15
|
coderay (~> 1.1.0)
|
16
16
|
method_source (~> 0.9.0)
|
17
|
-
rake (
|
17
|
+
rake (13.0.1)
|
18
18
|
rspec (3.8.0)
|
19
19
|
rspec-core (~> 3.8.0)
|
20
20
|
rspec-expectations (~> 3.8.0)
|
@@ -35,9 +35,9 @@ PLATFORMS
|
|
35
35
|
DEPENDENCIES
|
36
36
|
bundler (~> 1.16)
|
37
37
|
pry
|
38
|
-
rake (
|
38
|
+
rake (>= 12.3.3)
|
39
39
|
rshade!
|
40
40
|
rspec (~> 3.0)
|
41
41
|
|
42
42
|
BUNDLED WITH
|
43
|
-
1.
|
43
|
+
1.17.3
|
data/README.md
CHANGED
@@ -1,14 +1,11 @@
|
|
1
1
|
# RShade
|
2
|
-
|
3
2
|
|
4
3
|
![warcraft shade](https://github.com/gingray/rshade/raw/master/shade.jpg)
|
5
4
|
|
6
|
-
Ruby Shade or RShade gem to help you to reveal
|
7
|
-
|
5
|
+
Ruby Shade or RShade gem to help you to reveal what lines of code are used in program execution.
|
8
6
|
|
9
7
|
```ruby
|
10
|
-
trace = RShade::Trace.
|
11
|
-
trace.reveal do
|
8
|
+
trace = RShade::Trace.reveal do
|
12
9
|
#your code here
|
13
10
|
end
|
14
11
|
trace.show
|
@@ -18,6 +15,26 @@ trace.show
|
|
18
15
|
end
|
19
16
|
|
20
17
|
```
|
18
|
+
## Example
|
19
|
+
I've took example from https://github.com/spree/spree code base. Wrap code to take a look what code is in use when you save variant.
|
20
|
+
On such huge codebase as spree it's helpful to know what callbacks are triggered and so on.
|
21
|
+
```ruby
|
22
|
+
context '#cost_currency' do
|
23
|
+
context 'when cost currency is nil' do
|
24
|
+
before { variant.cost_currency = nil }
|
25
|
+
|
26
|
+
it 'populates cost currency with the default value on save', focus: true do
|
27
|
+
rshade_reveal do
|
28
|
+
variant.save!
|
29
|
+
end
|
30
|
+
expect(variant.cost_currency).to eql 'USD'
|
31
|
+
end
|
32
|
+
end
|
33
|
+
end
|
34
|
+
```
|
35
|
+
Below is example how output will look like.
|
36
|
+
As you can see all code that have been in use is printed.
|
37
|
+
[![asciicast](https://asciinema.org/a/MR5KL7TmHmYRUhwBUWQjBI373.svg)](https://asciinema.org/a/MR5KL7TmHmYRUhwBUWQjBI373)
|
21
38
|
|
22
39
|
## Installation
|
23
40
|
|
@@ -27,23 +44,13 @@ Add this line to your application's Gemfile:
|
|
27
44
|
gem 'rshade'
|
28
45
|
```
|
29
46
|
|
30
|
-
And then execute:
|
31
|
-
|
32
|
-
$ bundle
|
33
|
-
Or install it yourself as:
|
34
|
-
|
35
|
-
$ gem install rshade
|
36
|
-
## Usage
|
37
|
-
|
38
|
-
TODO: Write usage instructions here
|
39
|
-
|
40
47
|
## TODO
|
41
48
|
Use stack to keep connections between current method and caller
|
42
49
|
take a look on https://github.com/matugm/visual-call-graph
|
43
50
|
|
44
51
|
## Contributing
|
45
52
|
|
46
|
-
Bug reports and pull requests are welcome on GitHub at https://github.com/
|
53
|
+
Bug reports and pull requests are welcome on GitHub at https://github.com/gingray/rshade.
|
47
54
|
|
48
55
|
## License
|
49
56
|
|
data/lib/rshade.rb
CHANGED
@@ -1,12 +1,32 @@
|
|
1
1
|
require 'colorize'
|
2
|
-
require 'rshade/
|
3
|
-
require 'rshade/
|
4
|
-
require 'rshade/
|
2
|
+
require 'rshade/configuration'
|
3
|
+
require 'rshade/base'
|
4
|
+
require 'rshade/event_serializer'
|
5
|
+
require 'rshade/filter/app_filter'
|
6
|
+
require 'rshade/formatter/string'
|
7
|
+
require 'rshade/formatter/json'
|
8
|
+
require 'rshade/formatter/stdout'
|
9
|
+
require 'rshade/formatter/http'
|
10
|
+
require 'rshade/event'
|
11
|
+
require 'rshade/event_store'
|
5
12
|
require 'rshade/trace'
|
6
|
-
require 'rshade/rspec'
|
13
|
+
require 'rshade/rspec/rspec'
|
7
14
|
require 'rshade/version'
|
8
15
|
|
16
|
+
|
9
17
|
module RShade
|
10
18
|
APP_TRACE = :app_trace
|
11
19
|
FULL_TRACE = :full_trace
|
20
|
+
|
21
|
+
class << self
|
22
|
+
attr_writer :config
|
23
|
+
|
24
|
+
def config
|
25
|
+
@config ||= Configuration.new
|
26
|
+
end
|
27
|
+
|
28
|
+
def configure
|
29
|
+
yield configuration
|
30
|
+
end
|
31
|
+
end
|
12
32
|
end
|
data/lib/rshade/base.rb
ADDED
@@ -0,0 +1,39 @@
|
|
1
|
+
module RShade
|
2
|
+
class Configuration
|
3
|
+
RUBY_VERSION_PATTERN = /ruby-[0-9.]*/
|
4
|
+
|
5
|
+
attr_accessor :track_gems, :filter, :formatter
|
6
|
+
|
7
|
+
def initialize
|
8
|
+
@track_gems = Set.new
|
9
|
+
end
|
10
|
+
|
11
|
+
def excluded_paths
|
12
|
+
@excluded_paths ||= begin
|
13
|
+
paths = [ENV['GEM_PATH'].split(':'), parse_ruby_version].flatten.compact
|
14
|
+
paths.reject do |v|
|
15
|
+
track_gems.any? { |gem_name| v.include? gem_name }
|
16
|
+
end
|
17
|
+
end
|
18
|
+
end
|
19
|
+
|
20
|
+
def parse_ruby_version
|
21
|
+
val = RUBY_VERSION_PATTERN.match(ENV['GEM_PATH'])
|
22
|
+
return nil unless val
|
23
|
+
|
24
|
+
val[0]
|
25
|
+
end
|
26
|
+
|
27
|
+
def filter
|
28
|
+
@filter ||= ::RShade::Filter::AppFilter
|
29
|
+
end
|
30
|
+
|
31
|
+
def formatter
|
32
|
+
@formatter ||= ::RShade::Formatter::Stdout
|
33
|
+
end
|
34
|
+
|
35
|
+
def store_dir
|
36
|
+
File.expand_path('../../tmp', __dir__)
|
37
|
+
end
|
38
|
+
end
|
39
|
+
end
|
data/lib/rshade/event.rb
ADDED
@@ -0,0 +1,35 @@
|
|
1
|
+
module RShade
|
2
|
+
# nodoc
|
3
|
+
class Event
|
4
|
+
attr_reader :hash
|
5
|
+
attr_accessor :depth
|
6
|
+
|
7
|
+
def initialize(hash)
|
8
|
+
@hash = hash
|
9
|
+
end
|
10
|
+
|
11
|
+
def level
|
12
|
+
@hash[:level]
|
13
|
+
end
|
14
|
+
|
15
|
+
def klass
|
16
|
+
@hash[:klass]
|
17
|
+
end
|
18
|
+
|
19
|
+
def path
|
20
|
+
@hash[:path]
|
21
|
+
end
|
22
|
+
|
23
|
+
def lineno
|
24
|
+
@hash[:lineno]
|
25
|
+
end
|
26
|
+
|
27
|
+
def method_name
|
28
|
+
@hash[:method_name]
|
29
|
+
end
|
30
|
+
|
31
|
+
def vars
|
32
|
+
@hash[:vars]
|
33
|
+
end
|
34
|
+
end
|
35
|
+
end
|
@@ -0,0 +1,29 @@
|
|
1
|
+
require 'date'
|
2
|
+
module RShade
|
3
|
+
class EventSerializer < Base
|
4
|
+
attr_reader :evt, :level
|
5
|
+
SERIALIZE_CLASSES = [NilClass, TrueClass, FalseClass, Numeric, Time, Date, String, Symbol, Array, Hash]
|
6
|
+
def initialize(evt, level)
|
7
|
+
@evt = evt
|
8
|
+
@level = level
|
9
|
+
end
|
10
|
+
|
11
|
+
def call
|
12
|
+
{ level: @level, path: evt.path, lineno: evt.lineno, klass: evt.defined_class, method_name: evt.method_id, vars: process_locals(evt) }
|
13
|
+
end
|
14
|
+
|
15
|
+
def process_locals(evt)
|
16
|
+
vars = {}
|
17
|
+
evt.binding.local_variables.each do |var|
|
18
|
+
local_var = evt.binding.local_variable_get var
|
19
|
+
if SERIALIZE_CLASSES.any? { |klass| local_var.is_a?(klass) }
|
20
|
+
vars[var] = local_var
|
21
|
+
else
|
22
|
+
class_name = local_var.is_a?(Class) ? local_var.to_s : local_var.class.to_s
|
23
|
+
vars[var] = "FILTERED[#{class_name}]"
|
24
|
+
end
|
25
|
+
end
|
26
|
+
vars
|
27
|
+
end
|
28
|
+
end
|
29
|
+
end
|
@@ -0,0 +1,23 @@
|
|
1
|
+
module RShade
|
2
|
+
# nodoc
|
3
|
+
class EventStore
|
4
|
+
attr_reader :events
|
5
|
+
|
6
|
+
def initialize
|
7
|
+
@events = []
|
8
|
+
end
|
9
|
+
|
10
|
+
def <<(event)
|
11
|
+
events << event
|
12
|
+
end
|
13
|
+
|
14
|
+
def iterate(&block)
|
15
|
+
pos_map = {}
|
16
|
+
@events.map {|item| item.level }.uniq.sort.each_with_index { |item, index| pos_map[item] = index}
|
17
|
+
@events.uniq{|item| [item.level, "#{item.klass}##{item.method_name}"]}.sort_by { |item| item.depth }.each do |item|
|
18
|
+
item.depth = pos_map[item.level]
|
19
|
+
yield(item, item.depth)
|
20
|
+
end
|
21
|
+
end
|
22
|
+
end
|
23
|
+
end
|
@@ -0,0 +1,20 @@
|
|
1
|
+
module RShade
|
2
|
+
module Filter
|
3
|
+
class AppFilter < ::RShade::Base
|
4
|
+
attr_reader :data
|
5
|
+
|
6
|
+
def initialize(data)
|
7
|
+
@data = data
|
8
|
+
end
|
9
|
+
|
10
|
+
def call
|
11
|
+
valid?(data[:path])
|
12
|
+
end
|
13
|
+
|
14
|
+
def valid?(path)
|
15
|
+
return true if RShade.config.track_gems.any? { |item| path.include? item }
|
16
|
+
RShade.config.excluded_paths.none? { |item| path.include? item }
|
17
|
+
end
|
18
|
+
end
|
19
|
+
end
|
20
|
+
end
|
@@ -0,0 +1,70 @@
|
|
1
|
+
module RShade
|
2
|
+
module Formatter
|
3
|
+
class Json < ::RShade::Base
|
4
|
+
attr_reader :event_store
|
5
|
+
FILE_NAME = 'stacktrace.json'.freeze
|
6
|
+
|
7
|
+
def initialize(event_store)
|
8
|
+
@event_store = event_store
|
9
|
+
end
|
10
|
+
|
11
|
+
def call
|
12
|
+
flat
|
13
|
+
end
|
14
|
+
|
15
|
+
def flat
|
16
|
+
arr = []
|
17
|
+
event_store.iterate do |node, depth|
|
18
|
+
arr << item(node)
|
19
|
+
end
|
20
|
+
write_to_file(JSON.pretty_generate(arr.sort_by { |item| item[:depth]}))
|
21
|
+
arr
|
22
|
+
end
|
23
|
+
|
24
|
+
def hierarchical
|
25
|
+
hash = {}
|
26
|
+
event_store.iterate do |node, depth|
|
27
|
+
ref = hash_iterate(hash, depth)
|
28
|
+
ref[:data] = item(node)
|
29
|
+
end
|
30
|
+
hash = sort_hash(hash)
|
31
|
+
write_to_file(JSON.pretty_generate(hash))
|
32
|
+
hash
|
33
|
+
end
|
34
|
+
|
35
|
+
def write_to_file(data)
|
36
|
+
File.open(File.join(RShade.config.store_dir, FILE_NAME), "w+") do |f|
|
37
|
+
f.write data
|
38
|
+
end
|
39
|
+
end
|
40
|
+
|
41
|
+
def sort_hash(h)
|
42
|
+
{}.tap do |h2|
|
43
|
+
h.sort.each do |k,v|
|
44
|
+
h2[k] = v.is_a?(Hash) ? sort_hash(v) : v
|
45
|
+
end
|
46
|
+
end
|
47
|
+
end
|
48
|
+
|
49
|
+
def hash_iterate(hash, depth)
|
50
|
+
(0..depth).each do |lvl|
|
51
|
+
unless hash[:inner]
|
52
|
+
hash[:inner] = {}
|
53
|
+
end
|
54
|
+
hash = hash[:inner]
|
55
|
+
end
|
56
|
+
hash
|
57
|
+
end
|
58
|
+
|
59
|
+
def item(value)
|
60
|
+
{
|
61
|
+
class: value.klass.to_s,
|
62
|
+
method_name: value.method_name,
|
63
|
+
full_path: "#{value.path}:#{value.lineno}",
|
64
|
+
depth: value.depth,
|
65
|
+
vars: value.vars
|
66
|
+
}
|
67
|
+
end
|
68
|
+
end
|
69
|
+
end
|
70
|
+
end
|
@@ -0,0 +1,30 @@
|
|
1
|
+
module RShade
|
2
|
+
module Formatter
|
3
|
+
class String < ::RShade::Base
|
4
|
+
attr_reader :event_store
|
5
|
+
ROOT_SEP = "---\n"
|
6
|
+
|
7
|
+
def initialize(event_store)
|
8
|
+
@event_store = event_store
|
9
|
+
end
|
10
|
+
|
11
|
+
def call
|
12
|
+
buffer = StringIO.new
|
13
|
+
event_store.iterate do |node, depth|
|
14
|
+
if depth == 1
|
15
|
+
buffer << ROOT_SEP
|
16
|
+
next
|
17
|
+
end
|
18
|
+
puts line(node, depth)
|
19
|
+
end
|
20
|
+
buffer.string
|
21
|
+
end
|
22
|
+
|
23
|
+
def line(value, depth)
|
24
|
+
class_method = "#{value.klass}##{value.method_name}".colorize(:green)
|
25
|
+
full_path = "#{value.path}:#{value.lineno}".colorize(:blue)
|
26
|
+
"#{' ' * depth}#{class_method}(#{value.vars}) -> #{full_path}\n"
|
27
|
+
end
|
28
|
+
end
|
29
|
+
end
|
30
|
+
end
|
File without changes
|
@@ -2,15 +2,13 @@ module RShade
|
|
2
2
|
REPORTS = []
|
3
3
|
|
4
4
|
module RSpecHelper
|
5
|
-
def rshade_reveal(
|
5
|
+
def rshade_reveal(options = {})
|
6
6
|
raise 'No block given' unless block_given?
|
7
|
-
|
8
|
-
|
9
|
-
trace.reveal do
|
7
|
+
options.merge!(formatter: Formatter::String) { |_key,v1, _v2| v1 }
|
8
|
+
result = Trace.reveal(options) do
|
10
9
|
yield
|
11
10
|
end
|
12
|
-
|
13
|
-
REPORTS.push trace.show(type)
|
11
|
+
REPORTS.push result.show
|
14
12
|
end
|
15
13
|
end
|
16
14
|
end
|
data/lib/rshade/trace.rb
CHANGED
@@ -1,12 +1,21 @@
|
|
1
1
|
module RShade
|
2
2
|
class Trace
|
3
|
-
attr_accessor :
|
3
|
+
attr_accessor :event_store, :formatter, :filter
|
4
4
|
EVENTS = %i[call return].freeze
|
5
5
|
|
6
|
-
def initialize
|
7
|
-
@
|
6
|
+
def initialize(options={})
|
7
|
+
@event_store = EventStore.new
|
8
|
+
@formatter = options.fetch(:formatter, RShade.config.formatter)
|
9
|
+
@filter = options.fetch(:filter, RShade.config.filter)
|
8
10
|
@tp = TracePoint.new(*EVENTS, &method(:process_trace))
|
9
|
-
@
|
11
|
+
@level = 1
|
12
|
+
@stat = {}
|
13
|
+
@calls = 0
|
14
|
+
@returns = 0
|
15
|
+
end
|
16
|
+
|
17
|
+
def self.reveal(options={}, &block)
|
18
|
+
new(options).reveal(&block)
|
10
19
|
end
|
11
20
|
|
12
21
|
def reveal
|
@@ -14,50 +23,32 @@ module RShade
|
|
14
23
|
|
15
24
|
@tp.enable
|
16
25
|
yield
|
26
|
+
self
|
17
27
|
ensure
|
18
28
|
@tp.disable
|
19
29
|
end
|
20
30
|
|
21
|
-
def show
|
22
|
-
|
23
|
-
|
24
|
-
show_full_trace
|
25
|
-
end
|
26
|
-
|
27
|
-
def show_full_trace(tree = nil)
|
28
|
-
buffer = StringIO.new
|
29
|
-
tree ||= source_tree
|
30
|
-
tree.pre_order_traverse do |node, depth|
|
31
|
-
if node.root?
|
32
|
-
buffer << "---\n"
|
33
|
-
next
|
34
|
-
end
|
35
|
-
|
36
|
-
buffer << "#{' ' * depth} #{node.value.pretty}\n" if node.value
|
37
|
-
end
|
38
|
-
puts buffer.string
|
31
|
+
def show
|
32
|
+
formatter.call(event_store)
|
39
33
|
end
|
40
34
|
|
41
|
-
def
|
42
|
-
|
43
|
-
next true if node.root?
|
44
|
-
|
45
|
-
node.value.app_code?
|
46
|
-
end
|
47
|
-
show_full_trace(clone)
|
35
|
+
def stat
|
36
|
+
{ calls: @calls, returns: @returns }
|
48
37
|
end
|
49
38
|
|
50
39
|
def process_trace(tp)
|
51
40
|
if tp.event == :call
|
52
|
-
|
53
|
-
hash =
|
54
|
-
|
55
|
-
|
56
|
-
|
57
|
-
@stack.push node
|
41
|
+
@level +=1
|
42
|
+
hash = EventSerializer.call(tp, @level)
|
43
|
+
return unless filter.call(hash)
|
44
|
+
@calls += 1
|
45
|
+
event_store << Event.new(hash)
|
58
46
|
end
|
59
47
|
|
60
|
-
|
48
|
+
if tp.event == :return && @level > 0
|
49
|
+
@returns += 1
|
50
|
+
@level -=1
|
51
|
+
end
|
61
52
|
end
|
62
53
|
end
|
63
54
|
end
|
data/lib/rshade/version.rb
CHANGED
data/rshade.gemspec
CHANGED
@@ -39,6 +39,6 @@ Gem::Specification.new do |spec|
|
|
39
39
|
spec.add_runtime_dependency 'colorize'
|
40
40
|
|
41
41
|
spec.add_development_dependency "bundler", "~> 1.16"
|
42
|
-
spec.add_development_dependency "rake", "
|
42
|
+
spec.add_development_dependency "rake", ">= 12.3.3"
|
43
43
|
spec.add_development_dependency "rspec", "~> 3.0"
|
44
44
|
end
|
data/todo.md
ADDED
@@ -0,0 +1,8 @@
|
|
1
|
+
1. Should I use rails way organizing module/file naming or not?
|
2
|
+
2. Reduce global state usage
|
3
|
+
3. Problem with stack deep
|
4
|
+
4. Problem when have binary values error in serialization (Encoding problems)
|
5
|
+
5. Make filter while tracing that will be more efficient
|
6
|
+
6. sort depth and than replace values
|
7
|
+
7. tree not working bcz of vars serialization
|
8
|
+
8. Some classes in Rails can't serialize safely produce StackTraceTooDeep
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: rshade
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.1.
|
4
|
+
version: 0.1.7
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Ivan Lopatin
|
8
8
|
autorequire:
|
9
9
|
bindir: exe
|
10
10
|
cert_chain: []
|
11
|
-
date:
|
11
|
+
date: 2020-06-24 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: colorize
|
@@ -42,16 +42,16 @@ dependencies:
|
|
42
42
|
name: rake
|
43
43
|
requirement: !ruby/object:Gem::Requirement
|
44
44
|
requirements:
|
45
|
-
- - "
|
45
|
+
- - ">="
|
46
46
|
- !ruby/object:Gem::Version
|
47
|
-
version:
|
47
|
+
version: 12.3.3
|
48
48
|
type: :development
|
49
49
|
prerelease: false
|
50
50
|
version_requirements: !ruby/object:Gem::Requirement
|
51
51
|
requirements:
|
52
|
-
- - "
|
52
|
+
- - ">="
|
53
53
|
- !ruby/object:Gem::Version
|
54
|
-
version:
|
54
|
+
version: 12.3.3
|
55
55
|
- !ruby/object:Gem::Dependency
|
56
56
|
name: rspec
|
57
57
|
requirement: !ruby/object:Gem::Requirement
|
@@ -84,14 +84,24 @@ files:
|
|
84
84
|
- bin/console
|
85
85
|
- bin/setup
|
86
86
|
- lib/rshade.rb
|
87
|
-
- lib/rshade/
|
88
|
-
- lib/rshade/
|
89
|
-
- lib/rshade/
|
87
|
+
- lib/rshade/base.rb
|
88
|
+
- lib/rshade/configuration.rb
|
89
|
+
- lib/rshade/event.rb
|
90
|
+
- lib/rshade/event_serializer.rb
|
91
|
+
- lib/rshade/event_store.rb
|
92
|
+
- lib/rshade/filter/app_filter.rb
|
93
|
+
- lib/rshade/formatter/http.rb
|
94
|
+
- lib/rshade/formatter/json.rb
|
95
|
+
- lib/rshade/formatter/stdout.rb
|
96
|
+
- lib/rshade/formatter/string.rb
|
97
|
+
- lib/rshade/rails/rails.rb
|
98
|
+
- lib/rshade/rspec/rspec.rb
|
99
|
+
- lib/rshade/storage.rb
|
90
100
|
- lib/rshade/trace.rb
|
91
|
-
- lib/rshade/tree.rb
|
92
101
|
- lib/rshade/version.rb
|
93
102
|
- rshade.gemspec
|
94
103
|
- shade.jpg
|
104
|
+
- todo.md
|
95
105
|
homepage: https://github.com/gingray/rshade
|
96
106
|
licenses:
|
97
107
|
- MIT
|
@@ -115,8 +125,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
|
|
115
125
|
- !ruby/object:Gem::Version
|
116
126
|
version: '0'
|
117
127
|
requirements: []
|
118
|
-
|
119
|
-
rubygems_version: 2.7.8
|
128
|
+
rubygems_version: 3.0.8
|
120
129
|
signing_key:
|
121
130
|
specification_version: 4
|
122
131
|
summary: https://github.com/gingray/rshade
|
data/lib/rshade/source.rb
DELETED
@@ -1,53 +0,0 @@
|
|
1
|
-
module RShade
|
2
|
-
# nodoc
|
3
|
-
class Source
|
4
|
-
RUBY_VERSION_PATTERN = /ruby-[0-9.]*/
|
5
|
-
|
6
|
-
def initialize(hash)
|
7
|
-
@hash = hash
|
8
|
-
end
|
9
|
-
|
10
|
-
def klass
|
11
|
-
@hash[:klass]
|
12
|
-
end
|
13
|
-
|
14
|
-
def lib_code?
|
15
|
-
!app_code?
|
16
|
-
end
|
17
|
-
|
18
|
-
def app_code?
|
19
|
-
@app_code ||= exclude_path.none? { |item| path.include? item }
|
20
|
-
end
|
21
|
-
|
22
|
-
def path
|
23
|
-
@hash[:path]
|
24
|
-
end
|
25
|
-
|
26
|
-
def lineno
|
27
|
-
@hash[:lineno]
|
28
|
-
end
|
29
|
-
|
30
|
-
def method_name
|
31
|
-
@hash[:method_name]
|
32
|
-
end
|
33
|
-
|
34
|
-
def exclude_path
|
35
|
-
@path_arr ||= begin
|
36
|
-
[ENV['GEM_PATH'].split(':'), parse_ruby_version].flatten.compact
|
37
|
-
end
|
38
|
-
end
|
39
|
-
|
40
|
-
def parse_ruby_version
|
41
|
-
val = RUBY_VERSION_PATTERN.match(ENV['GEM_PATH'])
|
42
|
-
return nil unless val
|
43
|
-
|
44
|
-
val[0]
|
45
|
-
end
|
46
|
-
|
47
|
-
def pretty
|
48
|
-
class_method = "#{klass}##{method_name}".colorize(:green)
|
49
|
-
full_path = "#{path}:#{lineno}".colorize(:blue)
|
50
|
-
"#{class_method} -> #{full_path}"
|
51
|
-
end
|
52
|
-
end
|
53
|
-
end
|
data/lib/rshade/source_node.rb
DELETED
@@ -1,23 +0,0 @@
|
|
1
|
-
module RShade
|
2
|
-
# nodoc
|
3
|
-
class SourceNode < Tree
|
4
|
-
def initialize(value = nil)
|
5
|
-
super(value)
|
6
|
-
end
|
7
|
-
|
8
|
-
def clone_by(new_tree = SourceNode.new(nil), &block)
|
9
|
-
if yield(self)
|
10
|
-
new_tree.value = value
|
11
|
-
node = SourceNode.new(nil)
|
12
|
-
node.parent = new_tree
|
13
|
-
new_tree << node
|
14
|
-
new_tree = node
|
15
|
-
end
|
16
|
-
|
17
|
-
nodes.each do |item|
|
18
|
-
item.clone_by(new_tree, &block)
|
19
|
-
end
|
20
|
-
new_tree
|
21
|
-
end
|
22
|
-
end
|
23
|
-
end
|
data/lib/rshade/tree.rb
DELETED
@@ -1,30 +0,0 @@
|
|
1
|
-
module RShade
|
2
|
-
# nodoc
|
3
|
-
class Tree
|
4
|
-
attr_accessor :parent, :value
|
5
|
-
attr_reader :nodes
|
6
|
-
|
7
|
-
def initialize(value = nil)
|
8
|
-
@value = value
|
9
|
-
@nodes = []
|
10
|
-
@parent = nil
|
11
|
-
end
|
12
|
-
|
13
|
-
def root?
|
14
|
-
!parent
|
15
|
-
end
|
16
|
-
|
17
|
-
def <<(node)
|
18
|
-
@nodes << node
|
19
|
-
end
|
20
|
-
|
21
|
-
def pre_order_traverse(depth = 0, &block)
|
22
|
-
return unless block_given?
|
23
|
-
|
24
|
-
yield(self, depth)
|
25
|
-
nodes.each do |item|
|
26
|
-
item.pre_order_traverse(depth + 1, &block)
|
27
|
-
end
|
28
|
-
end
|
29
|
-
end
|
30
|
-
end
|