/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/manipulator.h

  • 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

28
28
{
29
29
 
30
30
 
31
 
struct _null_t { };
32
 
struct _exec_t { };
33
 
struct _set_index_t { unsigned int _index; };
 
31
namespace detail
 
32
{
 
33
        // types to represent special manipulators for use with stream operators
 
34
        struct null_t { };
 
35
        struct exec_t { };
 
36
        struct set_index_t { unsigned int _index; };
 
37
}
34
38
 
35
39
 
36
40
/**
38
42
 * specifies a NULL value to bind to a parameter. When used with a row's stream
39
43
 * operator, no value is fetched for a column.
40
44
 */
41
 
extern _null_t null;
 
45
extern detail::null_t null;
42
46
 
43
47
/**
44
48
 * Stream manipulator. When used with a statment's stream operator, this
48
52
 * operator, behaviour is the same except that it will not throw when the
49
53
 * execution returns results.
50
54
 */
51
 
extern _exec_t exec;
 
55
extern detail::exec_t exec;
52
56
 
53
57
/**
54
58
 * Stream manipulator. When used with a statment's or a row's stream operator,
56
60
 * column values.
57
61
 * @param index the new index
58
62
 */
59
 
_set_index_t set_index(
 
63
detail::set_index_t set_index(
60
64
        unsigned int index );
61
65
 
62
66