 Chromium Code Reviews
 Chromium Code Reviews Issue 11280143:
  Create CachingRietveld to automatically cache results for presubmit checks.  (Closed) 
  Base URL: svn://svn.chromium.org/chrome/trunk/tools/depot_tools
    
  
    Issue 11280143:
  Create CachingRietveld to automatically cache results for presubmit checks.  (Closed) 
  Base URL: svn://svn.chromium.org/chrome/trunk/tools/depot_tools| Index: rietveld.py | 
| diff --git a/rietveld.py b/rietveld.py | 
| index d4ac39bab08060ea3c6414d3b9ad32b986d266f0..5d81e7396e4016831b330923a53994de67d060cf 100644 | 
| --- a/rietveld.py | 
| +++ b/rietveld.py | 
| @@ -14,6 +14,7 @@ The following hypothesis are made: | 
| - A patch set cannot be modified | 
| """ | 
| +import copy | 
| import json | 
| import logging | 
| import re | 
| @@ -395,3 +396,41 @@ class Rietveld(object): | 
| # DEPRECATED. | 
| Send = get | 
| + | 
| + | 
| +class CachingRietveld(Rietveld): | 
| + """Caches the common queries. | 
| + | 
| + Not to be used in long-standing processes, like the commit queue. | 
| + """ | 
| + def __init__(self, *args, **kwargs): | 
| + super(CachingRietveld, self).__init__(*args, **kwargs) | 
| + self._cache = {} | 
| + | 
| + def _lookup(self, function_name, args, update): | 
| + """Caches the return values corresponding to the arguments. | 
| + | 
| + It is important that the arguments are standardized, like None vs False. | 
| + """ | 
| + function_cache = self._cache.setdefault(function_name, {}) | 
| + if args not in function_cache: | 
| + function_cache[args] = update(*args) | 
| + return copy.deepcopy(function_cache[args]) | 
| + | 
| + def get_description(self, issue): | 
| + return self._lookup( | 
| + 'get_description', | 
| + (issue,), | 
| + super(CachingRietveld, self).get_description) | 
| + | 
| + def get_issue_properties(self, issue, messages): | 
| 
Isaac (away)
2012/11/26 05:12:39
get_issue_properties(<issue>, True) returns a supe
 
M-A Ruel
2012/11/27 20:15:06
Done
 | 
| + return self._lookup( | 
| + 'get_issue_properties', | 
| + (issue, bool(messages)), | 
| + super(CachingRietveld, self).get_issue_properties) | 
| + | 
| + def get_patchset_properties(self, issue, patchset): | 
| + return self._lookup( | 
| + 'get_patchset_properties', | 
| + (issue, patchset), | 
| + super(CachingRietveld, self).get_patchset_properties) |