blob: f14e8a1c70e96a1befc6f9919d28da3fe90c23fa (
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
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
|
// Copyright (C) 2016 The Qt Company Ltd.
// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR GPL-3.0+ OR GPL-3.0 WITH Qt-GPL-exception-1.0
#include "stringinputstream.h"
#include <ctype.h>
namespace Debugger {
namespace Internal {
StringInputStream::StringInputStream(QString &str) :
m_target(str)
{
}
void StringInputStream::appendSeparator(char c)
{
if (!m_target.isEmpty() && !m_target.endsWith(c))
m_target.append(c);
}
void hexPrefixOn(StringInputStream &bs)
{
bs.setHexPrefix(true);
}
void hexPrefixOff(StringInputStream &bs)
{
bs.setHexPrefix(false);
}
void hex(StringInputStream &bs)
{
bs.setIntegerBase(16);
}
void dec(StringInputStream &bs)
{
bs.setIntegerBase(10);
}
void blankSeparator(StringInputStream &bs)
{
bs.appendSeparator();
}
QByteArray trimFront(QByteArray in)
{
if (in.isEmpty())
return in;
const int size = in.size();
int pos = 0;
for ( ; pos < size && isspace(in.at(pos)); pos++) ;
if (pos)
in.remove(0, pos);
return in;
}
QByteArray trimBack(QByteArray in)
{
if (in.isEmpty())
return in;
const int size = in.size();
int pos = size - 1;
for ( ; pos >= 0 && isspace(in.at(pos)); pos--) ;
if (pos != size - 1)
in.truncate(pos + 1);
return in;
}
// Simplify: replace tabs, find all occurrences
// of 2 blanks, check further up for blanks and remove that bit.
QByteArray simplify(const QByteArray &inIn)
{
if (inIn.isEmpty())
return inIn;
QByteArray in = trimFront(trimBack(inIn));
in.replace('\t', ' ');
in.replace('\n', ' ');
in.replace('\r', ' ');
const QByteArray twoBlanks = " ";
while (true) {
const int pos = in.indexOf(twoBlanks);
if (pos != -1) {
const int size = in.size();
int endPos = pos + twoBlanks.size();
for ( ; endPos < size && in.at(endPos) == ' '; endPos++) ;
in.remove(pos + 1, endPos - pos - 1);
} else {
break;
}
}
return in;
}
} // namespace Internal
} // namespace Debugger
|