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