72a59eb077773e8aa15eb4b826a3b95d9a576560
[WebKit-https.git] / WebKitTools / Drosera / win / DebuggerDocumentPlatform.cpp
1 /*
2  * Copyright (C) 2007 Apple, Inc.  All rights reserved.
3  *
4  * Redistribution and use in source and binary forms, with or without
5  * modification, are permitted provided that the following conditions
6  * are met:
7  *
8  * 1.  Redistributions of source code must retain the above copyright
9  *     notice, this list of conditions and the following disclaimer. 
10  * 2.  Redistributions in binary form must reproduce the above copyright
11  *     notice, this list of conditions and the following disclaimer in the
12  *     documentation and/or other materials provided with the distribution. 
13  * 3.  Neither the name of Apple Computer, Inc. ("Apple") nor the names of
14  *     its contributors may be used to endorse or promote products derived
15  *     from this software without specific prior written permission. 
16  *
17  * THIS SOFTWARE IS PROVIDED BY APPLE AND ITS CONTRIBUTORS "AS IS" AND ANY
18  * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
19  * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
20  * DISCLAIMED. IN NO EVENT SHALL APPLE OR ITS CONTRIBUTORS BE LIABLE FOR ANY
21  * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
22  * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
23  * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
24  * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
25  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
26  * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27  */
28 #include "config.h"
29 #include "DebuggerDocument.h"
30
31 #include "ServerConnection.h"
32
33 #include <JavaScriptCore/JSRetainPtr.h>
34 #include <JavaScriptCore/JSStringRef.h>
35 #include <JavaScriptCore/JSStringRefBSTR.h>
36 #include <WebKit/IWebScriptCallFrame.h>
37 #include <WebKit/IWebScriptScope.h>
38
39 JSValueRef JSValueRefCreateWithBSTR(JSContextRef context, BSTR string)
40 {
41     JSRetainPtr<JSStringRef> jsString(Adopt, JSStringCreateWithBSTR(string));
42     return JSValueMakeString(context, jsString.get());
43 }
44
45 // DebuggerDocument platform specific implementations
46
47 void DebuggerDocument::platformPause()
48 {
49     m_server->pause();
50 }
51
52 void DebuggerDocument::platformResume()
53 {
54     m_server->resume();
55 }
56
57 void DebuggerDocument::platformStepInto()
58 {
59     m_server->stepInto();
60 }
61
62 JSValueRef DebuggerDocument::platformEvaluateScript(JSContextRef context, JSStringRef script, int callFrame)
63 {
64     HRESULT ret = S_OK;
65
66     COMPtr<IWebScriptCallFrame> cframe = m_server->getCallerFrame(callFrame);
67     if (!cframe)
68         return JSValueMakeUndefined(context);
69
70     // Convert script to BSTR
71     BSTR scriptBSTR = JSStringCopyBSTR(script);
72     BSTR value = 0;
73     ret = cframe->stringByEvaluatingJavaScriptFromString(scriptBSTR, &value);
74     SysFreeString(scriptBSTR);
75     if (FAILED(ret)) {
76         SysFreeString(value);
77         return JSValueMakeUndefined(context);
78     }
79
80     JSValueRef returnValue = JSValueRefCreateWithBSTR(context, value);
81     SysFreeString(value);
82     return returnValue;
83
84 }
85
86 void DebuggerDocument::getPlatformCurrentFunctionStack(JSContextRef context, Vector<JSValueRef>& currentStack)
87 {
88     COMPtr<IWebScriptCallFrame> frame = m_server->currentFrame();
89     while (frame) {
90         COMPtr<IWebScriptCallFrame> caller;
91         BSTR function = 0;
92         if (FAILED(frame->functionName(&function)))
93             return;
94
95         if (FAILED(frame->caller(&caller)))
96             return;
97
98         if (!function) {
99             if (caller)
100                 function = SysAllocString(L"(anonymous function)");
101             else
102                 function = SysAllocString(L"(global scope)");
103         }
104
105         currentStack.append(JSValueRefCreateWithBSTR(context, function));
106         SysFreeString(function);
107
108         frame = caller;
109     }
110 }
111
112 void DebuggerDocument::getPlatformLocalScopeVariableNamesForCallFrame(JSContextRef context, int callFrame, Vector<JSValueRef>& variableNames)
113 {
114     COMPtr<IWebScriptCallFrame> cframe = m_server->getCallerFrame(callFrame);
115     if (!cframe)
116         return;
117
118     VARIANT var;
119     VariantInit(&var);
120
121     COMPtr<IEnumVARIANT> localScopeVariableNames;
122     if (FAILED(cframe->variableNames(&localScopeVariableNames)))
123         return;
124
125     while (localScopeVariableNames->Next(1, &var, 0) == S_OK) {
126         ASSERT(V_VT(&var) == VT_BSTR);
127         BSTR variableName;
128
129         variableName = V_BSTR(&var);
130         variableNames.append(JSValueRefCreateWithBSTR(context, variableName));
131
132         SysFreeString(variableName);
133         VariantClear(&var);
134     }
135 }
136
137 JSValueRef DebuggerDocument::platformValueForScopeVariableNamed(JSContextRef context, JSStringRef key, int callFrame)
138 {
139     COMPtr<IWebScriptCallFrame> cframe = m_server->getCallerFrame(callFrame);
140     if (!cframe)
141         return JSValueMakeUndefined(context);
142
143     BSTR bstrKey = JSStringCopyBSTR(key);
144
145     BSTR variableValue;
146     HRESULT hr = cframe->valueForVariable(bstrKey, &variableValue);
147     SysFreeString(bstrKey);
148     if (FAILED(hr))
149         return JSValueMakeUndefined(context);
150
151     JSValueRef returnValue = JSValueRefCreateWithBSTR(context, variableValue);
152     SysFreeString(variableValue);
153
154     return returnValue;
155 }
156
157
158 void DebuggerDocument::platformLog(JSStringRef msg)
159 {
160     printf("%S\n", JSStringGetCharactersPtr(msg));
161 }