diff options
| author | Malthe Borch <mborch@gmail.com> | 2009-08-27 10:26:12 +0000 |
|---|---|---|
| committer | Malthe Borch <mborch@gmail.com> | 2009-08-27 10:26:12 +0000 |
| commit | 2234c998d4eb7672065fb02c4974c0535f409dca (patch) | |
| tree | 3755d4bd9f8722b728bee92ec4741fc942e48134 /repoze/bfg/zcml.py | |
| parent | 3d1abbd5be1d1bc0f27e488059ccf7aaca225f31 (diff) | |
| download | pyramid-2234c998d4eb7672065fb02c4974c0535f409dca.tar.gz pyramid-2234c998d4eb7672065fb02c4974c0535f409dca.tar.bz2 pyramid-2234c998d4eb7672065fb02c4974c0535f409dca.zip | |
Rebase module-relative static views on the nearest package path.
Diffstat (limited to 'repoze/bfg/zcml.py')
| -rw-r--r-- | repoze/bfg/zcml.py | 10 |
1 files changed, 9 insertions, 1 deletions
diff --git a/repoze/bfg/zcml.py b/repoze/bfg/zcml.py index e0c8d2e8e..dbc145149 100644 --- a/repoze/bfg/zcml.py +++ b/repoze/bfg/zcml.py @@ -1,3 +1,5 @@ +import os +import sys import inspect import types @@ -46,6 +48,8 @@ from repoze.bfg.security import ViewPermissionFactory from repoze.bfg.secpols import registerBBBAuthn +from repoze.bfg.static import find_package + from repoze.bfg.view import static as static_view import martian @@ -365,7 +369,11 @@ def static(_context, name, path, cache_max_age=3600): if ':' in path: package_name, path = path.split(':') else: - package_name = _context.resolve('.').__name__ + package_path = _context.resolve('.').__path__[0] + package_name = find_package(package_path) + if package_name is not None: + path = os.path.join(package_path, path) + path = path[len(sys.modules[package_name].__path__[0])+1:] view = static_view( path, cache_max_age=cache_max_age, package_name=package_name) |
