OLD | NEW |
---|---|
1 # Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 # Copyright (c) 2012 The Chromium Authors. All rights reserved. |
2 # Use of this source code is governed by a BSD-style license that can be | 2 # Use of this source code is governed by a BSD-style license that can be |
3 # found in the LICENSE file. | 3 # found in the LICENSE file. |
4 | 4 |
5 import json | 5 import json |
6 import logging | 6 import logging |
7 import os | 7 import os |
8 | 8 |
9 from handlebar_dict_generator import HandlebarDictGenerator | 9 from handlebar_dict_generator import HandlebarDictGenerator |
10 import third_party.json_schema_compiler.json_comment_eater as json_comment_eater | 10 import third_party.json_schema_compiler.json_comment_eater as json_comment_eater |
11 import third_party.json_schema_compiler.model as model | 11 import third_party.json_schema_compiler.model as model |
12 import third_party.json_schema_compiler.idl_schema as idl_schema | 12 import third_party.json_schema_compiler.idl_schema as idl_schema |
13 import third_party.json_schema_compiler.idl_parser as idl_parser | 13 import third_party.json_schema_compiler.idl_parser as idl_parser |
14 | 14 |
15 class APIDataSource(object): | 15 class APIDataSource(object): |
16 """This class fetches and loads JSON APIs from the FileSystem passed in with | 16 """This class fetches and loads JSON APIs from the FileSystem passed in with |
17 |cache_builder|, so the APIs can be plugged into templates. | 17 |cache_builder|, so the APIs can be plugged into templates. |
18 """ | 18 """ |
19 def __init__(self, cache_builder, base_path): | 19 def __init__(self, cache_builder, file_system, base_path): |
20 self._file_system = file_system | |
20 self._json_cache = cache_builder.build(self._LoadJsonAPI) | 21 self._json_cache = cache_builder.build(self._LoadJsonAPI) |
21 self._idl_cache = cache_builder.build(self._LoadIdlAPI) | 22 self._idl_cache = cache_builder.build(self._LoadIdlAPI) |
22 self._base_path = base_path | 23 self._base_path = base_path |
23 | 24 |
24 def _LoadJsonAPI(self, api): | 25 def _LoadJsonAPI(self, api): |
25 generator = HandlebarDictGenerator( | 26 generator = HandlebarDictGenerator( |
26 json.loads(json_comment_eater.Nom(api))[0]) | 27 json.loads(json_comment_eater.Nom(api))[0]) |
27 return generator.Generate() | 28 return generator.Generate() |
28 | 29 |
29 def _LoadIdlAPI(self, api): | 30 def _LoadIdlAPI(self, api): |
30 idl = idl_parser.IDLParser().ParseData(api) | 31 idl = idl_parser.IDLParser().ParseData(api) |
31 generator = HandlebarDictGenerator(idl_schema.IDLSchema(idl).process()[0]) | 32 generator = HandlebarDictGenerator(idl_schema.IDLSchema(idl).process()[0]) |
32 return generator.Generate() | 33 return generator.Generate() |
33 | 34 |
35 def _GetChannel(self, path): | |
not at google - send to devlin
2012/07/30 12:43:23
This is getting the Feature, not the Channel ("cha
cduvall
2012/07/30 19:08:29
Done.
| |
36 path = path.replace('experimental_', '') | |
37 try: | |
38 perms = json.loads(json_comment_eater.Nom( | |
39 self._file_system.ReadSingle( | |
40 self._base_path + '/_permission_features.json'))) | |
not at google - send to devlin
2012/07/30 12:43:23
Could you put the loaded JSON in a cache (like the
cduvall
2012/07/30 19:08:29
Done.
| |
41 return perms.get(path, None) | |
42 except: | |
43 return None | |
44 | |
34 def __getitem__(self, key): | 45 def __getitem__(self, key): |
35 return self.get(key) | 46 return self.get(key) |
36 | 47 |
37 def get(self, key): | 48 def get(self, key): |
38 path, ext = os.path.splitext(key) | 49 path, ext = os.path.splitext(key) |
50 api_dict = { 'perms': self._GetChannel(path) } | |
not at google - send to devlin
2012/07/30 12:43:23
no need to abbr perms
cduvall
2012/07/30 19:08:29
Done.
| |
39 unix_name = model.UnixName(path) | 51 unix_name = model.UnixName(path) |
40 json_path = unix_name + '.json' | 52 json_path = unix_name + '.json' |
41 idl_path = unix_name + '.idl' | 53 idl_path = unix_name + '.idl' |
42 try: | 54 try: |
43 return self._json_cache.GetFromFile(self._base_path + '/' + json_path) | 55 api_dict.update( |
56 self._json_cache.GetFromFile(self._base_path + '/' + json_path)) | |
57 return api_dict | |
not at google - send to devlin
2012/07/30 12:43:23
looks like this is a job for a helper method...
cduvall
2012/07/30 19:08:29
Done.
| |
44 except Exception: | 58 except Exception: |
45 try: | 59 try: |
46 return self._idl_cache.GetFromFile(self._base_path + '/' + idl_path) | 60 api_dict.update( |
61 self._idl_cache.GetFromFile(self._base_path + '/' + idl_path)) | |
62 return api_dict | |
47 except Exception as e: | 63 except Exception as e: |
48 logging.warn(e) | 64 logging.warn(e) |
49 return None | 65 return None |
OLD | NEW |