diff options
| author | Chris McDonough <chrism@agendaless.com> | 2009-01-20 19:55:54 +0000 |
|---|---|---|
| committer | Chris McDonough <chrism@agendaless.com> | 2009-01-20 19:55:54 +0000 |
| commit | eca67ac2005bcac3b8d14d051e5e800ea36f42a8 (patch) | |
| tree | 0dcac61810cba831bd1d484478781cd76ca2e09f /repoze/bfg/router.py | |
| parent | 32634a8734321d0c61892dd6fd90451d380cf6f9 (diff) | |
| download | pyramid-eca67ac2005bcac3b8d14d051e5e800ea36f42a8.tar.gz pyramid-eca67ac2005bcac3b8d14d051e5e800ea36f42a8.tar.bz2 pyramid-eca67ac2005bcac3b8d14d051e5e800ea36f42a8.zip | |
# We use 'precooked' Request subclasses that correspond to HTTP
# request methods within ``router.py`` when constructing a request
# object rather than using ``alsoProvides`` to attach the proper
# interface to an unsubclassed webob.Request. This pattern is purely
# an optimization (e.g. preventing calls to ``alsoProvides`` means the
# difference between 590 r/s and 690 r/s on a MacBook 2GHz).
Diffstat (limited to 'repoze/bfg/router.py')
| -rw-r--r-- | repoze/bfg/router.py | 18 |
1 files changed, 7 insertions, 11 deletions
diff --git a/repoze/bfg/router.py b/repoze/bfg/router.py index 849b40d7e..6630d0a0a 100644 --- a/repoze/bfg/router.py +++ b/repoze/bfg/router.py @@ -7,10 +7,8 @@ from zope.component import queryUtility from zope.component.event import dispatch from zope.component.registry import Components -from zope.interface import alsoProvides from zope.interface import implements -from webob import Request from webob.exc import HTTPNotFound from webob.exc import HTTPUnauthorized @@ -20,11 +18,8 @@ from repoze.bfg.events import WSGIApplicationCreatedEvent from repoze.bfg.interfaces import ILogger from repoze.bfg.interfaces import ITraverserFactory -from repoze.bfg.interfaces import IRequest from repoze.bfg.interfaces import IRequestFactory from repoze.bfg.interfaces import IRoutesMapper -from repoze.bfg.interfaces import HTTP_METHOD_INTERFACES - from repoze.bfg.interfaces import IRouter from repoze.bfg.interfaces import IRootFactory from repoze.bfg.interfaces import ISettings @@ -33,6 +28,8 @@ from repoze.bfg.log import make_stream_logger from repoze.bfg.registry import registry_manager from repoze.bfg.registry import populateRegistry +from repoze.bfg.request import HTTP_METHOD_FACTORIES +from repoze.bfg.request import Request from repoze.bfg.settings import Settings from repoze.bfg.urldispatch import RoutesRootFactory @@ -63,14 +60,13 @@ class Router(object): registry_manager.push(self.registry) try: - request_factory = queryUtility(IRequestFactory, default=Request) + + request_factory = queryUtility(IRequestFactory) + if request_factory is None: + method = environ.get('REQUEST_METHOD', 'GET') + request_factory = HTTP_METHOD_FACTORIES.get(method, Request) request = request_factory(environ) - alsoProvides(request, IRequest) - also_http = HTTP_METHOD_INTERFACES.get(request.method) - if also_http is not None: - alsoProvides(request, also_http) - dispatch(NewRequest(request)) root_factory = getUtility(IRootFactory) root = root_factory(environ) |
