Skip to content
Snippets Groups Projects
Code owners
Assign users and groups as approvers for specific file changes. Learn more.
internal_stanza.rb 3.84 KiB
module Hbc
  class CLI
    class InternalStanza < InternalUseBase
      # Syntax
      #
      #     brew cask _stanza <stanza_name> [ --table | --yaml | --inspect | --quiet ] [ <cask_token> ... ]
      #
      # If no tokens are given, then data for all Casks is returned.
      #
      # The pseudo-stanza "artifacts" is available.
      #
      # On failure, a blank line is returned on the standard output.
      #
      # Examples
      #
      #     brew cask _stanza appcast   --table
      #     brew cask _stanza app       --table alfred google-chrome adium voicemac logisim vagrant
      #     brew cask _stanza url       --table alfred google-chrome adium voicemac logisim vagrant
      #     brew cask _stanza version   --table alfred google-chrome adium voicemac logisim vagrant
      #     brew cask _stanza artifacts --table --inspect alfred google-chrome adium voicemac logisim vagrant
      #     brew cask _stanza artifacts --table --yaml    alfred google-chrome adium voicemac logisim vagrant
      #

      # TODO: this should be retrievable from Hbc::DSL
      ARTIFACTS = Set.new [
        :app,
        :suite,
        :artifact,
        :prefpane,
        :qlplugin,
        :dictionary,
        :font,
        :service,
        :colorpicker,
        :binary,
        :input_method,
        :internet_plugin,
        :audio_unit_plugin,
        :vst_plugin,
        :vst3_plugin,
        :screen_saver,
        :pkg,
        :installer,
        :stage_only,
        :nested_container,
        :uninstall,
        :postflight,
        :uninstall_postflight,
        :preflight,
        :uninstall_postflight,
      ]

      def self.run(*args)
        table = args.include? "--table"
        quiet = args.include? "--quiet"
        format = :to_yaml if args.include? "--yaml"
        format = :inspect if args.include? "--inspect"
        cask_tokens = cask_tokens_from(args)
        stanza = cask_tokens.shift.to_sym
        cask_tokens = Hbc.all_tokens if cask_tokens.empty?

        retval = print_stanzas(stanza, format, table, quiet, *cask_tokens)

        # retval is ternary: true/false/nil
        if retval.nil?
          exit 1 if quiet
          raise CaskError, "nothing to print"
        elsif !retval
          exit 1 if quiet
          raise CaskError, "print incomplete"
        end
      end

      def self.print_stanzas(stanza, format = nil, table = nil, quiet = nil, *cask_tokens)
        count = 0
        if ARTIFACTS.include?(stanza)
          artifact_name = stanza
          stanza = :artifacts
        end

        cask_tokens.each do |cask_token|
          print "#{cask_token}\t" if table

          begin
            cask = Hbc.load(cask_token)
          rescue StandardError
            opoo "Cask '#{cask_token}' was not found" unless quiet
            puts ""
            next
          end

          unless cask.respond_to?(stanza)
            opoo "no such stanza '#{stanza}' on Cask '#{cask_token}'" unless quiet
            puts ""
            next
          end

          begin
            value = cask.send(stanza)
          rescue StandardError
            opoo "failure calling '#{stanza}' on Cask '#{cask_token}'" unless quiet
            puts ""
            next
          end

          if artifact_name && !value.key?(artifact_name)
            opoo "no such stanza '#{artifact_name}' on Cask '#{cask_token}'" unless quiet
            puts ""
            next
          end

          value = value.fetch(artifact_name).to_a.flatten if artifact_name

          if format
            puts value.send(format)
          elsif artifact_name || value.is_a?(Symbol)
            puts value.inspect
          else
            puts value.to_s
          end

          count += 1
        end
        count.zero? ? nil : count == cask_tokens.length
      end

      def self.help
        "extract and render a specific stanza for the given Casks"
      end
    end
  end
end