summaryrefslogtreecommitdiffstats
path: root/src/core/Text.h
diff options
context:
space:
mode:
Diffstat (limited to 'src/core/Text.h')
-rw-r--r--src/core/Text.h52
1 files changed, 52 insertions, 0 deletions
diff --git a/src/core/Text.h b/src/core/Text.h
new file mode 100644
index 00000000..2592e6b8
--- /dev/null
+++ b/src/core/Text.h
@@ -0,0 +1,52 @@
+#pragma once
+
+void AsciiToUnicode(const char *src, wchar *dst);
+void TextCopy(wchar *dst, const wchar *src);
+
+struct CKeyEntry
+{
+ wchar *value;
+ char key[8];
+};
+// If this fails, CKeyArray::Load will have to be fixed
+static_assert(sizeof(CKeyEntry) == 12, "CKeyEntry: error");
+
+class CKeyArray
+{
+public:
+ CKeyEntry *entries;
+ int numEntries;
+
+ void Load(uint32 length, uint8 *data, int *offset);
+ void Unload(void);
+ void Update(wchar *chars);
+ CKeyEntry *BinarySearch(const char *key, CKeyEntry *entries, int16 low, int16 high);
+ wchar *Search(const char *key);
+};
+
+class CData
+{
+public:
+ wchar *chars;
+ int numChars;
+
+ void Load(uint32 length, uint8 *data, int *offset);
+ void Unload(void);
+};
+
+class CText
+{
+ CKeyArray keyArray;
+ CData data;
+ int8 encoding;
+public:
+ CText(void);
+ ~CText(void);
+ void Load(void);
+ void Unload(void);
+ wchar *Get(const char *key);
+ wchar GetUpperCase(wchar c);
+ void UpperCase(wchar *s);
+};
+
+extern CText &TheText;