yay repo cleanup

This commit is contained in:
John Cote 2015-07-05 19:59:25 -04:00
parent 3f55a00f0e
commit ad09d429fb
368 changed files with 1156 additions and 1231 deletions

View file

@ -32,7 +32,3 @@ print 'Encrypted string:', encoded
# decode the encoded string # decode the encoded string
decoded = DecodeAES(cipher, encoded) decoded = DecodeAES(cipher, encoded)
print 'Decrypted string:', decoded print 'Decrypted string:', decoded

View file

@ -29,50 +29,50 @@ def generate_token(accessLevel):
random.seed() random.seed()
while True: while True:
try: try:
res = client.ping(generate_token(700), 12345) res = client.ping(generate_token(700), 12345)
if res != 12345: if res != 12345:
print "Is the server accessable?\n" print "Is the server accessable?\n"
exit exit
# How many times a day is this script going to be called? # How many times a day is this script going to be called?
ChecksPerDay = 60.0*24.0 # Once a minute ChecksPerDay = 60.0*24.0 # Once a minute
InvasionsPerDay = 72.0 # How many invasions a day per district InvasionsPerDay = 72.0 # How many invasions a day per district
BaseInvasionChance = InvasionsPerDay/ChecksPerDay BaseInvasionChance = InvasionsPerDay/ChecksPerDay
safeHarbor = {'Wacky Falls'} safeHarbor = {'Wacky Falls'}
superDistricts = {'Nuttyboro'} superDistricts = {'Nuttyboro'}
while True: while True:
shards = client.listShards(generate_token(700)) shards = client.listShards(generate_token(700))
print shards print shards
count = 0 count = 0
for skey in shards: for skey in shards:
shard = shards[skey] shard = shards[skey]
if shard['invasion'] != None: if shard['invasion'] != None:
count = count + 1 count = count + 1
for skey in shards: for skey in shards:
shard = shards[skey] shard = shards[skey]
if shard['invasion'] == None: if shard['invasion'] == None:
if shard['name'] in superDistricts: if shard['name'] in superDistricts:
typ = int(float(random.random()) * 4.0) typ = int(float(random.random()) * 4.0)
suit = int(float(random.random()) * 4.0) + 4 # Bias the cogs to be big suit = int(float(random.random()) * 4.0) + 4 # Bias the cogs to be big
client.startInvasion(generate_token(700), int(skey), typ, suit, 0, 0) client.startInvasion(generate_token(700), int(skey), typ, suit, 0, 0)
count = count + 1 count = count + 1
print 'Calling invasion for %s with %d,%d'%(shard['name'],typ,suit) print 'Calling invasion for %s with %d,%d'%(shard['name'],typ,suit)
if count < 3: if count < 3:
for skey in shards: for skey in shards:
shard = shards[skey] shard = shards[skey]
if shard['invasion'] == None and not shard['name'] in safeHarbor: if shard['invasion'] == None and not shard['name'] in safeHarbor:
r = random.random() r = random.random()
if r < BaseInvasionChance and not shard['name'] in superDistricts: if r < BaseInvasionChance and not shard['name'] in superDistricts:
typ = int(float(random.random()) * 4.0) typ = int(float(random.random()) * 4.0)
suit = int(float(random.random()) * 8.0) suit = int(float(random.random()) * 8.0)
client.startInvasion(generate_token(700), int(skey), typ, suit, 0, 0) client.startInvasion(generate_token(700), int(skey), typ, suit, 0, 0)
print 'Calling invasion for %s with %d,%d'%(shard['name'],typ,suit) print 'Calling invasion for %s with %d,%d'%(shard['name'],typ,suit)
print "tick..(was %d)\n"%(count) print "tick..(was %d)\n"%(count)
time.sleep(60) time.sleep(60)
except Exception, e: except Exception, e:
print e print e
time.sleep(300) time.sleep(300)

View file

@ -14,7 +14,7 @@ class MagicWordManagerAI(DistributedObjectAI):
if not 'DistributedToonAI' in str(self.air.doId2do.get(targetId)): if not 'DistributedToonAI' in str(self.air.doId2do.get(targetId)):
self.sendUpdateToAvatarId(invokerId, 'sendMagicWordResponse', ['Target is not a toon object!']) self.sendUpdateToAvatarId(invokerId, 'sendMagicWordResponse', ['Target is not a toon object!'])
return return
if not invoker: if not invoker:
self.sendUpdateToAvatarId(invokerId, 'sendMagicWordResponse', ['missing invoker']) self.sendUpdateToAvatarId(invokerId, 'sendMagicWordResponse', ['missing invoker'])
return return
@ -56,21 +56,20 @@ def help(wordName=None):
return 'Did you mean %s' % (spellbook.words.get(key).name) return 'Did you mean %s' % (spellbook.words.get(key).name)
return 'I have no clue what %s is referring to' % (wordName) return 'I have no clue what %s is referring to' % (wordName)
return word.doc return word.doc
@magicWord(category=CATEGORY_COMMUNITY_MANAGER, types=[]) @magicWord(category=CATEGORY_COMMUNITY_MANAGER, types=[])
def words(): def words():
accessLevel = spellbook.getInvoker().getAdminAccess() accessLevel = spellbook.getInvoker().getAdminAccess()
wordString = None wordString = None
for key in spellbook.words: for key in spellbook.words:
word = spellbook.words.get(key) word = spellbook.words.get(key)
if word.access <= accessLevel: if word.access <= accessLevel:
if wordString is None: if wordString is None:
wordString = key wordString = key
else: else:
wordString += ", "; wordString += ", ";
wordString += key; wordString += key;
if wordString is None: if wordString is None:
return "You are chopped liver" return "You are chopped liver"
else: else:
return wordString return wordString

View file

@ -125,4 +125,4 @@ class TimeManager(DistributedObject.DistributedObject):
info = TTPythonUtil.describeException() info = TTPythonUtil.describeException()
self.notify.info('Client exception: %s' % info) self.notify.info('Client exception: %s' % info)
self.sendUpdate('setExceptionInfo', [info]) self.sendUpdate('setExceptionInfo', [info])
self.cr.flush() self.cr.flush()

View file

@ -10,13 +10,13 @@ class TimeManagerAI(DistributedObjectAI):
def __init__(self, air): def __init__(self, air):
DistributedObjectAI.__init__(self, air) DistributedObjectAI.__init__(self, air)
self.avId2DcReason = {} self.avId2DcReason = {}
def requestServerTime(self, context): def requestServerTime(self, context):
self.sendUpdateToAvatarId(self.air.getAvatarIdFromSender(), 'serverTime', [context, globalClockDelta.getRealNetworkTime(bits=32), int(time.time())]) self.sendUpdateToAvatarId(self.air.getAvatarIdFromSender(), 'serverTime', [context, globalClockDelta.getRealNetworkTime(bits=32), int(time.time())])
def setDisconnectReason(self, reason): def setDisconnectReason(self, reason):
avId = self.air.getAvatarIdFromSender() avId = self.air.getAvatarIdFromSender()
if reason == OTPGlobals.DisconnectNone and avId in self.avId2DcReason: if reason == OTPGlobals.DisconnectNone and avId in self.avId2DcReason:
del self.avId2DcReason[avId] del self.avId2DcReason[avId]
else: else:
@ -25,6 +25,6 @@ class TimeManagerAI(DistributedObjectAI):
def setExceptionInfo(self, exception): def setExceptionInfo(self, exception):
avId = self.air.getAvatarIdFromSender() avId = self.air.getAvatarIdFromSender()
self.air.writeServerEvent('client-exception', avId, exception) self.air.writeServerEvent('client-exception', avId, exception)
def getDisconnectReason(self, avId): def getDisconnectReason(self, avId):
return self.avId2DcReason.get(avId, 0) return self.avId2DcReason.get(avId, 0)

View file

@ -222,11 +222,11 @@ class Avatar(Actor, ShadowCaster):
if self.isDisguised: if self.isDisguised:
return return
self.setNametagName(str) self.setNametagName(str)
def setNametagName(self, name=None): def setNametagName(self, name=None):
if not name: if not name:
name = self.name name = self.name
self.nametag.setName(name) self.nametag.setName(name)
if hasattr(self, 'adminAccess') and self.isAdmin(): if hasattr(self, 'adminAccess') and self.isAdmin():

View file

@ -69,4 +69,4 @@ class DistributedAvatarAI(DistributedNodeAI.DistributedNodeAI):
senderId = self.air.getAvatarIdFromSender() senderId = self.air.getAvatarIdFromSender()
self.air.writeServerEvent('Admin chat warning', senderId, 'using setParentStr to send "%s"' % parentToken) self.air.writeServerEvent('Admin chat warning', senderId, 'using setParentStr to send "%s"' % parentToken)
self.notify.warning('Admin chat warning: %s using setParentStr to send "%s"' % (senderId, parentToken)) self.notify.warning('Admin chat warning: %s using setParentStr to send "%s"' % (senderId, parentToken))
DistributedNodeAI.DistributedNodeAI.setParentStr(self, parentToken) DistributedNodeAI.DistributedNodeAI.setParentStr(self, parentToken)

View file

@ -14,4 +14,4 @@ class DistributedAvatarUD(DistributedObjectUD):
pass pass
def confirmAvOnShard(self, todo0, todo1): def confirmAvOnShard(self, todo0, todo1):
pass pass

View file

@ -195,7 +195,7 @@ class DistributedPlayer(DistributedAvatar.DistributedAvatar, PlayerBase.PlayerBa
def displayTalk(self, chat): def displayTalk(self, chat):
print 'Talk: %s' % chat print 'Talk: %s' % chat
def displayTalkWhisper(self, avId, chat): def displayTalkWhisper(self, avId, chat):
print 'TalkWhisper from %s: %s' % (avId, chat) print 'TalkWhisper from %s: %s' % (avId, chat)
@ -258,7 +258,7 @@ class DistributedPlayer(DistributedAvatar.DistributedAvatar, PlayerBase.PlayerBa
def teleportQuery(self, requesterId): def teleportQuery(self, requesterId):
avatar = base.cr.identifyFriend(requesterId) avatar = base.cr.identifyFriend(requesterId)
if avatar is None: if avatar is None:
self.d_teleportResponse(self.doId, 0, 0, 0, 0, sendToId=requesterId) self.d_teleportResponse(self.doId, 0, 0, 0, 0, sendToId=requesterId)
elif base.localAvatar.isIgnored(requesterId): elif base.localAvatar.isIgnored(requesterId):
@ -354,4 +354,4 @@ class DistributedPlayer(DistributedAvatar.DistributedAvatar, PlayerBase.PlayerBa
self.autoRun = value self.autoRun = value
def getAutoRun(self): def getAutoRun(self):
return self.autoRun return self.autoRun

View file

@ -99,7 +99,7 @@ class DistributedPlayerAI(DistributedAvatarAI.DistributedAvatarAI, PlayerBase.Pl
def getAdminAccess(self): def getAdminAccess(self):
return self.adminAccess return self.adminAccess
def isAdmin(self): def isAdmin(self):
return self.adminAccess >= MINIMUM_MAGICWORD_ACCESS return self.adminAccess >= MINIMUM_MAGICWORD_ACCESS
@ -248,4 +248,4 @@ def enableGM():
target.d_setAdminAccess(target.oldAccess) target.d_setAdminAccess(target.oldAccess)
del target.oldAccess del target.oldAccess
return 'GM features are enabled!' return 'GM features are enabled!'

View file

@ -1100,7 +1100,7 @@ class LocalAvatar(DistributedAvatar.DistributedAvatar, DistributedSmoothNode.Dis
def clickedWhisper(self, doId): def clickedWhisper(self, doId):
friend = base.cr.identifyFriend(doId) friend = base.cr.identifyFriend(doId)
if friend != None: if friend != None:
messenger.send('clickedNametag', [friend]) messenger.send('clickedNametag', [friend])
self.chatMgr.whisperTo(friend.getName(), doId) self.chatMgr.whisperTo(friend.getName(), doId)

View file

@ -4,4 +4,4 @@ class PlayerBase:
return True return True
def getLocation(self): def getLocation(self):
return [] return []

View file

@ -125,4 +125,4 @@ class ShadowCaster:
def __globalDropShadowGrayLevelChanged(self): def __globalDropShadowGrayLevelChanged(self):
if self.dropShadow != None: if self.dropShadow != None:
self.dropShadow.setColor(0.0, 0.0, 0.0, globalDropShadowGrayLevel, 1) self.dropShadow.setColor(0.0, 0.0, 0.0, globalDropShadowGrayLevel, 1)

View file

@ -48,4 +48,4 @@ def chatmode(mode=-1):
# Like this will ever happen, but whatever. # Like this will ever happen, but whatever.
return "Chat mode 1 is reserved for moderators." return "Chat mode 1 is reserved for moderators."
base.cr.chatAgent.chatMode = mode base.cr.chatAgent.chatMode = mode
return "You are now talking in the %s chat mode." % mode2name.get(mode, "N/A") return "You are now talking in the %s chat mode." % mode2name.get(mode, "N/A")

View file

@ -37,4 +37,4 @@ class ChatAgentUD(DistributedObjectGlobalUD):
DistributedAvatar = self.air.dclassesByName['DistributedAvatarUD'] DistributedAvatar = self.air.dclassesByName['DistributedAvatarUD']
dg = DistributedAvatar.aiFormatUpdate('setTalk', sender, self.chatMode2channel.get(chatMode, sender), self.air.ourChannel, [message]) dg = DistributedAvatar.aiFormatUpdate('setTalk', sender, self.chatMode2channel.get(chatMode, sender), self.air.ourChannel, [message])
self.air.send(dg) self.air.send(dg)

View file

@ -1,7 +1,7 @@
import random import random
class ChatGarbler: class ChatGarbler:
def __init__(self, messages): def __init__(self, messages):
self.messages = messages self.messages = messages
@ -19,4 +19,4 @@ class ChatGarbler:
if i < numWords: if i < numWords:
newMessage = newMessage + ' ' newMessage = newMessage + ' '
return '\x01WLDisplay\x01%s\x02' % newMessage return '\x01WLDisplay\x01%s\x02' % newMessage

View file

@ -108,10 +108,10 @@ class ChatInputWhiteListFrame(FSM.FSM, DirectFrame):
if text: if text:
self.chatEntry.set('') self.chatEntry.set('')
if not base.cr.chatAgent.verifyMessage(text): if not base.cr.chatAgent.verifyMessage(text):
return return
self.sendChatBySwitch(text) self.sendChatBySwitch(text)
if not overflow: if not overflow:
@ -151,4 +151,4 @@ class ChatInputWhiteListFrame(FSM.FSM, DirectFrame):
def applyFilter(self, keyArgs): def applyFilter(self, keyArgs):
if base.whiteList: if base.whiteList:
self.chatEntry.set(base.whiteList.processThroughAll(self.chatEntry.get(plain=True))) self.chatEntry.set(base.whiteList.processThroughAll(self.chatEntry.get(plain=True)))

View file

@ -276,4 +276,4 @@ class ChatManager(DirectObject.DirectObject):
pass pass
def exitOtherDialog(self): def exitOtherDialog(self):
pass pass

View file

@ -12,4 +12,4 @@ def removeThoughtPrefix(message):
def findAvatarName(id): def findAvatarName(id):
info = base.cr.identifyAvatar(id) info = base.cr.identifyAvatar(id)
return info.getName() if info else '' return info.getName() if info else ''

View file

@ -376,4 +376,4 @@ SEQUENCES = {
'push': ['y', 'ye', 'cee', 'say', 'says', 'sea', 'seas', 'see', 'sees', 'she', 'shes', "she's", 'si'], 'push': ['y', 'ye', 'cee', 'say', 'says', 'sea', 'seas', 'see', 'sees', 'she', 'shes', "she's", 'si'],
'ashton': ['hole', 'whole', 'ole', 'ooo le', 'holes', 'zzz', "'s"], 'ashton': ['hole', 'whole', 'ole', 'ooo le', 'holes', 'zzz', "'s"],
'having': ['sec', 'see ex'], 'having': ['sec', 'see ex'],
} }

View file

@ -12,7 +12,7 @@ class WhiteList:
def setSequenceList(self, sequences): def setSequenceList(self, sequences):
self.sequenceList = sequences self.sequenceList = sequences
def getSequenceList(self, word): def getSequenceList(self, word):
return self.sequenceList[word] if word and word in self.sequenceList else None return self.sequenceList[word] if word and word in self.sequenceList else None
@ -27,7 +27,7 @@ class WhiteList:
i = bisect_left(self.words, text) i = bisect_left(self.words, text)
return i != self.numWords and self.words[i].startswith(text) return i != self.numWords and self.words[i].startswith(text)
def getReplacement(self, text, av=None, garbler=None): def getReplacement(self, text, av=None, garbler=None):
return '\x01WLRed\x01%s\x02' % text if not garbler else garbler.garble(av, len(text.split(' '))) return '\x01WLRed\x01%s\x02' % text if not garbler else garbler.garble(av, len(text.split(' ')))
@ -53,7 +53,7 @@ class WhiteList:
newWords[-1] = self.getReplacement(lastWord, av, garbler) newWords[-1] = self.getReplacement(lastWord, av, garbler)
return ' '.join(newWords) return ' '.join(newWords)
def processSequences(self, text, av=None, garbler=None): def processSequences(self, text, av=None, garbler=None):
if not self.sequenceList: if not self.sequenceList:
return text return text
@ -80,4 +80,4 @@ class WhiteList:
if (text.startswith('~') and not garbler): if (text.startswith('~') and not garbler):
return text return text
return self.processSequences(self.processText(re.sub(' +', ' ', text), av, garbler), av, garbler) return self.processSequences(self.processText(re.sub(' +', ' ', text), av, garbler), av, garbler)

View file

@ -36861,4 +36861,4 @@ WHITELIST = [
'zyyk', 'zyyk',
'zzz', 'zzz',
'zzzzzs', 'zzzzzs',
] ]

View file

@ -3,4 +3,3 @@ from direct.distributed.DistributedObjectAI import DistributedObjectAI
class AccountAI(DistributedObjectAI): class AccountAI(DistributedObjectAI):
notify = DirectNotifyGlobal.directNotify.newCategory("AccountAI") notify = DirectNotifyGlobal.directNotify.newCategory("AccountAI")

View file

@ -3,4 +3,3 @@ from direct.distributed.DistributedObjectUD import DistributedObjectUD
class AccountUD(DistributedObjectUD): class AccountUD(DistributedObjectUD):
notify = DirectNotifyGlobal.directNotify.newCategory("AccountUD") notify = DirectNotifyGlobal.directNotify.newCategory("AccountUD")

View file

@ -2,4 +2,4 @@ from direct.directnotify import DirectNotifyGlobal
from direct.distributed.DistributedObjectAI import DistributedObjectAI from direct.distributed.DistributedObjectAI import DistributedObjectAI
class DistributedDirectoryAI(DistributedObjectAI): class DistributedDirectoryAI(DistributedObjectAI):
notify = DirectNotifyGlobal.directNotify.newCategory("DistributedDirectoryAI") notify = DirectNotifyGlobal.directNotify.newCategory("DistributedDirectoryAI")

View file

@ -30,4 +30,4 @@ class DistributedDistrict(DistributedObject):
def setName(self, name): def setName(self, name):
self.name = name self.name = name
messenger.send('shardInfoUpdated') messenger.send('shardInfoUpdated')

View file

@ -9,4 +9,3 @@ class DistributedDistrictUD(DistributedObjectUD):
def setAvailable(self, todo0): def setAvailable(self, todo0):
pass pass

View file

@ -1217,7 +1217,7 @@ class OTPClientRepository(ClientRepositoryBase):
def identifyAvatar(self, doId): def identifyAvatar(self, doId):
info = self.doId2do.get(doId) info = self.doId2do.get(doId)
return info if info else self.identifyFriend(doId) return info if info else self.identifyFriend(doId)
def sendDisconnect(self): def sendDisconnect(self):
@ -1407,4 +1407,4 @@ class OTPClientRepository(ClientRepositoryBase):
ITAG_GAME = 'game' ITAG_GAME = 'game'
def addTaggedInterest(self, parentId, zoneId, mainTag, desc, otherTags = [], event = None): def addTaggedInterest(self, parentId, zoneId, mainTag, desc, otherTags = [], event = None):
return self.addInterest(parentId, zoneId, desc, event) return self.addInterest(parentId, zoneId, desc, event)

View file

@ -16,4 +16,4 @@ class PotentialAvatar:
self.shared = shared self.shared = shared
self.online = online self.online = online
self.defaultShard = defaultShard self.defaultShard = defaultShard
self.lastLogout = lastLogout self.lastLogout = lastLogout

View file

@ -5,4 +5,4 @@ class PotentialShard:
self.name = None self.name = None
self.population = 0 self.population = 0
self.active = 1 self.active = 1
self.available = 1 self.available = 1

View file

@ -117,4 +117,4 @@ class FriendManagerAI(DistributedObjectAI):
self.air.writeServerEvent('suspicious', avId, 'Player tried to cancel non-cancelled request!') self.air.writeServerEvent('suspicious', avId, 'Player tried to cancel non-cancelled request!')
return return
del self.requests[context] del self.requests[context]

View file

@ -30,4 +30,4 @@ class AmbientSound(BasicEntities.NodePathEntity):
self.soundIval.pause() self.soundIval.pause()
del self.soundIval del self.soundIval
if hasattr(self, 'sound'): if hasattr(self, 'sound'):
del self.sound del self.sound

View file

@ -31,4 +31,4 @@ class CollisionSolidEntity(BasicEntities.NodePathEntity):
if self.collNodePath is not None: if self.collNodePath is not None:
self.collNodePath.removeNode() self.collNodePath.removeNode()
self.collNodePath = None self.collNodePath = None
return return

View file

@ -34,4 +34,4 @@ class DistributedEntityAI(DistributedObjectAI.DistributedObjectAI, Entity.Entity
return self.levelDoId return self.levelDoId
def getEntId(self): def getEntId(self):
return self.entId return self.entId

View file

@ -21,4 +21,3 @@ class DistributedInteractiveEntityAI(DistributedEntityAI):
def setState(self, todo0, todo1): def setState(self, todo0, todo1):
pass pass

View file

@ -95,4 +95,4 @@ class DistributedLevelAI(DistributedObjectAI.DistributedObjectAI, Level.Level):
av.takeDamage(penalty) av.takeDamage(penalty)
if av.getHp() <= 0: if av.getHp() <= 0:
av.inventory.zeroInv() av.inventory.zeroInv()
av.d_setInventory(av.inventory.makeNetString()) av.d_setInventory(av.inventory.makeNetString())

View file

@ -84,4 +84,4 @@ class Entity(DirectObject):
return return
def setAttribInit(self, attrib, value): def setAttribInit(self, attrib, value):
self.__dict__[attrib] = value self.__dict__[attrib] = value

View file

@ -30,4 +30,4 @@ class EntrancePoint(BasicEntities.NodePathEntity):
def destroyEntrancePoint(self): def destroyEntrancePoint(self):
if self.entranceId >= 0: if self.entranceId >= 0:
if self.entranceId in self.level.entranceId2entity: if self.entranceId in self.level.entranceId2entity:
del self.level.entranceId2entity[self.entranceId] del self.level.entranceId2entity[self.entranceId]

View file

@ -216,4 +216,4 @@ class Level:
self.createdEntIds.remove(entId) self.createdEntIds.remove(entId)
def handleVisChange(self): def handleVisChange(self):
pass pass

View file

@ -1,4 +1,4 @@
MinZoneNum = 0 MinZoneNum = 0
MaxZoneNum = 999 MaxZoneNum = 999
UberZoneEntId = 0 UberZoneEntId = 0
LevelMgrEntId = 1000 LevelMgrEntId = 1000

View file

@ -6,7 +6,7 @@ class LevelMgr(LevelMgrBase.LevelMgrBase):
def __init__(self, level, entId): def __init__(self, level, entId):
LevelMgrBase.LevelMgrBase.__init__(self, level, entId) LevelMgrBase.LevelMgrBase.__init__(self, level, entId)
self.geom = loader.loadModel(self.modelFilename) self.geom = loader.loadModel(self.modelFilename)
if hasattr(self, 'removeNodes'): if hasattr(self, 'removeNodes'):
for node in self.removeNodes: for node in self.removeNodes:
self.geom.find(node).removeNode() self.geom.find(node).removeNode()

View file

@ -30,4 +30,4 @@ class LevelMgrAI(LevelMgrBase.LevelMgrBase):
zoneNums.sort() zoneNums.sort()
self.level.zoneIds = [] self.level.zoneIds = []
for zoneNum in zoneNums: for zoneNum in zoneNums:
self.level.zoneIds.append(self.level.zoneNum2zoneId[zoneNum]) self.level.zoneIds.append(self.level.zoneNum2zoneId[zoneNum])

View file

@ -25,4 +25,4 @@ class LocatorEntity(Entity.Entity, NodePath):
LocatorEntity.notify.warning("could not find '%s'" % self.searchPath) LocatorEntity.notify.warning("could not find '%s'" % self.searchPath)
self.reparentTo(hidden) self.reparentTo(hidden)
else: else:
self.reparentTo(parent) self.reparentTo(parent)

View file

@ -42,4 +42,4 @@ class PathEntity(BasicEntities.NodePathEntity):
duration = distance / velocity duration = distance / velocity
track.append(LerpPosInterval(node, duration=duration, pos=endPoint, startPos=startPoint)) track.append(LerpPosInterval(node, duration=duration, pos=endPoint, startPos=startPoint))
return track return track

View file

@ -49,4 +49,4 @@ class PropSpinner(Entity):
def destroyProps(self): def destroyProps(self):
if hasattr(self, 'spinTracks'): if hasattr(self, 'spinTracks'):
self.spinTracks.pause() self.spinTracks.pause()
del self.spinTracks del self.spinTracks

View file

@ -41,4 +41,4 @@ class VisibilityExtender(Entity.Entity):
def destroy(self): def destroy(self):
self.destroyVisExt() self.destroyVisExt()
Entity.Entity.destroy(self) Entity.Entity.destroy(self)

View file

@ -31,4 +31,4 @@ class ZoneEntity(ZoneEntityBase.ZoneEntityBase, BasicEntities.NodePathAttribs):
for zoneNum in zoneNumList: for zoneNum in zoneNumList:
self.visibleZoneNums[zoneNum] -= 1 self.visibleZoneNums[zoneNum] -= 1
if self.visibleZoneNums[zoneNum] == 0: if self.visibleZoneNums[zoneNum] == 0:
del self.visibleZoneNums[zoneNum] del self.visibleZoneNums[zoneNum]

View file

@ -157,4 +157,4 @@ class Nametag(ClickablePopup):
self.frame = (t.node().getLeft()-self.NAME_PADDING/2.0, self.frame = (t.node().getLeft()-self.NAME_PADDING/2.0,
t.node().getRight()+self.NAME_PADDING/2.0, t.node().getRight()+self.NAME_PADDING/2.0,
t.node().getBottom()-self.NAME_PADDING/2.0, t.node().getBottom()-self.NAME_PADDING/2.0,
t.node().getTop()+self.NAME_PADDING/2.0) t.node().getTop()+self.NAME_PADDING/2.0)

View file

@ -19,7 +19,7 @@ class OTPBase(ShowBase):
self.enviroCam = None self.enviroCam = None
self.pixelZoomSetup = False self.pixelZoomSetup = False
self.whiteList = None self.whiteList = None
if config.GetBool('want-whitelist', True): if config.GetBool('want-whitelist', True):
self.whiteList = WhiteList.WhiteList() self.whiteList = WhiteList.WhiteList()
self.whiteList.setWords(WhiteListData.WHITELIST) self.whiteList.setWords(WhiteListData.WHITELIST)
@ -283,4 +283,4 @@ def backgroundColor(r=None, g=1, b=1, a=1):
if r is None: if r is None:
r, g, b, a = OTPGlobals.DefaultBackgroundColor r, g, b, a = OTPGlobals.DefaultBackgroundColor
base.setBackgroundColor(Vec4(r, g, b, a)) base.setBackgroundColor(Vec4(r, g, b, a))
return 'The background color has been changed.' return 'The background color has been changed.'

View file

@ -297,4 +297,4 @@ AvatarFriendInvitationEvent = 'avatarFriendInvitationEvent'
AvatarFriendRejectInviteEvent = 'avatarFriendRejectInviteEvent' AvatarFriendRejectInviteEvent = 'avatarFriendRejectInviteEvent'
AvatarFriendRetractInviteEvent = 'avatarFriendRetractInviteEvent' AvatarFriendRetractInviteEvent = 'avatarFriendRetractInviteEvent'
AvatarFriendRejectRemoveEvent = 'avatarFriendRejectRemoveEvent' AvatarFriendRejectRemoveEvent = 'avatarFriendRejectRemoveEvent'
WhisperIncomingEvent = 'whisperIncomingEvent' WhisperIncomingEvent = 'whisperIncomingEvent'

View file

@ -2344,4 +2344,4 @@ AccessToString = {
500: '\x01androidGreen\x01Developer\x02', 500: '\x01androidGreen\x01Developer\x02',
600: '\x01cobalt\x01Admin\x02', 600: '\x01cobalt\x01Admin\x02',
700: '\x01azure\x01System Admin\x02' 700: '\x01azure\x01System Admin\x02'
} }

View file

@ -21,4 +21,4 @@ class CogSuitManagerAI:
parts = toon.getCogParts() parts = toon.getCogParts()
if CogDisguiseGlobals.isSuitComplete(parts, suitDept): if CogDisguiseGlobals.isSuitComplete(parts, suitDept):
toon.loseCogParts(suitDept) toon.loseCogParts(suitDept)

View file

@ -1,7 +1,7 @@
from direct.directnotify import DirectNotifyGlobal from direct.directnotify import DirectNotifyGlobal
from direct.distributed.DistributedObject import DistributedObject from direct.distributed.DistributedObject import DistributedObject
from toontown.toonbase import ToontownGlobals from toontown.toonbase import ToontownGlobals
class DistributedBlackCatMgr(DistributedObject): class DistributedBlackCatMgr(DistributedObject):
neverDisable = 1 neverDisable = 1
notify = DirectNotifyGlobal.directNotify.newCategory('DistributedBlackCatMgr') notify = DirectNotifyGlobal.directNotify.newCategory('DistributedBlackCatMgr')
@ -21,4 +21,4 @@ class DistributedBlackCatMgr(DistributedObject):
self.sendUpdate('requestBlackCatTransformation') self.sendUpdate('requestBlackCatTransformation')
def doBlackCatTransformation(self): def doBlackCatTransformation(self):
base.localAvatar.getDustCloud(0.0, color=base.localAvatar.style.getBlackColor()).start() base.localAvatar.getDustCloud(0.0, color=base.localAvatar.style.getBlackColor()).start()

View file

@ -20,4 +20,4 @@ class DistributedBlackCatMgrAI(DistributedObjectAI):
newDNA.makeFromNetString(av.getDNAString()) newDNA.makeFromNetString(av.getDNAString())
newDNA.updateToonProperties(armColor=26, legColor=26, headColor=26) newDNA.updateToonProperties(armColor=26, legColor=26, headColor=26)
taskMgr.doMethodLater(1.0, lambda task: av.b_setDNAString(newDNA.makeNetString()), 'transform-%d' % avId) taskMgr.doMethodLater(1.0, lambda task: av.b_setDNAString(newDNA.makeNetString()), 'transform-%d' % avId)
self.sendUpdateToAvatarId(avId, 'doBlackCatTransformation', []) self.sendUpdateToAvatarId(avId, 'doBlackCatTransformation', [])

View file

@ -7,7 +7,7 @@ class DistributedEffectMgr(DistributedObject):
def __init__(self, cr): def __init__(self, cr):
DistributedObject.__init__(self, cr) DistributedObject.__init__(self, cr)
self.nextTime = 0 self.nextTime = 0
def delete(self): def delete(self):
self.ignoreAll() self.ignoreAll()
DistributedObject.delete(self) DistributedObject.delete(self)
@ -46,4 +46,4 @@ class DistributedEffectMgr(DistributedObject):
if type == HolidayGlobals.TRICK_OR_TREAT: if type == HolidayGlobals.TRICK_OR_TREAT:
base.localAvatar.trickOrTreatTargetMet(amount) base.localAvatar.trickOrTreatTargetMet(amount)
elif type == HolidayGlobals.WINTER_CAROLING: elif type == HolidayGlobals.WINTER_CAROLING:
base.localAvatar.winterCarolingTargetMet(amount) base.localAvatar.winterCarolingTargetMet(amount)

View file

@ -40,4 +40,4 @@ class DistributedEffectMgrAI(DistributedObjectAI):
av.b_setCheesyEffect(self.effectId, 0, expireTime) av.b_setCheesyEffect(self.effectId, 0, expireTime)
else: else:
av.b_setCheesyEffect(self.effectId, 0, expireTime) av.b_setCheesyEffect(self.effectId, 0, expireTime)
self.sendUpdateToAvatarId(avId, 'effectDone', [0]) self.sendUpdateToAvatarId(avId, 'effectDone', [0])

View file

@ -23,4 +23,4 @@ class DistributedPolarPlaceEffectMgrAI(DistributedObjectAI, FSM):
return return
expireTime = int((time.time()/60) + 0.5) + 60 expireTime = int((time.time()/60) + 0.5) + 60
av.b_setCheesyEffect(13, 3000, expireTime) av.b_setCheesyEffect(13, 3000, expireTime)

View file

@ -37,7 +37,7 @@ class HalloweenHolidayDecorator(HolidayDecorator.HolidayDecorator):
base.cr.playGame.getPlace().loader.hood.loader and base.cr.playGame.getPlace().loader.hood.loader and
hasattr(base.cr.playGame.getPlace().loader.hood.loader, 'geom') and hasattr(base.cr.playGame.getPlace().loader.hood.loader, 'geom') and
base.cr.playGame.getPlace().loader.hood.loader.geom): base.cr.playGame.getPlace().loader.hood.loader.geom):
return True return True
else: else:
if hasattr(base.cr.playGame, 'getPlace') and base.cr.playGame.getPlace(): if hasattr(base.cr.playGame, 'getPlace') and base.cr.playGame.getPlace():
self.notify.debug('Failed Hood Check %s' % base.cr.playGame.getPlace()) self.notify.debug('Failed Hood Check %s' % base.cr.playGame.getPlace())

View file

@ -61,4 +61,4 @@ class HolidayDecorator:
s = Sequence(Wait(wait), np.colorScaleInterval(tFadeOut, Vec4(1, 1, 1, 0), startColorScale=Vec4(1, 1, 1, 1), blendType='easeInOut'), Func(np.detachNode), Func(np.clearTransparency), newNP.colorScaleInterval(tFadeOut, Vec4(1, 1, 1, 1), startColorScale=Vec4(1, 1, 1, 0), blendType='easeInOut'), Func(newNP.clearTransparency), Func(newNP.clearColorScale)) s = Sequence(Wait(wait), np.colorScaleInterval(tFadeOut, Vec4(1, 1, 1, 0), startColorScale=Vec4(1, 1, 1, 1), blendType='easeInOut'), Func(np.detachNode), Func(np.clearTransparency), newNP.colorScaleInterval(tFadeOut, Vec4(1, 1, 1, 1), startColorScale=Vec4(1, 1, 1, 0), blendType='easeInOut'), Func(newNP.clearTransparency), Func(newNP.clearColorScale))
p.append(s) p.append(s)
return p return p

View file

@ -133,7 +133,7 @@ def getStartDate(holiday, rightNow=None):
startMonth = holiday['startMonth'] if 'startMonth' in holiday else rightNow.month startMonth = holiday['startMonth'] if 'startMonth' in holiday else rightNow.month
startDay = holiday['startDay'] if 'startDay' in holiday else (rightNow.day if 'weekDay' in holiday else calendar.monthrange(rightNow.year, startMonth)[0]) startDay = holiday['startDay'] if 'startDay' in holiday else (rightNow.day if 'weekDay' in holiday else calendar.monthrange(rightNow.year, startMonth)[0])
startDate = datetime.datetime(rightNow.year, startMonth, startDay, tzinfo=TIME_ZONE) startDate = datetime.datetime(rightNow.year, startMonth, startDay, tzinfo=TIME_ZONE)
return startDate return startDate
def getEndDate(holiday, rightNow=None): def getEndDate(holiday, rightNow=None):
@ -149,4 +149,4 @@ def getEndDate(holiday, rightNow=None):
endDate = datetime.datetime(endYear, endMonth, endDay, tzinfo=TIME_ZONE) endDate = datetime.datetime(endYear, endMonth, endDay, tzinfo=TIME_ZONE)
return endDate return endDate

View file

@ -22,7 +22,7 @@ class NewsManager(DistributedObject):
def isHolidayRunning(self, id): def isHolidayRunning(self, id):
return id in self.activeHolidays return id in self.activeHolidays
def setActiveHolidays(self, ids): def setActiveHolidays(self, ids):
for id in ids: for id in ids:
self.startHoliday(id, True) self.startHoliday(id, True)
@ -30,13 +30,13 @@ class NewsManager(DistributedObject):
def broadcastHoliday(self, holiday, type): def broadcastHoliday(self, holiday, type):
if type in holiday: if type in holiday:
base.localAvatar.setSystemMessage(0, holiday[type]) base.localAvatar.setSystemMessage(0, holiday[type])
def startHoliday(self, id, ongoing=False): def startHoliday(self, id, ongoing=False):
if id in self.activeHolidays or id not in HolidayGlobals.Holidays: if id in self.activeHolidays or id not in HolidayGlobals.Holidays:
return return
holiday = HolidayGlobals.getHoliday(id) holiday = HolidayGlobals.getHoliday(id)
self.activeHolidays.append(id) self.activeHolidays.append(id)
self.broadcastHoliday(holiday, 'ongoingMessage' if ongoing else 'startMessage') self.broadcastHoliday(holiday, 'ongoingMessage' if ongoing else 'startMessage')
self.startSpecialHoliday(id) self.startSpecialHoliday(id)
@ -82,7 +82,7 @@ class NewsManager(DistributedObject):
base.localAvatar.chatMgr.chatInputSpeedChat.removeHalloweenMenu() base.localAvatar.chatMgr.chatInputSpeedChat.removeHalloweenMenu()
elif id == ToontownGlobals.CHRISTMAS: elif id == ToontownGlobals.CHRISTMAS:
base.localAvatar.chatMgr.chatInputSpeedChat.removeWinterMenu() base.localAvatar.chatMgr.chatInputSpeedChat.removeWinterMenu()
def setInvasionStatus(self, msgType, suitType, remaining, flags): def setInvasionStatus(self, msgType, suitType, remaining, flags):
if msgType not in ToontownGlobals.SuitInvasions: if msgType not in ToontownGlobals.SuitInvasions:
return return
@ -97,9 +97,9 @@ class NewsManager(DistributedObject):
track = Sequence() track = Sequence()
base.localAvatar.inventory.setInvasionCreditMultiplier(1 if msgType in ToontownGlobals.EndingInvasions else ToontownBattleGlobals.getInvasionMultiplier()) base.localAvatar.inventory.setInvasionCreditMultiplier(1 if msgType in ToontownGlobals.EndingInvasions else ToontownBattleGlobals.getInvasionMultiplier())
for i, message in enumerate(ToontownGlobals.SuitInvasions[msgType]): for i, message in enumerate(ToontownGlobals.SuitInvasions[msgType]):
track.append(Wait(5 if i else 1)) track.append(Wait(5 if i else 1))
track.append(Func(base.localAvatar.setSystemMessage, 0, (TTLocalizer.SuitInvasionPrefix + message) % suitNames)) track.append(Func(base.localAvatar.setSystemMessage, 0, (TTLocalizer.SuitInvasionPrefix + message) % suitNames))
track.start() track.start()

View file

@ -14,18 +14,18 @@ class NewsManagerAI(DistributedObjectAI):
DistributedObjectAI.__init__(self, air) DistributedObjectAI.__init__(self, air)
self.activeHolidays = [] self.activeHolidays = []
self.fireworkTask = None self.fireworkTask = None
def announceGenerate(self): def announceGenerate(self):
DistributedObjectAI.announceGenerate(self) DistributedObjectAI.announceGenerate(self)
self.__checkHolidays() self.__checkHolidays()
self.checkTask = taskMgr.doMethodLater(15, self.__checkHolidays, 'holidayCheckTask') self.checkTask = taskMgr.doMethodLater(15, self.__checkHolidays, 'holidayCheckTask')
self.accept('avatarEntered', self.__handleAvatarEntered) self.accept('avatarEntered', self.__handleAvatarEntered)
def delete(self): def delete(self):
DistributedObjectAI.delete(self) DistributedObjectAI.delete(self)
taskMgr.remove(self.checkTask) taskMgr.remove(self.checkTask)
self.deleteFireworkTask() self.deleteFireworkTask()
def deleteFireworkTask(self): def deleteFireworkTask(self):
if self.fireworkTask: if self.fireworkTask:
taskMgr.remove(self.fireworkTask) taskMgr.remove(self.fireworkTask)
@ -48,7 +48,7 @@ class NewsManagerAI(DistributedObjectAI):
for id in HolidayGlobals.Holidays: for id in HolidayGlobals.Holidays:
holiday = HolidayGlobals.Holidays[id] holiday = HolidayGlobals.Holidays[id]
running = self.isHolidayRunning(id) running = self.isHolidayRunning(id)
if self.isHolidayInRange(holiday, date): if self.isHolidayInRange(holiday, date):
if not running: if not running:
self.startHoliday(id) self.startHoliday(id)
@ -56,7 +56,7 @@ class NewsManagerAI(DistributedObjectAI):
self.endHoliday(id) self.endHoliday(id)
return Task.again return Task.again
def isHolidayInRange(self, holiday, date): def isHolidayInRange(self, holiday, date):
if 'weekDay' in holiday: if 'weekDay' in holiday:
return holiday['weekDay'] == date.weekday() return holiday['weekDay'] == date.weekday()
@ -73,7 +73,7 @@ class NewsManagerAI(DistributedObjectAI):
self.activeHolidays.append(id) self.activeHolidays.append(id)
self.startSpecialHoliday(id) self.startSpecialHoliday(id)
self.sendUpdate('startHoliday', [id]) self.sendUpdate('startHoliday', [id])
def endHoliday(self, id): def endHoliday(self, id):
if id not in self.activeHolidays or id not in HolidayGlobals.Holidays: if id not in self.activeHolidays or id not in HolidayGlobals.Holidays:
return return
@ -81,7 +81,7 @@ class NewsManagerAI(DistributedObjectAI):
self.activeHolidays.remove(id) self.activeHolidays.remove(id)
self.endSpecialHoliday(id) self.endSpecialHoliday(id)
self.sendUpdate('endHoliday', [id]) self.sendUpdate('endHoliday', [id])
def startSpecialHoliday(self, id): def startSpecialHoliday(self, id):
if id == ToontownGlobals.FISH_BINGO or id == ToontownGlobals.SILLY_SATURDAY: if id == ToontownGlobals.FISH_BINGO or id == ToontownGlobals.SILLY_SATURDAY:
messenger.send('checkBingoState') messenger.send('checkBingoState')
@ -94,7 +94,7 @@ class NewsManagerAI(DistributedObjectAI):
messenger.send('checkBingoState') messenger.send('checkBingoState')
elif id in [ToontownGlobals.SUMMER_FIREWORKS, ToontownGlobals.NEW_YEAR_FIREWORKS]: elif id in [ToontownGlobals.SUMMER_FIREWORKS, ToontownGlobals.NEW_YEAR_FIREWORKS]:
self.deleteFireworkTask() self.deleteFireworkTask()
def startFireworks(self, type, task=None): def startFireworks(self, type, task=None):
maxShow = len(FireworkShows.shows.get(type, [])) - 1 maxShow = len(FireworkShows.shows.get(type, [])) - 1
@ -106,4 +106,4 @@ class NewsManagerAI(DistributedObjectAI):
fireworkShow.generateWithRequired(hood.zoneId) fireworkShow.generateWithRequired(hood.zoneId)
fireworkShow.b_startShow(type, random.randint(0, maxShow), globalClockDelta.getRealNetworkTime()) fireworkShow.b_startShow(type, random.randint(0, maxShow), globalClockDelta.getRealNetworkTime())
return Task.again return Task.again

View file

@ -544,7 +544,7 @@ def quests(command, arg0=0, arg1=0):
if canCarry: if canCarry:
if arg0 in Quests.QuestDict.keys(): if arg0 in Quests.QuestDict.keys():
quest = Quests.QuestDict[arg0] quest = Quests.QuestDict[arg0]
simbase.air.questManager.avatarChoseQuest(invoker.doId, None, arg0, quest[5], quest[4]) simbase.air.questManager.avatarChoseQuest(invoker.doId, None, arg0, quest[5], quest[4])
return 'Added QuestID %s'%(arg0) return 'Added QuestID %s'%(arg0)
else: else:

View file

@ -7,4 +7,4 @@ def isValidCategoryName(value):
return value in categories return value in categories
def getCategory(value): def getCategory(value):
return categories[value] return categories[value]

View file

@ -98,7 +98,7 @@ class BattleCalculatorAI:
debug = self.notify.getDebug() debug = self.notify.getDebug()
attack = self.battle.toonAttacks[attackIndex] attack = self.battle.toonAttacks[attackIndex]
atkTrack, atkLevel = self.__getActualTrackLevel(attack) atkTrack, atkLevel = self.__getActualTrackLevel(attack)
if atkTrack == NPCSOS: if atkTrack == NPCSOS:
return (1, 95) return (1, 95)
if atkTrack == FIRE: if atkTrack == FIRE:
@ -506,7 +506,7 @@ class BattleCalculatorAI:
suit = self.battle.findSuit(targetId) suit = self.battle.findSuit(targetId)
if suit: if suit:
slips = toon.getPinkSlips() slips = toon.getPinkSlips()
if slips < 1: if slips < 1:
simbase.air.writeServerEvent('suspicious', toonId, 'Toon attempting to fire a cog without any pinkslips') simbase.air.writeServerEvent('suspicious', toonId, 'Toon attempting to fire a cog without any pinkslips')
else: else:

View file

@ -38,4 +38,4 @@ class BattleManagerAI:
cellId = battle.battleCellId cellId = battle.battleCellId
self.notify.debug('BattleManager - destroying battle %d' % cellId) self.notify.debug('BattleManager - destroying battle %d' % cellId)
del self.cellId2battle[cellId] del self.cellId2battle[cellId]
battle.requestDelete() battle.requestDelete()

View file

@ -146,4 +146,4 @@ def __makeShiftLift():
particles.emitter.setRadius(0.01) particles.emitter.setRadius(0.01)
effect.setHpr(0, 180, 0) effect.setHpr(0, 180, 0)
effect.setPos(0, 0, 0) effect.setPos(0, 0, 0)
return effect return effect

View file

@ -43,4 +43,4 @@ class BattleSounds:
return self.mgr.getSound(filename.getFullpath()) return self.mgr.getSound(filename.getFullpath())
return self.mgr.getNullSound() return self.mgr.getNullSound()
globalBattleSoundCache = BattleSounds() globalBattleSoundCache = BattleSounds()

View file

@ -124,4 +124,4 @@ class DistributedBattleAI(DistributedBattleBaseAI.DistributedBattleBaseAI):
DistributedBattleBaseAI.DistributedBattleBaseAI.enterResume(self) DistributedBattleBaseAI.DistributedBattleBaseAI.enterResume(self)
if self.finishCallback: if self.finishCallback:
self.finishCallback(self.zoneId) self.finishCallback(self.zoneId)
self.battleMgr.destroy(self) self.battleMgr.destroy(self)

View file

@ -320,7 +320,7 @@ class DistributedBattleBase(DistributedNode.DistributedNode, BattleBase):
pass pass
def getInteractiveProp(self): def getInteractiveProp(self):
if config.GetBool('want-anim-props', True): if config.GetBool('want-anim-props', True):
if self.interactiveProp: if self.interactiveProp:
return self.interactiveProp return self.interactiveProp
elif base.cr.playGame.hood and hasattr(base.cr.playGame.hood, 'loader'): elif base.cr.playGame.hood and hasattr(base.cr.playGame.hood, 'loader'):

View file

@ -1843,4 +1843,4 @@ def skipMovie():
return 'You are not currently in a battle!' return 'You are not currently in a battle!'
battle = simbase.air.doId2do.get(battleId) battle = simbase.air.doId2do.get(battleId)
battle._DistributedBattleBaseAI__movieDone() battle._DistributedBattleBaseAI__movieDone()
return 'Battle movie skipped.' return 'Battle movie skipped.'

View file

@ -311,9 +311,9 @@ class Movie(DirectObject.DirectObject):
elif tutTrack >= len(earnedXp): elif tutTrack >= len(earnedXp):
self.playTutorialReward_2() self.playTutorialReward_2()
return return
xp = earnedXp[tutTrack] xp = earnedXp[tutTrack]
if xp > 0: if xp > 0:
self.tutRewardDialog = TTDialog.TTDialog(text=TTLocalizer.MovieTutorialReward1 % (xp, TTLocalizer.BattleGlobalTracks[tutTrack].capitalize()), command=self.playTutorialReward_1, extraArgs=[earnedXp, tutTrack + 1], style=TTDialog.Acknowledge, fadeScreen=None, pos=(0.65, 0, 0.5), scale=0.8) self.tutRewardDialog = TTDialog.TTDialog(text=TTLocalizer.MovieTutorialReward1 % (xp, TTLocalizer.BattleGlobalTracks[tutTrack].capitalize()), command=self.playTutorialReward_1, extraArgs=[earnedXp, tutTrack + 1], style=TTDialog.Acknowledge, fadeScreen=None, pos=(0.65, 0, 0.5), scale=0.8)
sequence = Sequence() sequence = Sequence()
@ -321,7 +321,7 @@ class Movie(DirectObject.DirectObject):
sequence.start() sequence.start()
else: else:
self.playTutorialReward_1(None, earnedXp, tutTrack + 1) self.playTutorialReward_1(None, earnedXp, tutTrack + 1)
def playTutorialReward_2(self, value=None): def playTutorialReward_2(self, value=None):
from toontown.toon import Toon from toontown.toon import Toon
from toontown.toon import ToonDNA from toontown.toon import ToonDNA

View file

@ -342,4 +342,4 @@ ActorInterval(kapow, 'kapow'), Func(kapow.hide)), LerpPosInterval(suit, 3.0, Poi
return [toonTrack, return [toonTrack,
soundTrack, soundTrack,
buttonTrack, buttonTrack,
suitResponseTrack] suitResponseTrack]

View file

@ -745,4 +745,4 @@ squirtfn_array = (__doFlower,
__doSeltzerBottle, __doSeltzerBottle,
__doFireHose, __doFireHose,
__doStormCloud, __doStormCloud,
__doGeyser) __doGeyser)

View file

@ -718,7 +718,7 @@ def getToonTakeDamageTrack(toon, attack, died, dmg, delay, damageAnimNames = Non
toonTrack.append(Func(toon.loop, 'neutral')) toonTrack.append(Func(toon.loop, 'neutral'))
if died: if died:
pbpText = attack['playByPlayText'] pbpText = attack['playByPlayText']
toonTrack.append(pbpText.getToonsDiedInterval([TTLocalizer.ToonDefeatedMessage % toon.getName()], 7.0)) toonTrack.append(pbpText.getToonsDiedInterval([TTLocalizer.ToonDefeatedMessage % toon.getName()], 7.0))
return Parallel(toonTrack, indicatorTrack) return Parallel(toonTrack, indicatorTrack)

View file

@ -4902,5 +4902,3 @@ def bossCogFrontAttack(self):
force0.setActive(1) force0.setActive(1)
f0.addForce(force0) f0.addForce(force0)
self.addForceGroup(f0) self.addForceGroup(f0)

View file

@ -29,4 +29,4 @@ class PlayByPlayText(OnscreenText.OnscreenText):
track += newList track += newList
track.append(Wait(duration * 0.1)) track.append(Wait(duration * 0.1))
return track return track

View file

@ -96,7 +96,7 @@ class DistributedBoardingPartyAI(DistributedObjectAI.DistributedObjectAI, Boardi
# to merge groups. # to merge groups.
# mergeDict - This is a link that points back to the original # mergeDict - This is a link that points back to the original
# invitee before we mapped it to the leader of the other group. # invitee before we mapped it to the leader of the other group.
def requestInvite(self, inviteeId): def requestInvite(self, inviteeId):
self.notify.debug('requestInvite %s' % inviteeId) self.notify.debug('requestInvite %s' % inviteeId)
inviterId = self.air.getAvatarIdFromSender() inviterId = self.air.getAvatarIdFromSender()
@ -167,7 +167,7 @@ class DistributedBoardingPartyAI(DistributedObjectAI.DistributedObjectAI, Boardi
reason = BoardingPartyBase.BOARDCODE_PROMOTION reason = BoardingPartyBase.BOARDCODE_PROMOTION
self.sendUpdateToAvatarId(inviterId, 'postInviteNotQualify', [inviterId, reason, self.elevatorIdList[0]]) self.sendUpdateToAvatarId(inviterId, 'postInviteNotQualify', [inviterId, reason, self.elevatorIdList[0]])
return return
# Is the inviter already in the avIdDict? It follows they either must be in a group or have a pending invite... # Is the inviter already in the avIdDict? It follows they either must be in a group or have a pending invite...
if inviterId in self.avIdDict: if inviterId in self.avIdDict:
self.notify.debug('old group') self.notify.debug('old group')
# Everything is indexed by the leaders # Everything is indexed by the leaders
@ -184,7 +184,7 @@ class DistributedBoardingPartyAI(DistributedObjectAI.DistributedObjectAI, Boardi
if len(self.getGroupMemberList(leaderId)) >= self.maxSize: if len(self.getGroupMemberList(leaderId)) >= self.maxSize:
self.sendUpdate('postSizeReject', [leaderId, inviterId, inviteeId]) self.sendUpdate('postSizeReject', [leaderId, inviterId, inviteeId])
elif merger: elif merger:
# We cannot muck with the avIdDict because they are pointing to their original groups. # We cannot muck with the avIdDict because they are pointing to their original groups.
# We shall stash away the info into a different # We shall stash away the info into a different
# dictionary.. This way, if something goes wrong, # dictionary.. This way, if something goes wrong,
# the original groups with their original data # the original groups with their original data
@ -195,12 +195,12 @@ class DistributedBoardingPartyAI(DistributedObjectAI.DistributedObjectAI, Boardi
self.mergeDict[inviteeId] = originalInviteeId self.mergeDict[inviteeId] = originalInviteeId
self.sendUpdateToAvatarId(inviteeId, 'postInvite', [leaderId, inviterId, True]) self.sendUpdateToAvatarId(inviteeId, 'postInvite', [leaderId, inviterId, True])
# notify everybody in the inviters group of the # notify everybody in the inviters group of the
# invitation.. # invitation..
for memberId in groupList[0]: for memberId in groupList[0]:
if not memberId == inviterId: if not memberId == inviterId:
self.sendUpdateToAvatarId(memberId, 'postMessageInvited', [inviteeId, inviterId]) self.sendUpdateToAvatarId(memberId, 'postMessageInvited', [inviteeId, inviterId])
elif inviterId not in groupList[1] and inviterId not in groupList[2]: elif inviterId not in groupList[1] and inviterId not in groupList[2]:
# If the invitee isn't already in the group, add them.. # If the invitee isn't already in the group, add them..
if inviteeId not in groupList[1]: if inviteeId not in groupList[1]:
groupList[1].append(inviteeId) groupList[1].append(inviteeId)
self.groupListDict[leaderId] = groupList self.groupListDict[leaderId] = groupList
@ -213,7 +213,7 @@ class DistributedBoardingPartyAI(DistributedObjectAI.DistributedObjectAI, Boardi
for memberId in groupList[0]: for memberId in groupList[0]:
if not memberId == inviterId: if not memberId == inviterId:
self.sendUpdateToAvatarId(memberId, 'postMessageInvited', [inviteeId, inviterId]) self.sendUpdateToAvatarId(memberId, 'postMessageInvited', [inviteeId, inviterId])
# The inviter was kicked.. so, we cannot let them back in since they are not the leader... # The inviter was kicked.. so, we cannot let them back in since they are not the leader...
elif inviterId in groupList[2]: elif inviterId in groupList[2]:
self.sendUpdate('postKickReject', [leaderId, inviterId, inviteeId]) self.sendUpdate('postKickReject', [leaderId, inviterId, inviteeId])
else: else:

View file

@ -258,10 +258,10 @@ class DistributedBuilding(DistributedObject.DistributedObject):
def enterSuit(self, ts): def enterSuit(self, ts):
prop = self.getInteractiveProp() prop = self.getInteractiveProp()
if prop and not prop.state == 'Sad': if prop and not prop.state == 'Sad':
prop.gotoSad(self.doId) prop.gotoSad(self.doId)
self.setToSuit() self.setToSuit()
def exitSuit(self): def exitSuit(self):

View file

@ -14,4 +14,4 @@ class DistributedBuildingQueryMgrAI(DistributedObjectAI.DistributedObjectAI):
building = self.buildings.get(zoneId) building = self.buildings.get(zoneId)
if building is None: if building is None:
return return
self.sendUpdateToAvatarId(avId, 'response', [context, building.isSuitBlock()]) self.sendUpdateToAvatarId(avId, 'response', [context, building.isSuitBlock()])

View file

@ -7,4 +7,3 @@ class DistributedCJElevatorAI(DistributedBossElevatorAI.DistributedBossElevatorA
DistributedBossElevatorAI.DistributedBossElevatorAI.__init__(self, air, bldg, zone, antiShuffle=antiShuffle, minLaff=minLaff) DistributedBossElevatorAI.DistributedBossElevatorAI.__init__(self, air, bldg, zone, antiShuffle=antiShuffle, minLaff=minLaff)
self.type = ELEVATOR_CJ self.type = ELEVATOR_CJ
self.countdownTime = ElevatorData[self.type]['countdown'] self.countdownTime = ElevatorData[self.type]['countdown']

View file

@ -11,7 +11,7 @@ from direct.directnotify import DirectNotifyGlobal
from toontown.battle import BattleBase from toontown.battle import BattleBase
class DistributedElevatorIntAI(DistributedElevatorAI.DistributedElevatorAI): class DistributedElevatorIntAI(DistributedElevatorAI.DistributedElevatorAI):
def __init__(self, air, bldg, avIds): def __init__(self, air, bldg, avIds):
DistributedElevatorAI.DistributedElevatorAI.__init__(self, air, bldg) DistributedElevatorAI.DistributedElevatorAI.__init__(self, air, bldg)
self.countdownTime = simbase.config.GetFloat('int-elevator-timeout', INTERIOR_ELEVATOR_COUNTDOWN_TIME) self.countdownTime = simbase.config.GetFloat('int-elevator-timeout', INTERIOR_ELEVATOR_COUNTDOWN_TIME)
@ -35,7 +35,7 @@ class DistributedElevatorIntAI(DistributedElevatorAI.DistributedElevatorAI):
numFullSeats = self.countFullSeats() numFullSeats = self.countFullSeats()
if not numFullSeats <= len(self.avIds): if not numFullSeats <= len(self.avIds):
self.notify.warning('we are about to crash. self.seats=%s self.avIds=%s' % (self.seats, self.avIds)) self.notify.warning('we are about to crash. self.seats=%s self.avIds=%s' % (self.seats, self.avIds))
if numFullSeats == len(self.avIds): if numFullSeats == len(self.avIds):
self.fsm.request('allAboard') self.fsm.request('allAboard')
@ -133,4 +133,4 @@ class DistributedElevatorIntAI(DistributedElevatorAI.DistributedElevatorAI):
def enterClosed(self): def enterClosed(self):
DistributedElevatorAI.DistributedElevatorAI.enterClosed(self) DistributedElevatorAI.DistributedElevatorAI.enterClosed(self)
self.__doorsClosed() self.__doorsClosed()

View file

@ -35,7 +35,7 @@ class DistributedKnockKnockDoorAI(DistributedAnimatedPropAI.DistributedAnimatedP
DistributedAnimatedPropAI.DistributedAnimatedPropAI.exitPlaying(self) DistributedAnimatedPropAI.DistributedAnimatedPropAI.exitPlaying(self)
taskMgr.remove(self.doLaterTask) taskMgr.remove(self.doLaterTask)
self.doLaterTask = None self.doLaterTask = None
def requestToonup(self): def requestToonup(self):
av = self.air.doId2do.get(self.air.getAvatarIdFromSender()) av = self.air.doId2do.get(self.air.getAvatarIdFromSender())
@ -43,4 +43,4 @@ class DistributedKnockKnockDoorAI(DistributedAnimatedPropAI.DistributedAnimatedP
return return
av.toonUp(ToontownGlobals.KnockKnockHeal) av.toonUp(ToontownGlobals.KnockKnockHeal)
av.b_setNextKnockHeal(int(time.time() + ToontownGlobals.KnockKnockCooldown)) av.b_setNextKnockHeal(int(time.time() + ToontownGlobals.KnockKnockCooldown))

View file

@ -11,4 +11,4 @@ class DistributedPetshopInteriorAI(DistributedObjectAI.DistributedObjectAI):
DistributedObjectAI.DistributedObjectAI.generate(self) DistributedObjectAI.DistributedObjectAI.generate(self)
def getZoneIdAndBlock(self): def getZoneIdAndBlock(self):
return [self.zoneId, self.block] return [self.zoneId, self.block]

View file

@ -40,7 +40,7 @@ class DistributedToonHallInterior(DistributedToonInterior):
self.interior.flattenMedium() self.interior.flattenMedium()
for npcToon in self.cr.doFindAllInstances(DistributedNPCToonBase.DistributedNPCToonBase): for npcToon in self.cr.doFindAllInstances(DistributedNPCToonBase.DistributedNPCToonBase):
npcToon.initToonState() npcToon.initToonState()
self.createSillyMeter() self.createSillyMeter()
def createSillyMeter(self): def createSillyMeter(self):
@ -83,19 +83,19 @@ class DistributedToonHallInterior(DistributedToonInterior):
self.arrowSfx = self.audio3d.loadSfx('phase_4/audio/sfx/tt_s_prp_sillyMeterArrow.ogg') self.arrowSfx = self.audio3d.loadSfx('phase_4/audio/sfx/tt_s_prp_sillyMeterArrow.ogg')
self.arrowSfx.setLoop(False) self.arrowSfx.setLoop(False)
self.audio3d.setDropOffFactor(0.1) self.audio3d.setDropOffFactor(0.1)
self.startSillyMeter(config.GetInt('silly-meter-phase', 12)) self.startSillyMeter(config.GetInt('silly-meter-phase', 12))
def startSillyMeter(self, phase): def startSillyMeter(self, phase):
self.stopSillyMeter() self.stopSillyMeter()
if hasattr(self, 'enterPhase%s' % phase): if hasattr(self, 'enterPhase%s' % phase):
getattr(self, 'enterPhase%s' % phase)() getattr(self, 'enterPhase%s' % phase)()
self.phase = phase self.phase = phase
def stopSillyMeter(self): def stopSillyMeter(self):
if hasattr(self, 'phase') and hasattr(self, 'exitPhase%s' % self.phase): if hasattr(self, 'phase') and hasattr(self, 'exitPhase%s' % self.phase):
getattr(self, 'exitPhase%s' % self.phase)() getattr(self, 'exitPhase%s' % self.phase)()
def enterPhase0(self): def enterPhase0(self):
self.animSeq = Parallel(ActorInterval(self.sillyMeter, 'arrowTube', partName='arrow', duration=604800, constrainedLoop=1, startFrame=1, endFrame=30), Sequence(Func(self.phase1Sfx.play), Func(self.audio3d.attachSoundToObject, self.phase1Sfx, self.sillyMeter))) self.animSeq = Parallel(ActorInterval(self.sillyMeter, 'arrowTube', partName='arrow', duration=604800, constrainedLoop=1, startFrame=1, endFrame=30), Sequence(Func(self.phase1Sfx.play), Func(self.audio3d.attachSoundToObject, self.phase1Sfx, self.sillyMeter)))
@ -421,9 +421,9 @@ def sillyPhase(phase):
""" """
Set the silly meter phase. Set the silly meter phase.
""" """
if phase < -1 or phase > 14: if phase < -1 or phase > 14:
return 'Phase number must be between 0 and 14!' return 'Phase number must be between 0 and 14!'
messenger.send('SillyMeterPhase', [phase]) messenger.send('SillyMeterPhase', [phase])
return 'Successfully set the silly meter phase!' return 'Successfully set the silly meter phase!'

View file

@ -1,4 +1,4 @@
from DistributedToonInteriorAI import * from DistributedToonInteriorAI import *
class DistributedToonHallInteriorAI(DistributedToonInteriorAI): class DistributedToonHallInteriorAI(DistributedToonInteriorAI):
pass pass

View file

@ -7,4 +7,4 @@ INT_HOUSE = 6
EXT_COGHQ = 7 EXT_COGHQ = 7
INT_COGHQ = 8 INT_COGHQ = 8
EXT_KS = 9 EXT_KS = 9
INT_KS = 10 INT_KS = 10

View file

@ -35,7 +35,7 @@ class PetshopBuildingAI:
self.interior.generateWithRequired(self.interiorZone) self.interior.generateWithRequired(self.interiorZone)
self.npcs = NPCToons.createNpcsInZone(self.air, self.interiorZone) self.npcs = NPCToons.createNpcsInZone(self.air, self.interiorZone)
door = DistributedDoorAI.DistributedDoorAI( door = DistributedDoorAI.DistributedDoorAI(
self.air, blockNumber, DoorTypes.EXT_STANDARD) self.air, blockNumber, DoorTypes.EXT_STANDARD)
insideDoor = DistributedDoorAI.DistributedDoorAI( insideDoor = DistributedDoorAI.DistributedDoorAI(
@ -50,4 +50,4 @@ class PetshopBuildingAI:
self.insideDoor = insideDoor self.insideDoor = insideDoor
def createPet(self, ownerId, seed): def createPet(self, ownerId, seed):
return return

View file

@ -201,7 +201,7 @@ buildingMinMax = {
ToontownGlobals.PajamaPlace: [config.GetInt('pajama-place-building-min', 6), ToontownGlobals.PajamaPlace: [config.GetInt('pajama-place-building-min', 6),
config.GetInt('pajama-place-building-max', 12)], config.GetInt('pajama-place-building-max', 12)],
ToontownGlobals.BedtimeBoulevard: [config.GetInt('bedtime-boulevard-building-min', 6), ToontownGlobals.BedtimeBoulevard: [config.GetInt('bedtime-boulevard-building-min', 6),
config.GetInt('bedtime-boulevard-building-max', 12)], config.GetInt('bedtime-boulevard-building-max', 12)],
ToontownGlobals.SellbotHQ: [0, 0], ToontownGlobals.SellbotHQ: [0, 0],
ToontownGlobals.SellbotFactoryExt: [0, 0], ToontownGlobals.SellbotFactoryExt: [0, 0],
ToontownGlobals.CashbotHQ: [0, 0], ToontownGlobals.CashbotHQ: [0, 0],

View file

@ -5,7 +5,7 @@ from datetime import datetime
class AccountDate(DistributedObject): class AccountDate(DistributedObject):
neverDisable = 1 neverDisable = 1
notify = directNotify.newCategory('AccountDate') notify = directNotify.newCategory('AccountDate')
def __init__(self, cr): def __init__(self, cr):
DistributedObject.__init__(self, cr) DistributedObject.__init__(self, cr)
self.accountDays = 0 self.accountDays = 0
@ -20,20 +20,20 @@ class AccountDate(DistributedObject):
if base.cr.accountDateMgr is self: if base.cr.accountDateMgr is self:
del base.cr.accountDateMgr del base.cr.accountDateMgr
DistributedObject.delete(self) DistributedObject.delete(self)
def getAccountDays(self): def getAccountDays(self):
return self.accountDays return self.accountDays
def requestDate(self, task=None): def requestDate(self, task=None):
self.sendUpdate('requestDate') self.sendUpdate('requestDate')
if task is not None: if task is not None:
return task.done return task.done
def requestDateResult(self, result): def requestDateResult(self, result):
if result is None: if result is None:
notify.warning('Invalid response from server.') notify.warning('Invalid response from server.')
self.accountDays = 0 self.accountDays = 0
else: else:
date = datetime.strptime(result, "%a %b %d %H:%M:%S %Y") date = datetime.strptime(result, "%a %b %d %H:%M:%S %Y")
self.accountDays = (datetime.now() - date).days self.accountDays = (datetime.now() - date).days

View file

@ -3,21 +3,21 @@ from direct.distributed.DistributedObjectAI import DistributedObjectAI
class AccountDateAI(DistributedObjectAI): class AccountDateAI(DistributedObjectAI):
notify = DirectNotifyGlobal.directNotify.newCategory("AccountDateAI") notify = DirectNotifyGlobal.directNotify.newCategory("AccountDateAI")
def announceGenerate(self): def announceGenerate(self):
DistributedObjectAI.announceGenerate(self) DistributedObjectAI.announceGenerate(self)
def requestDate(self): def requestDate(self):
avId = self.air.getAvatarIdFromSender() avId = self.air.getAvatarIdFromSender()
av = self.air.doId2do.get(avId) av = self.air.doId2do.get(avId)
if not av: if not av:
return return
def callback(dclass, fields): def callback(dclass, fields):
if dclass is not None and dclass == self.air.dclassesByName['AccountAI'] and fields.has_key('CREATED'): if dclass is not None and dclass == self.air.dclassesByName['AccountAI'] and fields.has_key('CREATED'):
self.sendUpdateToAvatarId(avId, 'requestDateResult', [fields.get('CREATED')]) self.sendUpdateToAvatarId(avId, 'requestDateResult', [fields.get('CREATED')])
else: else:
self.sendUpdateToAvatarId(avId, 'requestDateResult', [None]) self.sendUpdateToAvatarId(avId, 'requestDateResult', [None])
self.air.dbInterface.queryObject(self.air.dbId, av.DISLid, callback) self.air.dbInterface.queryObject(self.air.dbId, av.DISLid, callback)

View file

@ -408,4 +408,4 @@ def getAllAccessories(*accessoryTypes):
base = CatalogAccessoryItem(accessoryType) base = CatalogAccessoryItem(accessoryType)
list.append(base) list.append(base)
return list return list

View file

@ -739,4 +739,4 @@ AccessoryTypes = {101: (AHat,
449: (AShoes, 449: (AShoes,
'shw2', 'shw2',
APriceCool, APriceCool,
7)} 7)}

View file

@ -580,4 +580,4 @@ def getAllClothes(*clothingTypes):
for n in range(1, len(base.getColorChoices())): for n in range(1, len(base.getColorChoices())):
list.append(CatalogClothingItem(clothingType, n)) list.append(CatalogClothingItem(clothingType, n))
return list return list

View file

@ -124,4 +124,4 @@ class CatalogEmoteItem(CatalogItem.CatalogItem):
dg.addBool(self.isSpecial) dg.addBool(self.isSpecial)
def isGift(self): def isGift(self):
return not self.getEmblemPrices() return not self.getEmblemPrices()

View file

@ -1086,7 +1086,7 @@ class CatalogFurnitureItem(CatalogAtticItem.CatalogAtticItem):
movie.synchronizeTo(self.sound) movie.synchronizeTo(self.sound)
screen = NodePath(CardMaker('tv-screen').generate()) screen = NodePath(CardMaker('tv-screen').generate())
screen.reparentTo(model) screen.reparentTo(model)
screen.setScale(2.5, 1.7, 1.4) screen.setScale(2.5, 1.7, 1.4)
screen.setPos(-1.15, -0.5, 1.1) screen.setPos(-1.15, -0.5, 1.1)
screen.setTexture(movie) screen.setTexture(movie)
@ -1146,12 +1146,12 @@ def nextAvailableCloset(avatar, duplicateItems):
def nextAvailableBank(avatar, duplicateItems): def nextAvailableBank(avatar, duplicateItems):
if not avatar.getMaxBankMoney() in MoneyToBank: if not avatar.getMaxBankMoney() in MoneyToBank:
return CatalogFurnitureItem(1300) return CatalogFurnitureItem(1300)
currentBank = MoneyToBank[avatar.getMaxBankMoney()] currentBank = MoneyToBank[avatar.getMaxBankMoney()]
if currentBank == MaxBankId: if currentBank == MaxBankId:
return return
return CatalogFurnitureItem(currentBank + 10) return CatalogFurnitureItem(currentBank + 10)
def get50ItemCloset(avatar, duplicateItems): def get50ItemCloset(avatar, duplicateItems):
@ -1183,10 +1183,10 @@ def getAllClosets():
def getAllBanks(): def getAllBanks():
list = [] list = []
for bankId in BankToMoney.keys(): for bankId in BankToMoney.keys():
list.append(CatalogFurnitureItem(bankId)) list.append(CatalogFurnitureItem(bankId))
return list return list
def get50ItemTrunk(avatar, duplicateItems): def get50ItemTrunk(avatar, duplicateItems):

View file

@ -1479,7 +1479,7 @@ class CatalogGenerator:
def __init__(self): def __init__(self):
self.__itemLists = {} self.__itemLists = {}
if config.GetBool('save-catalog-schedule', False): if config.GetBool('save-catalog-schedule', False):
self.outputSchedule('catalog-schedule.txt') self.outputSchedule('catalog-schedule.txt')
@ -1511,13 +1511,13 @@ class CatalogGenerator:
if nextAvailableCloset not in schedule: if nextAvailableCloset not in schedule:
weeklyCatalog += self.__selectItem(avatar, nextAvailableCloset, monthlyCatalog, saleItem=0) weeklyCatalog += self.__selectItem(avatar, nextAvailableCloset, monthlyCatalog, saleItem=0)
if nextAvailableBank not in schedule: if nextAvailableBank not in schedule:
weeklyCatalog += self.__selectItem(avatar, nextAvailableBank, monthlyCatalog, saleItem=0) weeklyCatalog += self.__selectItem(avatar, nextAvailableBank, monthlyCatalog, saleItem=0)
if nextAvailableTank not in schedule: if nextAvailableTank not in schedule:
weeklyCatalog += self.__selectItem(avatar, nextAvailableTank, monthlyCatalog, saleItem=0) weeklyCatalog += self.__selectItem(avatar, nextAvailableTank, monthlyCatalog, saleItem=0)
weeklyCatalog += self.__selectItem(avatar, get50ItemTrunk, monthlyCatalog, saleItem=0) weeklyCatalog += self.__selectItem(avatar, get50ItemTrunk, monthlyCatalog, saleItem=0)
if True: if True:

View file

@ -9,10 +9,10 @@ class CatalogHouseItem(CatalogItem.CatalogItem):
def makeNewItem(self, houseId): def makeNewItem(self, houseId):
self.houseId = houseId self.houseId = houseId
CatalogItem.CatalogItem.makeNewItem(self) CatalogItem.CatalogItem.makeNewItem(self)
def notOfferedTo(self, avatar): def notOfferedTo(self, avatar):
return 1 return 1
def requestPurchase(self, phone, callback): def requestPurchase(self, phone, callback):
from toontown.toontowngui import TTDialog from toontown.toontowngui import TTDialog
avatar = base.localAvatar avatar = base.localAvatar
@ -43,16 +43,16 @@ class CatalogHouseItem(CatalogItem.CatalogItem):
def getDeliveryTime(self): def getDeliveryTime(self):
return 0 return 0
def getEmblemPrices(self): def getEmblemPrices(self):
return HouseGlobals.HouseEmblemPrices[self.houseId] return HouseGlobals.HouseEmblemPrices[self.houseId]
def getPicture(self, avatar): def getPicture(self, avatar):
model = loader.loadModel(HouseGlobals.houseModels[self.houseId]) model = loader.loadModel(HouseGlobals.houseModels[self.houseId])
model.setBin('unsorted', 0, 1) model.setBin('unsorted', 0, 1)
self.hasPicture = True self.hasPicture = True
return self.makeFrameModel(model) return self.makeFrameModel(model)
def decodeDatagram(self, di, versionNumber, store): def decodeDatagram(self, di, versionNumber, store):
CatalogItem.CatalogItem.decodeDatagram(self, di, versionNumber, store) CatalogItem.CatalogItem.decodeDatagram(self, di, versionNumber, store)
self.houseId = di.getUint8() self.houseId = di.getUint8()
@ -60,13 +60,12 @@ class CatalogHouseItem(CatalogItem.CatalogItem):
def encodeDatagram(self, dg, store): def encodeDatagram(self, dg, store):
CatalogItem.CatalogItem.encodeDatagram(self, dg, store) CatalogItem.CatalogItem.encodeDatagram(self, dg, store)
dg.addUint8(self.houseId) dg.addUint8(self.houseId)
def recordPurchase(self, av, optional): def recordPurchase(self, av, optional):
house = simbase.air.doId2do.get(av.getHouseId()) house = simbase.air.doId2do.get(av.getHouseId())
if house: if house:
house.b_setHouseType(self.houseId) house.b_setHouseType(self.houseId)
return ToontownGlobals.P_ItemAvailable return ToontownGlobals.P_ItemAvailable
def getAllHouses(): def getAllHouses():
return [CatalogHouseItem(i) for i in xrange(6)] return [CatalogHouseItem(i) for i in xrange(6)]

View file

@ -6,7 +6,7 @@ import time
class CatalogManagerAI(DistributedObjectAI): class CatalogManagerAI(DistributedObjectAI):
notify = DirectNotifyGlobal.directNotify.newCategory("CatalogManagerAI") notify = DirectNotifyGlobal.directNotify.newCategory("CatalogManagerAI")
def __init__(self, air): def __init__(self, air):
DistributedObjectAI.__init__(self, air) DistributedObjectAI.__init__(self, air)
self.catalogGenerator = CatalogGenerator() self.catalogGenerator = CatalogGenerator()
@ -15,8 +15,8 @@ class CatalogManagerAI(DistributedObjectAI):
avId = self.air.getAvatarIdFromSender() avId = self.air.getAvatarIdFromSender()
av = self.air.doId2do.get(avId) av = self.air.doId2do.get(avId)
if av: if av:
self.deliverCatalogFor(av) self.deliverCatalogFor(av)
def deliverCatalogFor(self, av): def deliverCatalogFor(self, av):
monthlyCatalog = self.catalogGenerator.generateMonthlyCatalog(av, time.time() / 60) monthlyCatalog = self.catalogGenerator.generateMonthlyCatalog(av, time.time() / 60)
newWeek = (av.catalogScheduleCurrentWeek + 1) % ToontownGlobals.CatalogNumWeeks newWeek = (av.catalogScheduleCurrentWeek + 1) % ToontownGlobals.CatalogNumWeeks
@ -25,4 +25,3 @@ class CatalogManagerAI(DistributedObjectAI):
av.b_setCatalog(monthlyCatalog, weeklyCatalog, backCatalog) av.b_setCatalog(monthlyCatalog, weeklyCatalog, backCatalog)
av.b_setCatalogSchedule(newWeek, int((time.time() + 604800)/60)) av.b_setCatalogSchedule(newWeek, int((time.time() + 604800)/60))
av.b_setCatalogNotify(ToontownGlobals.NewItems, av.mailboxNotify) av.b_setCatalogNotify(ToontownGlobals.NewItems, av.mailboxNotify)

View file

@ -614,7 +614,7 @@ class CatalogScreen(DirectFrame):
if item in allBankItems and item.furnitureType == CatalogFurnitureItem.MaxBankId: if item in allBankItems and item.furnitureType == CatalogFurnitureItem.MaxBankId:
isMaxBankOffered = True isMaxBankOffered = True
break break
for item in itemList: for item in itemList:
if isinstance(item, CatalogInvalidItem.CatalogInvalidItem): if isinstance(item, CatalogInvalidItem.CatalogInvalidItem):
self.notify.warning('skipping catalog invalid item %s' % item) self.notify.warning('skipping catalog invalid item %s' % item)

Some files were not shown because too many files have changed in this diff Show more