/sqlite3cc

To get this branch, use:
bzr branch http://bzr.ed.am/sqlite3cc

« back to all changes in this revision

Viewing changes to include/sqlite3cc/database.h

  • Committer: edam
  • Date: 2010-07-29 09:16:26 UTC
  • Revision ID: edam@waxworlds.org-20100729091626-h8fmg0r74eyfo5ae
- fixed error caused by finialising in-progress queries during rollback that were later finaliased by RAII.

Show diffs side-by-side

added added

removed removed

1
1
/*
2
 
 * database.hpp
 
2
 * database.h
3
3
 *
4
4
 * Copyright (C) 2009 Tim Marston <edam@waxworlds.org>
5
5
 *
6
 
 * This file is part of sqlitepp (hereafter referred to as "this program").
7
 
 * See http://www.waxworlds.org/edam/software/sqlitepp for more information.
 
6
 * This file is part of sqlite3cc (hereafter referred to as "this program").
 
7
 * See http://www.waxworlds.org/edam/software/sqlite3cc for more information.
8
8
 *
9
9
 * This program is free software: you can redistribute it and/or modify
10
10
 * it under the terms of the GNU Lesser General Public License as published
20
20
 * along with this program.  If not, see <http://www.gnu.org/licenses/>.
21
21
 */
22
22
 
23
 
#ifndef DATABASE_HPP_
24
 
#define DATABASE_HPP_
 
23
#ifndef SQLITE3CC_DATABASE_H_
 
24
#define SQLITE3CC_DATABASE_H_
25
25
 
26
26
 
27
27
#include <sqlite3.h>
28
28
#include <boost/utility.hpp>
 
29
#include <string>
29
30
 
30
31
 
31
32
namespace sqlite
32
33
{
33
34
 
34
35
 
35
 
class statement;
36
 
class transaction;
 
36
class basic_statement;
 
37
class basic_transaction;
37
38
 
38
39
 
39
40
class database
49
50
         * @param filename the filename of the database file to open
50
51
         * @throws database_error on error
51
52
         */
52
 
        database(
 
53
        explicit database(
53
54
                const std::string &filename );
54
55
 
55
 
        database();
56
 
        virtual ~database() throw( );
 
56
        explicit database();
 
57
        virtual ~database();
57
58
 
58
59
//______________________________________________________________________________
59
60
//                                                              public interface
78
79
        void close();
79
80
 
80
81
        /**
81
 
         * Execute an SQL statement.
 
82
         * Execute an SQL statement. An exception is thrown on error.
82
83
         * @param sql an SQL statement in UTF-8
83
 
         * @return an sqlite error code
84
84
         * @see sqlite3_exc()
85
85
         */
86
 
        int exec(
 
86
        void exec(
87
87
                const std::string &sql );
88
88
 
89
89
        /**
98
98
 
99
99
//______________________________________________________________________________
100
100
//                                                                implementation
 
101
protected:
 
102
 
 
103
        friend class basic_statement;
 
104
        friend class basic_transaction;
 
105
        friend class command;
 
106
        friend class query;
 
107
        friend class sqlite_error;
 
108
 
 
109
        /** class to provide a scope lock for the database mutex */
 
110
        class database_mutex_guard
 
111
        {
 
112
        public:
 
113
 
 
114
                /** constructor that provides a database */
 
115
                database_mutex_guard(
 
116
                        database &database );
 
117
 
 
118
                ~database_mutex_guard();
 
119
 
 
120
                /** release the mutex early */
 
121
                void leave();
 
122
 
 
123
        private:
 
124
                sqlite3_mutex *_mutex;
 
125
        };
 
126
 
101
127
private:
102
128
 
103
 
        friend class statement;
104
 
        friend class transaction;
105
 
 
106
129
        /** the database handle */
107
130
        sqlite3 *_handle;
108
131
 
109
132
};
110
133
 
111
134
 
112
 
}
113
 
 
114
 
 
115
 
#endif /* DATABASE_HPP_ */
 
135
} // namespace sqlite
 
136
 
 
137
 
 
138
#endif /* SQLITE3CC_DATABASE_H_ */