summaryrefslogtreecommitdiffhomepage
path: root/dev/LibCompiler/NFC/StringView.h
diff options
context:
space:
mode:
authorAmlal El Mahrouss <amlal@nekernel.org>2025-03-25 20:34:13 +0100
committerAmlal El Mahrouss <amlal@nekernel.org>2025-03-25 20:34:13 +0100
commit337d36ee5f1f8376f3dcc863270bbe92fd7f8ca7 (patch)
tree78638ce3ca247f185d94cb4f7612c49d49265af5 /dev/LibCompiler/NFC/StringView.h
parenta54afb132d4c1e71fc57425a25c68e9ca6053c9b (diff)
fix(linker): A critical fix regarding the output being repetadely
written on the file. refactor(NFC): Rename String.h to StringView.h Signed-off-by: Amlal El Mahrouss <amlal@nekernel.org>
Diffstat (limited to 'dev/LibCompiler/NFC/StringView.h')
-rw-r--r--dev/LibCompiler/NFC/StringView.h90
1 files changed, 90 insertions, 0 deletions
diff --git a/dev/LibCompiler/NFC/StringView.h b/dev/LibCompiler/NFC/StringView.h
new file mode 100644
index 0000000..51fb8b8
--- /dev/null
+++ b/dev/LibCompiler/NFC/StringView.h
@@ -0,0 +1,90 @@
+/*
+ * ========================================================
+ *
+ * LibCompiler
+ * Copyright (C) 2024-2025 Amlal EL Mahrouss, all rights reserved.
+ *
+ * ========================================================
+ */
+
+#pragma once
+
+#include <LibCompiler/Defines.h>
+#include <LibCompiler/NFC/ErrorOr.h>
+
+namespace LibCompiler
+{
+ /**
+ * @brief StringView class, contains a C string and manages it.
+ * @note No need to manage it it's getting deleted by default.
+ */
+
+ class StringView final
+ {
+ public:
+ explicit StringView() = delete;
+
+ explicit StringView(SizeType Sz) noexcept
+ : m_Sz(Sz)
+ {
+ m_Data = new CharType[Sz];
+ assert(m_Data);
+ }
+
+ ~StringView() noexcept
+ {
+ if (m_Data)
+ {
+ memset(m_Data, 0, m_Sz);
+ delete[] m_Data;
+
+ m_Data = nullptr;
+ }
+ }
+
+ LIBCOMPILER_COPY_DEFAULT(StringView);
+
+ CharType* Data();
+ const CharType* CData() const;
+ SizeType Length() const;
+
+ bool operator==(const CharType* rhs) const;
+ bool operator!=(const CharType* rhs) const;
+
+ bool operator==(const StringView& rhs) const;
+ bool operator!=(const StringView& rhs) const;
+
+ StringView& operator+=(const CharType* rhs);
+ StringView& operator+=(const StringView& rhs);
+
+ operator bool()
+ {
+ return m_Data && m_Data[0] != 0;
+ }
+
+ bool operator!()
+ {
+ return !m_Data || m_Data[0] == 0;
+ }
+
+ private:
+ CharType* m_Data{nullptr};
+ SizeType m_Sz{0};
+ SizeType m_Cur{0};
+
+ friend class StringBuilder;
+ };
+
+ /**
+ * @brief StringBuilder class
+ * @note These results shall call delete[] after they're used.
+ */
+ struct StringBuilder final
+ {
+ static StringView Construct(const CharType* data);
+ static const char* FromInt(const char* fmt, int n);
+ static const char* FromBool(const char* fmt, bool n);
+ static const char* Format(const char* fmt, const char* from);
+ static bool Equals(const char* lhs, const char* rhs);
+ };
+} // namespace LibCompiler