aboutsummaryrefslogtreecommitdiff
path: root/Minecraft.World/HtmlString.cpp
diff options
context:
space:
mode:
authorLoki Rautio <lokirautio@gmail.com>2026-03-04 03:56:03 -0600
committerLoki Rautio <lokirautio@gmail.com>2026-03-04 03:56:03 -0600
commit42aec6dac53dffa6afe072560a7e1d4986112538 (patch)
tree0836426857391df1b6a83f6368a183f83ec9b104 /Minecraft.World/HtmlString.cpp
parentc9d58eeac7c72f0b3038e084667b4d89a6249fce (diff)
parentef9b6fd500dfabd9463267b0dd9e29577eea8a2b (diff)
Merge branch 'main' into pr/win64-world-saves
# Conflicts: # Minecraft.Client/MinecraftServer.cpp # README.md
Diffstat (limited to 'Minecraft.World/HtmlString.cpp')
-rw-r--r--Minecraft.World/HtmlString.cpp57
1 files changed, 57 insertions, 0 deletions
diff --git a/Minecraft.World/HtmlString.cpp b/Minecraft.World/HtmlString.cpp
new file mode 100644
index 00000000..ce25740e
--- /dev/null
+++ b/Minecraft.World/HtmlString.cpp
@@ -0,0 +1,57 @@
+#include "stdafx.h"
+#include "HtmlString.h"
+#include <iomanip>
+
+HtmlString::HtmlString(wstring text, eMinecraftColour hexColor, bool italics, bool indent)
+{
+ this->text = escapeXML(text);
+ this->color = hexColor;
+ this->italics = italics;
+ this->indent = indent;
+}
+
+wstring HtmlString::ToString()
+{
+ std::wstringstream ss;
+
+ if (indent)
+ {
+ ss << L"&nbsp;&nbsp;";
+ }
+
+ if (italics)
+ {
+ ss << "<i>";
+ }
+
+ eMinecraftColour color = this->color == eMinecraftColour_NOT_SET ? eHTMLColor_7 : this->color;
+
+ ss << L"<font color=\"#" << std::setfill(L'0') << std::setw(6) << std::hex << app.GetHTMLColor(color) << L"\">" << text << "</font>";
+
+ if (italics)
+ {
+ ss << "</i>";
+ }
+
+ return ss.str();
+}
+
+wstring HtmlString::Compose(vector<HtmlString> *strings)
+{
+ if (strings == NULL) return L"";
+
+ std::wstringstream ss;
+
+ for(int i = 0; i < strings->size(); i++)
+ {
+ ss << strings->at(i).ToString();
+
+ // Add a break if there's another line
+ if (i + 1 < strings->size())
+ {
+ ss << L"<br>";
+ }
+ }
+
+ return ss.str();
+} \ No newline at end of file