summaryrefslogtreecommitdiff
path: root/src/commodity.cc
diff options
context:
space:
mode:
authorkanreki <32443233+kanreki@users.noreply.github.com>2022-04-13 18:17:30 -0700
committerMartin Michlmayr <tbm@cyrius.com>2022-04-14 11:02:45 +0800
commitc2aa2e1ac4b53023ccba295b0c96c324ef40684c (patch)
tree3d2b2a58cdc97a8e2d972e684bf4481259cd3bad /src/commodity.cc
parentc8151dea46cdc2a0af7e26a146402a6ebb98310d (diff)
downloadfork-ledger-c2aa2e1ac4b53023ccba295b0c96c324ef40684c.tar.gz
fork-ledger-c2aa2e1ac4b53023ccba295b0c96c324ef40684c.tar.bz2
fork-ledger-c2aa2e1ac4b53023ccba295b0c96c324ef40684c.zip
Remove some UTF-8 code that was having no effect
Fixes #2061.
Diffstat (limited to 'src/commodity.cc')
-rw-r--r--src/commodity.cc43
1 files changed, 5 insertions, 38 deletions
diff --git a/src/commodity.cc b/src/commodity.cc
index 29c04e59..5ddff5d1 100644
--- a/src/commodity.cc
+++ b/src/commodity.cc
@@ -307,47 +307,14 @@ void commodity_t::parse_symbol(std::istream& in, string& symbol)
throw_(amount_error, _("Quoted commodity symbol lacks closing quote"));
} else {
char * _p = buf;
- while (_p - buf < 255 && in.good() && ! in.eof() && c != '\n') {
- std::size_t bytes = 0;
- std::ptrdiff_t size = _p - buf;
-
- // Check for the start of a UTF-8 multi-byte encoded string
- if (c >= 192 && c <= 223 && size < 254)
- bytes = 2;
- else if (c >= 224 && c <= 239 && size < 253)
- bytes = 3;
- else if (c >= 240 && c <= 247 && size < 252)
- bytes = 4;
- else if (c >= 248 && c <= 251 && size < 251)
- bytes = 5;
- else if (c >= 252 && c <= 253 && size < 250)
- bytes = 6;
- else if (c >= 254) // UTF-8 encoding error
- break;
-
- if (bytes > 0) { // we're looking at a UTF-8 encoding
- for (std::size_t i = 0; i < bytes; i++) {
- c = in.get();
- if (in.bad() || in.eof())
- throw_(amount_error, _("Invalid UTF-8 encoding for commodity name"));
- *_p++ = c;
- }
- }
- else if (invalid_chars[c]) {
- break;
- }
- else {
+ while (_p - buf < 255 && in.good() && ! in.eof() && ! invalid_chars[c]) {
+ c = in.get();
+ if (c == '\\') {
c = in.get();
if (in.eof())
- break;
- if (c == '\\') {
- c = in.get();
- if (in.eof())
- throw_(amount_error, _("Backslash at end of commodity name"));
- }
- *_p++ = c;
+ throw_(amount_error, _("Backslash at end of commodity name"));
}
-
+ *_p++ = c;
c = in.peek();
}
*_p = '\0';