Mercurial > foo_out_sdl
diff foosdk/sdk/pfc/string_simple.h @ 1:20d02a178406 default tip
*: check in everything else
yay
| author | Paper <paper@tflc.us> |
|---|---|
| date | Mon, 05 Jan 2026 02:15:46 -0500 |
| parents | |
| children |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/foosdk/sdk/pfc/string_simple.h Mon Jan 05 02:15:46 2026 -0500 @@ -0,0 +1,59 @@ +#pragma once +#include "array.h" +namespace pfc { + // FOR LEGACY CODE ONLY + // DO NOT USE IN NEW CODE + template<typename t_char> + class string_simple_t { + private: + typedef string_simple_t<t_char> t_self; + public: + t_size length() const { + t_size s = m_buffer.get_size(); + if (s == 0) return 0; else return s - 1; + } + bool is_empty() const { return m_buffer.get_size() == 0; } + + void set_string_nc(const t_char* p_source, t_size p_length) { + if (p_length == 0) { + m_buffer.set_size(0); + } else { + m_buffer.set_size(p_length + 1); + pfc::memcpy_t(m_buffer.get_ptr(), p_source, p_length); + m_buffer[p_length] = 0; + } + } + void set_string(const t_char* p_source) { + set_string_nc(p_source, pfc::strlen_t(p_source)); + } + void set_string(const t_char* p_source, t_size p_length) { + set_string_nc(p_source, strlen_max_t(p_source, p_length)); + } + void add_string(const t_char* p_source, t_size p_length) { + add_string_nc(p_source, strlen_max_t(p_source, p_length)); + } + void add_string(const t_char* p_source) { + add_string_nc(p_source, strlen_t(p_source)); + } + void add_string_nc(const t_char* p_source, t_size p_length) { + if (p_length > 0) { + t_size base = length(); + m_buffer.set_size(base + p_length + 1); + memcpy_t(m_buffer.get_ptr() + base, p_source, p_length); + m_buffer[base + p_length] = 0; + } + } + string_simple_t() {} + string_simple_t(const t_char* p_source) { set_string(p_source); } + string_simple_t(const t_char* p_source, t_size p_length) { set_string(p_source, p_length); } + const t_self& operator=(const t_char* p_source) { set_string(p_source); return *this; } + operator const t_char* () const { return get_ptr(); } + const t_char* get_ptr() const { return m_buffer.get_size() > 0 ? m_buffer.get_ptr() : pfc::empty_string_t<t_char>(); } + const t_char* c_str() const { return get_ptr(); } + private: + pfc::array_t<t_char> m_buffer; + }; + + template<typename t_char> class traits_t<string_simple_t<t_char> > : public traits_t<array_t<t_char> > {}; + +} \ No newline at end of file
