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

Unified Diff: extensions/renderer/user_script_slave.h

Issue 284153006: Introduce ScriptInjection in extensions/renderer to inject UserScripts (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 6 years, 7 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: extensions/renderer/user_script_slave.h
diff --git a/extensions/renderer/user_script_slave.h b/extensions/renderer/user_script_slave.h
index fc3da79ae05a9223e52566cc1118043fb3b75119..c7e0014cbbd48e448bdde790fb75c2e888f584cf 100644
--- a/extensions/renderer/user_script_slave.h
+++ b/extensions/renderer/user_script_slave.h
@@ -10,12 +10,14 @@
#include <string>
#include <vector>
+#include "base/memory/linked_ptr.h"
#include "base/memory/scoped_ptr.h"
#include "base/memory/shared_memory.h"
#include "base/stl_util.h"
#include "base/strings/string_piece.h"
#include "extensions/common/user_script.h"
-#include "third_party/WebKit/public/web/WebScriptSource.h"
+#include "extensions/renderer/script_injection.h"
+#include "third_party/WebKit/public/platform/WebString.h"
class GURL;
@@ -23,7 +25,9 @@ namespace blink {
class WebFrame;
}
-using blink::WebScriptSource;
+namespace content {
+class RenderView;
+}
namespace extensions {
class Extension;
@@ -38,14 +42,12 @@ class UserScriptSlave {
// Returns the unique set of extension IDs this UserScriptSlave knows about.
void GetActiveExtensions(std::set<std::string>* extension_ids);
+ // Gets the extension with the given |id|, if one exists.
+ const Extension* GetExtension(const std::string& extension_id);
+
// Update the parsed scripts from shared memory.
bool UpdateScripts(base::SharedMemoryHandle shared_memory);
- // Inject the appropriate scripts into a frame based on its URL.
- // TODO(aa): Extract a UserScriptFrame interface out of this to improve
- // testability.
- void InjectScripts(blink::WebFrame* frame, UserScript::RunLocation location);
-
// Gets the isolated world ID to use for the given |extension| in the given
// |frame|. If no isolated world has been created for that extension,
// one will be created and initialized.
@@ -59,16 +61,24 @@ class UserScriptSlave {
void RemoveIsolatedWorld(const std::string& extension_id);
+ // Inject the appropriate scripts into a frame based on its URL.
+ // TODO(aa): Extract a UserScriptFrame interface out of this to improve
+ // testability.
+ void InjectScripts(blink::WebFrame* frame, UserScript::RunLocation location);
+
private:
+ // Log the data from scripts being run, including doing UMA and notifying the
+ // browser.
+ void LogScriptsRun(blink::WebFrame* frame,
+ UserScript::RunLocation location,
+ const ScriptInjection::ScriptsRunInfo& info);
+
// Shared memory containing raw script data.
scoped_ptr<base::SharedMemory> shared_memory_;
- // Parsed script data.
- std::vector<UserScript*> scripts_;
- STLElementDeleter<std::vector<UserScript*> > script_deleter_;
-
- // Greasemonkey API source that is injected with the scripts.
- base::StringPiece api_js_;
+ // Parsed script data, ready to inject.
+ std::vector<ScriptInjection*> script_injections_;
not at google - send to devlin 2014/05/15 23:23:21 mind changing this to a ScopedVector?
Devlin 2014/05/16 22:32:20 Sure.
+ STLElementDeleter<std::vector<ScriptInjection*> > script_deleter_;
// Extension metadata.
const ExtensionSet* extensions_;

Powered by Google App Engine
This is Rietveld 408576698