2015-03-07 02:46:05 +00:00
from otp . ai . AIBaseGlobal import *
from toontown . suit import SuitDNA
from direct . directnotify import DirectNotifyGlobal
from toontown . suit import DistributedSuitAI
from toontown . building import SuitBuildingGlobals
2015-03-27 23:25:31 +00:00
from toontown . suit . SuitInvasionGlobals import IFSkelecog , IFWaiter , IFV2
2015-03-07 02:46:05 +00:00
import types , math , random
2015-03-03 22:10:12 +00:00
2015-03-07 02:46:05 +00:00
BASE_RESERVE = 10
2015-03-03 22:10:12 +00:00
2015-03-07 02:46:05 +00:00
MAX_RESERVES = {
' s ' : BASE_RESERVE * .9 ,
' m ' : BASE_RESERVE * 1.1 ,
' l ' : BASE_RESERVE * 1.25 ,
' c ' : BASE_RESERVE * 1.5 ,
}
2015-03-03 22:10:12 +00:00
2015-03-07 02:46:05 +00:00
def filterReviveChance ( track , revive ) :
if revive > = 0 :
return revive
2015-04-27 23:51:51 +00:00
2015-03-07 02:46:05 +00:00
return random . randint ( config . GetInt ( ' min-lt-vs ' , 0 ) , config . GetInt ( ' max-lt-vs ' , 2 ) )
2015-04-27 23:51:51 +00:00
# Implements difficulty 19 / LT.
2015-03-07 02:46:05 +00:00
def getMaxReserves ( track ) :
return int ( math . ceil ( MAX_RESERVES [ track ] ) )
class SuitPlannerCogdoInteriorAI :
notify = DirectNotifyGlobal . directNotify . newCategory ( ' SuitPlannerCogdoInteriorAI ' )
def __init__ ( self , layout , difficulty , track , zoneId , numFloors = 1 ) :
self . zoneId = zoneId
self . numFloors = layout . getNumFloors ( )
difficulty = min ( difficulty + 4 , len ( SuitBuildingGlobals . SuitBuildingInfo ) - 1 )
self . respectInvasions = 1
2015-04-27 23:51:51 +00:00
2015-03-07 02:46:05 +00:00
if isinstance ( difficulty , types . StringType ) :
self . notify . warning ( ' difficulty is a string! ' )
difficulty = int ( difficulty )
2015-04-27 23:51:51 +00:00
2015-03-07 02:46:05 +00:00
self . _genSuitInfos ( numFloors , difficulty , track )
def __genJoinChances ( self , num ) :
joinChances = [ ]
2015-07-06 01:02:35 +00:00
for currChance in xrange ( num ) :
2015-03-07 02:46:05 +00:00
joinChances . append ( random . randint ( 1 , 100 ) )
joinChances . sort ( cmp )
return joinChances
def _genSuitInfos ( self , numFloors , difficulty , bldgTrack ) :
self . suitInfos = [ ]
self . notify . debug ( ' \n \n generating suitsInfos with numFloors ( ' + str ( numFloors ) + ' ) difficulty ( ' + str ( difficulty ) + ' +1) and bldgTrack ( ' + str ( bldgTrack ) + ' ) ' )
2015-07-06 01:02:35 +00:00
for currFloor in xrange ( numFloors ) :
2015-03-07 02:46:05 +00:00
infoDict = { }
lvls = self . __genLevelList ( difficulty , currFloor , numFloors )
activeDicts = [ ]
numActive = random . randint ( 1 , min ( 4 , len ( lvls ) ) )
2015-04-27 23:51:51 +00:00
2015-03-07 02:46:05 +00:00
if currFloor + 1 == numFloors and len ( lvls ) > 1 :
origBossSpot = len ( lvls ) - 1
2015-04-27 23:51:51 +00:00
2015-03-07 02:46:05 +00:00
if numActive == 1 :
newBossSpot = numActive - 1
else :
newBossSpot = numActive - 2
2015-04-27 23:51:51 +00:00
2015-03-07 02:46:05 +00:00
tmp = lvls [ newBossSpot ]
lvls [ newBossSpot ] = lvls [ origBossSpot ]
lvls [ origBossSpot ] = tmp
2015-04-27 23:51:51 +00:00
2015-03-07 02:46:05 +00:00
bldgInfo = SuitBuildingGlobals . SuitBuildingInfo [ difficulty ]
2015-04-27 23:51:51 +00:00
2015-03-07 02:46:05 +00:00
if len ( bldgInfo ) > SuitBuildingGlobals . SUIT_BLDG_INFO_REVIVES :
revives = bldgInfo [ SuitBuildingGlobals . SUIT_BLDG_INFO_REVIVES ] [ 0 ]
else :
revives = 0
2015-04-27 23:51:51 +00:00
2015-07-06 01:02:35 +00:00
for currActive in xrange ( numActive - 1 , - 1 , - 1 ) :
2015-03-07 02:46:05 +00:00
level = lvls [ currActive ]
type = self . __genNormalSuitType ( level )
activeDict = { }
activeDict [ ' type ' ] = type
activeDict [ ' track ' ] = bldgTrack
activeDict [ ' level ' ] = level
activeDict [ ' revives ' ] = filterReviveChance ( bldgTrack , revives )
activeDicts . append ( activeDict )
infoDict [ ' activeSuits ' ] = activeDicts
reserveDicts = [ ]
numReserve = min ( len ( lvls ) - numActive , getMaxReserves ( bldgTrack ) )
joinChances = self . __genJoinChances ( numReserve )
2015-07-06 01:02:35 +00:00
for currReserve in xrange ( numReserve ) :
2015-03-07 02:46:05 +00:00
level = lvls [ currReserve + numActive ]
type = self . __genNormalSuitType ( level )
reserveDict = { }
reserveDict [ ' type ' ] = type
reserveDict [ ' track ' ] = bldgTrack
reserveDict [ ' level ' ] = level
reserveDict [ ' revives ' ] = filterReviveChance ( bldgTrack , revives )
reserveDict [ ' joinChance ' ] = joinChances [ currReserve ]
reserveDicts . append ( reserveDict )
infoDict [ ' reserveSuits ' ] = reserveDicts
self . suitInfos . append ( infoDict )
def __genNormalSuitType ( self , lvl ) :
return SuitDNA . getRandomSuitType ( lvl )
def __genLevelList ( self , difficulty , currFloor , numFloors ) :
bldgInfo = SuitBuildingGlobals . SuitBuildingInfo [ difficulty ]
lvlPoolRange = bldgInfo [ SuitBuildingGlobals . SUIT_BLDG_INFO_LVL_POOL ]
maxFloors = bldgInfo [ SuitBuildingGlobals . SUIT_BLDG_INFO_FLOORS ] [ 1 ]
lvlPoolMults = bldgInfo [ SuitBuildingGlobals . SUIT_BLDG_INFO_LVL_POOL_MULTS ]
floorIdx = min ( currFloor , maxFloors - 1 )
lvlPoolMin = lvlPoolRange [ 0 ] * lvlPoolMults [ floorIdx ]
lvlPoolMax = lvlPoolRange [ 1 ] * lvlPoolMults [ floorIdx ]
lvlPool = random . randint ( int ( lvlPoolMin ) , int ( lvlPoolMax ) )
lvlMin = bldgInfo [ SuitBuildingGlobals . SUIT_BLDG_INFO_SUIT_LVLS ] [ 0 ]
lvlMax = bldgInfo [ SuitBuildingGlobals . SUIT_BLDG_INFO_SUIT_LVLS ] [ 1 ]
self . notify . debug ( ' Level Pool: ' + str ( lvlPool ) )
lvlList = [ ]
while lvlPool > = lvlMin :
newLvl = random . randint ( lvlMin , min ( lvlPool , lvlMax ) )
lvlList . append ( newLvl )
lvlPool - = newLvl
if currFloor + 1 == numFloors :
bossLvlRange = bldgInfo [ SuitBuildingGlobals . SUIT_BLDG_INFO_BOSS_LVLS ]
newLvl = random . randint ( bossLvlRange [ 0 ] , bossLvlRange [ 1 ] )
lvlList . append ( newLvl )
lvlList . sort ( cmp )
self . notify . debug ( ' LevelList: ' + repr ( lvlList ) )
return lvlList
def __setupSuitInfo ( self , suit , bldgTrack , suitLevel , suitType ) :
2015-03-27 23:25:31 +00:00
suitDeptIndex , suitTypeIndex , flags = simbase . air . suitInvasionManager . getInvadingCog ( )
if self . respectInvasions :
if suitDeptIndex is not None :
bldgTrack = SuitDNA . suitDepts [ suitDeptIndex ]
if suitTypeIndex is not None :
suitName = SuitDNA . getSuitName ( suitDeptIndex , suitTypeIndex )
suitType = SuitDNA . getSuitType ( suitName )
suitLevel = min ( max ( suitLevel , suitType ) , suitType + 4 )
2015-03-07 02:46:05 +00:00
dna = SuitDNA . SuitDNA ( )
dna . newSuitRandom ( suitType , bldgTrack )
suit . dna = dna
self . notify . debug ( ' Creating suit type ' + suit . dna . name + ' of level ' + str ( suitLevel ) + ' from type ' + str ( suitType ) + ' and track ' + str ( bldgTrack ) )
suit . setLevel ( suitLevel )
2015-03-27 23:25:31 +00:00
return flags
2015-03-07 02:46:05 +00:00
def __genSuitObject ( self , suitZone , suitType , bldgTrack , suitLevel , revives = 0 ) :
newSuit = DistributedSuitAI . DistributedSuitAI ( simbase . air , None )
2015-03-27 23:25:31 +00:00
flags = self . __setupSuitInfo ( newSuit , bldgTrack , suitLevel , suitType )
if flags & IFSkelecog :
2015-03-07 02:46:05 +00:00
newSuit . setSkelecog ( 1 )
newSuit . setSkeleRevives ( revives )
newSuit . generateWithRequired ( suitZone )
2015-03-27 23:25:31 +00:00
if flags & IFWaiter :
newSuit . b_setWaiter ( 1 )
if flags & IFV2 :
newSuit . b_setSkeleRevives ( 1 )
2015-03-07 02:46:05 +00:00
newSuit . node ( ) . setName ( ' suit- %s ' % newSuit . doId )
return newSuit
def myPrint ( self ) :
print ' Generated suits for cogdo: '
for floor , currInfo in enumerate ( self . suitInfos ) :
floor + = 1
2015-04-27 23:51:51 +00:00
2015-03-07 02:46:05 +00:00
actives = currInfo [ ' activeSuits ' ]
reserves = currInfo [ ' reserveSuits ' ]
2015-04-27 23:51:51 +00:00
2015-03-07 02:46:05 +00:00
print ' Floor %d has %d active suits. ' % ( floor , len ( actives ) )
print ' Floor %d has %d reserve suits. ' % ( floor , len ( reserves ) )
2015-04-27 23:51:51 +00:00
2015-03-07 02:46:05 +00:00
for idx , currActive in enumerate ( actives ) :
type , track , level , revives = map ( lambda x : currActive [ x ] , ( ' type ' , ' track ' , ' level ' , ' revives ' ) )
2015-04-27 23:51:51 +00:00
2015-03-07 02:46:05 +00:00
print ' -- Active suit %d is %s , %s and level %d and revives is %d ' % ( idx , type , track , level , revives )
2015-04-27 23:51:51 +00:00
2015-03-07 02:46:05 +00:00
for idx , currReserve in enumerate ( reserves ) :
type , track , level , revives , res = map ( lambda x : currReserve [ x ] , ( ' type ' , ' track ' , ' level ' , ' revives ' , ' joinChance ' ) )
print ' - Reserve suit %d is %s , %s and level %d and JC = %d and revives is %d ' % ( idx , type , track , level , res , revives )
def genFloorSuits ( self , floor ) :
suitHandles = { }
floorInfo = self . suitInfos [ floor ]
activeSuits = [ ]
for activeSuitInfo in floorInfo [ ' activeSuits ' ] :
suit = self . __genSuitObject ( self . zoneId , activeSuitInfo [ ' type ' ] , activeSuitInfo [ ' track ' ] , activeSuitInfo [ ' level ' ] , activeSuitInfo [ ' revives ' ] )
activeSuits . append ( suit )
suitHandles [ ' activeSuits ' ] = activeSuits
reserveSuits = [ ]
for reserveSuitInfo in floorInfo [ ' reserveSuits ' ] :
suit = self . __genSuitObject ( self . zoneId , reserveSuitInfo [ ' type ' ] , reserveSuitInfo [ ' track ' ] , reserveSuitInfo [ ' level ' ] , reserveSuitInfo [ ' revives ' ] )
reserveSuits . append ( ( suit , reserveSuitInfo [ ' joinChance ' ] ) )
suitHandles [ ' reserveSuits ' ] = reserveSuits
return suitHandles
def genSuits ( self ) :
suitHandles = [ ]
2015-07-06 01:02:35 +00:00
for floor in xrange ( len ( self . suitInfos ) ) :
2015-03-07 02:46:05 +00:00
floorSuitHandles = self . genFloorSuits ( floor )
suitHandles . append ( floorSuitHandles )
return suitHandles