Sha256: 922a352653e1c3a9ff338f41d6e508d98b29b549ff156c240b94a161a4c6115e

Contents?: true

Size: 1.6 KB

Versions: 56

Compression:

Stored size: 1.6 KB

Contents

require 'cli/ui'

module CLI
  module UI
    class Printer
      # Print a message to a stream with common utilities.
      # Allows overriding the color, encoding, and target stream.
      # By default, it formats the string using CLI:UI and rescues common stream errors.
      #
      # ==== Attributes
      #
      # * +msg+ - (required) the string to output. Can be frozen.
      #
      # ==== Options
      #
      # * +:frame_color+ - Override the frame color. Defaults to nil.
      # * +:to+ - Target stream, like $stdout or $stderr. Can be anything with a puts method. Defaults to $stdout.
      # * +:encoding+ - Force the output to be in a certain encoding. Defaults to UTF-8.
      # * +:format+ - Whether to format the string using CLI::UI.fmt. Defaults to true.
      # * +:graceful+ - Whether to gracefully ignore common I/O errors. Defaults to true.
      #
      # ==== Returns
      # Returns whether the message was successfully printed,
      # which can be useful if +:graceful+ is set to true.
      #
      # ==== Example
      #
      #   CLI::UI::Printer.puts('{x} Ouch', stream: $stderr, color: :red)
      #
      def self.puts(msg, frame_color: nil, to: $stdout, encoding: Encoding::UTF_8, format: true, graceful: true)
        msg = (+msg).force_encoding(encoding) if encoding
        msg = CLI::UI.fmt(msg) if format

        if frame_color
          CLI::UI::Frame.with_frame_color_override(frame_color) { to.puts(msg) }
        else
          to.puts(msg)
        end

        true
      rescue Errno::EIO, Errno::EPIPE, IOError => e
        raise(e) unless graceful
        false
      end
    end
  end
end

Version data entries

56 entries across 56 versions & 3 rubygems

Version Path
rfix-1.4.1 vendor/shopify/cli-ui/lib/cli/ui/printer.rb
rfix-1.4.0.pre.201 vendor/shopify/cli-ui/lib/cli/ui/printer.rb
rfix-1.4.0 vendor/shopify/cli-ui/lib/cli/ui/printer.rb
shopify-cli-1.5.0 vendor/deps/cli-ui/lib/cli/ui/printer.rb
rfix-1.3.0.pre.199 vendor/shopify/cli-ui/lib/cli/ui/printer.rb
cli-ui-1.4.0 lib/cli/ui/printer.rb
shopify-cli-1.4.1 vendor/deps/cli-ui/lib/cli/ui/printer.rb
shopify-cli-1.4.0 vendor/deps/cli-ui/lib/cli/ui/printer.rb
rfix-1.2.6.pre.198 vendor/shopify/cli-ui/lib/cli/ui/printer.rb
shopify-cli-1.3.1 vendor/deps/cli-ui/lib/cli/ui/printer.rb
shopify-cli-1.3.0 vendor/deps/cli-ui/lib/cli/ui/printer.rb
shopify-cli-1.2.0 vendor/deps/cli-ui/lib/cli/ui/printer.rb
shopify-cli-1.1.2 vendor/deps/cli-ui/lib/cli/ui/printer.rb
rfix-1.2.6 vendor/shopify/cli-ui/lib/cli/ui/printer.rb
shopify-cli-1.1.1 vendor/deps/cli-ui/lib/cli/ui/printer.rb
shopify-cli-1.1.0 vendor/deps/cli-ui/lib/cli/ui/printer.rb
shopify-cli-1.0.5 vendor/deps/cli-ui/lib/cli/ui/printer.rb
shopify-cli-1.0.4 vendor/deps/cli-ui/lib/cli/ui/printer.rb
shopify-cli-1.0.3 vendor/deps/cli-ui/lib/cli/ui/printer.rb
rfix-1.2.2.pre.174 vendor/shopify/cli-ui/lib/cli/ui/printer.rb