88 lines
2.6 KiB
Python
88 lines
2.6 KiB
Python
|
"""DistributedLargeBlobSender module: contains the DistributedLargeBlobSender class"""
|
||
|
|
||
|
from direct.distributed import DistributedObject
|
||
|
from direct.directnotify import DirectNotifyGlobal
|
||
|
from . import LargeBlobSenderConsts
|
||
|
|
||
|
class DistributedLargeBlobSender(DistributedObject.DistributedObject):
|
||
|
"""DistributedLargeBlobSender: for sending large chunks of data through
|
||
|
the DC system"""
|
||
|
notify = DirectNotifyGlobal.directNotify.newCategory('DistributedLargeBlobSender')
|
||
|
|
||
|
def __init__(self, cr):
|
||
|
DistributedObject.DistributedObject.__init__(self, cr)
|
||
|
|
||
|
def generate(self):
|
||
|
DistributedLargeBlobSender.notify.debug('generate')
|
||
|
DistributedObject.DistributedObject.generate(self)
|
||
|
self.complete = 0
|
||
|
self.doneEvent = None
|
||
|
|
||
|
def setMode(self, mode):
|
||
|
self.mode = mode
|
||
|
self.useDisk = mode & LargeBlobSenderConsts.USE_DISK
|
||
|
|
||
|
def setTargetAvId(self, avId):
|
||
|
self.targetAvId = avId
|
||
|
|
||
|
def announceGenerate(self):
|
||
|
DistributedLargeBlobSender.notify.debug('announceGenerate')
|
||
|
DistributedObject.DistributedObject.announceGenerate(self)
|
||
|
|
||
|
if self.targetAvId != base.localAvatar.doId:
|
||
|
# it's not for us
|
||
|
return
|
||
|
|
||
|
if not self.useDisk:
|
||
|
self.blob = ''
|
||
|
|
||
|
def setChunk(self, chunk):
|
||
|
DistributedLargeBlobSender.notify.debug('setChunk')
|
||
|
assert not self.useDisk
|
||
|
if len(chunk) > 0:
|
||
|
self.blob += chunk
|
||
|
else:
|
||
|
self.privOnBlobComplete()
|
||
|
|
||
|
def setFilename(self, filename):
|
||
|
DistributedLargeBlobSender.notify.debug('setFilename: %s' % filename)
|
||
|
assert self.useDisk
|
||
|
|
||
|
import os
|
||
|
origDir = os.getcwd()
|
||
|
bPath = LargeBlobSenderConsts.getLargeBlobPath()
|
||
|
try:
|
||
|
os.chdir(bPath)
|
||
|
except OSError:
|
||
|
DistributedLargeBlobSender.notify.error(
|
||
|
'could not access %s' % bPath)
|
||
|
f = file(filename, 'rb')
|
||
|
self.blob = f.read()
|
||
|
f.close()
|
||
|
os.unlink(filename)
|
||
|
os.chdir(origDir)
|
||
|
|
||
|
self.privOnBlobComplete()
|
||
|
|
||
|
def isComplete(self):
|
||
|
""" returns non-zero if we've got the full blob """
|
||
|
return self.complete
|
||
|
|
||
|
def setDoneEvent(self, event):
|
||
|
self.doneEvent = event
|
||
|
|
||
|
def privOnBlobComplete(self):
|
||
|
assert not self.isComplete()
|
||
|
self.complete = 1
|
||
|
# announce that we've got it?
|
||
|
if self.doneEvent is not None:
|
||
|
messenger.send(self.doneEvent, [self.blob])
|
||
|
|
||
|
def getBlob(self):
|
||
|
""" returns the full blob """
|
||
|
assert self.isComplete()
|
||
|
return self.blob
|
||
|
|
||
|
def sendAck(self):
|
||
|
self.sendUpdate('setAck', [])
|