comparison pylons_app/lib/base.py @ 245:a83a1799480c

Reimplemented way of caching repos list, hg model now get's repos objects right from cached dict, this way we skipp creating instances of MercurialRepository and gain performance. Some import cleanup
author Marcin Kuzminski <marcin@python-works.com>
date Thu, 03 Jun 2010 00:04:48 +0200
parents fdcef6ea3b55
children d303aacb3349
comparison
equal deleted inserted replaced
244:782f0692b29c 245:a83a1799480c
1 """The base Controller API 1 """The base Controller API
2 2
3 Provides the BaseController class for subclassing. 3 Provides the BaseController class for subclassing.
4 """ 4 """
5 from beaker.cache import cache_region
6 from pylons import config, tmpl_context as c, request, session 5 from pylons import config, tmpl_context as c, request, session
7 from pylons.controllers import WSGIController 6 from pylons.controllers import WSGIController
8 from pylons.templating import render_mako as render 7 from pylons.templating import render_mako as render
9 from pylons_app.lib.auth import LoginRequired, AuthUser 8 from pylons_app.lib.auth import LoginRequired, AuthUser
10 from pylons_app.lib.utils import get_repo_slug 9 from pylons_app.lib.utils import get_repo_slug
11 from pylons_app.model import meta 10 from pylons_app.model import meta
12 from pylons_app.model.hg_model import HgModel 11 from pylons_app.model.hg_model import _get_repos_cached
13 from pylons_app import __version__ 12 from pylons_app import __version__
14
15 @cache_region('long_term', 'cached_repo_list')
16 def _get_repos_cached():
17 return [rep for rep in HgModel().get_repos()]
18
19 @cache_region('long_term', 'full_changelog')
20 def _full_changelog_cached(repo_name):
21 return list(reversed(list(HgModel().get_repo(repo_name))))
22 13
23 class BaseController(WSGIController): 14 class BaseController(WSGIController):
24 15
25 def __before__(self): 16 def __before__(self):
26 c.hg_app_version = __version__ 17 c.hg_app_version = __version__