00001 /* 00002 This file is part of the Opie Project 00003 Copyright (C) Stefan Eilers (Eilers.Stefan@epost.de) 00004 =. Copyright (C) The Opie Team <opie-devel@handhelds.org> 00005 .=l. 00006 .>+-= 00007 _;:, .> :=|. This program is free software; you can 00008 .> <`_, > . <= redistribute it and/or modify it under 00009 :`=1 )Y*s>-.-- : the terms of the GNU Library General Public 00010 .="- .-=="i, .._ License as published by the Free Software 00011 - . .-<_> .<> Foundation; either version 2 of the License, 00012 ._= =} : or (at your option) any later version. 00013 .%`+i> _;_. 00014 .i_,=:_. -<s. This program is distributed in the hope that 00015 + . -:. = it will be useful, but WITHOUT ANY WARRANTY; 00016 : .. .:, . . . without even the implied warranty of 00017 =_ + =;=|` MERCHANTABILITY or FITNESS FOR A 00018 _.=:. : :=>`: PARTICULAR PURPOSE. See the GNU 00019 ..}^=.= = ; Library General Public License for more 00020 ++= -. .` .: details. 00021 : = ...= . :.=- 00022 -. .:....=;==+<; You should have received a copy of the GNU 00023 -_. . . )=. = Library General Public License along with 00024 -- :-=` this library; see the file COPYING.LIB. 00025 If not, write to the Free Software Foundation, 00026 Inc., 59 Temple Place - Suite 330, 00027 Boston, MA 02111-1307, USA. 00028 */ 00029 #ifndef OPIE_PIM_ACCESS_SQL_H 00030 #define OPIE_PIM_ACCESS_SQL_H 00031 00032 /* #include <qasciidict.h> */ 00033 00034 #include <opie2/otodoaccessbackend.h> 00035 00036 namespace Opie { 00037 namespace DB { 00038 class OSQLDriver; 00039 class OSQLResult; 00040 class OSQLResultItem; 00041 } 00042 } 00043 00044 namespace Opie { 00045 00046 class OPimTodoAccessBackendSQL : public OPimTodoAccessBackend { 00047 public: 00048 OPimTodoAccessBackendSQL( const QString& file ); 00049 ~OPimTodoAccessBackendSQL(); 00050 00051 bool load(); 00052 bool reload(); 00053 bool save(); 00054 QArray<UID> allRecords()const; 00055 00056 /* QArray<UID> queryByExample( const UIDArray& uidlist, const OPimTodo& t, int settings, const QDateTime& d = QDateTime() ); */ 00057 OPimTodo find(UID uid)const; 00058 OPimTodo find(UID uid, const QArray<int>&, uint cur, Frontend::CacheDirection )const; 00059 void clear(); 00060 bool add( const OPimTodo& t ); 00061 bool remove( UID uid ); 00062 bool replace( const OPimTodo& t ); 00063 00064 QArray<UID> overDue()const; 00065 QArray<UID> effectiveToDos( const QDate& start, 00066 const QDate& end, bool includeNoDates )const; 00067 QArray<UID> matchRegexp( const QRegExp &r ) const; 00068 void removeAllCompleted(); 00069 00070 00071 private: 00072 void update()const; 00073 inline bool date( QDate& date, const QString& )const; 00074 inline OPimTodo parseResultAndCache( UID uid, const Opie::DB::OSQLResult& )const; 00075 inline OPimTodo parse( Opie::DB::OSQLResultItem& )const; 00076 inline QArray<UID> uids( const Opie::DB::OSQLResult& )const; 00077 OPimTodo todo( UID uid )const; 00078 QMap<QString, QString> requestCustom( UID uid ) const; 00079 00080 // QAsciiDict<int> m_dict; 00081 Opie::DB::OSQLDriver* m_driver; 00082 QArray<UID> m_uids; 00083 bool m_dirty : 1; 00084 }; 00085 00086 } 00087 00088 #endif
1.4.2