KBEngine |
KBEngine module
This KBEngine module provides the Python script access to the entity's cell part, in particular it provides the registration and removal of timers, as well as the creation of entities.Classes
Entity |
Member functions
def addSpaceGeometryMapping( spaceID, mapper, path, shouldLoadOnServer, params ): |
def addWatcher( path, dataType, getFunction ): |
def address( ): |
def MemoryStream( ): |
def createEntity( entityType, spaceID, position, direction, params ): |
def debugTracing( ): |
def delSpaceData( spaceID, key ): |
def delWatcher( path ): |
def deregisterReadFileDescriptor( fileDescriptor ): |
def deregisterWriteFileDescriptor( fileDescriptor ): |
def executeRawDatabaseCommand( command, callback, threadID, dbInterfaceName ): |
def genUUID64( ): |
def getResFullPath( res ): |
def getSpaceData( spaceID, key ): |
def getSpaceGeometryMapping( spaceID ): |
def getWatcher( path ): |
def getWatcherDir( path ): |
def getAppFlags( ): |
def hasRes( res ): |
def isShuttingDown( ): |
def listPathRes( path, extension ): |
def matchPath( res ): |
def open( res, mode ): |
def publish( ): |
def registerReadFileDescriptor( fileDescriptor, callback ): |
def registerWriteFileDescriptor( fileDescriptor, callback ): |
def raycast( spaceID, layer, src, dst ): |
def reloadScript( fullReload ): |
def scriptLogType( logType ): |
def setAppFlags( flags ): |
def setSpaceData( spaceID, key, value ): |
def time( ): |
Callback
def onCellAppData( key, value ): |
def onCellAppDataDel( key ): |
def onGlobalData( key, value ): |
def onGlobalDataDel( key ): |
def onInit( isReload ): |
def onSpaceData( spaceID, key, value ): |
def onSpaceGeometryLoaded( spaceID, mapping ): |
def onAllSpaceGeometryLoaded( spaceID, isBootstrap, mapping ): |
Attributes
LOG_TYPE_DBG | |
LOG_TYPE_ERR | |
LOG_TYPE_INFO | |
LOG_TYPE_NORMAL | |
LOG_TYPE_WAR | |
NEXT_ONLY | |
cellAppData | |
component | Read-only string |
entities | Entities |
globalData | GlobalDataClient |
Member functions documentation
def addSpaceGeometryMapping( spaceID, mapper, path, shouldLoadOnServer, params ):
Associate a geometric mapping of a given space. After the function is called, the server and client will load the corresponding geometry data.
On the server, all geometry data is loaded from the given directory into the specified space. These data may be divided into many blocks. Different blocks are loaded asynchronously. The following callback methods are called when all the geometry data is loaded:
def onAllSpaceGeometryLoaded( self, spaceID, mappingName ):
The server only loads the geometric data of the scene for use by the navigation and collision functions. In addition to the geometric data, the client also loads data such as textures.
3D scenes currently use the data exported by the recastnavigation plugin-in by default. 2D scenes currently use the data exported by MapEditor by default.
There is a possibility that onAllSpaceGeometryLoaded() will not be invoked, that is, if multiple Cellapps call this method at the same time to add geometry to the same space, cellappmgr crashes.
parameters:
spaceID | uint32, ID of the space, specifies in which space to operate |
mapper | Not yet implemented |
path | Directory path containing geometry data |
shouldLoadOnServer | Optional boolean parameter that specifies whether to load geometry on the server. Default is True. |
params |
Optional PyDict parameter, specifies the navmesh used by different layers, for example: KBEngine.addSpaceGeometryMapping(self.spaceID, None, resPath, True, {0 : "srv_xinshoucun_1.navmesh", 1 : "srv_xinshoucun.navmesh"}) |
def addWatcher( path, dataType, getFunction ):
Interacts with the debug monitoring system to allow users to register a monitoring variable with the monitoring system.
Example:
>>> def countPlayers( ): >>> i = 0 >>> for e in KBEngine.entities.values(): >>> if e.__class__.__name__ == "Avatar": >>> i += 1 >>> return i >>> >>> KBEngine.addWatcher( "players", "UINT32", countPlayers )
This function adds a watch variable under the "scripts/players" watch path. The function countPlayers is called when the watcher observes a change.
parameters:
path | The path to create a watcher. |
dataType | The value type of the monitored variable. Reference: Basic data types |
getFunction | This function is called when the observer retrieves the variable. This function returns a value representing a watch variable without arguments. |
def address( ):
Returns the address of the internal network interface.
def MemoryStream( ):
Return a new MemoryStream object.
The MemoryStream object stores binary information. This type is provided to allow the user to easily serialize and deserialize the Python base types following the same KBEngine underlying serialization rules.
For example, you can use this object to construct a network packet that KBEngine can parse.
Usage:
>>> s = KBEngine.MemoryStream() >>> s >>> b'' >>> s.append("UINT32", 1) >>> s.pop("UINT32") >>> 1
The types that MemoryStream currently supports are only basic data types. Reference: Basic data types
def createEntity( entityType, spaceID, position, direction, params ):
createEntity creates a new entity in the specified space of the current process.
When calling this function you must specifiy the type, location, and direction of the entity to be created. Optionally, any attribute of the entity can be set with the params Python dictionary parameter. (the attributes are described in the entity's .def file).
Example:
# Create an open Door entity in the same space as the "thing" entity direction = ( 0, 0, thing.yaw ) properties = { "open":1 } KBEngine.createEntity( "Door", thing.space, thing.position, direction, properties )
parameters:
entityType |
string, the name of the entity to create, declared in the |
spaceID | int32, the ID of the space to place the entity |
position | A sequence of 3 floats that specify the creation point of the new entity, in world coordinates. |
direction | A sequence of 3 floats that specify the initial orientation (roll, pitch, yaw) of the new entity in world coordinates. |
params | Optional parameters, a Python dictionary object. If a specified key is an Entity attribute, its value will be used to initialize the properties of the new Entity. |
returns:
The new Entity. |
def debugTracing( ):
Outputs the Python extension object counter that outputs KBEngine trace.
Extended objects include: fixed dictionary, fixed array, Entity, EntityCall...
If the counter is not zero when the server is shut down normally, it means that the leak already exists and the log will output an error message.
ERROR cellapp [0x0000cd64] [2014-11-12 00:38:07,300] - PyGC::debugTracing(): FixedArray : leaked(128)
ERROR cellapp [0x0000cd64] [2014-11-12 00:38:07,300] - PyGC::debugTracing(): EntityCall : leaked(8)
def delSpaceData( spaceID, key ):
Deletes the space data of the specified key (if space is divided into multiple parts, it will be deleted synchronously).
The space data is set by the user via setSpaceData.
parameters:
spaceID | int32, the ID of the space |
key | string, a string keyword |
def delWatcher( path ):
Interacts with the debug monitoring system, allowing users to delete watcher variables in the script.
parameters:
path | The path of the variable to delete. |
def deregisterReadFileDescriptor( fileDescriptor ):
Deregisters the callback registered with KBEngine.registerReadFileDescriptor.
Example:
http://www.kbengine.org/assets/other/py/Poller.py
parameters:
fileDescriptor | Socket descriptor/file descriptor |
def deregisterWriteFileDescriptor( fileDescriptor ):
Deregisters the callback registered with KBEngine.registerWriteFileDescriptor.
Example:
http://www.kbengine.org/assets/other/py/Poller.py
parameters:
fileDescriptor | Socket descriptor/file descriptor |
def executeRawDatabaseCommand( command, callback, threadID, dbInterfaceName ):
This script function executes a database command on the database, which will be directly parsed by the relevant database.
Please note that using this function to modify the entity data may not be effective because if the entity has been checked out, the modified entity data will still be archived by the entity and cause overwriting.
This function is strongly not recommended for reading or modifying entity data.
parameters:
command | This database command will be different for different database configurations. For MySQL databases it will be an SQL query statement. |
callback |
Optional parameter, callbacks object (for example, a function) with the
command's execution result. This callback has 4 parameters: result set,
number of rows affected, auto value, and error message. |
threadID |
int32, optional parameter, specifies a thread to process this command.
Users can use this parameter to control the execution order of certain
commands (dbmgr is multi-threaded). The default is not specified. If
threadID is the ID of the entity, it will be added to the entity's archive
queue and written by the thread one by one. |
dbInterfaceName | string, optional parameter, specified by a database interface, defaults to "default" interface. The database interface is defined by kbengine_defaults.xml->dbmgr->databaseInterfaces. |
def genUUID64( ):
This function generates a 64-bit unique ID.
Note: This function is dependent on the 'gus' startup argument of the Cellapp service process. Please set the startup arguments to be unique.
In addition, if gus exceeds 65535, this function can only remain unique on the current process.
Usage
A unique item ID is generated on multiple service processes and there is no conflict when combined.
A room ID is generated on multiple service processes and no uniqueness verification is required.
returns:
64-bit integer |
def getResFullPath( res ):
Get the absolute path of the resource.
Note: Resoures must be accessible under KBE_RES_PATH.
parameters:
res | string, if there is an absolute path to return the resource, otherwise it returns null. |
returns:
string, the absolute path to the resource. |
def getSpaceData( spaceID, key ):
Get the space data of the specified key.
The space data is set by the user via setSpaceData.
parameters:
spaceID | int32, the ID of the space |
key | string, a string keyword |
returns:
string, string data for the given key |
def getSpaceGeometryMapping( spaceID ):
Returns the geometry map name of a specified space.
parameters:
spaceID | The ID of the space to be queried |
returns:
string, the name of the geometry map. |
def getWatcher( path ):
Gets the value of a watch variable from the KBEngine debug system.
Example: In the baseapp1 Python console, enter:
>>>KBEngine.getWatcher("/root/stats/runningTime")
12673648533
>>>KBEngine.getWatcher("/root/scripts/players")
32133
parameters:
path | string, the absolute path of the variable including the variable name (can be viewed on the GUIConsole watcher page). |
returns:
The value of the variable. |
def getWatcherDir( path ):
Get a list of elements (directories, variable names) under the watch directory from the KBEngine debugging system.
Example: In baseapp1 Python console, enter:
>>>KBEngine.getWatcher("/root")
('stats', 'objectPools', 'network', 'syspaths', 'ThreadPool', 'cprofiles', 'scripts', 'numProxices', 'componentID', 'componentType', 'uid', 'numClients', 'globalOrder', 'username', 'load', 'gametime', 'entitiesSize', 'groupOrder')
parameters:
path | string, the absolute path of the variable including the variable name (can be viewed on the GUIConsole watcher page). |
returns:
The list of elements (directory, variable name) under the Watch directory. |
def getAppFlags( ):
returns:
KBEngine.APP_FLAGS_* |
def hasRes( res ):
Use this interface to determine if a relative path exists.
Note: Resources must be accessible under KBE_RES_PATH.
Example:
>>>KBEngine.hasRes("scripts/entities.xml")
True
parameters:
res | string, the relative path of the resource |
returns:
BOOL, if it exists return True, otherwise False. |
def isShuttingDown( ):
Returns whether the server is shutting down. After the onBaseAppShuttingDown callback function is called, this function returns True.
returns:
BOOL, if the server is shutting down True, otherwise False. |
def listPathRes( path, extension ):
Get a list of resources in a resource directory
Note: Resources must be accesible under KBE_RES_PATH.
Example:
>>>KBEngine.listPathRes("scripts/cell/interfaces")
('/home/kbe/kbengine/demo/res/scripts/cell/interfaces/AI.py', '/home/kbe/kbengine/demo/res/scripts/cell/interfaces/New Text Document.txt')
>>>KBEngine.listPathRes("scripts/cell/interfaces", "txt")
('/home/kbe/kbengine/demo/res/scripts/cell/interfaces/New Text Document.txt')
>>>KBEngine.listPathRes("scripts/cell/interfaces", "txt|py")
('/home/kbe/kbengine/demo/res/scripts/cell/interfaces/AI.py', '/home/kbe/kbengine/demo/res/scripts/cell/interfaces/New Text Document.txt')
>>>KBEngine.listPathRes("scripts/cell/interfaces", ("txt", "py"))
('/home/kbe/kbengine/demo/res/scripts/cell/interfaces/AI.py', '/home/kbe/kbengine/demo/res/scripts/cell/interfaces/New Text Document.txt')
parameters:
res | string, the relative path of the resource. |
extension | string, optional parameter, file extension. |
returns:
Tuple, resource list. |
def matchPath( res ):
Use the relative path of the resource to get its absolute path.
Note: Resources must be accessible under KBE_RES_PATH.
Example:
>>>KBEngine.matchPath("scripts/entities.xml")
'/home/kbe/kbengine/demo/res/scripts/entities.xml'
parameters:
res | string, the relative path to the resource (including the resource name) |
returns:
string, the absolute path of the resource. |
def open( res, mode ):
Use this interface to open resources using relative paths. Note: Resources must be accessible under KBE_RES_PATH.
parameters:
res | string, the relative path of the resource. |
mode |
string, file operation mode: w Open in write mode, a Open in append mode (Start from EOF, create new file if necessary) r+ Open w+ in read/write mode Open in read/write mode (see w) a+ Open in read/write mode (See a) rb Opens wb in binary read mode Opens in binary write mode (see w) ab Opens in binary append mode (see a) rb+ Opens in binary read and write mode (see r+) wb+ Opens in binary read and write mode (see w+ ) ab+ Open in binary read/write mode (see a+) |
def publish( ):
This interface returns the current server release mode.
returns:
int8, 0: debug, 1: release, others can be customized. |
def raycast( spaceID, layer, src, dst ):
In the specified layer of the specified space, a ray is emitted from the source coordinates to the destination coordinates, and the collided coordinate point is returned.
Note: Space must load geometry using addSpaceGeometryMapping.
Below is an example:
>>> KBEngine.raycast( spaceID, entity.layer, (0, 10, 0), (0,-10,0) ) ((0.0000, 0.0000, 0.0000), ( (0.0000, 0.0000, 0.0000), (4.0000, 0.0000, 0.0000), (4.0000, 0.0000, 4.0000)), 0)
parameters:
spaceID | int32, space ID |
layer | int8, geometric layer. A space can load multiple navmesh data at the same time. Different navmesh can be in different layers. Different layers can be abstracted into the ground, the water surface and so on. |
returns:
list, list of coordinate points collided |
def registerReadFileDescriptor( fileDescriptor, callback ):
Registers a callback function that is called when the file descriptor is readable.
Example:
http://www.kbengine.org/assets/other/py/Poller.py
parameters:
fileDescriptor | Socket descriptor/file descriptor |
callback | A callback function with the socket descriptor/file descriptor as its only parameter. |
def registerWriteFileDescriptor( fileDescriptor, callback ):
Registers a callback function that is called when the socket descriptor/file descriptor is writable.
Example:
http://www.kbengine.org/assets/other/py/Poller.py
parameters:
fileDescriptor | Socket descriptor/file descriptor |
callback | A callback function with the socket descriptor/file descriptor as its only parameter. |
def reloadScript( fullReload ):
Reloads Python modules related to entity and custom data types. The current entity class is set to the newly loaded class. This method should only be used for development mode and not for product mode. The following points should be noted:
1) The overloaded script can only be executed on Cellapp. The user should ensure that all server components are loaded.
2) The custom type should ensure that the objects already instantiated in memory are updated after the script is reloaded. Here is an example:
for e in KBEngine.entities.values(): if type( e ) is Avatar.Avatar: e.customData.__class__ = CustomClassWhen this method completes KBEngine.onInit( True ) is called.
parameters:
fullReload | Optional boolean parameter that specifies whether to reload entity definitions at the same time. If this parameter is False, the entity definition will not be reloaded. The default is True. |
returns:
True if the reload succeeds, False otherwise. |
def scriptLogType( logType ):
Set the type of information output by the current Python.print (Reference: KBEngine.LOG_TYPE_*).
def setAppFlags( flags ):
Set the flags of the current engine APP.
KBEngine.APP_FLAGS_NONE // Default (not set)
KBEngine.APP_FLAGS_NOT_PARTCIPATING_LOAD_BALANCING // Do not participate in load balancing
Example:
KBEngine.setAppFlags(KBEngine.APP_FLAGS_NOT_PARTCIPATING_LOAD_BALANCING | KBEngine.APP_FLAGS_*)
def setSpaceData( spaceID, key, value ):
Sets the space data for the specified key.
The space data can be obtained via getSpaceData.
parameters:
spaceID | int32, the ID of the space. |
key | string, a string keyword |
value | string, the string value. |
def time( ):
This method returns the current game time (number of cycles).
returns:
uint32, the current time of the game. This refers to the number of cycles. The period is affected by the frequency. The frequency is determined by the configuration file kbengine.xml or kbengine_defaults.xml-> gameUpdateHertz. |
Callback functions documentation
def onCellAppData( key, value ):
This function is called back when KBEngine.cellAppData changes.
Note: This callback interface must be implemented in the portal module ( kbengine_defaults.xml->entryScriptFile ).
parameters:
key | The key of the changed data. |
value | The value of the changed data. |
def onCellAppDataDel( key ):
This function is called back when KBEngine.cellAppData is deleted.
Note: This callback interface must be implemented in the portal module (kbengine_defaults.xml->entryScriptFile).
parameters:
key | Deleted data key. |
def onGlobalData( key, value ):
This function is called back when KBEngine.globalData changes.
Note: This callback interface must be implemented in the portal moodule (kbengine_defaults.xml->entryScriptFile).
parameters:
key | The key of the changed data. |
value | The value of the changed data. |
def onGlobalDataDel( key ):
This function is called back when KBEngine.globalData is deleted.
Note: This callback interface must be implemented in the portal module (kbengine_defaults.xml->entryScriptFile).
parameters:
key | Deleted data key. |
def onInit( isReload ):
This interface is called after all scripts have been initialized since the engine started.
Note: This callback interface must be implemented in the portal module (kbengine_defaults.xml->entryScriptFile).
parameters:
isReload | Bool, whether it was triggered after reloading the loading the script. |
def onSpaceData( spaceID, key, value ):
Called when there is a change in the space data.
The space data is set by the user via setSpaceData.
parameters:
spaceID | The ID of the space. |
key | The key of the changed data. |
value | The value of the changed data. |
def onSpaceGeometryLoaded( spaceID, mapping ):
The space required by the grid collision data is loaded.
Set by user through addSpaceGeometryMapping.
parameters:
spaceID | The ID of the space. |
mapping | The map value of the grid collision data. |
def onAllSpaceGeometryLoaded( spaceID, isBootstrap, mapping ):
The space required for grid collision and other data is completely loaded.
Set by user through addSpaceGeometryMapping.
parameters:
spaceID | The ID of the space. |
isBootstrap | If a space is partitioned by multiple cells, isBootstrap describes whether it is the originating cell of the loading request. |
mapping | The map value of grid collision data. |
Attribute documentation
LOG_TYPE_DBG
LOG_TYPE_ERR
LOG_TYPE_INFO
LOG_TYPE_NORMAL
LOG_TYPE_WAR
NEXT_ONLY
This constant is currently unused in Cellap.
cellAppData
This property contains a dictionary-like object that is automatically synchronized across all CellApps. When a value in the dictionary is modified, this change is broadcast to all Cellapps.
Example:
KBEngine.cellAppData[ "hello" ] = "there"
The rest of Cellap can access the following:
print KBEngine.cellAppData[ "hello" ]
Keys and values can be of any type, but these types must be encapsulated and unpacked on all target components.
When a value is changed or deleted, a callback function is called on all components. See: KBEngine.onCellAppData and KBEngine.onDelCellAppData.
Note: Only the top-level value will be broadcast. If you have a value (such as a list) that changes the internal value (such as just changing a number), this information will not be broadcast.
Do not do the following:
KBEngine.cellAppData[ "list" ] = [1, 2, 3] KBEngine.cellAppData[ "list" ][1] = 7This will cause the local access to read [1, 7, 3] and the remote [1, 2, 3]
component
This is the component that is running in the current Python environment. (So far) Possible values are 'cell', 'base', 'client', 'database', 'bot' and 'editor'.
entities
entities is a dictinary object that contains all entities in the current process, including ghost entities.
Debugging leaked entities: (instances that call destroy without releasing memory, usually as a result of the reference not being released)
>>> KBEngine.entities.garbages.items() [(1025, Avatar object at 0x7f92431ceae8.)]
>>> e = _[0][1] >>> import gc >>> gc.get_referents(e) [{'spacesIsOk': True, 'bootstrapIdx': 1},]
Debugging a leaked KBEngine-encapsulated Python object:
KBEngine.debugTracing
Types:
Entities |
globalData
This attribute contains a dictionary-like object that is automatically copied between all BaseApps and CellApps. When a value in a dictionary is modified, this change is broadcast to all BaseApps and CellApps. CellAppMgr solves completion conditions and ensures the authority of information replication.
Example:
KBEngine.globalData[ "hello" ] = "there"
The rest of Cellapp or Baseapp can access the following:
print KBEngine.globalData[ "hello" ]
Keys and values can be of any type, but these types must be encapsulated and unpacked on all target components.
When a value is changed or deleted, a callback function is called on all components. See: KBEngine.onGlobalData and KBEngine.onGlobalDataDel.
Note: Only the top-level value will be broadcast. If you have a volatile value (such as a list) that changes the internal value (such as just changing a number), this information will not be broadcast.
Do not do the following:
KBEngine.globalData[ "list" ] = [1, 2, 3] KBEngine.globalData[ "list" ][1] = 7This will cause the local access to read [1, 7, 3] and the remote [1, 2, 3]