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

Unified Diff: chrome/renderer/resources/extensions/declarative_webrequest_custom_bindings.js

Issue 11571014: Lazy load chrome.* APIs (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: addressed comments Created 7 years, 10 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/renderer/resources/extensions/declarative_webrequest_custom_bindings.js
diff --git a/chrome/renderer/resources/extensions/declarative_webrequest_custom_bindings.js b/chrome/renderer/resources/extensions/declarative_webrequest_custom_bindings.js
index f015bf72840d09339b465a0406bc5bc394902bab..556e394535251cfeafdb87139e4419c6de3c440a 100644
--- a/chrome/renderer/resources/extensions/declarative_webrequest_custom_bindings.js
+++ b/chrome/renderer/resources/extensions/declarative_webrequest_custom_bindings.js
@@ -2,19 +2,23 @@
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
-// Custom bindings for the declarativeWebRequest API.
+// Custom binding for the declarativeWebRequest API.
+
+var binding = require('binding').Binding.create('declarativeWebRequest');
var chromeHidden = requireNative('chrome_hidden').GetChromeHidden();
+var chrome = requireNative('chrome').GetChrome();
var utils = require('utils');
var validate = require('schemaUtils').validate;
-chromeHidden.registerCustomHook('declarativeWebRequest', function(api) {
+binding.registerCustomHook(function(api) {
+ declarativeWebRequest = api.compiledApi;
+
// Returns the schema definition of type |typeId| defined in |namespace|.
- function getSchema(namespace, typeId) {
- var apiSchema = utils.lookup(api.apiDefinitions, 'namespace', namespace);
- var resultSchema = utils.lookup(
- apiSchema.types, 'id', namespace + '.' + typeId);
- return resultSchema;
+ function getSchema(typeId) {
+ return utils.lookup(api.schema.types,
+ 'id',
+ 'declarativeWebRequest.' + typeId);
}
// Helper function for the constructor of concrete datatypes of the
@@ -29,64 +33,66 @@ chromeHidden.registerCustomHook('declarativeWebRequest', function(api) {
}
}
instance.instanceType = 'declarativeWebRequest.' + typeId;
- var schema = getSchema('declarativeWebRequest', typeId);
+ var schema = getSchema(typeId);
validate([instance], [schema]);
}
// Setup all data types for the declarative webRequest API.
- chrome.declarativeWebRequest.RequestMatcher = function(parameters) {
+ declarativeWebRequest.RequestMatcher = function(parameters) {
setupInstance(this, parameters, 'RequestMatcher');
};
- chrome.declarativeWebRequest.CancelRequest = function(parameters) {
+ declarativeWebRequest.CancelRequest = function(parameters) {
setupInstance(this, parameters, 'CancelRequest');
};
- chrome.declarativeWebRequest.RedirectRequest = function(parameters) {
+ declarativeWebRequest.RedirectRequest = function(parameters) {
setupInstance(this, parameters, 'RedirectRequest');
};
- chrome.declarativeWebRequest.SetRequestHeader = function(parameters) {
+ declarativeWebRequest.SetRequestHeader = function(parameters) {
setupInstance(this, parameters, 'SetRequestHeader');
};
- chrome.declarativeWebRequest.RemoveRequestHeader = function(parameters) {
+ declarativeWebRequest.RemoveRequestHeader = function(parameters) {
setupInstance(this, parameters, 'RemoveRequestHeader');
};
- chrome.declarativeWebRequest.AddResponseHeader = function(parameters) {
+ declarativeWebRequest.AddResponseHeader = function(parameters) {
setupInstance(this, parameters, 'AddResponseHeader');
};
- chrome.declarativeWebRequest.RemoveResponseHeader = function(parameters) {
+ declarativeWebRequest.RemoveResponseHeader = function(parameters) {
setupInstance(this, parameters, 'RemoveResponseHeader');
};
- chrome.declarativeWebRequest.RedirectToTransparentImage =
+ declarativeWebRequest.RedirectToTransparentImage =
function(parameters) {
setupInstance(this, parameters, 'RedirectToTransparentImage');
};
- chrome.declarativeWebRequest.RedirectToEmptyDocument = function(parameters) {
+ declarativeWebRequest.RedirectToEmptyDocument = function(parameters) {
setupInstance(this, parameters, 'RedirectToEmptyDocument');
};
- chrome.declarativeWebRequest.RedirectByRegEx = function(parameters) {
+ declarativeWebRequest.RedirectByRegEx = function(parameters) {
setupInstance(this, parameters, 'RedirectByRegEx');
};
- chrome.declarativeWebRequest.IgnoreRules = function(parameters) {
+ declarativeWebRequest.IgnoreRules = function(parameters) {
setupInstance(this, parameters, 'IgnoreRules');
};
- chrome.declarativeWebRequest.AddRequestCookie = function(parameters) {
+ declarativeWebRequest.AddRequestCookie = function(parameters) {
setupInstance(this, parameters, 'AddRequestCookie');
};
- chrome.declarativeWebRequest.AddResponseCookie = function(parameters) {
+ declarativeWebRequest.AddResponseCookie = function(parameters) {
setupInstance(this, parameters, 'AddResponseCookie');
};
- chrome.declarativeWebRequest.EditRequestCookie = function(parameters) {
+ declarativeWebRequest.EditRequestCookie = function(parameters) {
setupInstance(this, parameters, 'EditRequestCookie');
};
- chrome.declarativeWebRequest.EditResponseCookie = function(parameters) {
+ declarativeWebRequest.EditResponseCookie = function(parameters) {
setupInstance(this, parameters, 'EditResponseCookie');
};
- chrome.declarativeWebRequest.RemoveRequestCookie = function(parameters) {
+ declarativeWebRequest.RemoveRequestCookie = function(parameters) {
setupInstance(this, parameters, 'RemoveRequestCookie');
};
- chrome.declarativeWebRequest.RemoveResponseCookie = function(parameters) {
+ declarativeWebRequest.RemoveResponseCookie = function(parameters) {
setupInstance(this, parameters, 'RemoveResponseCookie');
};
- chrome.declarativeWebRequest.SendMessageToExtension = function(parameters) {
+ declarativeWebRequest.SendMessageToExtension = function(parameters) {
setupInstance(this, parameters, 'SendMessageToExtension');
};
});
+
+exports.binding = binding.generate();

Powered by Google App Engine
This is Rietveld 408576698