/sqlite3cc

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

« back to all changes in this revision

Viewing changes to src/row.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

Lines of Context:
27
27
 
28
28
sqlite::row::row(
29
29
        sqlite3_stmt *handle,
30
 
        unsigned long long index )
 
30
        unsigned long long row_number )
31
31
        :
32
32
        _handle( handle ),
33
33
        _column_index( 0 ),
34
 
        _index( index )
 
34
        _row_number( row_number )
35
35
{
36
36
}
37
37
 
38
38
 
39
39
sqlite::row::row()
40
40
        :
41
 
        _index( std::numeric_limits< unsigned long long >::max() )
42
 
{
 
41
        _handle( NULL )
 
42
{
 
43
}
 
44
 
 
45
 
 
46
sqlite::row::operator bool()
 
47
        const
 
48
{
 
49
        return _handle? true : false;
43
50
}
44
51
 
45
52
 
60
67
 
61
68
 
62
69
sqlite::row &sqlite::row::operator >>(
63
 
        _set_index_t t )
 
70
        sqlite::detail::set_index_t t )
64
71
{
65
72
        _column_index = t._index;
66
73
        return *this;
67
74
}
68
75
 
69
76
 
 
77
bool sqlite::row::operator ==(
 
78
        const sqlite::row &other )
 
79
        const
 
80
{
 
81
        return !_handle? !other._handle :
 
82
                _handle == other._handle && _row_number == other._row_number;
 
83
}
 
84
 
 
85
 
70
86
template< >
71
 
sqlite::row &sqlite::row::operator >> < sqlite::_null_t >(
72
 
        _null_t & )
 
87
sqlite::row &sqlite::row::operator >> < sqlite::detail::null_t >(
 
88
        sqlite::detail::null_t & )
73
89
{
74
90
        assert( _column_index <
75
91
                static_cast< unsigned int >( sqlite3_column_count( _handle ) ) );