diff options
author | brettw@chromium.org <brettw@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-11-03 16:52:53 +0000 |
---|---|---|
committer | brettw@chromium.org <brettw@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-11-03 16:52:53 +0000 |
commit | aedf21e6299d270c7e044e2f9c2f7f3135551c7c (patch) | |
tree | e0c42a85c508647004189eb5ae165cf922601327 /webkit/tools/pepper_test_plugin | |
parent | b2d8b5e8189485482b85e6d1a21d10d7779a4d3c (diff) | |
download | chromium_src-aedf21e6299d270c7e044e2f9c2f7f3135551c7c.zip chromium_src-aedf21e6299d270c7e044e2f9c2f7f3135551c7c.tar.gz chromium_src-aedf21e6299d270c7e044e2f9c2f7f3135551c7c.tar.bz2 |
Add the plumbing and test code for plugins opening files from the sandbox. This
does not implement the actual opening of the files (currently the chain ends in
resource_message_filter.cc), I will do that separately with some additional
security review. This current patch just gets the synchronous request to the
browser and returns a NULL result.
TEST=none
BUG=none
Review URL: http://codereview.chromium.org/340050
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@30819 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'webkit/tools/pepper_test_plugin')
-rw-r--r-- | webkit/tools/pepper_test_plugin/plugin_object.cc | 34 |
1 files changed, 22 insertions, 12 deletions
diff --git a/webkit/tools/pepper_test_plugin/plugin_object.cc b/webkit/tools/pepper_test_plugin/plugin_object.cc index bd3e9e2..8af7591 100644 --- a/webkit/tools/pepper_test_plugin/plugin_object.cc +++ b/webkit/tools/pepper_test_plugin/plugin_object.cc @@ -25,6 +25,7 @@ #include "webkit/tools/pepper_test_plugin/plugin_object.h" +#include <stdio.h> #include <string> #include "base/logging.h" @@ -223,8 +224,7 @@ void DrawSampleBitmap(SkCanvas& canvas, int width, int height) { canvas.drawPath(path, paint); } -NPInitializeRenderContextPtr initialize_render_context = NULL; -NPFlushRenderContextPtr flush_render_context = NULL; +NPPepperExtensions* pepper = NULL; void FlushCallback(NPRenderContext* context, void* user_data) { } @@ -237,15 +237,10 @@ void FlushCallback(NPRenderContext* context, void* user_data) { PluginObject::PluginObject(NPP npp) : npp_(npp), test_object_(browser->createobject(npp, GetTestClass())) { - if (!initialize_render_context || !flush_render_context) { - NPPepperExtensions* extensions; + if (!pepper) { browser->getvalue(npp_, NPNVPepperExtensions, - reinterpret_cast<void*>(&extensions)); - CHECK(extensions); - initialize_render_context = extensions->initializeRender; - CHECK(initialize_render_context); - flush_render_context = extensions->flushRender; - CHECK(flush_render_context); + reinterpret_cast<void*>(&pepper)); + CHECK(pepper); } } @@ -259,11 +254,26 @@ NPClass* PluginObject::GetPluginClass() { } void PluginObject::SetWindow(const NPWindow& window) { + // File test + /* TODO(brettw): remove this when the file stuff is complete. This code is for + testing the OpenFileInSandbox function which is not complete. + { + void* handle = (void*)112358; + NPError err = pepper->openFile(npp_, + "q:\\prj\\src2\\src\\webkit\\tools\\pepper_test_plugin\\README", + &handle); + CHECK(err == NPERR_NO_ERROR); + + char buf[256]; + sprintf(buf, "Got the handle %d", (int)handle); + ::MessageBoxA(NULL, buf, "pepper", 0); + }*/ + size_.set_width(window.width); size_.set_height(window.height); NPRenderContext context; - initialize_render_context(npp_, NPRenderGraphicsRGBA, &context); + pepper->initializeRender(npp_, NPRenderGraphicsRGBA, &context); SkBitmap bitmap; bitmap.setConfig(SkBitmap::kARGB_8888_Config, window.width, window.height); @@ -276,5 +286,5 @@ void PluginObject::SetWindow(const NPWindow& window) { // match. Could be a calling convention mismatch? NPFlushRenderContextCallbackPtr callback = reinterpret_cast<NPFlushRenderContextCallbackPtr>(&FlushCallback); - flush_render_context(npp_, &context, callback, NULL); + pepper->flushRender(npp_, &context, callback, NULL); } |