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

Unified Diff: chrome/common/extensions/docs/server2/api_list_data_source.py

Issue 10815042: Extensions Docs Server: api_index.html, experimental.html (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 8 years, 5 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 side-by-side diff with in-line comments
Download patch
Index: chrome/common/extensions/docs/server2/api_list_data_source.py
diff --git a/chrome/common/extensions/docs/server2/api_list_data_source.py b/chrome/common/extensions/docs/server2/api_list_data_source.py
new file mode 100644
index 0000000000000000000000000000000000000000..a060872f5dbf34bc412ac9214bae2e81521099f7
--- /dev/null
+++ b/chrome/common/extensions/docs/server2/api_list_data_source.py
@@ -0,0 +1,47 @@
+# 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 os
+
+import third_party.json_schema_compiler.model as model
+
+class APIListDataSource(object):
+ """ This class creates a list of chrome.* APIs and chrome.experimental.* APIs
+ that are used in the api_index.html and experimental.html pages.
+ """
+ def __init__(self, cache_builder, file_system, api_path, public_path):
+ self._cache = cache_builder.build(self._ListAPIs)
+ self._file_system = file_system
+ self._api_path = api_path + '/'
+ self._public_path = public_path + '/'
+
+ def _ListAPIs(self, apis):
+ api_names = [os.path.splitext(name)[0] for name in apis]
not at google - send to devlin 2012/07/23 12:40:24 this is only used for lookup, so make it a set? a
cduvall 2012/07/23 20:38:19 Done.
+ template_names = [os.path.splitext(name)[0] for name in
+ self._file_system.Read(
not at google - send to devlin 2012/07/23 12:40:24 Use that fancy new ReadSingle method? (or add it
+ [self._public_path]).Get()[self._public_path]]
+ unix_template_names = [model.UnixName(name) for name in template_names]
+ experimental_names = []
+ # Go through the template names, and remove all names not found in the api
+ # folder from the list. Add all experimental APIs to a separate list.
+ for name, i in zip(template_names, range(len(template_names))):
not at google - send to devlin 2012/07/23 12:40:24 Perhaps for i, template_name in enumerate(templat
cduvall 2012/07/23 20:38:19 Done.
+ if unix_template_names[i] not in api_names:
+ template_names.remove(name)
not at google - send to devlin 2012/07/23 12:40:24 removing stuff is O(n). Instead, add to a list lik
cduvall 2012/07/23 20:38:19 Done.
+ elif unix_template_names[i].startswith('experimental'):
+ template_names.remove(name)
+ experimental_names.append(name)
+ return {
+ 'chrome': sorted([name.replace('_', '.') for name in template_names]),
+ 'experimental': sorted([name.replace('_', '.') for name in
+ experimental_names])
not at google - send to devlin 2012/07/23 12:40:24 similar comment as above, list comp "for foo in ba
cduvall 2012/07/23 20:38:19 Done.
+ }
+
+ def __getitem__(self, key):
+ return self.get(key)
+
+ def get(self, key):
+ try:
+ return self._cache.GetFromFile(self._api_path)
not at google - send to devlin 2012/07/23 12:40:24 if you added [key] at the end of here then you cou
cduvall 2012/07/23 20:38:19 Done.
+ except Exception as e:
+ return None

Powered by Google App Engine
This is Rietveld 408576698