2015-06-18 10:25:33 -06:00
|
|
|
##
|
|
|
|
##
|
|
|
|
|
|
|
|
#
|
|
|
|
# Adapter for com.raytheon.uf.common.dataplugin.gfe.server.lock.LockTable
|
2016-03-16 16:32:17 -05:00
|
|
|
#
|
|
|
|
#
|
2015-06-18 10:25:33 -06:00
|
|
|
# SOFTWARE HISTORY
|
2016-03-16 16:32:17 -05:00
|
|
|
#
|
2015-06-18 10:25:33 -06:00
|
|
|
# Date Ticket# Engineer Description
|
|
|
|
# ------------ ---------- ----------- --------------------------
|
|
|
|
# 04/22/13 rjpeter Initial Creation.
|
|
|
|
# 06/12/13 #2099 dgilling Use new Lock constructor.
|
2016-03-16 16:32:17 -05:00
|
|
|
#
|
2015-06-18 10:25:33 -06:00
|
|
|
#
|
|
|
|
|
|
|
|
from dynamicserialize.dstypes.com.raytheon.uf.common.dataplugin.gfe.server.lock import LockTable
|
|
|
|
from dynamicserialize.dstypes.com.raytheon.uf.common.dataplugin.gfe.server.lock import Lock
|
|
|
|
|
|
|
|
ClassAdapter = 'com.raytheon.uf.common.dataplugin.gfe.server.lock.LockTable'
|
|
|
|
|
|
|
|
def serialize(context, lockTable):
|
|
|
|
index=0
|
|
|
|
wsIds = {lockTable.getWsId().toString() : index}
|
|
|
|
index += 1
|
|
|
|
locks = lockTable.getLocks()
|
|
|
|
lockWsIdIndex = []
|
|
|
|
for lock in locks:
|
|
|
|
wsIdString = lock.getWsId().toString()
|
2016-03-16 16:32:17 -05:00
|
|
|
|
2016-04-16 17:00:50 -06:00
|
|
|
if wsIdString in wsIds:
|
2015-06-18 10:25:33 -06:00
|
|
|
lockWsIdIndex.append(wsIds[wsIdString])
|
|
|
|
else:
|
|
|
|
lockWsIdIndex.append(index)
|
|
|
|
wsIds[wsIdString] = index
|
|
|
|
index += 1
|
|
|
|
|
|
|
|
context.writeObject(lockTable.getParmId())
|
2016-03-16 16:32:17 -05:00
|
|
|
|
2015-06-18 10:25:33 -06:00
|
|
|
context.writeI32(index)
|
|
|
|
for wsId in sorted(wsIds, key=wsIds.get):
|
|
|
|
context.writeObject(wsId)
|
2016-03-16 16:32:17 -05:00
|
|
|
|
2015-06-18 10:25:33 -06:00
|
|
|
context.writeI32(len(locks))
|
|
|
|
for lock, wsIndex in zip(locks, lockWsIdIndex):
|
|
|
|
serializer.writeI64(lock.getStartTime())
|
|
|
|
serializer.writeI64(lock.getEndTime())
|
|
|
|
serializer.writeI32(wsIndex)
|
2016-03-16 16:32:17 -05:00
|
|
|
|
2015-06-18 10:25:33 -06:00
|
|
|
def deserialize(context):
|
|
|
|
parmId = context.readObject()
|
|
|
|
numWsIds = context.readI32()
|
|
|
|
wsIds = []
|
2016-04-16 17:00:50 -06:00
|
|
|
for x in range(numWsIds):
|
2015-06-18 10:25:33 -06:00
|
|
|
wsIds.append(context.readObject())
|
2016-03-16 16:32:17 -05:00
|
|
|
|
2015-06-18 10:25:33 -06:00
|
|
|
numLocks = context.readI32()
|
|
|
|
locks = []
|
2016-04-16 17:00:50 -06:00
|
|
|
for x in range(numLocks):
|
2015-06-18 10:25:33 -06:00
|
|
|
startTime = context.readI64()
|
|
|
|
endTime = context.readI64()
|
|
|
|
wsId = wsIds[context.readI32()]
|
|
|
|
lock = Lock(parmId, wsId, startTime, endTime)
|
|
|
|
locks.append(lock)
|
2016-03-16 16:32:17 -05:00
|
|
|
|
2015-06-18 10:25:33 -06:00
|
|
|
lockTable = LockTable()
|
|
|
|
lockTable.setParmId(parmId)
|
|
|
|
lockTable.setWsId(wsIds[0])
|
|
|
|
lockTable.setLocks(locks)
|
|
|
|
|
2017-04-03 10:57:14 -06:00
|
|
|
return lockTable
|