summaryrefslogtreecommitdiff
path: root/src/text
diff options
context:
space:
mode:
authorMehmet Samet Duman <yongdohyun@projecttick.org>2026-04-02 17:35:01 +0300
committerMehmet Samet Duman <yongdohyun@projecttick.org>2026-04-02 17:35:01 +0300
commit1a0ffe372f4da8408c5d08a36013536a3396b9e6 (patch)
tree440f2a9a325c9ab4cb5b16dc6a8193317cabf8d7 /src/text
parentf4d8ea0fa76174843adf7f77ebad0ad17d2377ed (diff)
downloadProject-Tick-1a0ffe372f4da8408c5d08a36013536a3396b9e6.tar.gz
Project-Tick-1a0ffe372f4da8408c5d08a36013536a3396b9e6.zip
NOISSUE reformat libnbtplusplus to new MeshMC clang format rules
Signed-off-by: Mehmet Samet Duman <yongdohyun@projecttick.org>
Diffstat (limited to 'src/text')
-rw-r--r--src/text/json_formatter.cpp426
1 files changed, 222 insertions, 204 deletions
diff --git a/src/text/json_formatter.cpp b/src/text/json_formatter.cpp
index 88f3a7c58e..46d726a3c9 100644
--- a/src/text/json_formatter.cpp
+++ b/src/text/json_formatter.cpp
@@ -30,209 +30,227 @@
namespace nbt
{
-namespace text
-{
+ namespace text
+ {
-namespace //anonymous
-{
- ///Helper class which uses the Visitor pattern to pretty-print tags
- class json_fmt_visitor : public const_nbt_visitor
- {
- public:
- json_fmt_visitor(std::ostream& os):
- os(os)
- {}
-
- void visit(const tag_byte& b) override
- { os << static_cast<int>(b.get()) << "b"; } //We don't want to print a character
-
- void visit(const tag_short& s) override
- { os << s.get() << "s"; }
-
- void visit(const tag_int& i) override
- { os << i.get(); }
-
- void visit(const tag_long& l) override
- { os << l.get() << "l"; }
-
- void visit(const tag_float& f) override
- {
- write_float(f.get());
- os << "f";
- }
-
- void visit(const tag_double& d) override
- {
- write_float(d.get());
- os << "d";
- }
-
- void visit(const tag_byte_array& ba) override
- { os << "[" << ba.size() << " bytes]"; }
-
- void visit(const tag_string& s) override
- {
- os << '"';
- write_escaped_string(s.get());
- os << '"';
- }
-
- void visit(const tag_list& l) override
- {
- //Wrap lines for lists of lists or compounds.
- //Lists of other types can usually be on one line without problem.
- const bool break_lines = l.size() > 0 &&
- (l.el_type() == tag_type::List || l.el_type() == tag_type::Compound);
-
- os << "[";
- if(break_lines)
- {
- os << "\n";
- ++indent_lvl;
- for(unsigned int i = 0; i < l.size(); ++i)
- {
- indent();
- if(l[i])
- l[i].get().accept(*this);
- else
- write_null();
- if(i != l.size()-1)
- os << ",";
- os << "\n";
- }
- --indent_lvl;
- indent();
- }
- else
- {
- for(unsigned int i = 0; i < l.size(); ++i)
- {
- if(l[i])
- l[i].get().accept(*this);
- else
- write_null();
- if(i != l.size()-1)
- os << ", ";
- }
- }
- os << "]";
- }
-
- void visit(const tag_compound& c) override
- {
- if(c.size() == 0) //No line breaks inside empty compounds please
- {
- os << "{}";
- return;
- }
-
- os << "{\n";
- ++indent_lvl;
- unsigned int i = 0;
- for(const auto& kv: c)
- {
- indent();
- os << kv.first << ": ";
- if(kv.second)
- kv.second.get().accept(*this);
- else
- write_null();
- if(i != c.size()-1)
- os << ",";
- os << "\n";
- ++i;
- }
- --indent_lvl;
- indent();
- os << "}";
- }
-
- void visit(const tag_int_array& ia) override
- {
- os << "[";
- for(unsigned int i = 0; i < ia.size(); ++i)
- {
- os << ia[i];
- if(i != ia.size()-1)
- os << ", ";
- }
- os << "]";
- }
-
- void visit(const tag_long_array& la) override
- {
- os << "[";
- for(unsigned int i = 0; i < la.size(); ++i)
- {
- os << la[i];
- if(i != la.size()-1)
- os << ", ";
- }
- os << "]";
- }
-
- private:
- const std::string indent_str = " ";
-
- std::ostream& os;
- int indent_lvl = 0;
-
- void indent()
- {
- for(int i = 0; i < indent_lvl; ++i)
- os << indent_str;
- }
-
- template<class T>
- void write_float(T val, int precision = std::numeric_limits<T>::max_digits10)
- {
- if(std::isfinite(val))
- os << std::setprecision(precision) << val;
- else if(std::isinf(val))
- {
- if(std::signbit(val))
- os << "-";
- os << "Infinity";
- }
- else
- os << "NaN";
- }
-
- void write_null()
- {
- os << "null";
- }
-
- void write_escaped_string(const std::string& str)
- {
- for (char c : str) {
- switch (c) {
- case '"': os << "\\\""; break;
- case '\\': os << "\\\\"; break;
- case '\b': os << "\\b"; break;
- case '\f': os << "\\f"; break;
- case '\n': os << "\\n"; break;
- case '\r': os << "\\r"; break;
- case '\t': os << "\\t"; break;
- default:
- if (c < 32 || c == 127) {
- // Control characters, escape as \u00XX
- os << "\\u00" << std::hex << std::setw(2) << std::setfill('0') << static_cast<int>(c);
- } else {
- os << c;
- }
- break;
- }
- }
- }
- };
-}
-
-void json_formatter::print(std::ostream& os, const tag& t) const
-{
- json_fmt_visitor v(os);
- t.accept(v);
-}
+ namespace // anonymous
+ {
+ /// Helper class which uses the Visitor pattern to pretty-print tags
+ class json_fmt_visitor : public const_nbt_visitor
+ {
+ public:
+ json_fmt_visitor(std::ostream& os) : os(os) {}
+
+ void visit(const tag_byte& b) override
+ {
+ os << static_cast<int>(b.get()) << "b";
+ } // We don't want to print a character
+
+ void visit(const tag_short& s) override
+ {
+ os << s.get() << "s";
+ }
+
+ void visit(const tag_int& i) override
+ {
+ os << i.get();
+ }
+
+ void visit(const tag_long& l) override
+ {
+ os << l.get() << "l";
+ }
+
+ void visit(const tag_float& f) override
+ {
+ write_float(f.get());
+ os << "f";
+ }
+
+ void visit(const tag_double& d) override
+ {
+ write_float(d.get());
+ os << "d";
+ }
+
+ void visit(const tag_byte_array& ba) override
+ {
+ os << "[" << ba.size() << " bytes]";
+ }
+
+ void visit(const tag_string& s) override
+ {
+ os << '"';
+ write_escaped_string(s.get());
+ os << '"';
+ }
+
+ void visit(const tag_list& l) override
+ {
+ // Wrap lines for lists of lists or compounds.
+ // Lists of other types can usually be on one line without
+ // problem.
+ const bool break_lines =
+ l.size() > 0 && (l.el_type() == tag_type::List ||
+ l.el_type() == tag_type::Compound);
+
+ os << "[";
+ if (break_lines) {
+ os << "\n";
+ ++indent_lvl;
+ for (unsigned int i = 0; i < l.size(); ++i) {
+ indent();
+ if (l[i])
+ l[i].get().accept(*this);
+ else
+ write_null();
+ if (i != l.size() - 1)
+ os << ",";
+ os << "\n";
+ }
+ --indent_lvl;
+ indent();
+ } else {
+ for (unsigned int i = 0; i < l.size(); ++i) {
+ if (l[i])
+ l[i].get().accept(*this);
+ else
+ write_null();
+ if (i != l.size() - 1)
+ os << ", ";
+ }
+ }
+ os << "]";
+ }
+
+ void visit(const tag_compound& c) override
+ {
+ if (c.size() ==
+ 0) // No line breaks inside empty compounds please
+ {
+ os << "{}";
+ return;
+ }
+
+ os << "{\n";
+ ++indent_lvl;
+ unsigned int i = 0;
+ for (const auto& kv : c) {
+ indent();
+ os << kv.first << ": ";
+ if (kv.second)
+ kv.second.get().accept(*this);
+ else
+ write_null();
+ if (i != c.size() - 1)
+ os << ",";
+ os << "\n";
+ ++i;
+ }
+ --indent_lvl;
+ indent();
+ os << "}";
+ }
+
+ void visit(const tag_int_array& ia) override
+ {
+ os << "[";
+ for (unsigned int i = 0; i < ia.size(); ++i) {
+ os << ia[i];
+ if (i != ia.size() - 1)
+ os << ", ";
+ }
+ os << "]";
+ }
+
+ void visit(const tag_long_array& la) override
+ {
+ os << "[";
+ for (unsigned int i = 0; i < la.size(); ++i) {
+ os << la[i];
+ if (i != la.size() - 1)
+ os << ", ";
+ }
+ os << "]";
+ }
+
+ private:
+ const std::string indent_str = " ";
+
+ std::ostream& os;
+ int indent_lvl = 0;
+
+ void indent()
+ {
+ for (int i = 0; i < indent_lvl; ++i)
+ os << indent_str;
+ }
+
+ template <class T>
+ void write_float(
+ T val, int precision = std::numeric_limits<T>::max_digits10)
+ {
+ if (std::isfinite(val))
+ os << std::setprecision(precision) << val;
+ else if (std::isinf(val)) {
+ if (std::signbit(val))
+ os << "-";
+ os << "Infinity";
+ } else
+ os << "NaN";
+ }
+
+ void write_null()
+ {
+ os << "null";
+ }
+
+ void write_escaped_string(const std::string& str)
+ {
+ for (char c : str) {
+ switch (c) {
+ case '"':
+ os << "\\\"";
+ break;
+ case '\\':
+ os << "\\\\";
+ break;
+ case '\b':
+ os << "\\b";
+ break;
+ case '\f':
+ os << "\\f";
+ break;
+ case '\n':
+ os << "\\n";
+ break;
+ case '\r':
+ os << "\\r";
+ break;
+ case '\t':
+ os << "\\t";
+ break;
+ default:
+ if (c < 32 || c == 127) {
+ // Control characters, escape as \u00XX
+ os << "\\u00" << std::hex << std::setw(2)
+ << std::setfill('0')
+ << static_cast<int>(c);
+ } else {
+ os << c;
+ }
+ break;
+ }
+ }
+ }
+ };
+ } // namespace
+
+ void json_formatter::print(std::ostream& os, const tag& t) const
+ {
+ json_fmt_visitor v(os);
+ t.accept(v);
+ }
-}
-}
+ } // namespace text
+} // namespace nbt