Sha256: bc2ba649fb5b5a394bfe3bc91651f69789393f00e708bfcf0a01ad3d8713a50d

Contents?: true

Size: 1.6 KB

Versions: 2

Compression:

Stored size: 1.6 KB

Contents

# frozen_string_literal: true

module Dynflow
  # Input/output format validation logic calling
  # input_format/output_format with block acts as a setter for
  # specifying the format. Without a block it acts as a getter
  module Action::Format
    # we don't evaluate tbe block immediatelly, but postpone it till all the
    # action classes are loaded, because we can use them to reference output format
    def input_format(&block)
      case
      when block && !@input_format_block
        @input_format_block = block
      when !block && @input_format_block
        return @input_format ||= Apipie::Params::Description.define(&@input_format_block)
      when block && @input_format_block
        raise "The input_format has already been defined in #{self.class}"
      when !block && !@input_format_block
        if superclass.respond_to? :input_format
          superclass.input_format
        else
          raise "The input_format has not been defined yet in #{self.class}"
        end
      end
    end

    def output_format(&block)
      case
      when block && !@output_format_block
        @output_format_block = block
      when !block && @output_format_block
        return @output_format ||= Apipie::Params::Description.define(&@output_format_block)
      when block && @output_format_block
        raise "The output_format has already been defined in #{self.class}"
      when !block && !@output_format_block
        if superclass.respond_to? :output_format
          superclass.output_format
        else
          raise "The output_format has not been defined yet in #{self.class}"
        end
      end
    end
  end
end

Version data entries

2 entries across 2 versions & 1 rubygems

Version Path
dynflow-1.9.0 lib/dynflow/action/format.rb
dynflow-1.8.3 lib/dynflow/action/format.rb