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

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: fixes 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..289d34309a5a8a106598b5ec9c5579cf0704c6cf
--- /dev/null
+++ b/chrome/common/extensions/docs/server2/api_list_data_source.py
@@ -0,0 +1,43 @@
+# 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 = set(os.path.splitext(name)[0] for name in apis)
+ public_templates = self._file_system.ReadSingle(self._public_path)
+ template_names = [os.path.splitext(name)[0] for name in public_templates]
+ experimental_apis = []
+ chrome_apis = []
+ for i, template_name in enumerate(template_names):
+ if model.UnixName(template_name) in api_names:
+ if template_name.startswith('experimental'):
+ experimental_apis.append(template_name.replace('_', '.'))
+ else:
+ chrome_apis.append(template_name.replace('_', '.'))
+ return {
+ 'chrome': sorted(chrome_apis),
+ 'experimental': sorted(experimental_apis)
+ }
+
+ def __getitem__(self, key):
+ return self.get(key)
+
+ def get(self, key):
+ try:
+ return self._cache.GetFromFile(self._api_path)[key]
+ except Exception as e:
+ return None

Powered by Google App Engine
This is Rietveld 408576698