highline 2.1.0 → 3.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.
- checksums.yaml +4 -4
- data/.github/workflows/ci.yml +3 -7
- data/Changelog.md +15 -0
- data/README.md +37 -1
- data/examples/custom_parser_custom_validator.rb +39 -0
- data/highline.gemspec +4 -1
- data/lib/highline/io_console_compatible.rb +1 -1
- data/lib/highline/question/answer_converter.rb +2 -5
- data/lib/highline/question.rb +23 -13
- data/lib/highline/question_asker.rb +3 -1
- data/lib/highline/terminal/io_console.rb +1 -1
- data/lib/highline/terminal/unix_stty.rb +6 -4
- data/lib/highline/terminal.rb +7 -5
- data/lib/highline/version.rb +1 -1
- data/lib/highline.rb +18 -4
- metadata +47 -4
    
        checksums.yaml
    CHANGED
    
    | @@ -1,7 +1,7 @@ | |
| 1 1 | 
             
            ---
         | 
| 2 2 | 
             
            SHA256:
         | 
| 3 | 
            -
              metadata.gz:  | 
| 4 | 
            -
              data.tar.gz:  | 
| 3 | 
            +
              metadata.gz: 735a6b484551754886d61f83a5b2a8526c500a8e17302c000959de02d7cf5f82
         | 
| 4 | 
            +
              data.tar.gz: a5a5a390bd2951386d1f82c8124e300ad77af2e16460272a18d0ce7615e90434
         | 
| 5 5 | 
             
            SHA512:
         | 
| 6 | 
            -
              metadata.gz:  | 
| 7 | 
            -
              data.tar.gz:  | 
| 6 | 
            +
              metadata.gz: 25d3b1034cdf2bae31625ec982f2ea0dbe8261e9b32ac7071ad8ef6d84ff6da9e872998f1388050f808bffeab8085d47da1c080b98e1523445d44739cd38e3a0
         | 
| 7 | 
            +
              data.tar.gz: 70b42a24ef3b03046ffe82074b6b82acc5519fc37c6c07c95adf6b8edddeef66d211dcf5b44967460e2ec9116763a9871d668e8aaab5cff0cdb996958fc7fb50
         | 
    
        data/.github/workflows/ci.yml
    CHANGED
    
    | @@ -10,14 +10,10 @@ jobs: | |
| 10 10 | 
             
                    os: [ubuntu-latest]
         | 
| 11 11 | 
             
                    ruby-version:
         | 
| 12 12 | 
             
                      - head
         | 
| 13 | 
            +
                      - '3.3'
         | 
| 13 14 | 
             
                      - '3.2'
         | 
| 14 15 | 
             
                      - '3.1'
         | 
| 15 16 | 
             
                      - '3.0'
         | 
| 16 | 
            -
                      - '2.7'
         | 
| 17 | 
            -
                      - '2.6'
         | 
| 18 | 
            -
                      - '2.5'
         | 
| 19 | 
            -
                      - '2.4'
         | 
| 20 | 
            -
                      - '2.3'
         | 
| 21 17 | 
             
                      - jruby
         | 
| 22 18 | 
             
                      - jruby-head
         | 
| 23 19 | 
             
                      - truffleruby
         | 
| @@ -27,7 +23,7 @@ jobs: | |
| 27 23 | 
             
                      - os: windows-latest
         | 
| 28 24 | 
             
                        ruby-version: head
         | 
| 29 25 | 
             
                      - os: windows-latest
         | 
| 30 | 
            -
                        ruby-version: '3. | 
| 26 | 
            +
                        ruby-version: '3.3'
         | 
| 31 27 | 
             
                      - os: windows-latest
         | 
| 32 28 | 
             
                        ruby-version: mingw
         | 
| 33 29 | 
             
                      - os: windows-latest
         | 
| @@ -37,7 +33,7 @@ jobs: | |
| 37 33 | 
             
                      - os: macos-latest
         | 
| 38 34 | 
             
                        ruby-version: 'head'
         | 
| 39 35 | 
             
                      - os: macos-latest
         | 
| 40 | 
            -
                        ruby-version: '3. | 
| 36 | 
            +
                        ruby-version: '3.3'
         | 
| 41 37 | 
             
                runs-on: ${{ matrix.os }}
         | 
| 42 38 | 
             
                steps:
         | 
| 43 39 | 
             
                - uses: actions/checkout@v3
         | 
    
        data/Changelog.md
    CHANGED
    
    | @@ -2,6 +2,21 @@ | |
| 2 2 |  | 
| 3 3 | 
             
            Below is a complete listing of changes for each revision of HighLine.
         | 
| 4 4 |  | 
| 5 | 
            +
            ### 3.0.0 / 2024-01-05
         | 
| 6 | 
            +
            * PR #265 - Change Readline for Reline for Ruby 3.3 compat (@abinoam)
         | 
| 7 | 
            +
            * PR #264 - Add abbrev gem as dependency (@mathieujobin)
         | 
| 8 | 
            +
            * PR #263 - Release 3.0.0.pre.1
         | 
| 9 | 
            +
              * Raise minimum Ruby version requirement to 3.0
         | 
| 10 | 
            +
            * PR #262 - Do not call stty on non-tty (@kbrock)
         | 
| 11 | 
            +
            * PR #260 / I #43 - Ctrl-U (erase line) handling (@abinoam, issue by @gutenye)
         | 
| 12 | 
            +
            * PR #259 / I #236 - Handle Ctrl-C when Question#echo = false (@abinoam, @Fahhetah, issue by @aspyct)
         | 
| 13 | 
            +
            * PR #258 / I #246 - Add validation class support (@abinoam, issue by @Joshfindit)
         | 
| 14 | 
            +
              * Make it dry-types compatible through the use of `#valid?`
         | 
| 15 | 
            +
              * Solve the multiple answers in one line problem with a combination of custom coercion (parser) and custom validation
         | 
| 16 | 
            +
            * PR #257 / I #233 - Show Question#default hint for non String values (@abinoam, issue by @branch14)
         | 
| 17 | 
            +
              * Add Question#default_hint_show to allow disabling it.
         | 
| 18 | 
            +
            * PR #256 / I #249 - Fix Array validation in Question#in (@abinoam, issue by @esotericpig)
         | 
| 19 | 
            +
             | 
| 5 20 | 
             
            ### 2.1.0 / 2022-12-31
         | 
| 6 21 | 
             
            * PR #255 - Change minimum Ruby version requirement to 2.3 (@abinoam)
         | 
| 7 22 | 
             
            * PR #254 - Improve Github Actions file (@abinoam)
         | 
    
        data/README.md
    CHANGED
    
    | @@ -43,12 +43,48 @@ puts "You have answered: #{answer}" | |
| 43 43 |  | 
| 44 44 | 
             
            cli.ask("Company?  ") { |q| q.default = "none" }
         | 
| 45 45 |  | 
| 46 | 
            +
            ## Disable default value hint showing
         | 
| 47 | 
            +
             | 
| 48 | 
            +
            my_special_default_object = Object.new
         | 
| 49 | 
            +
             | 
| 50 | 
            +
            cli.ask("Question?  ") do |q|
         | 
| 51 | 
            +
              q.default = my_special_default_object
         | 
| 52 | 
            +
              q.default_hint_show = false
         | 
| 53 | 
            +
            end
         | 
| 54 | 
            +
             | 
| 46 55 |  | 
| 47 56 | 
             
            # Validation
         | 
| 48 57 |  | 
| 49 58 | 
             
            cli.ask("Age?  ", Integer) { |q| q.in = 0..105 }
         | 
| 50 59 | 
             
            cli.ask("Name?  (last, first)  ") { |q| q.validate = /\A\w+, ?\w+\Z/ }
         | 
| 51 60 |  | 
| 61 | 
            +
            ## Validation with custom class
         | 
| 62 | 
            +
            class ZeroToTwentyFourValidator
         | 
| 63 | 
            +
              def self.valid?(answer)
         | 
| 64 | 
            +
                (0..24).include? answer.to_i
         | 
| 65 | 
            +
              end
         | 
| 66 | 
            +
             | 
| 67 | 
            +
              def self.inspect
         | 
| 68 | 
            +
                "(0..24) rule"
         | 
| 69 | 
            +
              end
         | 
| 70 | 
            +
            end
         | 
| 71 | 
            +
             | 
| 72 | 
            +
            cli.ask("What hour of the day is it?:  ", Integer) do |q|
         | 
| 73 | 
            +
              q.validate = ZeroToTwentyFourValidator
         | 
| 74 | 
            +
            end
         | 
| 75 | 
            +
             | 
| 76 | 
            +
            ## Validation with Dry::Types
         | 
| 77 | 
            +
            ## `Dry::Types` provides a `valid?` method so it can be used effortlessly
         | 
| 78 | 
            +
             | 
| 79 | 
            +
            require 'dry-type'
         | 
| 80 | 
            +
             | 
| 81 | 
            +
            module Types
         | 
| 82 | 
            +
              include Dry.Types
         | 
| 83 | 
            +
            end
         | 
| 84 | 
            +
             | 
| 85 | 
            +
            cli.ask("Type an integer:", Integer) do |q|
         | 
| 86 | 
            +
              q.validate = Types::Coercible::Integer
         | 
| 87 | 
            +
            end
         | 
| 52 88 |  | 
| 53 89 | 
             
            # Type conversion for answers:
         | 
| 54 90 |  | 
| @@ -103,7 +139,7 @@ For more examples see the examples/ directory of this project. | |
| 103 139 | 
             
            Requirements
         | 
| 104 140 | 
             
            ------------
         | 
| 105 141 |  | 
| 106 | 
            -
            HighLine from version >=  | 
| 142 | 
            +
            HighLine from version >= 3.0.0 requires ruby >= 3.0.0
         | 
| 107 143 |  | 
| 108 144 | 
             
            Installing
         | 
| 109 145 | 
             
            ----------
         | 
| @@ -0,0 +1,39 @@ | |
| 1 | 
            +
            require 'highline'
         | 
| 2 | 
            +
             | 
| 3 | 
            +
            cli = HighLine.new
         | 
| 4 | 
            +
             | 
| 5 | 
            +
            # The parser
         | 
| 6 | 
            +
            class ArrayOfNumbersFromString
         | 
| 7 | 
            +
              def self.parse(string)
         | 
| 8 | 
            +
                string.scan(/\d+/).map(&:to_i)
         | 
| 9 | 
            +
              end
         | 
| 10 | 
            +
            end
         | 
| 11 | 
            +
             | 
| 12 | 
            +
            # The validator
         | 
| 13 | 
            +
            class ArrayOfNumbersFromStringInRange
         | 
| 14 | 
            +
              def self.in?(range)
         | 
| 15 | 
            +
                new(range)
         | 
| 16 | 
            +
              end
         | 
| 17 | 
            +
             | 
| 18 | 
            +
              attr_reader :range
         | 
| 19 | 
            +
             | 
| 20 | 
            +
              def initialize(range)
         | 
| 21 | 
            +
                @range = range
         | 
| 22 | 
            +
              end
         | 
| 23 | 
            +
             | 
| 24 | 
            +
              def valid?(answer)
         | 
| 25 | 
            +
                ary = ArrayOfNumbersFromString.parse(answer)
         | 
| 26 | 
            +
                ary.all? ->(number) { range.include? number }
         | 
| 27 | 
            +
              end
         | 
| 28 | 
            +
             | 
| 29 | 
            +
              def inspect
         | 
| 30 | 
            +
                "in range #@range validator"
         | 
| 31 | 
            +
              end
         | 
| 32 | 
            +
            end
         | 
| 33 | 
            +
             | 
| 34 | 
            +
            answer = cli.ask("Which number? (0 or <Enter> to skip): ", ArrayOfNumbersFromString) { |q|
         | 
| 35 | 
            +
              q.validate = ArrayOfNumbersFromStringInRange.in?(0..10)
         | 
| 36 | 
            +
              q.default = 0
         | 
| 37 | 
            +
            }
         | 
| 38 | 
            +
             | 
| 39 | 
            +
            puts "Your answer was: #{answer} and it was correctly validated and coerced into an #{answer.class}"
         | 
    
        data/highline.gemspec
    CHANGED
    
    | @@ -27,9 +27,12 @@ DESCRIPTION | |
| 27 27 |  | 
| 28 28 | 
             
              spec.extra_rdoc_files = %w[README.md TODO Changelog.md LICENSE]
         | 
| 29 29 |  | 
| 30 | 
            -
              spec.required_ruby_version = ">=  | 
| 30 | 
            +
              spec.required_ruby_version = ">= 3.0"
         | 
| 31 31 |  | 
| 32 | 
            +
              spec.add_runtime_dependency "abbrev"
         | 
| 32 33 | 
             
              spec.add_development_dependency "bundler"
         | 
| 33 34 | 
             
              spec.add_development_dependency "rake"
         | 
| 34 35 | 
             
              spec.add_development_dependency "minitest"
         | 
| 36 | 
            +
              spec.add_development_dependency "dry-types"
         | 
| 37 | 
            +
              spec.add_development_dependency "reline"
         | 
| 35 38 | 
             
            end
         | 
| @@ -9,7 +9,7 @@ class HighLine | |
| 9 9 | 
             
                  extend Forwardable
         | 
| 10 10 |  | 
| 11 11 | 
             
                  def_delegators :@question,
         | 
| 12 | 
            -
                                 :answer, :answer=, | 
| 12 | 
            +
                                 :answer, :answer=,
         | 
| 13 13 | 
             
                                 :directory, :answer_type, :choices_complete
         | 
| 14 14 |  | 
| 15 15 | 
             
                  # It should be initialized with a Question object.
         | 
| @@ -26,10 +26,7 @@ class HighLine | |
| 26 26 | 
             
                  # it makes the conversion and returns the answer.
         | 
| 27 27 | 
             
                  # @return [Object] the converted answer.
         | 
| 28 28 | 
             
                  def convert
         | 
| 29 | 
            -
                     | 
| 30 | 
            -
             | 
| 31 | 
            -
                    self.answer = convert_by_answer_type
         | 
| 32 | 
            -
                    check_range
         | 
| 29 | 
            +
                    self.answer = convert_by_answer_type if answer_type
         | 
| 33 30 | 
             
                    answer
         | 
| 34 31 | 
             
                  end
         | 
| 35 32 |  | 
    
        data/lib/highline/question.rb
    CHANGED
    
    | @@ -56,6 +56,7 @@ class HighLine | |
| 56 56 | 
             
                  @completion  = @answer_type
         | 
| 57 57 |  | 
| 58 58 | 
             
                  @echo         = true
         | 
| 59 | 
            +
                  @default_hint_show = true
         | 
| 59 60 | 
             
                  @whitespace   = :strip
         | 
| 60 61 | 
             
                  @case         = nil
         | 
| 61 62 | 
             
                  @in           = nil
         | 
| @@ -115,7 +116,7 @@ class HighLine | |
| 115 116 | 
             
                #
         | 
| 116 117 | 
             
                attr_accessor :echo
         | 
| 117 118 | 
             
                #
         | 
| 118 | 
            -
                # Use the  | 
| 119 | 
            +
                # Use the Reline library to fetch input.  This allows input editing as
         | 
| 119 120 | 
             
                # well as keeping a history.  In addition, tab will auto-complete
         | 
| 120 121 | 
             
                # within an Array of choices or a file listing.
         | 
| 121 122 | 
             
                #
         | 
| @@ -124,6 +125,7 @@ class HighLine | |
| 124 125 | 
             
                # specified _input_ stream.
         | 
| 125 126 | 
             
                #
         | 
| 126 127 | 
             
                attr_accessor :readline
         | 
| 128 | 
            +
             | 
| 127 129 | 
             
                #
         | 
| 128 130 | 
             
                # Used to control whitespace processing for the answer to this question.
         | 
| 129 131 | 
             
                # See HighLine::Question.remove_whitespace() for acceptable settings.
         | 
| @@ -136,10 +138,17 @@ class HighLine | |
| 136 138 | 
             
                attr_accessor :case
         | 
| 137 139 | 
             
                # Used to provide a default answer to this question.
         | 
| 138 140 | 
             
                attr_accessor :default
         | 
| 141 | 
            +
                # Set it to a truthy or falsy value to enable or disable showing the default
         | 
| 142 | 
            +
                # value hint between vertical bars (pipes) when asking the question.
         | 
| 143 | 
            +
                # Defaults to +true+
         | 
| 144 | 
            +
                attr_accessor :default_hint_show
         | 
| 139 145 | 
             
                #
         | 
| 140 146 | 
             
                # If set to a Regexp, the answer must match (before type conversion).
         | 
| 141 147 | 
             
                # Can also be set to a Proc which will be called with the provided
         | 
| 142 148 | 
             
                # answer to validate with a +true+ or +false+ return.
         | 
| 149 | 
            +
                # It's possible to use a custom validator class. It must respond to
         | 
| 150 | 
            +
                # `#valid?`. The result of `#inspect` will be used in error messages.
         | 
| 151 | 
            +
                # See README.md for details.
         | 
| 143 152 | 
             
                #
         | 
| 144 153 | 
             
                attr_accessor :validate
         | 
| 145 154 | 
             
                # Used to control range checks for answer.
         | 
| @@ -252,7 +261,7 @@ class HighLine | |
| 252 261 | 
             
                #   Same as {#answer_type}.
         | 
| 253 262 |  | 
| 254 263 | 
             
                def build_responses(message_source = answer_type)
         | 
| 255 | 
            -
                   | 
| 264 | 
            +
                  append_default_to_template if default_hint_show
         | 
| 256 265 |  | 
| 257 266 | 
             
                  new_hash = build_responses_new_hash(message_source)
         | 
| 258 267 | 
             
                  # Update our internal responses with the new hash
         | 
| @@ -497,7 +506,8 @@ class HighLine | |
| 497 506 | 
             
                def valid_answer?
         | 
| 498 507 | 
             
                  !validate ||
         | 
| 499 508 | 
             
                    (validate.is_a?(Regexp) && answer =~ validate) ||
         | 
| 500 | 
            -
                    (validate.is_a?(Proc)   && validate[answer])
         | 
| 509 | 
            +
                    (validate.is_a?(Proc)   && validate[answer]) ||
         | 
| 510 | 
            +
                    (validate.respond_to?(:valid?) && validate.valid?(answer))
         | 
| 501 511 | 
             
                end
         | 
| 502 512 |  | 
| 503 513 | 
             
                #
         | 
| @@ -571,11 +581,6 @@ class HighLine | |
| 571 581 | 
             
                  end
         | 
| 572 582 | 
             
                end
         | 
| 573 583 |  | 
| 574 | 
            -
                # readline() needs to handle its own output, but readline only supports
         | 
| 575 | 
            -
                # full line reading.  Therefore if question.echo is anything but true,
         | 
| 576 | 
            -
                # the prompt will not be issued. And we have to account for that now.
         | 
| 577 | 
            -
                # Also, JRuby-1.7's ConsoleReader.readLine() needs to be passed the prompt
         | 
| 578 | 
            -
                # to handle line editing properly.
         | 
| 579 584 | 
             
                # @param highline [HighLine] context
         | 
| 580 585 | 
             
                # @return [void]
         | 
| 581 586 | 
             
                def show_question(highline)
         | 
| @@ -607,15 +612,20 @@ class HighLine | |
| 607 612 | 
             
                # Trailing whitespace is preserved so the function of HighLine.say() is
         | 
| 608 613 | 
             
                # not affected.
         | 
| 609 614 | 
             
                #
         | 
| 610 | 
            -
                def  | 
| 615 | 
            +
                def append_default_to_template
         | 
| 616 | 
            +
                  return unless default.respond_to? :to_s
         | 
| 617 | 
            +
             | 
| 618 | 
            +
                  default_str = default.to_s
         | 
| 619 | 
            +
                  return if default_str.empty?
         | 
| 620 | 
            +
             | 
| 611 621 | 
             
                  if template =~ /([\t ]+)\Z/
         | 
| 612 | 
            -
                    template << "|#{ | 
| 622 | 
            +
                    template << "|#{default_str}|#{Regexp.last_match(1)}"
         | 
| 613 623 | 
             
                  elsif template == ""
         | 
| 614 | 
            -
                    template << "|#{ | 
| 624 | 
            +
                    template << "|#{default_str}|  "
         | 
| 615 625 | 
             
                  elsif template[-1, 1] == "\n"
         | 
| 616 | 
            -
                    template[-2, 0] = "  |#{ | 
| 626 | 
            +
                    template[-2, 0] = "  |#{default_str}|"
         | 
| 617 627 | 
             
                  else
         | 
| 618 | 
            -
                    template << "  |#{ | 
| 628 | 
            +
                    template << "  |#{default_str}|"
         | 
| 619 629 | 
             
                  end
         | 
| 620 630 | 
             
                end
         | 
| 621 631 |  | 
| @@ -24,13 +24,15 @@ class HighLine | |
| 24 24 | 
             
                #
         | 
| 25 25 | 
             
                # @return [String] answer
         | 
| 26 26 | 
             
                def ask_once
         | 
| 27 | 
            -
                   | 
| 27 | 
            +
                  # If in readline mode, let reline take care of the prompt
         | 
| 28 | 
            +
                  question.show_question(@highline) unless question.readline
         | 
| 28 29 |  | 
| 29 30 | 
             
                  begin
         | 
| 30 31 | 
             
                    question.get_response_or_default(@highline)
         | 
| 31 32 | 
             
                    raise NotValidQuestionError unless question.valid_answer?
         | 
| 32 33 |  | 
| 33 34 | 
             
                    question.convert
         | 
| 35 | 
            +
                    question.check_range
         | 
| 34 36 |  | 
| 35 37 | 
             
                    if question.confirm
         | 
| 36 38 | 
             
                      confirmation = @highline.send(:confirm, question)
         | 
| @@ -20,7 +20,9 @@ class HighLine | |
| 20 20 | 
             
                    rescue LoadError
         | 
| 21 21 | 
             
                    end
         | 
| 22 22 |  | 
| 23 | 
            -
                    if  | 
| 23 | 
            +
                    if !@output.tty?
         | 
| 24 | 
            +
                      [80, 24]
         | 
| 25 | 
            +
                    elsif /solaris/ =~ RUBY_PLATFORM &&
         | 
| 24 26 | 
             
                       `stty` =~ /\brows = (\d+).*\bcolumns = (\d+)/
         | 
| 25 27 | 
             
                      [Regexp.last_match(2), Regexp.last_match(1)].map(&:to_i)
         | 
| 26 28 | 
             
                    elsif `stty size` =~ /^(\d+)\s(\d+)$/
         | 
| @@ -32,13 +34,13 @@ class HighLine | |
| 32 34 |  | 
| 33 35 | 
             
                  # (see Terminal#raw_no_echo_mode)
         | 
| 34 36 | 
             
                  def raw_no_echo_mode
         | 
| 35 | 
            -
                     | 
| 36 | 
            -
                    system "stty raw -echo -icanon isig"
         | 
| 37 | 
            +
                    save_stty 
         | 
| 38 | 
            +
                    system "stty raw -echo -icanon isig" if input.tty?
         | 
| 37 39 | 
             
                  end
         | 
| 38 40 |  | 
| 39 41 | 
             
                  # (see Terminal#restore_mode)
         | 
| 40 42 | 
             
                  def restore_mode
         | 
| 41 | 
            -
                     | 
| 43 | 
            +
                    restore_stty
         | 
| 42 44 | 
             
                    print "\r"
         | 
| 43 45 | 
             
                  end
         | 
| 44 46 |  | 
    
        data/lib/highline/terminal.rb
    CHANGED
    
    | @@ -95,9 +95,9 @@ class HighLine | |
| 95 95 | 
             
                # Get one line using #readline_read
         | 
| 96 96 | 
             
                # @param (see #get_line)
         | 
| 97 97 | 
             
                def get_line_with_readline(question, highline)
         | 
| 98 | 
            -
                  require " | 
| 98 | 
            +
                  require "reline" # load only if needed
         | 
| 99 99 |  | 
| 100 | 
            -
                  raw_answer = readline_read(question)
         | 
| 100 | 
            +
                  raw_answer = readline_read(question, highline)
         | 
| 101 101 |  | 
| 102 102 | 
             
                  if !raw_answer && highline.track_eof?
         | 
| 103 103 | 
             
                    raise EOFError, "The input stream is exhausted."
         | 
| @@ -109,7 +109,7 @@ class HighLine | |
| 109 109 | 
             
                # Use readline to read one line
         | 
| 110 110 | 
             
                # @param question [HighLine::Question] question from where to get
         | 
| 111 111 | 
             
                #   autocomplete candidate strings
         | 
| 112 | 
            -
                def readline_read(question)
         | 
| 112 | 
            +
                def readline_read(question, highline)
         | 
| 113 113 | 
             
                  # prep auto-completion
         | 
| 114 114 | 
             
                  unless question.selection.empty?
         | 
| 115 115 | 
             
                    Readline.completion_proc = lambda do |str|
         | 
| @@ -117,12 +117,14 @@ class HighLine | |
| 117 117 | 
             
                    end
         | 
| 118 118 | 
             
                  end
         | 
| 119 119 |  | 
| 120 | 
            +
                  # TODO: Check if this is still needed after Reline
         | 
| 120 121 | 
             
                  # work-around ugly readline() warnings
         | 
| 121 122 | 
             
                  old_verbose = $VERBOSE
         | 
| 122 123 | 
             
                  $VERBOSE    = nil
         | 
| 123 124 |  | 
| 124 125 | 
             
                  raw_answer  = run_preserving_stty do
         | 
| 125 | 
            -
                     | 
| 126 | 
            +
                    prompt = highline.render_and_ident_statement(question)
         | 
| 127 | 
            +
                    Readline.readline(prompt, true)
         | 
| 126 128 | 
             
                  end
         | 
| 127 129 |  | 
| 128 130 | 
             
                  $VERBOSE = old_verbose
         | 
| @@ -176,7 +178,7 @@ class HighLine | |
| 176 178 | 
             
                # Saves terminal state using shell stty command.
         | 
| 177 179 | 
             
                def save_stty
         | 
| 178 180 | 
             
                  @stty_save = begin
         | 
| 179 | 
            -
                                 `stty -g`.chomp
         | 
| 181 | 
            +
                                 `stty -g`.chomp if input.tty?
         | 
| 180 182 | 
             
                               rescue StandardError
         | 
| 181 183 | 
             
                                 nil
         | 
| 182 184 | 
             
                               end
         | 
    
        data/lib/highline/version.rb
    CHANGED
    
    
    
        data/lib/highline.rb
    CHANGED
    
    | @@ -371,10 +371,8 @@ class HighLine | |
| 371 371 | 
             
              #
         | 
| 372 372 | 
             
              # @param statement [Statement, String] what to be said
         | 
| 373 373 | 
             
              def say(statement)
         | 
| 374 | 
            -
                statement =  | 
| 375 | 
            -
                return if statement.empty?
         | 
| 376 | 
            -
             | 
| 377 | 
            -
                statement = (indentation + statement)
         | 
| 374 | 
            +
                statement = render_and_ident_statement(statement)
         | 
| 375 | 
            +
                return statement if statement.empty?
         | 
| 378 376 |  | 
| 379 377 | 
             
                # Don't add a newline if statement ends with whitespace, OR
         | 
| 380 378 | 
             
                # if statement ends with whitespace before a color escape code.
         | 
| @@ -386,6 +384,18 @@ class HighLine | |
| 386 384 | 
             
                end
         | 
| 387 385 | 
             
              end
         | 
| 388 386 |  | 
| 387 | 
            +
              # Renders and indents a statement.
         | 
| 388 | 
            +
              #
         | 
| 389 | 
            +
              # Note: extracted here to be used by readline to render its prompt.
         | 
| 390 | 
            +
              #
         | 
| 391 | 
            +
              # @param statement [String] The statement to be rendered and indented.
         | 
| 392 | 
            +
              # @return [String] The rendered and indented statement.
         | 
| 393 | 
            +
              def render_and_ident_statement(statement)
         | 
| 394 | 
            +
                statement = render_statement(statement)
         | 
| 395 | 
            +
                statement = (indentation + statement) unless statement.empty?
         | 
| 396 | 
            +
                statement
         | 
| 397 | 
            +
              end
         | 
| 398 | 
            +
             | 
| 389 399 | 
             
              # Renders a statement using {HighLine::Statement}
         | 
| 390 400 | 
             
              # @param statement [String] any string
         | 
| 391 401 | 
             
              # @return [Statement] rendered statement
         | 
| @@ -538,6 +548,7 @@ class HighLine | |
| 538 548 | 
             
                terminal.raw_no_echo_mode_exec do
         | 
| 539 549 | 
             
                  loop do
         | 
| 540 550 | 
             
                    character = terminal.get_character
         | 
| 551 | 
            +
                    raise Interrupt if character == "\u0003"
         | 
| 541 552 | 
             
                    break unless character
         | 
| 542 553 | 
             
                    break if ["\n", "\r"].include? character
         | 
| 543 554 |  | 
| @@ -545,6 +556,9 @@ class HighLine | |
| 545 556 | 
             
                    if character == "\b" || character == "\u007F"
         | 
| 546 557 | 
             
                      chopped = line.chop!
         | 
| 547 558 | 
             
                      output_erase_char if chopped && question.echo
         | 
| 559 | 
            +
                    elsif character == "\cU"
         | 
| 560 | 
            +
                      line.size.times { output_erase_char } if question.echo
         | 
| 561 | 
            +
                      line = ""
         | 
| 548 562 | 
             
                    elsif character == "\e"
         | 
| 549 563 | 
             
                      ignore_arrow_key
         | 
| 550 564 | 
             
                    else
         | 
    
        metadata
    CHANGED
    
    | @@ -1,15 +1,29 @@ | |
| 1 1 | 
             
            --- !ruby/object:Gem::Specification
         | 
| 2 2 | 
             
            name: highline
         | 
| 3 3 | 
             
            version: !ruby/object:Gem::Version
         | 
| 4 | 
            -
              version:  | 
| 4 | 
            +
              version: 3.0.0
         | 
| 5 5 | 
             
            platform: ruby
         | 
| 6 6 | 
             
            authors:
         | 
| 7 7 | 
             
            - James Edward Gray II
         | 
| 8 8 | 
             
            autorequire: 
         | 
| 9 9 | 
             
            bindir: bin
         | 
| 10 10 | 
             
            cert_chain: []
         | 
| 11 | 
            -
            date:  | 
| 11 | 
            +
            date: 2024-01-05 00:00:00.000000000 Z
         | 
| 12 12 | 
             
            dependencies:
         | 
| 13 | 
            +
            - !ruby/object:Gem::Dependency
         | 
| 14 | 
            +
              name: abbrev
         | 
| 15 | 
            +
              requirement: !ruby/object:Gem::Requirement
         | 
| 16 | 
            +
                requirements:
         | 
| 17 | 
            +
                - - ">="
         | 
| 18 | 
            +
                  - !ruby/object:Gem::Version
         | 
| 19 | 
            +
                    version: '0'
         | 
| 20 | 
            +
              type: :runtime
         | 
| 21 | 
            +
              prerelease: false
         | 
| 22 | 
            +
              version_requirements: !ruby/object:Gem::Requirement
         | 
| 23 | 
            +
                requirements:
         | 
| 24 | 
            +
                - - ">="
         | 
| 25 | 
            +
                  - !ruby/object:Gem::Version
         | 
| 26 | 
            +
                    version: '0'
         | 
| 13 27 | 
             
            - !ruby/object:Gem::Dependency
         | 
| 14 28 | 
             
              name: bundler
         | 
| 15 29 | 
             
              requirement: !ruby/object:Gem::Requirement
         | 
| @@ -52,6 +66,34 @@ dependencies: | |
| 52 66 | 
             
                - - ">="
         | 
| 53 67 | 
             
                  - !ruby/object:Gem::Version
         | 
| 54 68 | 
             
                    version: '0'
         | 
| 69 | 
            +
            - !ruby/object:Gem::Dependency
         | 
| 70 | 
            +
              name: dry-types
         | 
| 71 | 
            +
              requirement: !ruby/object:Gem::Requirement
         | 
| 72 | 
            +
                requirements:
         | 
| 73 | 
            +
                - - ">="
         | 
| 74 | 
            +
                  - !ruby/object:Gem::Version
         | 
| 75 | 
            +
                    version: '0'
         | 
| 76 | 
            +
              type: :development
         | 
| 77 | 
            +
              prerelease: false
         | 
| 78 | 
            +
              version_requirements: !ruby/object:Gem::Requirement
         | 
| 79 | 
            +
                requirements:
         | 
| 80 | 
            +
                - - ">="
         | 
| 81 | 
            +
                  - !ruby/object:Gem::Version
         | 
| 82 | 
            +
                    version: '0'
         | 
| 83 | 
            +
            - !ruby/object:Gem::Dependency
         | 
| 84 | 
            +
              name: reline
         | 
| 85 | 
            +
              requirement: !ruby/object:Gem::Requirement
         | 
| 86 | 
            +
                requirements:
         | 
| 87 | 
            +
                - - ">="
         | 
| 88 | 
            +
                  - !ruby/object:Gem::Version
         | 
| 89 | 
            +
                    version: '0'
         | 
| 90 | 
            +
              type: :development
         | 
| 91 | 
            +
              prerelease: false
         | 
| 92 | 
            +
              version_requirements: !ruby/object:Gem::Requirement
         | 
| 93 | 
            +
                requirements:
         | 
| 94 | 
            +
                - - ">="
         | 
| 95 | 
            +
                  - !ruby/object:Gem::Version
         | 
| 96 | 
            +
                    version: '0'
         | 
| 55 97 | 
             
            description: |
         | 
| 56 98 | 
             
              A high-level IO library that provides validation, type conversion, and more for
         | 
| 57 99 | 
             
              command-line interfaces. HighLine also includes a complete menu system that can
         | 
| @@ -83,6 +125,7 @@ files: | |
| 83 125 | 
             
            - examples/asking_for_arrays.rb
         | 
| 84 126 | 
             
            - examples/basic_usage.rb
         | 
| 85 127 | 
             
            - examples/color_scheme.rb
         | 
| 128 | 
            +
            - examples/custom_parser_custom_validator.rb
         | 
| 86 129 | 
             
            - examples/get_character.rb
         | 
| 87 130 | 
             
            - examples/limit.rb
         | 
| 88 131 | 
             
            - examples/menus.rb
         | 
| @@ -136,14 +179,14 @@ required_ruby_version: !ruby/object:Gem::Requirement | |
| 136 179 | 
             
              requirements:
         | 
| 137 180 | 
             
              - - ">="
         | 
| 138 181 | 
             
                - !ruby/object:Gem::Version
         | 
| 139 | 
            -
                  version: ' | 
| 182 | 
            +
                  version: '3.0'
         | 
| 140 183 | 
             
            required_rubygems_version: !ruby/object:Gem::Requirement
         | 
| 141 184 | 
             
              requirements:
         | 
| 142 185 | 
             
              - - ">="
         | 
| 143 186 | 
             
                - !ruby/object:Gem::Version
         | 
| 144 187 | 
             
                  version: '0'
         | 
| 145 188 | 
             
            requirements: []
         | 
| 146 | 
            -
            rubygems_version: 3. | 
| 189 | 
            +
            rubygems_version: 3.5.3
         | 
| 147 190 | 
             
            signing_key: 
         | 
| 148 191 | 
             
            specification_version: 4
         | 
| 149 192 | 
             
            summary: HighLine is a high-level command-line IO library.
         |