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

Unified Diff: chrome/renderer/extensions/schema_generated_bindings.cc

Issue 9918006: Split SchemaGeneratedBindings up into smaller, more targetted native handlers. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: rebase Created 8 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 side-by-side diff with in-line comments
Download patch
Index: chrome/renderer/extensions/schema_generated_bindings.cc
diff --git a/chrome/renderer/extensions/schema_generated_bindings.cc b/chrome/renderer/extensions/schema_generated_bindings.cc
deleted file mode 100644
index c33aae2b4aa0cae159dd043f215adfee9bd278c1..0000000000000000000000000000000000000000
--- a/chrome/renderer/extensions/schema_generated_bindings.cc
+++ /dev/null
@@ -1,207 +0,0 @@
-// 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.
-
-#include "chrome/renderer/extensions/schema_generated_bindings.h"
-
-#include <map>
-#include <set>
-#include <string>
-
-#include "base/callback.h"
-#include "base/command_line.h"
-#include "base/json/json_reader.h"
-#include "base/memory/scoped_ptr.h"
-#include "base/string_number_conversions.h"
-#include "base/string_util.h"
-#include "chrome/common/extensions/extension.h"
-#include "chrome/common/extensions/extension_action.h"
-#include "chrome/common/extensions/extension_constants.h"
-#include "chrome/common/extensions/extension_messages.h"
-#include "chrome/common/extensions/extension_set.h"
-#include "chrome/common/extensions/url_pattern.h"
-#include "chrome/common/extensions/api/extension_api.h"
-#include "chrome/common/render_messages.h"
-#include "chrome/renderer/chrome_render_process_observer.h"
-#include "chrome/renderer/extensions/chrome_v8_context.h"
-#include "chrome/renderer/extensions/chrome_v8_context_set.h"
-#include "chrome/renderer/extensions/event_bindings.h"
-#include "chrome/renderer/extensions/extension_dispatcher.h"
-#include "chrome/renderer/extensions/extension_request_sender.h"
-#include "chrome/renderer/extensions/miscellaneous_bindings.h"
-#include "chrome/renderer/extensions/user_script_slave.h"
-#include "content/public/renderer/render_thread.h"
-#include "content/public/renderer/render_view.h"
-#include "content/public/renderer/v8_value_converter.h"
-#include "grit/common_resources.h"
-#include "grit/renderer_resources.h"
-#include "third_party/skia/include/core/SkBitmap.h"
-#include "third_party/skia/include/core/SkColor.h"
-#include "ui/base/resource/resource_bundle.h"
-#include "v8/include/v8.h"
-#include "webkit/glue/webkit_glue.h"
-
-using content::RenderThread;
-using content::V8ValueConverter;
-using extensions::ExtensionAPI;
-using extensions::Feature;
-using WebKit::WebFrame;
-using WebKit::WebSecurityOrigin;
-
-namespace extensions {
-
-SchemaGeneratedBindings::SchemaGeneratedBindings(
- ExtensionDispatcher* extension_dispatcher,
- ExtensionRequestSender* request_sender)
- : ChromeV8Extension(extension_dispatcher),
- request_sender_(request_sender) {
- RouteFunction("GetExtensionAPIDefinition",
- base::Bind(&SchemaGeneratedBindings::GetExtensionAPIDefinition,
- base::Unretained(this)));
- RouteFunction("GetNextRequestId",
- base::Bind(&SchemaGeneratedBindings::GetNextRequestId,
- base::Unretained(this)));
- RouteFunction("StartRequest",
- base::Bind(&SchemaGeneratedBindings::StartRequest,
- base::Unretained(this)));
- RouteFunction("SetIconCommon",
- base::Bind(&SchemaGeneratedBindings::SetIconCommon,
- base::Unretained(this)));
-}
-
-v8::Handle<v8::Value> SchemaGeneratedBindings::GetExtensionAPIDefinition(
- const v8::Arguments& args) {
- ChromeV8Context* v8_context =
- extension_dispatcher()->v8_context_set().GetCurrent();
- CHECK(v8_context);
-
- // TODO(kalman): This is being calculated twice, first in
- // ExtensionDispatcher then again here. It might as well be a property of
- // ChromeV8Context, however, this would require making ChromeV8Context take
- // an Extension rather than an extension ID. In itself this is fine,
- // however it does not play correctly with the "IsTestExtensionId" checks.
- // We need to remove that first.
- scoped_ptr<std::set<std::string> > apis;
-
- const std::string& extension_id = v8_context->extension_id();
- if (extension_dispatcher()->IsTestExtensionId(extension_id)) {
- apis.reset(new std::set<std::string>());
- // The minimal set of APIs that tests need.
- apis->insert("extension");
- } else {
- apis = ExtensionAPI::GetSharedInstance()->GetAPIsForContext(
- v8_context->context_type(),
- extension_dispatcher()->extensions()->GetByID(extension_id),
- UserScriptSlave::GetDataSourceURLForFrame(v8_context->web_frame()));
- }
-
- return extension_dispatcher()->v8_schema_registry()->GetSchemas(*apis);
-}
-
-v8::Handle<v8::Value> SchemaGeneratedBindings::GetNextRequestId(
- const v8::Arguments& args) {
- static int next_request_id = 0;
- return v8::Integer::New(next_request_id++);
-}
-
-v8::Handle<v8::Value> SchemaGeneratedBindings::StartRequestCommon(
- const v8::Arguments& args, ListValue* value_args) {
- std::string name = *v8::String::AsciiValue(args[0]);
- int request_id = args[2]->Int32Value();
- bool has_callback = args[3]->BooleanValue();
- bool for_io_thread = args[4]->BooleanValue();
-
- request_sender_->StartRequest(name,
- request_id,
- has_callback,
- for_io_thread,
- value_args);
- return v8::Undefined();
-}
-
-// Starts an API request to the browser, with an optional callback. The
-// callback will be dispatched to EventBindings::HandleResponse.
-v8::Handle<v8::Value> SchemaGeneratedBindings::StartRequest(
- const v8::Arguments& args) {
- std::string str_args = *v8::String::Utf8Value(args[1]);
- base::JSONReader reader;
- scoped_ptr<Value> value_args;
- value_args.reset(reader.JsonToValue(str_args, false, false));
-
- // Since we do the serialization in the v8 extension, we should always get
- // valid JSON.
- if (!value_args.get() || !value_args->IsType(Value::TYPE_LIST)) {
- NOTREACHED() << "Invalid JSON passed to StartRequest.";
- return v8::Undefined();
- }
-
- return StartRequestCommon(args, static_cast<ListValue*>(value_args.get()));
-}
-
-bool SchemaGeneratedBindings::ConvertImageDataToBitmapValue(
- const v8::Arguments& args, Value** bitmap_value) {
- v8::Local<v8::Object> extension_args = args[1]->ToObject();
- v8::Local<v8::Object> details =
- extension_args->Get(v8::String::New("0"))->ToObject();
- v8::Local<v8::Object> image_data =
- details->Get(v8::String::New("imageData"))->ToObject();
- v8::Local<v8::Object> data =
- image_data->Get(v8::String::New("data"))->ToObject();
- int width = image_data->Get(v8::String::New("width"))->Int32Value();
- int height = image_data->Get(v8::String::New("height"))->Int32Value();
-
- int data_length = data->Get(v8::String::New("length"))->Int32Value();
- if (data_length != 4 * width * height) {
- NOTREACHED() << "Invalid argument to setIcon. Expecting ImageData.";
- return false;
- }
-
- SkBitmap bitmap;
- bitmap.setConfig(SkBitmap::kARGB_8888_Config, width, height);
- bitmap.allocPixels();
- bitmap.eraseARGB(0, 0, 0, 0);
-
- uint32_t* pixels = bitmap.getAddr32(0, 0);
- for (int t = 0; t < width*height; t++) {
- // |data| is RGBA, pixels is ARGB.
- pixels[t] = SkPreMultiplyColor(
- ((data->Get(v8::Integer::New(4*t + 3))->Int32Value() & 0xFF) << 24) |
- ((data->Get(v8::Integer::New(4*t + 0))->Int32Value() & 0xFF) << 16) |
- ((data->Get(v8::Integer::New(4*t + 1))->Int32Value() & 0xFF) << 8) |
- ((data->Get(v8::Integer::New(4*t + 2))->Int32Value() & 0xFF) << 0));
- }
-
- // Construct the Value object.
- IPC::Message bitmap_pickle;
- IPC::WriteParam(&bitmap_pickle, bitmap);
- *bitmap_value = base::BinaryValue::CreateWithCopiedBuffer(
- static_cast<const char*>(bitmap_pickle.data()), bitmap_pickle.size());
-
- return true;
-}
-
-v8::Handle<v8::Value> SchemaGeneratedBindings::SetIconCommon(
- const v8::Arguments& args) {
- Value* bitmap_value = NULL;
- if (!ConvertImageDataToBitmapValue(args, &bitmap_value))
- return v8::Undefined();
-
- v8::Local<v8::Object> extension_args = args[1]->ToObject();
- v8::Local<v8::Object> details =
- extension_args->Get(v8::String::New("0"))->ToObject();
-
- DictionaryValue* dict = new DictionaryValue();
- dict->Set("imageData", bitmap_value);
-
- if (details->Has(v8::String::New("tabId"))) {
- dict->SetInteger("tabId",
- details->Get(v8::String::New("tabId"))->Int32Value());
- }
-
- ListValue list_value;
- list_value.Append(dict);
-
- return StartRequestCommon(args, &list_value);
-}
-
-} // namespace extensions
« no previous file with comments | « chrome/renderer/extensions/schema_generated_bindings.h ('k') | chrome/renderer/extensions/send_request_natives.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698