/* * Copyright 2010-2018 Max Kellermann * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * * - Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * * - Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the * distribution. * * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE * FOUNDATION OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED * OF THE POSSIBILITY OF SUCH DAMAGE. */ #ifndef STRING_BUFFER_HXX #define STRING_BUFFER_HXX #include /** * A statically allocated string buffer. */ template class BasicStringBuffer { public: typedef T value_type; using reference = T &; using pointer = T *; using const_pointer = const T *; using size_type = std::size_t; static constexpr value_type SENTINEL = '\0'; protected: using Array = std::array; Array the_data; public: using iterator = typename Array::iterator; using const_iterator = typename Array::const_iterator; static constexpr size_type capacity() noexcept { return CAPACITY; } constexpr bool empty() const noexcept { return front() == SENTINEL; } void clear() noexcept { the_data[0] = SENTINEL; } constexpr const_pointer c_str() const noexcept { return the_data.data(); } pointer data() noexcept { return the_data.data(); } constexpr value_type front() const noexcept { return the_data.front(); } /** * Returns one character. No bounds checking. */ value_type operator[](size_type i) const noexcept { return the_data[i]; } /** * Returns one writable character. No bounds checking. */ reference operator[](size_type i) noexcept { return the_data[i]; } constexpr iterator begin() noexcept { return the_data.begin(); } constexpr iterator end() noexcept { return the_data.end(); } constexpr const_iterator begin() const noexcept { return the_data.begin(); } constexpr const_iterator end() const noexcept { return the_data.end(); } constexpr operator const_pointer() const noexcept { return c_str(); } }; template class StringBuffer : public BasicStringBuffer {}; #endif