X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/5de06a5f2e7ad10617f1b44d25de18a37a097b1b..e76db741f886560cbf49a0dd833b35489c778ac1:/include/xbt/string.hpp diff --git a/include/xbt/string.hpp b/include/xbt/string.hpp index bd174b8044..a4624489fb 100644 --- a/include/xbt/string.hpp +++ b/include/xbt/string.hpp @@ -1,4 +1,4 @@ -/* Copyright (c) 2015-2020. The SimGrid Team. All rights reserved. */ +/* Copyright (c) 2015-2022. The SimGrid Team. All rights reserved. */ /* This program is free software; you can redistribute it and/or modify it * under the terms of the license (GNU LGPL) which comes with this package. */ @@ -31,13 +31,13 @@ namespace xbt { * * @ingroup XBT_str */ -XBT_PUBLIC std::string string_printf(const char* fmt, ...); +XBT_PUBLIC std::string string_printf(const char* fmt, ...) XBT_ATTRIB_PRINTF(1, 2); /** Create a C++ string from a C-style format * * @ingroup XBT_str */ -XBT_PUBLIC std::string string_vprintf(const char* fmt, va_list ap); +XBT_PUBLIC std::string string_vprintf(const char* fmt, va_list ap) XBT_ATTRIB_PRINTF(1, 0); #if SIMGRID_HAVE_MC @@ -72,11 +72,11 @@ class XBT_PUBLIC string { public: // Types - typedef std::size_t size_type; - typedef char& reference; - typedef const char& const_reference; - typedef char* iterator; - typedef const char* const_iterator; + using size_type = std::size_t; + using reference = char&; + using const_reference = const char&; + using iterator = char*; + using const_iterator = const char*; // Dtor ~string() @@ -101,7 +101,7 @@ public: string() : string(&NUL, 0) {} explicit string(const char* s) : string(s, strlen(s)) {} string(string const& s) : string(s.c_str(), s.size()) {} - string(string&& s) noexcept : str(std::move(s.str)) + string(string&& s) noexcept : str(s.str) { s.str.len = 0; s.str.data = &NUL; @@ -145,7 +145,7 @@ public: // Capacity size_t size() const { return str.len; } size_t length() const { return str.len; } - bool empty() const { return str.len != 0; } + bool empty() const { return str.len == 0; } void shrink_to_fit() { /* Being there, but doing nothing */} // Element access @@ -174,7 +174,7 @@ public: return data()[i]; } // Conversion - static string_data& to_string_data(string& s) { return s.str; } + static const string_data& to_string_data(const string& s) { return s.str; } operator std::string() const { return std::string(this->c_str(), this->size()); } // Iterators @@ -193,6 +193,15 @@ public: str.data = &NUL; } + size_t copy(char* s, size_t len, size_t pos = 0) const + { + if (pos > str.len) + throw std::out_of_range(string_printf("xbt::string::copy with pos > size() (%zu > %zu)", pos, str.len)); + size_t count = std::min(len, str.len - pos); + std::copy_n(str.data + pos, count, s); + return count; + } + bool equals(const char* data, std::size_t len) const { return this->size() == len