blob: 21257c00f2a4e830c8a15a7bc5082a60f2dcdf43 (
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
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
|
/******************************************************************************
*
*
*
*
* Copyright (C) 1997-2002 by Dimitri van Heesch.
*
* Permission to use, copy, modify, and distribute this software and its
* documentation under the terms of the GNU General Public License is hereby
* granted. No representations are made about the suitability of this software
* for any purpose. It is provided "as is" without express or implied warranty.
* See the GNU General Public License for more details.
*
* Documents produced by Doxygen are derivative works derived from the
* input used in their production; they are not affected by this license.
*
*/
#ifndef _BUFSTR_H
#define _BUFSTR_H
#include "qtbc.h"
/*! String that can deal more efficiently with large large numbers
* of resizing.
*/
class BufStr : public QCString
{
public:
BufStr(int size) : QCString(size), offset(0), spareRoom(10240) {}
void addChar(char c)
{
if (offset>=size())
{
QCString::resize(size()+spareRoom);
}
QCString::data()[offset++]=c;
}
void addArray(const char *a,int len)
{
if (offset+len>=size())
{
QCString::resize(size()+len+spareRoom);
}
memcpy(QCString::data()+offset,a,len);
offset+=len;
}
uint curPos() { return offset; }
void skip(uint s)
{
if (offset+s>=size())
{
QCString::resize(size()+s+spareRoom);
}
offset+=s;
}
void resize( uint newlen )
{
//QCString::resize(newlen);
//if (offset>newlen)
//{
// offset=newlen;
//}
offset=newlen;
if (offset>=size())
{
QCString::resize(size()+spareRoom);
}
}
private:
uint offset;
const int spareRoom; // 10Kb extra room to avoid frequent resizing
};
#endif
|