Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(70)

Side by Side Diff: chrome/common/extensions/docs/server2/api_list_data_source.py

Issue 10797039: Extensions Docs Server: devtools API (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: move parsing logic into utils Created 8 years, 4 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
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 os 5 import os
6 6
7 import third_party.json_schema_compiler.model as model 7 import third_party.json_schema_compiler.model as model
8 from docs_server_utils import SanitizeAPIName
8 9
9 class APIListDataSource(object): 10 class APIListDataSource(object):
10 """ This class creates a list of chrome.* APIs and chrome.experimental.* APIs 11 """ This class creates a list of chrome.* APIs and chrome.experimental.* APIs
11 that are used in the api_index.html and experimental.html pages. 12 that are used in the api_index.html and experimental.html pages.
12 """ 13 """
13 def __init__(self, cache_builder, file_system, api_path, public_path): 14 def __init__(self, cache_builder, file_system, api_path, public_path):
14 self._cache = cache_builder.build(self._ListAPIs) 15 self._cache = cache_builder.build(self._ListAPIs)
15 self._file_system = file_system 16 self._file_system = file_system
16 self._api_path = api_path + '/' 17 self._api_path = api_path + '/'
17 self._public_path = public_path + '/' 18 self._public_path = public_path + '/'
18 19
19 def _ListAPIs(self, apis): 20 def _ListAPIs(self, apis):
20 api_names = set(os.path.splitext(name)[0] for name in apis) 21 api_names = set(SanitizeAPIName(name, self._api_path) for name in apis)
21 public_templates = self._file_system.ReadSingle(self._public_path) 22 public_templates = self._file_system.ReadSingle(self._public_path)
22 template_names = [os.path.splitext(name)[0] for name in public_templates] 23 template_names = [os.path.splitext(name)[0] for name in public_templates]
23 experimental_apis = [] 24 experimental_apis = []
24 chrome_apis = [] 25 chrome_apis = []
25 for i, template_name in enumerate(sorted(template_names)): 26 for i, template_name in enumerate(sorted(template_names)):
26 if model.UnixName(template_name) in api_names: 27 if model.UnixName(template_name) in api_names:
27 if template_name.startswith('experimental'): 28 if template_name.startswith('experimental'):
28 experimental_apis.append({ 'name': template_name.replace('_', '.') }) 29 experimental_apis.append({ 'name': template_name.replace('_', '.') })
29 else: 30 else:
30 chrome_apis.append({ 'name': template_name.replace('_', '.') }) 31 chrome_apis.append({ 'name': template_name.replace('_', '.') })
31 chrome_apis[-1]['last'] = True 32 chrome_apis[-1]['last'] = True
32 experimental_apis[-1]['last'] = True 33 experimental_apis[-1]['last'] = True
33 return { 34 return {
34 'chrome': chrome_apis, 35 'chrome': chrome_apis,
35 'experimental': experimental_apis 36 'experimental': experimental_apis
36 } 37 }
37 38
38 def __getitem__(self, key): 39 def __getitem__(self, key):
39 return self.get(key) 40 return self.get(key)
40 41
41 def get(self, key): 42 def get(self, key):
42 try: 43 try:
43 return self._cache.GetFromFile(self._api_path)[key] 44 return self._cache.GetFromFileListing(self._api_path)[key]
44 except Exception as e: 45 except Exception as e:
45 return None 46 return None
OLDNEW
« no previous file with comments | « chrome/common/extensions/docs/js/api_page_generator.js ('k') | chrome/common/extensions/docs/server2/docs_server_utils.py » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698