Mercurial > fife-parpg
view engine/extensions/loaders.py @ 145:e7a431577c95
Cleaned the basic model up. Code is cleaner now and a bit faster.
Some code path were never tested in depth :-(
Added a 'time_to_load' attribute to XMLMapLoader, which records the seconds it took to load a map.
Down from 6s to 5.6s for reio de hola. Yay!
author | phoku@33b003aa-7bff-0310-803a-e67f0ece8222 |
---|---|
date | Thu, 09 Oct 2008 08:23:13 +0000 |
parents | 5e85737281bc |
children | 54b3984e1afc |
line wrap: on
line source
# coding: utf-8 # Loader interface for FIFE's native xml format. import fife from serializers.xmlmap import XMLMapLoader from serializers import WrongFileType, NameClash from serializers.xmlobject import XMLObjectLoader fileExtensions = ('xml',) def loadMapFile(path, engine, callback=None): """ load map file and get (an optional) callback if major stuff is done: - map creation - parsed imports - parsed layers - parsed cameras the callback will send both a string and a float (which shows the overall process), callback(string, float) @return map : map object """ map_loader = XMLMapLoader(engine, callback) map = map_loader.loadResource(fife.ResourceLocation(path)) #print "--- Loading map took: ", map_loader.time_to_load, " seconds." return map def loadImportFile(path, engine): object_loader = XMLObjectLoader(engine.getImagePool(), engine.getAnimationPool(), engine.getModel(), engine.getVFS()) res = None try: res = object_loader.loadResource(fife.ResourceLocation(path)) print 'imported object file ' + path except WrongFileType: pass # print 'ignored non-object file ' + path except NameClash: pass # print 'ignored already loaded file ' + path return res def loadImportDir(path, engine): for file in filter(lambda f: f.split('.')[-1] == 'xml', engine.getVFS().listFiles(path)): loadImportFile('/'.join([path, file]), engine) def loadImportDirRec(path, engine): loadImportDir(path, engine) for dir in filter(lambda d: not d.startswith('.'), engine.getVFS().listDirectories(path)): loadImportDirRec('/'.join([path, dir]), engine)