/sqlite3cc

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

« back to all changes in this revision

Viewing changes to src/exception.cc

  • Committer: edam
  • Date: 2010-07-29 20:56:19 UTC
  • Revision ID: edam@waxworlds.org-20100729205619-a9yo4uzu647nvnsj
- renamed database to connection to better identify what it is (would database_connection be better though?)
- moved basic_statement and basic_transaction to sqlite::detail
- made sqlite::threadsafe() return the threading mode int, not a bool
- renamed row::index() to row_number() so it isn't confused with column index
- added typedef for deferred_transaction
- added early rollback method to transaction_guard
- allowed transaction_guard::~transaction_guard() to throw exceptions, since when it needs to, we're really screwed anyway
- bugfix: query::reset() didn't reset the internal row counter
- added query::num_results()
- added docs/design-notes
- reimplemented query::iterator so that increment() (which performs a step() on the query) now caches the returned row to be returned during dereference() (previously it stashed details and returned new row!?)
- bugfix: resetting active queries during rollbacks would hang!

Show diffs side-by-side

added added

removed removed

21
21
 */
22
22
 
23
23
#include <sqlite3cc/exception.h>
 
24
#include <sqlite3cc/connection.h>
24
25
#include <boost/assign/list_of.hpp>
25
26
#include <map>
26
27
#include <string>
27
28
 
28
29
 
29
30
sqlite::sqlite_error::sqlite_error(
30
 
        int error_code )
31
 
        :
32
 
        _error_code( error_code ),
33
 
        _message( get_error_message( error_code ) )
 
31
        connection &connection,
 
32
        int code )
 
33
        :
 
34
        _code( code ),
 
35
        _message( get_message( code ) + ": " + sqlite3_errmsg( connection._handle ) )
 
36
{
 
37
}
 
38
 
 
39
 
 
40
sqlite::sqlite_error::sqlite_error(
 
41
        int code )
 
42
        :
 
43
        _code( code ),
 
44
        _message( get_message( code ) )
34
45
{
35
46
}
36
47
 
37
48
 
38
49
sqlite::sqlite_error::sqlite_error(
39
50
        const std::string &message,
40
 
        int error_code )
 
51
        int code )
41
52
        :
42
 
        _error_code( error_code ),
 
53
        _code( code ),
43
54
        _message( message )
44
55
{
45
56
}
50
61
}
51
62
 
52
63
 
53
 
int sqlite::sqlite_error::get_error_code() const
 
64
int sqlite::sqlite_error::get_code() const
54
65
{
55
 
        return _error_code;
 
66
        return _code;
56
67
}
57
68
 
58
69
 
62
73
}
63
74
 
64
75
 
65
 
const std::string &sqlite::sqlite_error::get_error_message(
66
 
        int error_code )
 
76
const std::string &sqlite::sqlite_error::get_message(
 
77
        int code )
67
78
{
68
79
        static const std::map< int, std::string > messages =
69
80
                boost::assign::map_list_of
98
109
                ( SQLITE_DONE, "sqlite3_step() has finished executing" );
99
110
 
100
111
        std::map< int, std::string >::const_iterator i =
101
 
                messages.find( error_code );
 
112
                messages.find( code );
102
113
        if( i == messages.end() )
103
114
                throw std::range_error( "bad sqlite error code" );
104
115
        return i->second;