summaryrefslogtreecommitdiff
path: root/noncore/apps/tableviewer/db/csvsource.h
blob: 691234cb97718401e7196ae519e0a4c4752c8d3e (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
/**********************************************************************
** Copyright (C) 2000 Trolltech AS.  All rights reserved.
**
** This file is part of Qtopia Environment.
**
** This file may be distributed and/or modified under the terms of the
** GNU General Public License version 2 as published by the Free Software
** Foundation and appearing in the file LICENSE.GPL included in the
** packaging of this file.
**
** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
**
** See http://www.trolltech.com/gpl/ for GPL licensing information.
**
** Contact info@trolltech.com if any conditions of this licensing are
** not clear to you.
**
**********************************************************************/

/* A Class to parse an comma seperated values docment of the form

"Displayed Name", key2name, key 3 name, key name 4
value1, , value 3, "value 4"
value1, , value 3, "value 4"

 * '\' is the escape character.  Basically \", \' and \\ escape the ", ' or \ 
 * into the actual value of the field. 
 * Before any other character will have the effect of dropping the '\'.
 *
 * Currently there is no support for comments. */

#ifndef __CSVSOURCE_H__
#define __CSVSOURCE_H__

#include <qstring.h>
#include "datacache.h"
#include "common.h"


class DBCsv : public DBAccess
{
public:
    /* create connection and either open or initialize */
    DBCsv(DBStore *d);
    QString type();
    bool openSource(QIODevice *);
    bool saveSource(QIODevice *);
    /* does a db write */
    ~DBCsv();
};

#endif