summaryrefslogtreecommitdiffstats
path: root/vcs/cvsservice/bufferedstringreader.h
blob: 1f96c0d1ac9f1f52e87a1cba139cb0e2ff20a158 (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
/***************************************************************************
 *   Copyright (C) 2003 by Mario Scalas                                    *
 *   mario.scalas@libero.it                                                *
 *                                                                         *
 *   This program is free software; you can redistribute it and/or modify  *
 *   it under the terms of the GNU General Public License as published by  *
 *   the Free Software Foundation; either version 2 of the License, or     *
 *   (at your option) any later version.                                   *
 *                                                                         *
 ***************************************************************************/

#ifndef BUFFEREDSTRINGREADER_H
#define BUFFEREDSTRINGREADER_H

#include <qstringlist.h>

class CvsServicePart;
class KConfig;
class KDevProject;

/* This class helps when we have to collect a string list from a text
 * stream, just as many cvs commands do. The problem is that the these commands
 * does not provide strings as we need: often a sent string is received
 * broken in two pieces and so we need a way to rebuild it. This class provide an
 * abstraction for avoiding this.
 * @author Mario Scalas <mario.scalas@libero.it>
*/
class BufferedStringReader
{
public:
    BufferedStringReader();
    virtual ~BufferedStringReader();

    /**
    * Add the specified characters to current buffered ones and grab
    * as many '\n'-terminated strings as found.
    * @param otherChars additional chars to be added to the buffer
    */
    QStringList process( const QString &otherChars );
private:
    QString m_stringBuffer;
};

#endif  // BUFFEREDSTRINGREADER_H