Skip to content
Switch branches/tags
Go to file
Cannot retrieve contributors at this time
135 lines (94 sloc) 4.24 KB
Pyramid TODOs
- config.set_registry_attr with conflict detection... make sure the attr is
added before a commit, but register an action so a conflict can be detected.
- Provide the presumed renderer name to the called view as an attribute of
the request.
- Have action methods return their discriminators.
- Modify view mapper narrative docs to not use pyramid_handlers.
- Modify the urldispatch chapter examples to assume a scan rather than
- Introspection:
* ``default root factory`` category (prevent folks from needing to searh
"root factories" category)?
* ``default view mapper`` category (prevent folks from needing to search
"view mappers" category)?
* get rid of "tweens" category (can't sort properly?)
- Fix deployment recipes in cookbook (discourage proxying without changing
- Add narrative docs for wsgiapp and wsgiapp2.
- Basic WSGI documentation (pipeline / app / server).
- Change docs about creating a venusian decorator to not use ZCA (use
configurator methods instead).
- Try to better explain the relationship between a renderer and a template in
the templates chapter and elsewhere. Scan the documentation for reference
to a renderer as *only* view configuration (it's a larger concept now).
- Add better docs about what-to-do-when-behind-a-proxy: rutter ("/foo =
app1" and "domain app1.localhost = app1"), ProxyPreserveHost and the nginx
proxy_params, preserving HTTPS URLs.
- Debug option to print view matching decision (e.g. debug_viewlookup or so).
- Non-bwcompat use of threadlocals that need to be documented or ameliorated:
resource.OverrideProvider._get_overrides: can't credibly be removed,
because it stores an overrideprovider as a module-scope global.
traversal.traverse: this API is a stepchild, and needs to be changed.
Configurator.add_translation_dirs: not passed any context but a message,
can't credibly be removed.
- Deprecate (it only works for
- Provide a ``has_view`` function.
- Update App engine chapter with less creaky directions.
- Idea from Zart:
diff --git a/pyramid/ b/pyramid/
index b0e4d79..b3bd82a 100644
--- a/pyramid/
+++ b/pyramid/
@@ -8,6 +8,7 @@ from paste.deploy import (
from pyramid.compat import configparser
from logging.config import fileConfig
from pyramid.scripting import prepare
+from pyramid.config import Configurator
def get_app(config_uri, name=None, loadapp=loadapp):
""" Return the WSGI application named ``name`` in the PasteDeploy
@@ -111,3 +112,10 @@ def bootstrap(config_uri, request=None):
env['app'] = app
return env
+def make_pyramid_app(global_conf, app=None, **settings):
+ """Return pyramid application configured with provided settings"""
+ config = Configurator(package='pyramid', settings=settings)
+ if app:
+ config.include(app)
+ app = config.make_wsgi_app()
+ return app
diff --git a/ b/
index 03ebb42..91e0e21 100644
--- a/
+++ b/
@@ -118,6 +118,8 @@ setup(name='pyramid',
wsgiref = pyramid.scripts.pserve:wsgiref_server_runner
cherrypy = pyramid.scripts.pserve:cherrypy_server_runner
+ [paster.app_factory]
+ main = pyramid.paster:make_pyramid_app
Probably Bad Ideas
- Add functionality that mocks the behavior of ``repoze.browserid``.
- Maybe add ``add_renderer_globals`` method to Configurator.
- Supply ``X-Vhm-Host`` support (probably better to do what paste#prefix
middleware does).
- Have ``remember`` and ``forget`` actually set headers on the response using
a response callback (and return the empty list)?
instead of thread locals
- Context manager for creating a new configurator (replacing
``with_package``). E.g.::
with config.partial(package='bar') as c:
with config.partial(introspection=False) as c:
- _fix_registry should dictify the registry being fixed.