module Presto::Client::ModelVersions::V0_173::QueryStats

Public Class Methods

decode(hash) click to toggle source
# File lib/presto/client/model_versions/0.173.rb, line 1148
def decode(hash)
  unless hash.is_a?(Hash)
    raise TypeError, "Can't convert #{hash.class} to Hash"
  end
  obj = allocate
  obj.send(:initialize_struct,
    hash["createTime"],
    hash["executionStartTime"],
    hash["lastHeartbeat"],
    hash["endTime"],
    hash["elapsedTime"],
    hash["queuedTime"],
    hash["analysisTime"],
    hash["distributedPlanningTime"],
    hash["totalPlanningTime"],
    hash["finishingTime"],
    hash["totalTasks"],
    hash["runningTasks"],
    hash["completedTasks"],
    hash["totalDrivers"],
    hash["queuedDrivers"],
    hash["runningDrivers"],
    hash["completedDrivers"],
    hash["cumulativeMemory"],
    hash["totalMemoryReservation"],
    hash["peakMemoryReservation"],
    hash["scheduled"],
    hash["totalScheduledTime"],
    hash["totalCpuTime"],
    hash["totalUserTime"],
    hash["totalBlockedTime"],
    hash["fullyBlocked"],
    hash["blockedReasons"] && hash["blockedReasons"].map {|h| h.downcase.to_sym },
    hash["rawInputDataSize"],
    hash["rawInputPositions"],
    hash["processedInputDataSize"],
    hash["processedInputPositions"],
    hash["outputDataSize"],
    hash["outputPositions"],
    hash["operatorSummaries"] && hash["operatorSummaries"].map {|h| OperatorStats.decode(h) },
  )
  obj
end