Sha256: cc11efb07555693a4706256d6af40398b33603c88d9ed1ef976e391f3338b89e

Contents?: true

Size: 1.64 KB

Versions: 1

Compression:

Stored size: 1.64 KB

Contents

require 'honey_format/row_builder'

module HoneyFormat
  # Holds data for a single row.
  class Row
    # Returns a new instance of Row.
    # @return [Row] a new instance of Row.
    # @param [Array] columns an array of symbols.
    # @param builder [#call, #to_csv] optional row builder
    # @raise [RowError] super class of errors raised when there is a row error.
    # @raise [EmptyRowColumnsError] raised when there are no columns.
    # @raise [InvalidRowLengthError] raised when row has more columns than header columns.
    # @example Create new row
    #     Row.new!([:id])
    def initialize(columns, builder: nil)
      if columns.empty?
        err_msg = 'Expected array with at least one element, but was empty.'
        raise(Errors::EmptyRowColumnsError, err_msg)
      end

      @row_builder = RowBuilder.new(*columns)
      @builder = builder
      @columns = columns
    end

    # Returns a Struct.
    # @return [Object] a new instance of built row.
    # @param row [Array] the row array.
    # @raise [InvalidRowLengthError] raised when there are more row elements longer than columns
    # @example Build new row
    #     r = Row.new([:id])
    #     r.build(['1']).id #=> '1'
    def build(row)
      built_row = @row_builder.call(row)
      return built_row unless @builder
      @builder.call(built_row)
    rescue ArgumentError => e
      raise unless e.message == 'struct size differs'

      err_msg = [
        "Row length #{row.length}",
        "column length #{@columns.length}",
        "row: #{row.inspect}",
        "orignal message: '#{e.message}'"
      ].join(', ')
      raise(Errors::InvalidRowLengthError, err_msg)
    end
  end
end

Version data entries

1 entries across 1 versions & 1 rubygems

Version Path
honey_format-0.10.0 lib/honey_format/row.rb