DebuggerCallFrame.cpp 3.55 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31
/*
 * Copyright (C) 2008 Apple Inc. All rights reserved.
 *
 * Redistribution and use in source and binary forms, with or without
 * modification, are permitted provided that the following conditions
 * are met:
 *
 * 1.  Redistributions of source code must retain the above copyright
 *     notice, this list of conditions and the following disclaimer.
 * 2.  Redistributions in binary form must reproduce the above copyright
 *     notice, this list of conditions and the following disclaimer in the
 *     documentation and/or other materials provided with the distribution.
 * 3.  Neither the name of Apple Computer, Inc. ("Apple") nor the names of
 *     its contributors may be used to endorse or promote products derived
 *     from this software without specific prior written permission.
 *
 * THIS SOFTWARE IS PROVIDED BY APPLE AND ITS CONTRIBUTORS "AS IS" AND ANY
 * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
 * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
 * DISCLAIMED. IN NO EVENT SHALL APPLE OR ITS CONTRIBUTORS BE LIABLE FOR ANY
 * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
 * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
 * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 */

#include "config.h"
#include "DebuggerCallFrame.h"

darin@apple.com's avatar
darin@apple.com committed
32
#include "JSFunction.h"
33
#include "CodeBlock.h"
ggaren@apple.com's avatar
ggaren@apple.com committed
34
#include "Interpreter.h"
35 36
#include "Parser.h"

37
namespace JSC {
38 39 40

const UString* DebuggerCallFrame::functionName() const
{
darin@apple.com's avatar
darin@apple.com committed
41
    if (!m_callFrame->codeBlock())
42 43
        return 0;

44 45 46
    if (!m_callFrame->callee())
        return 0;

47
    JSObject* function = m_callFrame->callee();
48
    if (!function || !function->inherits(&JSFunction::s_info))
49
        return 0;
50
    return &asFunction(function)->name(m_callFrame);
51
}
52 53 54 55
    
UString DebuggerCallFrame::calculatedFunctionName() const
{
    if (!m_callFrame->codeBlock())
56
        return UString();
57

58
    JSObject* function = m_callFrame->callee();
59
    if (!function || !function->inherits(&JSFunction::s_info))
60
        return UString();
61

62
    return asFunction(function)->calculatedDisplayName(m_callFrame);
63
}
64

65 66
DebuggerCallFrame::Type DebuggerCallFrame::type() const
{
darin@apple.com's avatar
darin@apple.com committed
67
    if (m_callFrame->callee())
68 69 70 71 72
        return FunctionType;

    return ProgramType;
}

73 74
JSObject* DebuggerCallFrame::thisObject() const
{
75 76 77 78
    CodeBlock* codeBlock = m_callFrame->codeBlock();
    if (!codeBlock)
        return 0;

79
    JSValue thisValue = m_callFrame->uncheckedR(codeBlock->thisRegister()).jsValue();
80
    if (!thisValue.isObject())
81 82
        return 0;

83
    return asObject(thisValue);
84 85
}

ggaren@apple.com's avatar
ggaren@apple.com committed
86
JSValue DebuggerCallFrame::evaluate(const UString& script, JSValue& exception) const
87
{
darin@apple.com's avatar
darin@apple.com committed
88
    if (!m_callFrame->codeBlock())
ggaren@apple.com's avatar
ggaren@apple.com committed
89
        return JSValue();
90

91
    RefPtr<EvalExecutable> eval = EvalExecutable::create(m_callFrame, makeSource(script), m_callFrame->codeBlock()->isStrictMode());
oliver@apple.com's avatar
oliver@apple.com committed
92
    JSObject* error = eval->compile(m_callFrame, m_callFrame->scopeChain());
93 94
    if (error)
        return error;
95

96 97 98
    JSGlobalData& globalData = m_callFrame->globalData();
    JSValue result = globalData.interpreter->execute(eval.get(), m_callFrame, thisObject(), m_callFrame->scopeChain());
    if (globalData.exception) {
99
        exception = globalData.exception.get();
100 101 102 103
        globalData.exception = JSValue();
    }
    ASSERT(result);
    return result;
104 105
}

106
} // namespace JSC