summaryrefslogtreecommitdiff
path: root/repoze/bfg/zcml.py
diff options
context:
space:
mode:
authorMalthe Borch <mborch@gmail.com>2009-08-27 10:26:12 +0000
committerMalthe Borch <mborch@gmail.com>2009-08-27 10:26:12 +0000
commit2234c998d4eb7672065fb02c4974c0535f409dca (patch)
tree3755d4bd9f8722b728bee92ec4741fc942e48134 /repoze/bfg/zcml.py
parent3d1abbd5be1d1bc0f27e488059ccf7aaca225f31 (diff)
downloadpyramid-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.py10
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)