ultimatepp/uppsrc/plugin/sqlite3/Sqlite3.h
cxl a5f7622ac4 Sqlite3: fixed problems with date
theide: sql hightlighting adjustment (keywords reduced)

git-svn-id: svn://ultimatepp.org/upp/trunk@1293 f0d560ea-af0d-0410-9eb7-867de7ffcac7
2009-06-10 12:50:17 +00:00

63 lines
1.4 KiB
C++

#ifndef __Plugin_Sqlite3__
#define __Plugin_Sqlite3__
#include <Sql/Sql.h>
NAMESPACE_UPP
bool Sqlite3PerformScript(const String& text,
#ifdef NOAPPSQL
StatementExecutor& se,
#else
StatementExecutor& se = SQLStatementExecutor(),
#endif
Gate2<int, int> progress_canceled = false
);
class Sqlite3Connection;
class Sqlite3Session : public SqlSession {
public:
virtual bool IsOpen() const { return NULL != db; }
virtual RunScript GetRunScript() const { return &Sqlite3PerformScript; }
virtual Vector<String> EnumUsers() { NEVER(); return Vector<String>(); } // No users in sqlite!
virtual Vector<String> EnumDatabases();
virtual Vector<String> EnumTables(String database);
virtual Vector<String> EnumViews(String database);
virtual Vector<SqlColumnInfo> EnumColumns(String database, String table);
// Some opaque structures used by the sqlite3 library
typedef struct sqlite3 sqlite3;
typedef struct sqlite3_stmt sqlite3_stmt;
protected:
virtual SqlConnection *CreateConnection();
private:
friend class Sqlite3Connection;
sqlite3 *db;
String current_filename;
String current_dbname;
Link<Sqlite3Connection> clink;
void Reset();
void Cancel();
public:
bool Open(const char *filename);
void Close();
operator sqlite3 *() { return db; }
virtual void Begin();
virtual void Commit();
virtual void Rollback();
Sqlite3Session();
~Sqlite3Session();
};
END_UPP_NAMESPACE
#endif