Chromium Code Reviews| Index: chrome/common/extensions/docs/server2/template_data_source.py |
| diff --git a/chrome/common/extensions/docs/server2/template_data_source.py b/chrome/common/extensions/docs/server2/template_data_source.py |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..532a62bfdb038c39ebc1f9d0a6dbfe192bbaa057 |
| --- /dev/null |
| +++ b/chrome/common/extensions/docs/server2/template_data_source.py |
| @@ -0,0 +1,43 @@ |
| +# Copyright (c) 2012 The Chromium Authors. All rights reserved. |
| +# Use of this source code is governed by a BSD-style license that can be |
| +# found in the LICENSE file. |
| + |
| +import logging |
| +import os |
| +import time |
| + |
| +from third_party.handlebar import Handlebar |
| + |
| +class TemplateDataSource(object): |
|
not at google - send to devlin
2012/06/07 04:43:57
I was thinking, should be build all the template r
cduvall
2012/06/08 00:39:23
Done.
|
| + def __init__(self, fetcher, base_paths, cache_timeout): |
|
not at google - send to devlin
2012/06/07 04:43:57
cache_timeout_seconds
cduvall
2012/06/08 00:39:23
Done.
|
| + logging.info('Template data source created.') |
|
not at google - send to devlin
2012/06/07 04:43:57
It's ok if you want to leave logging in for now (t
cduvall
2012/06/08 00:39:23
Done.
|
| + self._fetcher = fetcher |
| + self._template_cache = {} |
| + self._base_paths = base_paths |
| + self._cache_timeout = cache_timeout |
| + |
| + def __getitem__(self, key): |
| + return self.get(key) |
| + |
| + def get(self, key): |
| + index = key.rfind('.html') |
| + if index > 0: |
| + key = key[:index] |
| + path = key + '.html' |
| + if key in self._template_cache: |
| + compiled_template, compile_time = self._template_cache[key] |
| + if (time.time() - compile_time) > self._cache_timeout: |
| + self._template_cache.pop(key) |
| + if key not in self._template_cache: |
| + logging.info('Template cache miss for: ' + path) |
| + compiled_template = None |
| + for base_path in self._base_paths: |
| + try: |
| + template = self._fetcher.FetchResource(base_path + path).content |
| + compiled_template = Handlebar(template) |
| + self._template_cache[key] = (compiled_template, time.time()) |
|
not at google - send to devlin
2012/06/07 04:43:57
Consider making the cache entries actual objects t
cduvall
2012/06/08 00:39:23
Done.
|
| + break |
| + except: |
| + pass |
| + |
| + return compiled_template |