Fix negative number handling for snbt parsers
This commit is contained in:
parent
18e98ca918
commit
900a5358a8
7 changed files with 32 additions and 7 deletions
|
@ -1,3 +1,4 @@
|
|||
class Constants {
|
||||
static const VERSION = "1.3.010625+1127";
|
||||
static const VERSION = "1.3.012225+0304";
|
||||
static const NBT_REVISION = "1.3.012225+0304";
|
||||
}
|
||||
|
|
|
@ -537,7 +537,8 @@ class StringReader {
|
|||
// Read a number (int or double)
|
||||
String readNumber() {
|
||||
StringBuffer result = StringBuffer();
|
||||
while (canRead && (isDigit(peek()) || peek() == '.' || peek() == '-')) {
|
||||
while (canRead &&
|
||||
(isDigit(peek()) || peek() == '.' || peek() == '-' || peek() == "+")) {
|
||||
result.write(next());
|
||||
}
|
||||
return result.toString();
|
||||
|
|
|
@ -73,6 +73,10 @@ enum TagType {
|
|||
break;
|
||||
}
|
||||
|
||||
if (val == "-" || val == "+") {
|
||||
reader.next();
|
||||
}
|
||||
|
||||
if (val == '{') {
|
||||
ret = TagType.Compound; // Detected a CompoundTag
|
||||
reader.next(); // Consume '{'
|
||||
|
|
|
@ -1,3 +1,5 @@
|
|||
import 'package:intl/intl.dart';
|
||||
|
||||
import '../Stream.dart';
|
||||
import '../Tag.dart';
|
||||
|
||||
|
@ -41,13 +43,16 @@ class DoubleTag extends Tag {
|
|||
|
||||
@override
|
||||
void prettyPrint(int indent, bool recurse) {
|
||||
NumberFormat nf = NumberFormat("###.##", "en_US");
|
||||
print(
|
||||
"${"".padLeft(indent, '\t')}${Tag.getCanonicalName(getTagType())}: $value");
|
||||
"${"".padLeft(indent, '\t')}${Tag.getCanonicalName(getTagType())}: ${nf.format(value)}");
|
||||
}
|
||||
|
||||
@override
|
||||
void writeStringifiedValue(StringBuilder builder, int indent, bool isList) {
|
||||
builder.append("${isList ? "".padLeft(indent, '\t') : ""}${value}d");
|
||||
NumberFormat nf = NumberFormat("###.##", "en_US");
|
||||
builder.append(
|
||||
"${isList ? "".padLeft(indent, '\t') : ""}${nf.format(value)}d");
|
||||
}
|
||||
|
||||
@override
|
||||
|
|
|
@ -1,3 +1,5 @@
|
|||
import 'package:intl/intl.dart';
|
||||
|
||||
import '../Stream.dart';
|
||||
import '../Tag.dart';
|
||||
|
||||
|
@ -40,13 +42,16 @@ class FloatTag extends Tag {
|
|||
|
||||
@override
|
||||
void prettyPrint(int indent, bool recurse) {
|
||||
NumberFormat nf = NumberFormat("###.##", "en_US");
|
||||
print(
|
||||
"${"".padLeft(indent, '\t')}${Tag.getCanonicalName(getTagType())}: $value");
|
||||
"${"".padLeft(indent, '\t')}${Tag.getCanonicalName(getTagType())}: ${nf.format(value)}");
|
||||
}
|
||||
|
||||
@override
|
||||
void writeStringifiedValue(StringBuilder builder, int indent, bool isList) {
|
||||
builder.append("${isList ? "".padLeft(indent, '\t') : ""}${value}f");
|
||||
NumberFormat nf = NumberFormat("###.##", "en_US");
|
||||
builder.append(
|
||||
"${isList ? "".padLeft(indent, '\t') : ""}${nf.format(value)}f");
|
||||
}
|
||||
|
||||
@override
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue