pry-larry 0.3.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 +4 -0
- data/CHANGELOG.md +10 -0
- data/Gemfile +2 -0
- data/README.md +61 -0
- data/Rakefile +5 -0
- data/lib/pry-larry/version.rb +5 -0
- data/lib/pry-larry.rb +76 -0
- data/pry-larry.gemspec +14 -0
- metadata +67 -0
checksums.yaml
ADDED
@@ -0,0 +1,7 @@
|
|
1
|
+
---
|
2
|
+
SHA1:
|
3
|
+
metadata.gz: 8de86f32c7be4710144ba5781385d2114d7ca5ba
|
4
|
+
data.tar.gz: 13b0cdda5e0351baba30e35b0c81ddaa65069955
|
5
|
+
SHA512:
|
6
|
+
metadata.gz: 1e276eaf3307a5dae9f262153a7f4cc30d5eff36ce15dd0336a80700902d1c85b8e50cde33a3df0f13deaf55056f2e09d16cec338f3c1a04da50b9015780d2b5
|
7
|
+
data.tar.gz: e1cc0f9f2f3b7f5a149dd400e236ac2bc1ab046a5688eb051295d8873ad439bb25af971daf66e10f184060b286d568ba10966228722055bbd43810a93d476bab
|
data/.gitignore
ADDED
data/CHANGELOG.md
ADDED
@@ -0,0 +1,10 @@
|
|
1
|
+
__v0.3.0__
|
2
|
+
* The Larry command aliases "start" as "wakeup", and "stop" as "chill".
|
3
|
+
* Add a 'banner' to the 'larry' command.
|
4
|
+
* Print confirmation when running the 'larry start' and 'larry stop' commands.
|
5
|
+
|
6
|
+
__v0.2.0__
|
7
|
+
|
8
|
+
* Change the default of 'auto_start' configuration option to true.
|
9
|
+
* Change the default implementation of 'speak_if' configuration option to return true when 'walltime' is > 0.1s.
|
10
|
+
* Move the conditional require of 'pry' to top of lib/pry-larry.rb file.
|
data/Gemfile
ADDED
data/README.md
ADDED
@@ -0,0 +1,61 @@
|
|
1
|
+
[](https://codeclimate.com/github/jazzonmymind/pry-larry.rb)
|
2
|
+
|
3
|
+
__pry-larry.rb__
|
4
|
+
|
5
|
+
Larry is a plugin for Pry.
|
6
|
+
He keeps track of elapsed wall-clock time and tells you how long code or a Pry command
|
7
|
+
you ran took to complete.
|
8
|
+
|
9
|
+
__Configuration__
|
10
|
+
|
11
|
+
The `.pryrc` file in your home directory or in the current working directory can be used
|
12
|
+
to change the defaults of Larry. The example uses an API from Pry that might not be released
|
13
|
+
yet(`Pry.configure`) but the old way is [still supported](https://github.com/pry/pry/pull/1502).
|
14
|
+
|
15
|
+
```ruby
|
16
|
+
Pry.configure do |config|
|
17
|
+
config.larry.auto_start = false # default is true
|
18
|
+
config.larry.speak_if = ->(walltime) { # default is speak if walltime is > 0.1s
|
19
|
+
walltime > 0.5
|
20
|
+
}
|
21
|
+
end
|
22
|
+
```
|
23
|
+
|
24
|
+
__Examples__
|
25
|
+
|
26
|
+
__1.__
|
27
|
+
|
28
|
+

|
29
|
+
|
30
|
+
__Install__
|
31
|
+
|
32
|
+
There isn't a published gem on rubygems.org but there is a gemspec in the repository
|
33
|
+
that can be used to build a gem from source. If you are using Bundler the git repository
|
34
|
+
can be used to build a gem:
|
35
|
+
|
36
|
+
```ruby
|
37
|
+
gem "pry-larry", git: "https://github.com/jazzonmymind/pry-larry.rb.git", tag: "v0.3.0"
|
38
|
+
```
|
39
|
+
|
40
|
+
__License__
|
41
|
+
|
42
|
+
```
|
43
|
+
This is free and unencumbered software released into the public domain.
|
44
|
+
|
45
|
+
Anyone is free to copy, modify, publish, use, compile, sell, or
|
46
|
+
distribute this software, either in source code form or as a compiled
|
47
|
+
binary, for any purpose, commercial or non-commercial, and by any
|
48
|
+
means.
|
49
|
+
|
50
|
+
In jurisdictions that recognize copyright laws, the author or authors
|
51
|
+
of this software dedicate any and all copyright interest in the
|
52
|
+
software to the public domain.
|
53
|
+
|
54
|
+
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
55
|
+
EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
56
|
+
MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
|
57
|
+
IN NO EVENT SHALL THE AUTHORS BE LIABLE FOR ANY CLAIM, DAMAGES OR
|
58
|
+
OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
|
59
|
+
ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
|
60
|
+
OTHER DEALINGS IN THE SOFTWARE.
|
61
|
+
```
|
data/Rakefile
ADDED
data/lib/pry-larry.rb
ADDED
@@ -0,0 +1,76 @@
|
|
1
|
+
require 'pry' if not defined?(Pry::ClassCommand)
|
2
|
+
module Pry::Larry
|
3
|
+
MESSAGE_FORMAT = "%{LarrySays} %{WallTime}s"
|
4
|
+
MEMORY = Hash.new{|h,k| h[k] = [] }
|
5
|
+
BEFORE_EVAL = ->(_, pry) do
|
6
|
+
MEMORY[pry.hash].push Time.now.to_f
|
7
|
+
end
|
8
|
+
AFTER_EVAL = ->(_, pry) do
|
9
|
+
walltime = Time.now.to_f - MEMORY[pry.hash][-1]
|
10
|
+
if pry.config.larry.speak_if.call(walltime)
|
11
|
+
pry.pager.page MESSAGE_FORMAT % {
|
12
|
+
:LarrySays => Pry::Helpers::Text.green("Larry says:"),
|
13
|
+
:WallTime => sprintf("%.2f", walltime)
|
14
|
+
}
|
15
|
+
end
|
16
|
+
end
|
17
|
+
BEFORE_SESSION = ->(_,_, pry) do
|
18
|
+
Pry::Larry.start(pry) if pry.config.larry.auto_start
|
19
|
+
end
|
20
|
+
AFTER_SESSION = ->(_, _, pry) do
|
21
|
+
MEMORY.delete(pry.hash)
|
22
|
+
end
|
23
|
+
|
24
|
+
def self.start(pry)
|
25
|
+
if not pry.config.hooks.hook_exists? :before_eval, BEFORE_EVAL.hash
|
26
|
+
pry.config.hooks.add_hook :before_eval, BEFORE_EVAL.hash, BEFORE_EVAL
|
27
|
+
pry.config.hooks.add_hook :after_eval, AFTER_EVAL.hash , AFTER_EVAL
|
28
|
+
pry.config.hooks.add_hook :after_session, AFTER_SESSION.hash , AFTER_SESSION
|
29
|
+
end
|
30
|
+
end
|
31
|
+
|
32
|
+
def self.stop(pry)
|
33
|
+
pry.config.hooks.delete_hook :before_eval, BEFORE_EVAL.hash
|
34
|
+
pry.config.hooks.delete_hook :after_eval , AFTER_EVAL.hash
|
35
|
+
pry.config.hooks.delete_hook :after_session , AFTER_SESSION.hash
|
36
|
+
MEMORY[pry.hash].clear
|
37
|
+
end
|
38
|
+
|
39
|
+
class << self
|
40
|
+
alias_method :wakeup, :start
|
41
|
+
alias_method :chill, :stop
|
42
|
+
end
|
43
|
+
|
44
|
+
class LarryCommand < Pry::ClassCommand
|
45
|
+
match /larry (start|wakeup|stop|chill)\z/
|
46
|
+
group 'pry-larry'
|
47
|
+
description 'Ask larry to start or stop counting wall-clock time.'
|
48
|
+
command_options argument_required: true
|
49
|
+
banner <<-CMDBANNER
|
50
|
+
Usage: larry [start|stop]
|
51
|
+
Ask Larry to start or stop counting wall clock time.
|
52
|
+
CMDBANNER
|
53
|
+
|
54
|
+
TENSE_MAPPING = {
|
55
|
+
'start' => 'started',
|
56
|
+
'wakeup' => 'woken up',
|
57
|
+
'chill' => 'chilled',
|
58
|
+
'stop' => 'stopped'
|
59
|
+
}
|
60
|
+
TENSE_MAPPING.default_proc = lambda{|k,h| k}
|
61
|
+
START_COMMANDS = ["start", "wakeup"]
|
62
|
+
|
63
|
+
def process(input)
|
64
|
+
if START_COMMANDS.include?(input)
|
65
|
+
Pry::Larry.start(_pry_)
|
66
|
+
_pry_.pager.page("Alright, I have #{TENSE_MAPPING[input]}.")
|
67
|
+
else
|
68
|
+
Pry::Larry.stop(_pry_)
|
69
|
+
_pry_.pager.page("Alright, I have #{TENSE_MAPPING[input]}.")
|
70
|
+
end
|
71
|
+
end
|
72
|
+
end
|
73
|
+
Pry::Commands.add_command(LarryCommand)
|
74
|
+
Pry.config.hooks.add_hook :before_session, BEFORE_SESSION.hash, BEFORE_SESSION
|
75
|
+
Pry.config.larry = Pry::Config.from_hash({auto_start: true, speak_if: ->(walltime){ walltime > 0.1 }}, nil)
|
76
|
+
end
|
data/pry-larry.gemspec
ADDED
@@ -0,0 +1,14 @@
|
|
1
|
+
$LOAD_PATH.push './lib'
|
2
|
+
require 'pry-larry/version'
|
3
|
+
Gem::Specification.new do |spec|
|
4
|
+
spec.name = "pry-larry"
|
5
|
+
spec.version = Pry::Larry::VERSION
|
6
|
+
spec.authors = ["jazzonmymind"]
|
7
|
+
spec.email = "robert@jazzonmymind.xyz"
|
8
|
+
spec.summary = "Larry is a plugin for Pry that tracks wall clock time."
|
9
|
+
spec.description = "Larry keeps track of elapsed wall-clock time and tells you how long code or a Pry command you ran took to complete."
|
10
|
+
spec.homepage = "https://github.com/jazzonmymind/pry-larry.rb"
|
11
|
+
spec.licenses = ['Nonstandard']
|
12
|
+
spec.add_runtime_dependency "pry", "~> 0.10"
|
13
|
+
spec.files = `git ls-files`.each_line.map {|s| s.strip.chomp }
|
14
|
+
end
|
metadata
ADDED
@@ -0,0 +1,67 @@
|
|
1
|
+
--- !ruby/object:Gem::Specification
|
2
|
+
name: pry-larry
|
3
|
+
version: !ruby/object:Gem::Version
|
4
|
+
version: 0.3.0
|
5
|
+
platform: ruby
|
6
|
+
authors:
|
7
|
+
- jazzonmymind
|
8
|
+
autorequire:
|
9
|
+
bindir: bin
|
10
|
+
cert_chain: []
|
11
|
+
date: 2016-08-05 00:00:00.000000000 Z
|
12
|
+
dependencies:
|
13
|
+
- !ruby/object:Gem::Dependency
|
14
|
+
name: pry
|
15
|
+
requirement: !ruby/object:Gem::Requirement
|
16
|
+
requirements:
|
17
|
+
- - "~>"
|
18
|
+
- !ruby/object:Gem::Version
|
19
|
+
version: '0.10'
|
20
|
+
type: :runtime
|
21
|
+
prerelease: false
|
22
|
+
version_requirements: !ruby/object:Gem::Requirement
|
23
|
+
requirements:
|
24
|
+
- - "~>"
|
25
|
+
- !ruby/object:Gem::Version
|
26
|
+
version: '0.10'
|
27
|
+
description: Larry keeps track of elapsed wall-clock time and tells you how long code
|
28
|
+
or a Pry command you ran took to complete.
|
29
|
+
email: robert@jazzonmymind.xyz
|
30
|
+
executables: []
|
31
|
+
extensions: []
|
32
|
+
extra_rdoc_files: []
|
33
|
+
files:
|
34
|
+
- ".gitignore"
|
35
|
+
- CHANGELOG.md
|
36
|
+
- Gemfile
|
37
|
+
- README.md
|
38
|
+
- Rakefile
|
39
|
+
- lib/pry-larry.rb
|
40
|
+
- lib/pry-larry/version.rb
|
41
|
+
- pry-larry.gemspec
|
42
|
+
homepage: https://github.com/jazzonmymind/pry-larry.rb
|
43
|
+
licenses:
|
44
|
+
- Nonstandard
|
45
|
+
metadata: {}
|
46
|
+
post_install_message:
|
47
|
+
rdoc_options: []
|
48
|
+
require_paths:
|
49
|
+
- lib
|
50
|
+
required_ruby_version: !ruby/object:Gem::Requirement
|
51
|
+
requirements:
|
52
|
+
- - ">="
|
53
|
+
- !ruby/object:Gem::Version
|
54
|
+
version: '0'
|
55
|
+
required_rubygems_version: !ruby/object:Gem::Requirement
|
56
|
+
requirements:
|
57
|
+
- - ">="
|
58
|
+
- !ruby/object:Gem::Version
|
59
|
+
version: '0'
|
60
|
+
requirements: []
|
61
|
+
rubyforge_project:
|
62
|
+
rubygems_version: 2.5.1
|
63
|
+
signing_key:
|
64
|
+
specification_version: 4
|
65
|
+
summary: Larry is a plugin for Pry that tracks wall clock time.
|
66
|
+
test_files: []
|
67
|
+
has_rdoc:
|