|
14 | 14 |
|
15 | 15 | #include <QDir>
|
16 | 16 | #include <QFile>
|
17 |
| -#include <QTextStream> |
18 |
| -#include <QStringTokenizer> |
| 17 | +#include <QRegularExpression> |
19 | 18 |
|
20 | 19 | #include <QDebug>
|
21 | 20 |
|
@@ -57,33 +56,37 @@ bool NetrcParser::parse()
|
57 | 56 | return false;
|
58 | 57 | }
|
59 | 58 | QString content = netrc.readAll();
|
| 59 | + if (content.isEmpty()) { |
| 60 | + return false; |
| 61 | + } |
60 | 62 |
|
61 |
| - auto tokenizer = QStringTokenizer{content, u" \n\t"}; |
| 63 | + auto tokens = content.split(QRegularExpression("\\s+")); |
62 | 64 |
|
63 | 65 | LoginPair pair;
|
64 | 66 | QString machine;
|
65 | 67 | bool isDefault = false;
|
66 |
| - for(auto itToken = tokenizer.cbegin(); itToken != tokenizer.cend(); ++itToken) { |
67 |
| - const auto key = *itToken; |
| 68 | + for(int i=0; i<tokens.count(); i++) { |
| 69 | + const auto key = tokens[i]; |
68 | 70 | if (key == defaultKeyword) {
|
69 | 71 | tryAddEntryAndClear(machine, pair, isDefault);
|
70 | 72 | isDefault = true;
|
71 | 73 | continue; // don't read a value
|
72 | 74 | }
|
73 | 75 |
|
74 |
| - if (itToken != tokenizer.cend()) { |
| 76 | + i++; |
| 77 | + if (i >= tokens.count()) { |
75 | 78 | qDebug() << "error fetching value for" << key;
|
76 |
| - return false; |
| 79 | + break; |
77 | 80 | }
|
78 |
| - auto value = *(++itToken); |
| 81 | + auto value = tokens[i]; |
79 | 82 |
|
80 | 83 | if (key == machineKeyword) {
|
81 | 84 | tryAddEntryAndClear(machine, pair, isDefault);
|
82 |
| - machine = value.toString(); |
| 85 | + machine = value; |
83 | 86 | } else if (key == loginKeyword) {
|
84 |
| - pair.first = value.toString(); |
| 87 | + pair.first = value; |
85 | 88 | } else if (key == passwordKeyword) {
|
86 |
| - pair.second = value.toString(); |
| 89 | + pair.second = value; |
87 | 90 | } // ignore unsupported tokens
|
88 | 91 | }
|
89 | 92 | tryAddEntryAndClear(machine, pair, isDefault);
|
|
0 commit comments