2 * Copyright (C) 2006 Apple Computer, Inc. All rights reserved.
4 * Redistribution and use in source and binary forms, with or without
5 * modification, are permitted provided that the following conditions
7 * 1. Redistributions of source code must retain the above copyright
8 * notice, this list of conditions and the following disclaimer.
9 * 2. Redistributions in binary form must reproduce the above copyright
10 * notice, this list of conditions and the following disclaimer in the
11 * documentation and/or other materials provided with the distribution.
13 * THIS SOFTWARE IS PROVIDED BY APPLE COMPUTER, INC. ``AS IS'' AND ANY
14 * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
15 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
16 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE COMPUTER, INC. OR
17 * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
18 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
19 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
20 * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
21 * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
22 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
23 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
29 #include "PlatformString.h"
31 #include <wtf/Noncopyable.h>
32 #include <wtf/Vector.h>
38 class SQLDatabase : public Noncopyable
40 friend class SQLStatement;
44 bool open(const String& filename);
45 bool isOpen() { return m_db; }
46 String getPath(){ return m_path; }
49 bool executeCommand(const String&);
50 bool returnsAtLeastOneResult(const String&);
52 bool tableExists(const String&);
54 int64_t lastInsertRowID();
56 void setBusyTimeout(int ms);
57 void setBusyHandler(int(*)(void*, int));
59 // TODO - add pragma and sqlite_master accessors here
60 void setFullsync(bool);
62 // The SQLite SYNCHRONOUS pragma can be either FULL, NORMAL, or OFF
63 // FULL - Any writing calls to the DB block until the data is actually on the disk surface
64 // NORMAL - SQLite pauses at some critical moments when writing, but much less than FULL
65 // OFF - Calls return immediately after the data has been passed to disk
66 enum SynchronousPragma {
67 SyncOff = 0, SyncNormal = 1, SyncFull = 2
69 void setSynchronous(SynchronousPragma);
71 int lastError() { return m_db ? sqlite3_errcode(m_db) : SQLITE_ERROR; }
72 const char* lastErrorMsg() { return sqlite3_errmsg(m_db); }
78 }; // class SQLDatabase
80 inline String escapeSQLString(const String& s)
83 es.replace('\'', "''");
87 } // namespace WebCore