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.
- checksums.yaml +5 -5
- data/lib/extra_print.rb +69 -21
- metadata +11 -12
    
        checksums.yaml
    CHANGED
    
    | @@ -1,7 +1,7 @@ | |
| 1 1 | 
             
            ---
         | 
| 2 | 
            -
             | 
| 3 | 
            -
              metadata.gz:  | 
| 4 | 
            -
              data.tar.gz:  | 
| 2 | 
            +
            SHA256:
         | 
| 3 | 
            +
              metadata.gz: dfe8a5100f310b7b5da6bedb50b30d6d9185ed282018a53bfb194b6a4063197c
         | 
| 4 | 
            +
              data.tar.gz: fce01555d9b632bccff51614eab30da00e137c8da9a036d1c549cf3dfbd4dfa0
         | 
| 5 5 | 
             
            SHA512:
         | 
| 6 | 
            -
              metadata.gz:  | 
| 7 | 
            -
              data.tar.gz:  | 
| 6 | 
            +
              metadata.gz: 1ad32ddbd8a3b76e43e621c7177cb30f7e0c05954c7fbb4797c605475602f2fe7b4fd1e648e4f0d99994204ce99ff11f6fc394e499dd0b2a019a0359ceccb637
         | 
| 7 | 
            +
              data.tar.gz: d5b5339c8e65a97c4f3a9811d9eee066640aaf8f20785a80961045e0b1febe2953eb275b3943207baa01ef8b38d5eba7ae09d011268a199375315a5ebff55f4d
         | 
    
        data/lib/extra_print.rb
    CHANGED
    
    | @@ -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 ' | 
| 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 | 
            -
             | 
| 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,  | 
| 52 | 
            +
            def extra_print(variable = nil, msg = nil, add_amazing_print = false)
         | 
| 31 53 | 
             
              # Set variables
         | 
| 32 | 
            -
              @ | 
| 54 | 
            +
              @msg      = msg
         | 
| 33 55 | 
             
              @variable = variable
         | 
| 34 | 
            -
             | 
| 35 | 
            -
              #  | 
| 36 | 
            -
               | 
| 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 | 
            -
               | 
| 40 | 
            -
              display_variable( | 
| 41 | 
            -
               | 
| 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( | 
| 91 | 
            +
            def display_variable(add_amazing_print)
         | 
| 49 92 | 
             
              proc = Proc.new { @variable }
         | 
| 50 | 
            -
              if  | 
| 51 | 
            -
                require ' | 
| 52 | 
            -
                 | 
| 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  | 
| 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  | 
| 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 | 
| 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 | 
| 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:  | 
| 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:  | 
| 11 | 
            +
            date: 2018-04-25 00:00:00.000000000 Z
         | 
| 12 12 | 
             
            dependencies:
         | 
| 13 13 | 
             
            - !ruby/object:Gem::Dependency
         | 
| 14 | 
            -
              name:  | 
| 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. | 
| 19 | 
            +
                    version: '1.1'
         | 
| 20 20 | 
             
                - - ">="
         | 
| 21 21 | 
             
                  - !ruby/object:Gem::Version
         | 
| 22 | 
            -
                    version: 1. | 
| 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. | 
| 29 | 
            +
                    version: '1.1'
         | 
| 30 30 | 
             
                - - ">="
         | 
| 31 31 | 
             
                  - !ruby/object:Gem::Version
         | 
| 32 | 
            -
                    version: 1. | 
| 33 | 
            -
            description:  | 
| 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:  | 
| 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 | 
            -
             | 
| 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.
         |