extra_print 1.1.4 → 2.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.
Files changed (3) hide show
  1. checksums.yaml +5 -5
  2. data/lib/extra_print.rb +69 -21
  3. metadata +11 -12
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
- SHA1:
3
- metadata.gz: 452f4942f9ce05acba72cf92e1472d83cda3684a
4
- data.tar.gz: '089b882bf26e5af5376f076eb3797bd25f485991'
2
+ SHA256:
3
+ metadata.gz: dfe8a5100f310b7b5da6bedb50b30d6d9185ed282018a53bfb194b6a4063197c
4
+ data.tar.gz: fce01555d9b632bccff51614eab30da00e137c8da9a036d1c549cf3dfbd4dfa0
5
5
  SHA512:
6
- metadata.gz: ae04a466c7b6045c303f7937c294fff6b112607169ba65f49551e8701ab36172dc307f0b375caa89e50771740074b57738573022480ad5522635a9189e4db842
7
- data.tar.gz: 884c0d4185457618de5615fdae36cf5baed380b49d27dc979bddf14dbd65b8dfb06e5792c2351b4b2c3631b63d20dffb9aad709e20fb9661d26736a33121e490
6
+ metadata.gz: 1ad32ddbd8a3b76e43e621c7177cb30f7e0c05954c7fbb4797c605475602f2fe7b4fd1e648e4f0d99994204ce99ff11f6fc394e499dd0b2a019a0359ceccb637
7
+ data.tar.gz: d5b5339c8e65a97c4f3a9811d9eee066640aaf8f20785a80961045e0b1febe2953eb275b3943207baa01ef8b38d5eba7ae09d011268a199375315a5ebff55f4d
@@ -1,55 +1,102 @@
1
1
  $COLORS = {'red' => '031','green' => '032','yellow' => '033','blue' => '034','magenta' => '035','cyan' => '036'}
2
- $EMOJIS = %w"😎 😈 👹 👺 👻 👿 💀 👽 😂 🤣 🎃 🐶 🦊 ⭐ 🌟 🏈 🏀 ⚽ ⛔ ❓ 💽 🎁 🌠 🥓 🍤 🍗 🍖 🍕 🍰 🍦 🍭"
2
+ $EMOJIS = %w"😎 😈 👹 👺 👻 👿 💀 👽 😂 🤣 🎃 🐶 🦊 ⭐ 🌟 🏈 🏀 ⚽ ⛔ ♻️ ❓ 💽 🎁 🌠 🥓 🥑 🥦 🍤 🍗 🍖 🍕 🍰 🥃 💰 🍦 🍭 🤯 🤬 🐞 💛 💚 💙 💜"
3
3
 
4
4
  #### DEBUGGING gems ####
5
- # require 'awesome_print'
5
+ # require 'amazing_print'
6
6
  # require 'pry-byebug'
7
7
  ########################
8
8
 
9
+
9
10
  # Using ANSI color coding to spruce things up
10
11
  # SYNTAX: \033[COLOR_CODEmINNER_TEXT\033[0m
11
12
  # There are cleaner ways of doing the color manipulation
12
13
  # But this approach avoids extra dependencies, which is better :-)
13
14
 
14
- def eap(*args)
15
+ # Simply call pe or pea (extra_amazing_print) and pass a variable you want to inspect.
16
+ # Alternatively, call pe or pea with no arguments to display an emoji line break and calling line info.
17
+
18
+ def pe(*args)
19
+ @caller_path = caller
20
+ return display_emoji_break if args.empty?
21
+ extra_print(args[0], args[1])
22
+ return_value(args[0])
23
+ end
24
+
25
+ def pea(*args)
15
26
  @caller_path = caller
16
27
  return display_emoji_break if args.empty?
17
28
  extra_print(args[0], args[1], true)
18
- args[0]
29
+ return_value(args[0])
19
30
  end
20
31
 
32
+ #######################################################################
33
+ # NOTE: LEGACY CODE #ep #eap ensure compatibility for future versions #
34
+ #######################################################################
35
+
21
36
  def ep(*args)
22
37
  @caller_path = caller
23
38
  return display_emoji_break if args.empty?
24
39
  extra_print(args[0], args[1])
25
- args[0]
40
+ return_value(args[0])
41
+ end
42
+
43
+ def eap(*args)
44
+ @caller_path = caller
45
+ return display_emoji_break if args.empty?
46
+ extra_print(args[0], args[1], true)
47
+ return_value(args[0])
26
48
  end
27
49
 
28
50
  private
29
51
 
30
- def extra_print(variable = nil, msg = nil, add_awesome_print = false)
52
+ def extra_print(variable = nil, msg = nil, add_amazing_print = false)
31
53
  # Set variables
32
- @color = $COLORS.values.sample
54
+ @msg = msg
33
55
  @variable = variable
34
- @msg = msg ? msg : " FINISH "
35
- # If the color being passed in is RED set secondary color to BLUE
36
- @secondary_color = @color == '031' ? '034' : '031'
56
+
57
+ # No red/green if calling from a spec
58
+ if $0.split('.').last[/spec|test/]
59
+ $COLORS.delete('red')
60
+ $COLORS.delete('green')
61
+ @color = $COLORS.values.sample
62
+ @secondary_color = '034'
63
+ else
64
+ @color = $COLORS.values.sample
65
+ # If the color being passed in is RED set secondary color to BLUE
66
+ @secondary_color = @color == '031' ? '034' : '031'
67
+ end
37
68
 
38
69
  # View Methods
39
- display_detail_header
40
- display_variable(add_awesome_print)
41
- display_footer
70
+ display_detail_bar(true)
71
+ display_variable(add_amazing_print)
72
+ @msg ? display_msg_footer : display_detail_bar(false)
73
+ end
74
+
75
+ # Checks to see if running in a Ruby file
76
+ # IF so returns value, enabling ep's from the end of a method without disrupting functionality.
77
+ # ELSE returns nil, presuming it is running in a REPL and we don't want to see our output doubled because the REPL prints the return value as well.
78
+ def return_value(val)
79
+ return val if defined?(Rails::Server)
80
+ return nil if defined?(Rails::Console)
81
+ return nil if $0.split('.').last.include? 'pry'
82
+ return nil if $0.split('.').last.include? 'irb'
83
+ return val if $0.split('.').last == 'rb'
84
+ val
42
85
  end
43
86
 
44
87
  def path_clip
45
88
  @caller_path[0].split('/').last(2).join('/').split(':in')[0]
46
89
  end
47
90
 
48
- def display_variable(add_awesome_print)
91
+ def display_variable(add_amazing_print)
49
92
  proc = Proc.new { @variable }
50
- if add_awesome_print
51
- require 'awesome_print'
52
- ap proc.call
93
+ if add_amazing_print
94
+ require 'amazing_print'
95
+ AmazingPrint.defaults = {
96
+ indent: -2, # left aligned
97
+ sort_keys: true, # sort hash keys
98
+ }
99
+ ap @variable
53
100
  else
54
101
  p proc.call
55
102
  end
@@ -64,18 +111,19 @@ def display_emoji_break
64
111
  end
65
112
 
66
113
  # TODO: off by one error on dynamic footer length
67
- def display_footer
114
+ def display_msg_footer
68
115
  str = "\033[#{@color}m⬆ " * ((@length / 4) - (@msg.length / 2) - 1)
69
116
  str += "\033[#{@secondary_color}m #{@msg} "
70
117
  str += "\033[#{@color}m⬆ \033[0m" * ((@length / 4))
71
118
  puts str
72
119
  end
73
120
 
74
- def display_detail_header
121
+ def display_detail_bar(top_bar = true)
122
+ arrow = top_bar ? "⬇" : "⬆"
75
123
 
76
124
  # Initial arrows with a new line padding the top
77
125
  str = ""
78
- str += "\033[#{@color}m \033[m" * 5
126
+ str += "\033[#{@color}m#{arrow} \033[m" * 5
79
127
 
80
128
  # Variable Class Display
81
129
  str += "\033[#{@color}m CLASS:\033[m"
@@ -92,7 +140,7 @@ def display_detail_header
92
140
  str += "\033[#{@secondary_color}m #{path_clip} \033[m"
93
141
 
94
142
  # Closing arrows
95
- str += "\033[#{@color}m \033[m" * 5
143
+ str += "\033[#{@color}m#{arrow} \033[m" * 5
96
144
 
97
145
  # Output completed string
98
146
  puts
metadata CHANGED
@@ -1,43 +1,43 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: extra_print
3
3
  version: !ruby/object:Gem::Version
4
- version: 1.1.4
4
+ version: 2.1.0
5
5
  platform: ruby
6
6
  authors:
7
- - Hunter Chapman
7
+ - Hunter T. Chapman
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2017-12-27 00:00:00.000000000 Z
11
+ date: 2018-04-25 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
- name: awesome_print
14
+ name: amazing_print
15
15
  requirement: !ruby/object:Gem::Requirement
16
16
  requirements:
17
17
  - - "~>"
18
18
  - !ruby/object:Gem::Version
19
- version: '1.8'
19
+ version: '1.1'
20
20
  - - ">="
21
21
  - !ruby/object:Gem::Version
22
- version: 1.8.0
22
+ version: 1.1.0
23
23
  type: :runtime
24
24
  prerelease: false
25
25
  version_requirements: !ruby/object:Gem::Requirement
26
26
  requirements:
27
27
  - - "~>"
28
28
  - !ruby/object:Gem::Version
29
- version: '1.8'
29
+ version: '1.1'
30
30
  - - ">="
31
31
  - !ruby/object:Gem::Version
32
- version: 1.8.0
33
- description: Simple gem to display variables and visual breaks.
32
+ version: 1.1.0
33
+ description: 'Debugging Companion: Informative variable inspection || visual breaks.'
34
34
  email: bootcoder@gmail.com
35
35
  executables: []
36
36
  extensions: []
37
37
  extra_rdoc_files: []
38
38
  files:
39
39
  - lib/extra_print.rb
40
- homepage: http://rubygems.org/gems/extra_print
40
+ homepage: https://github.com/bootcoder/extra_print
41
41
  licenses:
42
42
  - MIT
43
43
  metadata: {}
@@ -56,8 +56,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
56
56
  - !ruby/object:Gem::Version
57
57
  version: '0'
58
58
  requirements: []
59
- rubyforge_project:
60
- rubygems_version: 2.6.11
59
+ rubygems_version: 3.1.2
61
60
  signing_key:
62
61
  specification_version: 4
63
62
  summary: Easily spot variables printed in a busy console.