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

Side by Side Diff: chrome/renderer/resources/extensions/send_request.js

Issue 11571014: Lazy load chrome.* APIs (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: windows interactive_ui_tests fix Created 7 years, 9 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 var chromeHidden = requireNative('chrome_hidden').GetChromeHidden(); 5 var chromeHidden = requireNative('chrome_hidden').GetChromeHidden();
6 var DCHECK = requireNative('logging').DCHECK;
6 var json = require('json'); 7 var json = require('json');
7 var lastError = require('lastError'); 8 var lastError = require('lastError');
8 var natives = requireNative('sendRequest'); 9 var natives = requireNative('sendRequest');
9 var validate = require('schemaUtils').validate; 10 var validate = require('schemaUtils').validate;
10 11
11 // Callback handling. 12 // Callback handling.
12 var requests = []; 13 var requests = [];
13 chromeHidden.handleResponse = function(requestId, name, 14 chromeHidden.handleResponse = function(requestId, name,
14 success, responseList, error) { 15 success, responseList, error) {
15 try { 16 try {
16 var request = requests[requestId]; 17 var request = requests[requestId];
18 DCHECK(request != null);
17 if (success) { 19 if (success) {
18 lastError.clear(); 20 lastError.clear();
19 } else { 21 } else {
20 if (!error) { 22 if (!error) {
21 error = "Unknown error."; 23 error = "Unknown error.";
22 } 24 }
23 console.error("Error during " + name + ": " + error); 25 console.error("Error during " + name + ": " + error);
24 lastError.set(error); 26 lastError.set(error);
25 } 27 }
26 28
27 if (request.customCallback) { 29 if (request.customCallback) {
28 var customCallbackArgs = [name, request].concat(responseList); 30 var customCallbackArgs = [name, request].concat(responseList);
29 request.customCallback.apply(request, customCallbackArgs); 31 request.customCallback.apply(request, customCallbackArgs);
30 } 32 }
31 33
32 if (request.callback) { 34 if (request.callback) {
33 // Validate callback in debug only -- and only when the 35 // Validate callback in debug only -- and only when the
34 // caller has provided a callback. Implementations of api 36 // caller has provided a callback. Implementations of api
35 // calls my not return data if they observe the caller 37 // calls may not return data if they observe the caller
36 // has not provided a callback. 38 // has not provided a callback.
37 if (chromeHidden.validateCallbacks && !error) { 39 if (chromeHidden.validateCallbacks && !error) {
38 try { 40 try {
39 if (!request.callbackSchema.parameters) { 41 if (!request.callbackSchema.parameters) {
40 throw new Error("No callback schemas defined"); 42 throw new Error("No callback schemas defined");
41 } 43 }
42 44
43 validate(responseList, request.callbackSchema.parameters); 45 validate(responseList, request.callbackSchema.parameters);
44 } catch (exception) { 46 } catch (exception) {
45 return "Callback validation error during " + name + " -- " + 47 return "Callback validation error during " + name + " -- " +
(...skipping 66 matching lines...) Expand 10 before | Expand all | Expand 10 after
112 var hasCallback = request.callback || optArgs.customCallback; 114 var hasCallback = request.callback || optArgs.customCallback;
113 return nativeFunction(functionName, 115 return nativeFunction(functionName,
114 requestArgs, 116 requestArgs,
115 requestId, 117 requestId,
116 hasCallback, 118 hasCallback,
117 optArgs.forIOThread, 119 optArgs.forIOThread,
118 optArgs.preserveNullInObjects); 120 optArgs.preserveNullInObjects);
119 } 121 }
120 122
121 exports.sendRequest = sendRequest; 123 exports.sendRequest = sendRequest;
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698