Home | Trees | Indices | Help |
|
---|
|
1 # ============================================================================ 2 # 3 # Copyright (C) 2007-2008 Conceptive Engineering bvba. All rights reserved. 4 # www.conceptive.be / project-camelot@conceptive.be 5 # 6 # This file is part of the Camelot Library. 7 # 8 # This file may be used under the terms of the GNU General Public 9 # License version 2.0 as published by the Free Software Foundation 10 # and appearing in the file LICENSE.GPL included in the packaging of 11 # this file. Please review the following information to ensure GNU 12 # General Public Licensing requirements will be met: 13 # http://www.trolltech.com/products/qt/opensource.html 14 # 15 # If you are unsure which license is appropriate for your use, please 16 # review the following information: 17 # http://www.trolltech.com/products/qt/licensing.html or contact 18 # project-camelot@conceptive.be. 19 # 20 # This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE 21 # WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. 22 # 23 # For use of this library in commercial applications, please contact 24 # project-camelot@conceptive.be 25 # 26 # ============================================================================ 27 28 """wrapper around pkg_resources, with fallback to using directories specified 29 in the settings file if pkg_resources cannot be used. 30 31 to allow fallback to the settings file, specify the settings_attribute method, 32 this is the attribute in the settings file that contains the folder with the 33 resources as opposed to the folder containing the module itself. 34 35 this mechanism will probably be rewritten to support the loading of resources 36 from zip files instead of falling back to settings. 37 38 when running from a bootstrapper, we'll try to use pgk_resources, even when 39 runnin from within a zip file. 40 """ 41 42 import pkg_resources 43 import sys 44 import os 45 import logging 46 47 logger = logging.getLogger('camelot.core.resources') 4850 """Return the absolute path to a file in a directory 51 if the directory for the module cannot be accessed through pkg_resources, 52 fall back to the settings attribute 53 """ 54 import settings 55 if sys.path[0].endswith('.zip') and not hasattr(settings, 'BOOTSTRAPPER'): 56 # we're running from a zip file, pkg_resources won't work 57 if not settings_attribute: 58 logger.error('resources of module %s cannot be loaded because no settings_attribute is specified and the module is inside a zip file') 59 return '' 60 absolute_path = os.path.join(getattr(settings, settings_attribute), filename) 61 if not os.path.exists(absolute_path): 62 logger.error('resources of module %s cannot be loaded because %s does not exist'%(module_name, absolute_path)) 63 return '' 64 return os.path.join(absolute_path) 65 else: 66 return pkg_resources.resource_filename(module_name, filename)6769 import settings 70 if sys.path[0].endswith('.zip') and not hasattr(settings, 'BOOTSTRAPPER'): 71 return open(resource_filename(module_name, filename, settings_attribute), 'rb').read() 72 else: 73 return pkg_resources.resource_string(module_name, filename)74
Home | Trees | Indices | Help |
|
---|
Generated by Epydoc 3.0.1 on Sat Jun 12 15:42:10 2010 | http://epydoc.sourceforge.net |