Index: Source/core/inspector/InjectedScript.h |
diff --git a/Source/core/inspector/InjectedScript.h b/Source/core/inspector/InjectedScript.h |
index 16ea58f2bb9c296b0f494c36668ca24d8864dde4..84265e5f9adce059d539feea6723b3a2fab1c58f 100644 |
--- a/Source/core/inspector/InjectedScript.h |
+++ b/Source/core/inspector/InjectedScript.h |
@@ -32,6 +32,7 @@ |
#define InjectedScript_h |
#include "InspectorTypeBuilder.h" |
+#include "bindings/common/StackTrace.h" |
#include "bindings/v8/ScriptObject.h" |
#include "core/inspector/InjectedScriptBase.h" |
#include "core/inspector/InjectedScriptManager.h" |
@@ -45,12 +46,73 @@ class InjectedScriptModule; |
class Node; |
class SerializedScriptValue; |
-class InjectedScript FINAL : public InjectedScriptBase { |
+class InjectedScript : public virtual InjectedScriptBase { |
public: |
- InjectedScript(); |
virtual ~InjectedScript() { } |
- void evaluate( |
+ virtual void evaluate(ErrorString*, |
+ const String& expression, |
+ const String& objectGroup, |
+ bool includeCommandLineAPI, |
+ bool returnByValue, |
+ bool generatePreview, |
+ RefPtr<TypeBuilder::Runtime::RemoteObject>* result, |
+ TypeBuilder::OptOutput<bool>* wasThrown) = 0; |
+ virtual void callFunctionOn(ErrorString*, |
+ const String& objectId, |
+ const String& expression, |
+ const String& arguments, |
+ bool returnByValue, |
+ bool generatePreview, |
+ RefPtr<TypeBuilder::Runtime::RemoteObject>* result, |
+ TypeBuilder::OptOutput<bool>* wasThrown) = 0; |
+ virtual void evaluateOnCallFrame( |
+ ErrorString*, |
+ const StackTrace& callFrames, |
+ const Vector<StackTrace>& asyncCallStacks, |
+ const String& callFrameId, |
+ const String& expression, |
+ const String& objectGroup, |
+ bool includeCommandLineAPI, |
+ bool returnByValue, |
+ bool generatePreview, |
+ RefPtr<TypeBuilder::Runtime::RemoteObject>* result, |
+ TypeBuilder::OptOutput<bool>* wasThrown) = 0; |
+ virtual void getCompletionsOnCallFrame( |
+ ErrorString*, |
+ const StackTrace& callFrames, |
+ const Vector<StackTrace>& asyncCallStacks, |
+ const String& callFrameId, |
+ const String& expression, |
+ RefPtr<TypeBuilder::Array<String> >* result) = 0; |
+ virtual void restartFrame(ErrorString*, const StackTrace& callFrames, const String& callFrameId, RefPtr<JSONObject>* result) = 0; |
+ virtual void getStepInPositions(ErrorString*, const StackTrace& callFrames, const String& callFrameId, RefPtr<TypeBuilder::Array<TypeBuilder::Debugger::Location> >& positions) = 0; |
+ virtual void setVariableValue(ErrorString*, const StackTrace& callFrames, const String* callFrameIdOpt, const String* functionObjectIdOpt, int scopeNumber, const String& variableName, const String& newValueStr) = 0; |
+ virtual void getFunctionDetails(ErrorString*, const String& functionId, RefPtr<TypeBuilder::Debugger::FunctionDetails>* result) = 0; |
+ virtual void getCompletions(ErrorString*, const String& expression, RefPtr<TypeBuilder::Array<String> >* result) = 0; |
+ virtual void getProperties(ErrorString*, const String& objectId, bool ownProperties, bool accessorPropertiesOnly, RefPtr<TypeBuilder::Array<TypeBuilder::Runtime::PropertyDescriptor> >* result) = 0; |
+ virtual void getInternalProperties(ErrorString*, const String& objectId, RefPtr<TypeBuilder::Array<TypeBuilder::Runtime::InternalPropertyDescriptor> >* result) = 0; |
+ virtual void getProperty(ErrorString*, const String& objectId, const RefPtr<JSONArray>& propertyPath, RefPtr<TypeBuilder::Runtime::RemoteObject>* result, TypeBuilder::OptOutput<bool>* wasThrown) = 0; |
+ |
+ virtual Node* nodeForObjectId(const String& objectId) = 0; |
+ virtual void releaseObject(const String& objectId) = 0; |
+ |
+ virtual PassRefPtr<TypeBuilder::Array<TypeBuilder::Debugger::CallFrame> > wrapCallFrames(const StackTrace&, int asyncOrdinal) = 0; |
+ |
+ virtual PassRefPtr<TypeBuilder::Runtime::RemoteObject> wrapObject(const ScriptValue&, const String& groupName, bool generatePreview = false) = 0; |
+ virtual PassRefPtr<TypeBuilder::Runtime::RemoteObject> wrapTable(const ScriptValue& table, const ScriptValue& columns) = 0; |
+ |
+ virtual ActivationFrame findCallFrameById(ErrorString*, const StackTrace& topCallFrame, const String& callFrameId) = 0; |
+ |
+ virtual void releaseObjectGroup(const String&) = 0; |
+}; |
+ |
+class V8InjectedScript FINAL : public V8InjectedScriptBase, public InjectedScript { |
+public: |
+ V8InjectedScript(); |
+ virtual ~V8InjectedScript() { } |
+ |
+ virtual void evaluate( |
ErrorString*, |
const String& expression, |
const String& objectGroup, |
@@ -59,7 +121,7 @@ public: |
bool generatePreview, |
RefPtr<TypeBuilder::Runtime::RemoteObject>* result, |
TypeBuilder::OptOutput<bool>* wasThrown); |
- void callFunctionOn( |
+ virtual void callFunctionOn( |
ErrorString*, |
const String& objectId, |
const String& expression, |
@@ -68,10 +130,10 @@ public: |
bool generatePreview, |
RefPtr<TypeBuilder::Runtime::RemoteObject>* result, |
TypeBuilder::OptOutput<bool>* wasThrown); |
- void evaluateOnCallFrame( |
+ virtual void evaluateOnCallFrame( |
ErrorString*, |
- const ScriptValue& callFrames, |
- const Vector<ScriptValue>& asyncCallStacks, |
+ const StackTrace& callFrames, |
+ const Vector<StackTrace>& asyncCallStacks, |
const String& callFrameId, |
const String& expression, |
const String& objectGroup, |
@@ -80,35 +142,44 @@ public: |
bool generatePreview, |
RefPtr<TypeBuilder::Runtime::RemoteObject>* result, |
TypeBuilder::OptOutput<bool>* wasThrown); |
- void restartFrame(ErrorString*, const ScriptValue& callFrames, const String& callFrameId, RefPtr<JSONObject>* result); |
- void getStepInPositions(ErrorString*, const ScriptValue& callFrames, const String& callFrameId, RefPtr<TypeBuilder::Array<TypeBuilder::Debugger::Location> >& positions); |
- void setVariableValue(ErrorString*, const ScriptValue& callFrames, const String* callFrameIdOpt, const String* functionObjectIdOpt, int scopeNumber, const String& variableName, const String& newValueStr); |
- void getFunctionDetails(ErrorString*, const String& functionId, RefPtr<TypeBuilder::Debugger::FunctionDetails>* result); |
- void getProperties(ErrorString*, const String& objectId, bool ownProperties, bool accessorPropertiesOnly, RefPtr<TypeBuilder::Array<TypeBuilder::Runtime::PropertyDescriptor> >* result); |
- void getInternalProperties(ErrorString*, const String& objectId, RefPtr<TypeBuilder::Array<TypeBuilder::Runtime::InternalPropertyDescriptor> >* result); |
- Node* nodeForObjectId(const String& objectId); |
- void releaseObject(const String& objectId); |
- |
- PassRefPtr<TypeBuilder::Array<TypeBuilder::Debugger::CallFrame> > wrapCallFrames(const ScriptValue&, int asyncOrdinal); |
- |
- PassRefPtr<TypeBuilder::Runtime::RemoteObject> wrapObject(const ScriptValue&, const String& groupName, bool generatePreview = false) const; |
- PassRefPtr<TypeBuilder::Runtime::RemoteObject> wrapTable(const ScriptValue& table, const ScriptValue& columns) const; |
+ virtual void getCompletionsOnCallFrame( |
+ ErrorString*, |
+ const StackTrace& callFrames, |
+ const Vector<StackTrace>& asyncCallStacks, |
+ const String& callFrameId, |
+ const String& expression, |
+ RefPtr<TypeBuilder::Array<String> >* result); |
+ virtual void restartFrame(ErrorString*, const StackTrace& callFrames, const String& callFrameId, RefPtr<JSONObject>* result); |
+ virtual void getStepInPositions(ErrorString*, const StackTrace& callFrames, const String& callFrameId, RefPtr<TypeBuilder::Array<TypeBuilder::Debugger::Location> >& positions); |
+ virtual void setVariableValue(ErrorString*, const StackTrace& callFrames, const String* callFrameIdOpt, const String* functionObjectIdOpt, int scopeNumber, const String& variableName, const String& newValueStr); |
+ virtual void getFunctionDetails(ErrorString*, const String& functionId, RefPtr<TypeBuilder::Debugger::FunctionDetails>* result); |
+ virtual void getCompletions(ErrorString*, const String& expression, RefPtr<TypeBuilder::Array<String> >* out_result); |
+ virtual void getProperties(ErrorString*, const String& objectId, bool ownProperties, bool accessorPropertiesOnly, RefPtr<TypeBuilder::Array<TypeBuilder::Runtime::PropertyDescriptor> >* result); |
+ virtual void getInternalProperties(ErrorString*, const String& objectId, RefPtr<TypeBuilder::Array<TypeBuilder::Runtime::InternalPropertyDescriptor> >* result); |
+ virtual void getProperty(ErrorString*, const String& objectId, const RefPtr<JSONArray>& propertyPath, RefPtr<TypeBuilder::Runtime::RemoteObject>* result, TypeBuilder::OptOutput<bool>* wasThrown); |
+ virtual Node* nodeForObjectId(const String& objectId); |
+ virtual void releaseObject(const String& objectId); |
+ |
+ virtual PassRefPtr<TypeBuilder::Array<TypeBuilder::Debugger::CallFrame> > wrapCallFrames(const StackTrace&, int asyncOrdinal); |
+ |
+ virtual PassRefPtr<TypeBuilder::Runtime::RemoteObject> wrapObject(const ScriptValue&, const String& groupName, bool generatePreview = false); |
+ virtual PassRefPtr<TypeBuilder::Runtime::RemoteObject> wrapTable(const ScriptValue& table, const ScriptValue& columns); |
+ |
PassRefPtr<TypeBuilder::Runtime::RemoteObject> wrapNode(Node*, const String& groupName); |
ScriptValue findObjectById(const String& objectId) const; |
- ScriptValue findCallFrameById(ErrorString*, const ScriptValue& topCallFrame, const String& callFrameId); |
+ virtual ActivationFrame findCallFrameById(ErrorString*, const StackTrace& topCallFrame, const String& callFrameId); |
void inspectNode(Node*); |
- void releaseObjectGroup(const String&); |
+ virtual void releaseObjectGroup(const String&); |
private: |
friend class InjectedScriptModule; |
- friend InjectedScript InjectedScriptManager::injectedScriptFor(ScriptState*); |
- InjectedScript(ScriptObject, InspectedStateAccessCheck); |
+ friend InjectedScript& InjectedScriptManager::injectedScriptFor(ScriptState*); |
+ V8InjectedScript(ScriptObject, InspectedStateAccessCheck); |
ScriptValue nodeAsScriptValue(Node*); |
}; |
- |
} // namespace WebCore |
#endif |