Sha256: 4bb86b14186ac63d42bd82ea3c5e7594159900bd5e6ca37ba2dc13db9a2c3f48

Contents?: true

Size: 1.84 KB

Versions: 16

Compression:

Stored size: 1.84 KB

Contents

# Licensed to the Apache Software Foundation (ASF) under one
# or more contributor license agreements.  See the NOTICE file
# distributed with this work for additional information
# regarding copyright ownership.  The ASF licenses this file
# to you under the Apache License, Version 2.0 (the
# "License"); you may not use this file except in compliance
# with the License.  You may obtain a copy of the License at
#
#   http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing,
# software distributed under the License is distributed on an
# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
# KIND, either express or implied.  See the License for the
# specific language governing permissions and limitations
# under the License.

module Arrow
  class TimestampArrayBuilder
    class << self
      def build(unit_or_data_type, values)
        builder = new(unit_or_data_type)
        builder.build(values)
      end
    end

    alias_method :initialize_raw, :initialize
    def initialize(unit_or_data_type)
      case unit_or_data_type
      when DataType
        data_type = unit_or_data_type
      else
        unit = unit_or_data_type
        data_type = TimestampDataType.new(unit)
      end
      initialize_raw(data_type)
    end

    private
    def unit_id
      @unit_id ||= value_data_type.unit.nick.to_sym
    end

    def convert_to_arrow_value(value)
      if value.respond_to?(:to_time) and not value.is_a?(Time)
        value = value.to_time
      end

      if value.is_a?(::Time)
        case unit_id
        when :second
          value.to_i
        when :milli
          value.to_i * 1_000 + value.usec / 1_000
        when :micro
          value.to_i * 1_000_000 + value.usec
        else
          value.to_i * 1_000_000_000 + value.nsec
        end
      else
        value
      end
    end
  end
end

Version data entries

16 entries across 16 versions & 1 rubygems

Version Path
red-arrow-8.0.0 lib/arrow/timestamp-array-builder.rb
red-arrow-7.0.0 lib/arrow/timestamp-array-builder.rb
red-arrow-6.0.1 lib/arrow/timestamp-array-builder.rb
red-arrow-6.0.0 lib/arrow/timestamp-array-builder.rb
red-arrow-5.0.0 lib/arrow/timestamp-array-builder.rb
red-arrow-4.0.1 lib/arrow/timestamp-array-builder.rb
red-arrow-4.0.0 lib/arrow/timestamp-array-builder.rb
red-arrow-3.0.0 lib/arrow/timestamp-array-builder.rb
red-arrow-2.0.0 lib/arrow/timestamp-array-builder.rb
red-arrow-1.0.1 lib/arrow/timestamp-array-builder.rb
red-arrow-1.0.0 lib/arrow/timestamp-array-builder.rb
red-arrow-0.17.1 lib/arrow/timestamp-array-builder.rb
red-arrow-0.17.0 lib/arrow/timestamp-array-builder.rb
red-arrow-0.16.0 lib/arrow/timestamp-array-builder.rb
red-arrow-0.15.1 lib/arrow/timestamp-array-builder.rb
red-arrow-0.15.0 lib/arrow/timestamp-array-builder.rb