1/*
2 * Copyright (C) 2007, 2013 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 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 "SQLStatement.h"
30
31#if ENABLE(SQL_DATABASE)
32
33#include "AbstractDatabaseServer.h"
34#include "AbstractSQLStatementBackend.h"
35#include "Database.h"
36#include "DatabaseManager.h"
37#include "Logging.h"
38#include "SQLStatementCallback.h"
39#include "SQLStatementErrorCallback.h"
40#include "SQLTransaction.h"
41#include "SQLValue.h"
42#include "SQLiteDatabase.h"
43#include "SQLiteStatement.h"
44#include <wtf/text/CString.h>
45
46namespace WebCore {
47
48SQLStatement::SQLStatement(Database* database, PassRefPtr<SQLStatementCallback> callback,
49    PassRefPtr<SQLStatementErrorCallback> errorCallback)
50    : m_statementCallbackWrapper(callback, database->scriptExecutionContext())
51    , m_statementErrorCallbackWrapper(errorCallback, database->scriptExecutionContext())
52{
53}
54
55void SQLStatement::setBackend(AbstractSQLStatementBackend* backend)
56{
57    m_backend = backend;
58}
59
60bool SQLStatement::hasCallback()
61{
62    return m_statementCallbackWrapper.hasCallback();
63}
64
65bool SQLStatement::hasErrorCallback()
66{
67    return m_statementErrorCallbackWrapper.hasCallback();
68}
69
70bool SQLStatement::performCallback(SQLTransaction* transaction)
71{
72    ASSERT(transaction);
73    ASSERT(m_backend);
74
75    bool callbackError = false;
76
77    RefPtr<SQLStatementCallback> callback = m_statementCallbackWrapper.unwrap();
78    RefPtr<SQLStatementErrorCallback> errorCallback = m_statementErrorCallbackWrapper.unwrap();
79    RefPtr<SQLError> error = m_backend->sqlError();
80
81    // Call the appropriate statement callback and track if it resulted in an error,
82    // because then we need to jump to the transaction error callback.
83    if (error) {
84        if (errorCallback)
85            callbackError = errorCallback->handleEvent(transaction, error.get());
86    } else if (callback) {
87        RefPtr<SQLResultSet> resultSet = m_backend->sqlResultSet();
88        callbackError = !callback->handleEvent(transaction, resultSet.get());
89    }
90
91    return callbackError;
92}
93
94} // namespace WebCore
95
96#endif // ENABLE(SQL_DATABASE)
97