/sqlite3cc

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

« back to all changes in this revision

Viewing changes to TODO

  • Committer: edam
  • Date: 2012-01-23 14:34:45 UTC
  • Revision ID: edam@waxworlds.org-20120123143445-s2v4v90nycmfm6bv
fixed up tests

Show diffs side-by-side

added added

removed removed

1
 
- add columns() to row that returns a boost::tuple of various types so multple
2
 
        columns can be fetched at once (look in to using BOOST_PP_ITERATE macro)
3
 
 
4
 
- make basic_statement and database keep a shared pointer to the database handle
5
 
        so the classes can be made copyable. The wrappers around the handle
6
 
        (implemented in sqlite::detail) can clean them up after use. This will also
7
 
        make the implementation of rows (to get round the forced non-dependency of
8
 
        rows on querys) a little easier to swallow.
9
 
        - A similar wrapper should be created for statement handles, making
10
 
                basic_statements, querys and commands copyable. Could weak_ptrs to these
11
 
                also be used in the database's list active querys?
12
 
 
13
 
- fix to force the finalisation of queries in progress for transactions causes
14
 
        errors; queries are now finalised twice, the second from basic_statement's
15
 
        dtor, which causes a segfault. We could:
16
 
        - keep a list of force-finalised sqlite3_stmt pointers in the database which
17
 
                we use to check queries against before finalising them to make sure we
18
 
                don't finalise them a second time
19
 
                - an efficient implementation, but not very OO
20
 
        - keep a map of active queries in the database (using the sqlite3_stmt
21
 
                pointer as the key), so that we can obtain the query and tell it to
22
 
                finalise its self
23
 
                - this seems like a messy and complicated implementation
24
 
 
25
 
- turn on extended errcodes in open() and handle them in sqlite_error
26
 
 
27
 
- use sqlite3_db_mutex() to provide extended error information during
28
 
        sqlite_error construction. The genreeal procedure would be to lock the db
29
 
        mutex, perform some sqlite3 command, check the error code, throw an
30
 
        sqlite_error (whilst obtaining extended error info) and then unlock the db
31
 
        mutex. Two options:
32
 
        - a macro would be simple
33
 
        - a templated safe-calling object (passing the comman's arg types as
34
 
                template params) may be overkill
35
 
 
36
 
- expand sqlite_error - perhaps use boost::system_error (see
37
 
        boost/asio/error.hpp for an example of extending system_error)
38
 
 
39
 
- see if we can #include "sqlite.h" in to a namespace.
 
1
 
 
2
IMMEDIATE ISSUES
 
3
 
 
4
 - rename _bind_index and _column_index to _next_*
 
5
 
 
6
 - change the transaction_guard interface so you can dereference it to
 
7
   get to its transaction and the transactions take care of not
 
8
   rolling back or committing when they already have done (as well as
 
9
   resetting in-progress queries).
 
10
 
 
11
 - turn on extended errcodes in open() and handle them in sqlite_error
 
12
 
 
13
 - query::prepare() isn't being called during construction (form
 
14
   basic_statement's constructor)
 
15
 
 
16
 - add columns() to row that returns a boost::tuple of various types
 
17
   so multple columns can be fetched at once (look in to using
 
18
   BOOST_PP_ITERATE macro)
 
19
 
 
20
 - add a rom::column() that can take a column name. This is nexessary
 
21
   when doing a "SELECT *" and you don't know the column indicies. To
 
22
   implement this, the first time it is called, a column-name-to-index
 
23
   lookup would have to be built. This should be done in the query,
 
24
   not the row. This means that the row will have to know it's query
 
25
   (currently is copies its _handle) to be able to call column_index()
 
26
   on it. Is this a problem?
 
27
 
 
28
 - use sqlite3_db_mutex() to provide extended error information during
 
29
   sqlite_error construction. The general procedure would be to lock
 
30
   the db mutex, perform some sqlite3 command, check the error code,
 
31
   throw an sqlite_error (whilst obtaining extended error info) and
 
32
   then unlock the db mutex. Two options:
 
33
        - a macro would be simple
 
34
        - a templated safe-calling object (passing the comman's arg types
 
35
      as template params) may be overkill
 
36
 
 
37
 
 
38
LONGER TERM IDEAS
 
39
 
 
40
 - make basic_statement and database keep a shared pointer to the
 
41
   database handle so the classes can be made copyable. The wrappers
 
42
   around the handle (implemented in sqlite::detail) can clean them up
 
43
   after use. This will also make the implementation of rows (to get
 
44
   round the forced non-dependency of rows on querys) a little easier
 
45
   to swallow.
 
46
    - A similar wrapper should be created for statement handles,
 
47
      making basic_statements, querys and commands copyable. Could
 
48
      weak_ptrs to these also be used in the database's list active
 
49
      querys?
 
50
 
 
51
 - expand sqlite_error - perhaps use boost::system_error (see
 
52
   boost/asio/error.hpp for an example of extending system_error)
 
53
 
 
54
 - see if we can #include "sqlite.h" in to a namespace.
 
55
 
40
56
        Pros:
41
 
                we better encapsulate the library
42
 
                we can reuse "sqlite3" as a namespace
 
57
         - we better encapsulate the library
 
58
         - we can reuse "sqlite3" as a namespace
43
59
        Cons:
44
 
                makes access to real sqlite stuff awkward to sqlite3cc users, but does
45
 
                        this matter? they can't access database._handle anyway!
46
 
                potential incompatibility when linking to libraries that also link
47
 
                        against sqlite
48
 
 
49
 
- query::prepare() isn't being called during construction (form
50
 
        basic_statement's constructor)
 
60
         - makes access to real sqlite stuff awkward to sqlite3cc users,
 
61
       but does this matter? they can't access database._handle
 
62
       anyway!
 
63
     - potential incompatibility when linking to libraries that also
 
64
       link against sqlite