From 240465626604ed9a7f7b2cb997ab4dffd419eabc Mon Sep 17 00:00:00 2001 From: Albrecht Schlosser Date: Sat, 4 Dec 2021 12:28:42 +0100 Subject: Add minimal version of class Fl_String This class will be used in fl_input_str() and fl_password_str(). Todo: add missing documentation ... --- FL/Fl_String.H | 114 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 114 insertions(+) create mode 100644 FL/Fl_String.H (limited to 'FL') diff --git a/FL/Fl_String.H b/FL/Fl_String.H new file mode 100644 index 000000000..471178cd6 --- /dev/null +++ b/FL/Fl_String.H @@ -0,0 +1,114 @@ +// +// Basic Fl_String header for the Fast Light Tool Kit (FLTK). +// +// Copyright 2021 by Bill Spitzak and others. +// +// This library is free software. Distribution and use rights are outlined in +// the file "COPYING" which should have been included with this file. If this +// file is missing or damaged, see the license at: +// +// https://www.fltk.org/COPYING.php +// +// Please see the following page on how to report bugs and issues: +// +// https://www.fltk.org/bugs.php +// + +#ifndef _FL_FL_STRING_H_ +#define _FL_FL_STRING_H_ + +/** \file FL/Fl_String.H + Basic Fl_String class for FLTK. +*/ + +/** + Fl_String is the basic string class for FLTK. + + In this version Fl_String can be used to store strings, copy strings, + and move strings. There are no string manipulation methods yet. + + Fl_String can hold the value of an Fl_Input widget including \e nul bytes + if the constructor Fl_String(const char *str, int size) is used. + + Assignment and copy constructors \b copy the string value such that the + source string can be freed immediately after the assignment. + + The string value() can be an empty string \c "" or \c NULL. + + If value() is not \c NULL it is guaranteed that the string is terminated by + a trailing \c nul byte even if the string contains embedded \c nul bytes. + + The method size() returns the full string size, whether the string contains + embedded \c nul bytes or not. The special method slen() returns 0 if value() + is \c NULL, otherwise the same as \c strlen() would do. + + Examples: + \code + Fl_String np(NULL); + printf(" np : value = %p, size = %d, slen = %d\n", np.value(), np.size(), np.slen()); + Fl_String empty(""); + printf(" empty : value = %p, size = %d\n", empty.value(), empty.size()); + Fl_String fltk("FLTK"); + Fl_Input i(0, 0, 0, 0); + i.value("abc\0def", 7); + Fl_String str(i.value(), i.size()); + printf(" str : strlen = %lu, size = %d, capacity = %d\n", + strlen(str.value()), str.size(), str.capacity()); + + Output: + + np : value = (nil), size = 0, slen = 0 + empty : value = 0x562840befbf0, size = 0 + str : strlen = 3, size = 7, capacity = 15 + \endcode + + \since 1.4.0 + + \todo Complete documentation of class Fl_String +*/ + +class Fl_String { +private: + int size_; + char *value_; + int capacity_; + +public: + Fl_String(); + Fl_String(const char *str); + Fl_String(const char *str, int size); + + // copy constructor + Fl_String(const Fl_String &in); + + // copy assignment operator + Fl_String& operator=(const Fl_String &in); + + // assignment operator for 'const char *' + Fl_String& operator=(const char *in); + + virtual ~Fl_String(); + +private: + void init(); + void alloc_buf(int size); + void release(); + +public: + void value(const char *str); + void value(const char *str, int slen); + + const char *value() const { return value_; } + int size() const { return size_; } + + int slen() const; + int capacity() const; + + // ================================== DEBUG ================================== + + void debug(const char *info) const; // output string info + void hexdump(const char *info) const; // output info + hexdump + +}; // class Fl_String + +#endif // _FL_FL_STRING_H_ -- cgit v1.2.3