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

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

Issue 10834144: Extensions Docs Server: Split apps from extensions (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: reworked 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 from docs_server_utils import SanitizeAPIName
9 9
10 class APIListDataSource(object): 10 class APIListDataSource(object):
11 """ 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
12 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.
13 """ 13 """
14 def __init__(self, cache_builder, file_system, api_path, public_path): 14 def __init__(self, cache_builder, file_system, api_path, public_path):
15 self._cache = cache_builder.build(self._ListAPIs) 15 self._cache = cache_builder.build(self._ListAPIs)
16 self._file_system = file_system 16 self._file_system = file_system
17 self._api_path = api_path + '/' 17 self._api_path = api_path + '/'
18 self._public_path = public_path + '/' 18 self._public_path = public_path + '/'
19 19
20 def _ListAPIs(self, apis): 20 def _ListAPIs(self, apis):
21 api_names = set(SanitizeAPIName(name, self._api_path) for name in apis) 21 api_names = set(SanitizeAPIName(name, self._api_path) for name in apis)
22 public_templates = self._file_system.ReadSingle(self._public_path) 22 return_dict = {}
not at google - send to devlin 2012/08/06 08:38:33 nit: I would have structured this like return {
cduvall 2012/08/06 18:36:16 Done.
23 template_names = [os.path.splitext(name)[0] for name in public_templates] 23 for doc_type in ['apps', 'extensions']:
24 experimental_apis = [] 24 public_templates = self._file_system.ReadSingle(
25 chrome_apis = [] 25 self._public_path + doc_type + '/')
26 for i, template_name in enumerate(sorted(template_names)): 26 template_names = [os.path.splitext(name)[0]
27 if model.UnixName(template_name) in api_names: 27 for name in public_templates]
28 if template_name.startswith('experimental'): 28 experimental_apis = []
29 experimental_apis.append({ 'name': template_name.replace('_', '.') }) 29 chrome_apis = []
30 else: 30 for i, template_name in enumerate(sorted(template_names)):
31 chrome_apis.append({ 'name': template_name.replace('_', '.') }) 31 if model.UnixName(template_name) in api_names:
32 chrome_apis[-1]['last'] = True 32 if template_name.startswith('experimental'):
33 experimental_apis[-1]['last'] = True 33 experimental_apis.append({
34 return { 34 'name': template_name.replace('_', '.')
35 'chrome': chrome_apis, 35 })
36 'experimental': experimental_apis 36 else:
37 } 37 chrome_apis.append({ 'name': template_name.replace('_', '.') })
38 chrome_apis[-1]['last'] = True
39 experimental_apis[-1]['last'] = True
40 return_dict[doc_type] = {
41 'chrome': chrome_apis,
42 'experimental': experimental_apis
43 }
44 return return_dict
38 45
39 def __getitem__(self, key): 46 def __getitem__(self, key):
40 return self.get(key) 47 return self.get(key)
41 48
42 def get(self, key): 49 def get(self, key):
43 try: 50 try:
44 return self._cache.GetFromFileListing(self._api_path)[key] 51 return self._cache.GetFromFileListing(self._api_path)[key]
45 except Exception as e: 52 except Exception as e:
46 return None 53 return None
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698