Sha256: b1c69209cf6641f4394a238fc8fadb51384993988fa8073ee477450fb0fe2dc2

Contents?: true

Size: 1.66 KB

Versions: 22

Compression:

Stored size: 1.66 KB

Contents

module Pacer::Routes

  # Additional iteration methods that allow for rapid data
  # manipulation in transactional graphs. Bulk operations automatically
  # manage transactions in larger batches rather than on every
  # element created or removed or every property set.
  module BulkOperations
    # Like bulk_job that also returns an array of results
    def bulk_map(size = nil, target_graph = nil)
      result = []
      bulk_job(size, target_graph) do |e|
        result << yield(e)
      end
      result
    end

    # Iterates over each element in the route, controlling
    # transactions so that they are only committed once every
    # +size+ records.
    def bulk_job(size = nil, target_graph = nil, pre_commit = nil)
      target_graph ||= graph
      graph.read_transaction do
        if target_graph and not target_graph.in_bulk_job?
          begin
            target_graph.in_bulk_job = true
            size ||= target_graph.bulk_job_size
            counter = 0
            print "Bulk job ->" if Pacer.verbose?
            each_slice(size) do |slice|
              target_graph.transaction(nesting: true) do
                print " #{counter}" if Pacer.verbose?
                counter += size
                slice.each do |element|
                  yield element
                end
                pre_commit.call if pre_commit
              end
            end
          ensure
            puts '!' if Pacer.verbose?
            target_graph.in_bulk_job = false
          end
        elsif target_graph
          each do |element|
            yield element
          end
        else
          raise 'No graph in route for bulk job'
        end
      end
    end
  end
end

Version data entries

22 entries across 22 versions & 1 rubygems

Version Path
pacer-1.5.2-java lib/pacer/route/mixin/bulk_operations.rb
pacer-1.5.1-java lib/pacer/route/mixin/bulk_operations.rb