simstr 1.0
Yet another strings library
 
Загрузка...
Поиск...
Не найдено
Шаблон структуры simstr::simple_str_nt< K >

Класс, заявляющий, что ссылается на нуль-терминированную строку. Подробнее...

#include <sstring.h>

Граф наследования:simstr::simple_str_nt< K >:
simstr::simple_str< K > simstr::str_algs< K, simple_str< K >, simple_str< K >, false >

Открытые члены

template<typename T>
requires std::is_same_v<std::remove_const_t<std::remove_pointer_t<std::remove_cvref_t<T>>>, K>
 simple_str_nt (T &&p) noexcept
 Явный конструктор из С-строки.
 
template<typename S>
requires (std::is_same_v<S, std::string&> || std::is_same_v<S, const std::string&> || std::is_same_v<S, std::string_view&> || std::is_same_v<S, const std::string_view&>)
constexpr simple_str_nt (S &&s) noexcept
 Конструктор, позволяющий инициализировать объектами std::string, и std::string_view при условии, что они lvalue, то есть не временные.
 
 operator const K * () const noexcept
 Оператор преобразования в нуль-терминированную C-строку
 
my_type to_nts (size_t from)
 Получить нуль-терминированную строку, сдвинув начало на заданное количество символов
 
constexpr size_t length () const noexcept
 Получить длину строки
 
constexpr const symb_type * symbols () const noexcept
 Получить указатель на константный буфер с символами строки
 
constexpr bool is_empty () const noexcept
 Проверить, не пуста ли строка
 
bool is_same (simple_str< K > other) const noexcept
 Проверить, не указывают ли два объекта на одну строку
 
bool is_part_of (simple_str< K > other) const noexcept
 Проверить, не является ли строка частью другой строки
 
operator[] (size_t idx) const
 Получить символ из указанной позиции. Проверка границ не выполняется.
 
my_typeremove_prefix (size_t delta)
 Сдвигает начало строки на заданное количество символов
 
my_typeremove_suffix (size_t delta)
 Укорачивает строку на заданное количество символов
 
constexpr K * place (K *ptr) const noexcept
 Копировать строку в указанный буфер.
 
void copy_to (K *buffer, size_t bufSize)
 Копировать строку в указанный буфер.
 
size_t size () const
 Размер строки в символах.
 
constexpr operator str_piece () const noexcept
 Преобразовать себя в "кусок строки", включающий всю строку
 
str_piece to_str () const noexcept
 Преобразовать себя в "кусок строки", включающий всю строку
 
std::string_view to_sv () const noexcept
 Конвертировать в std::string_view.
 
std::string to_string () const noexcept
 Конвертировать в std::string.
 
constexpr str_piece operator() (ptrdiff_t from, ptrdiff_t len=0) const noexcept
 Получить часть строки как "simple_str".
 
constexpr str_piece mid (size_t from, size_t len=-1) const noexcept
 Получить часть строки как "кусок строки".
 
constexpr str_piece from_to (size_t from, size_t to) const noexcept
 Получить подстроку simple_str с позиции от from до позиции to (не включая её)
 
bool operator! () const noexcept
 Проверка на пустоту
 
at (ptrdiff_t idx) const
 Получить символ на заданной позиции
 
constexpr int compare (str_piece o) const
 Сравнение строк посимвольно
 
constexpr int strcmp (const K *text) const
 Сравнение с C-строкой посимвольно
 
constexpr bool equal (str_piece other) const noexcept
 Сравнение строк на равенство
 
constexpr bool operator== (const base &other) const noexcept
 Оператор сравнение строк на равенство
 
bool operator== (T &&other) const noexcept
 Оператор сравнения строки и строкового литерала на равенство
 
constexpr auto operator<=> (const base &other) const noexcept
 Оператор сравнения строк
 
auto operator<=> (T &&other) const noexcept
 Оператор сравнения строки и строкового литерала
 
int compare_ia (str_piece text) const noexcept
 Сравнение строк посимвольно без учёта регистра ASCII символов
 
bool equal_ia (str_piece text) const noexcept
 Равна ли строка другой строке посимвольно без учёта регистра ASCII символов
 
bool less_ia (str_piece text) const noexcept
 Меньше ли строка другой строки посимвольно без учёта регистра ASCII символов
 
int compare_iu (str_piece text) const noexcept
 Сравнение строк посимвольно без учёта регистра Unicode символов первой плоскости (<0xFFFF)
 
bool equal_iu (str_piece text) const noexcept
 Равна ли строка другой строке посимвольно без учёта регистра Unicode символов первой плоскости (<0xFFFF)
 
bool less_iu (str_piece text) const noexcept
 Меньше ли строка другой строки посимвольно без учёта регистра Unicode символов первой плоскости (<0xFFFF)
 
size_t find (str_piece pattern, size_t offset=0) const noexcept
 Найти начало первого вхождения подстроки в этой строке.
 
size_t find (K s, size_t offset=0) const noexcept
 Найти символ в этой строке.
 
size_t find_or_throw (str_piece pattern, size_t offset=0, Args &&... args) const noexcept
 Найти начало первого вхождения подстроки в этой строке или выкинуть исключение.
 
size_t find_end (str_piece pattern, size_t offset=0) const noexcept
 Найти конец вхождения подстроки в этой строке.
 
size_t find_or_all (str_piece pattern, size_t offset=0) const noexcept
 Найти начало первого вхождения подстроки в этой строке или конец строки.
 
size_t find_or_all (K s, size_t offset=0) const noexcept
 Найти символ в этой строке или конец строки.
 
size_t find_end_or_all (str_piece pattern, size_t offset=0) const noexcept
 Найти конец первого вхождения подстроки в этой строке или конец строки.
 
size_t find_last (str_piece pattern, size_t offset=-1) const noexcept
 Найти начало последнего вхождения подстроки в этой строке.
 
size_t find_last (K s, size_t offset=-1) const noexcept
 Найти последнее вхождения символа в этой строке
 
size_t find_end_of_last (str_piece pattern, size_t offset=-1) const noexcept
 Найти конец последнего вхождения подстроки в этой строке.
 
size_t find_last_or_all (str_piece pattern, size_t offset=-1) const noexcept
 Найти начало последнего вхождения подстроки в этой строке или конец строки.
 
size_t find_end_of_last_or_all (str_piece pattern, size_t offset=-1) const noexcept
 Найти конец последнего вхождения подстроки в этой строке или конец строки.
 
bool contains (str_piece pattern, size_t offset=0) const noexcept
 Содержит ли строка указанную подстроку.
 
void for_all_finded (const Op &op, str_piece pattern, size_t offset=0, size_t maxCount=0) const
 Вызвать функтор для всех найденных вхождений подстроки в этой строке
 
std::vector< size_t > find_all (str_piece pattern, size_t offset=0, size_t maxCount=0) const
 Найти все вхождения подстроки в этой строке
 
size_t find_first_of (str_piece pattern, size_t offset=0) const noexcept
 Найти первое вхождение символа из заданного набора символов
 
std::pair< size_t, size_t > find_first_of_idx (str_piece pattern, size_t offset=0) const noexcept
 Найти первое вхождение символа из заданного набора символов
 
size_t find_first_not_of (str_piece pattern, size_t offset=0) const noexcept
 Найти первое вхождение символа не из заданного набора символов
 
size_t find_last_of (str_piece pattern, size_t offset=str::npos) const noexcept
 Найти последнее вхождение символа из заданного набора символов
 
std::pair< size_t, size_t > find_last_of_idx (str_piece pattern, size_t offset=str::npos) const noexcept
 Найти последнее вхождение символа из заданного набора символов
 
size_t find_last_not_of (str_piece pattern, size_t offset=str::npos) const noexcept
 Найти последнее вхождение символа не из заданного набора символов
 
my_type substr (ptrdiff_t from, ptrdiff_t len=0) const
 Получить подстроку. Работает аналогично operator(), только результат выдает того же типа, к которому применён метод
 
my_type str_mid (size_t from, size_t len=-1) const
 Получить часть строки объектом того же типа, к которому применён метод, аналогично mid.
 
as_int () const noexcept
 Преобразовать строку в число заданного типа
 
std::tuple< T, IntConvertResult, size_t > to_int () const noexcept
 Преобразовать строку в число заданного типа
 
double to_double () const noexcept
 Преобразовать строку в double.
 
void as_number (T &t)
 Преобразовать строку в целое число
 
void as_number (double &t)
 Преобразовать строку в double.
 
splitf (str_piece delimeter, const Op &beforeFunc, size_t offset=0) const
 Разделить строку на части по заданному разделителю, с возможным применением функтора к каждой подстроке
 
split (str_piece delimeter, size_t offset=0) const
 Разделить строку на подстроки по заданному разделителю
 
Splitter< K > splitter (str_piece delimeter) const
 Получить объект Splitter по заданному разделителю, который позволяет последовательно получать подстроки методом next(), пока is_done() false.
 
constexpr bool starts_with (str_piece prefix) const noexcept
 Начинается ли строка с заданной подстроки
 
constexpr bool starts_with_ia (str_piece prefix) const noexcept
 Начинается ли строка с заданной подстроки без учёта регистра ASCII символов
 
bool starts_with_iu (str_piece prefix) const noexcept
 Начинается ли строка с заданной подстроки без учёта регистра Unicode символов первой плоскости (<0xFFFF)
 
constexpr bool prefix_in (str_piece text) const noexcept
 Является ли эта строка началом другой строки
 
constexpr bool ends_with (str_piece suffix) const noexcept
 Заканчивается ли строка указанной подстрокой
 
constexpr bool ends_with_ia (str_piece suffix) const noexcept
 Заканчивается ли строка указанной подстрокой без учёта регистра ASCII символов
 
constexpr bool ends_with_iu (str_piece suffix) const noexcept
 Заканчивается ли строка указанной подстрокой без учёта регистра Unicode символов первой плоскости (<0xFFFF)
 
bool is_ascii () const noexcept
 Содержит ли строка только ASCII символы
 
uppered_only_ascii () const
 Получить копию строки в верхнем регистре ASCII символов
 
lowered_only_ascii () const
 Получить копию строки в нижнем регистре ASCII символов
 
uppered () const
 Получить копию строки в верхнем регистре Unicode символов первой плоскости (<0xFFFF)
 
lowered () const
 Получить копию строки в нижнем регистре Unicode символов первой плоскости (<0xFFFF)
 
replaced (str_piece pattern, str_piece repl, size_t offset=0, size_t maxCount=0) const
 Получить копию строки с заменёнными вхождениями подстрок
 
expr_replaces< K, N - 1, L - 1 > replace_init (T &&pattern, M &&repl) const
 Получить строковое выражение, которое выдает строку с заменёнными подстроками, заданными строковыми литералами.
 
trimmed () const
 Получить строку с удалением пробельных символов слева и справа
 
trimmed (T &&pattern) const
 Получить строку с удалением символов, заданных строковым литералом, слева и справа
 
trimmed (str_piece pattern) const
 Получить строку с удалением символов, заданных другой строкой, слева и справа
 
trimmed_left () const
 Получить строку с удалением пробельных символов слева
 
trimmed_left (T &&pattern) const
 Получить строку с удалением символов, заданных строковым литералом, слева
 
trimmed_left (str_piece pattern) const
 Получить строку с удалением символов, заданных другой строкой, слева
 
trimmed_right () const
 Получить строку с удалением пробельных символов справа
 
trimmed_right (T &&pattern) const
 Получить строку с удалением символов, заданных строковым литералом, справа
 
trimmed_right (str_piece pattern) const
 Получить строку с удалением символов, заданных другой строкой, справа
 
trimmed_with_spaces (T &&pattern) const
 Получить строку с удалением символов, заданных строковым литералом, а также пробельных символов, слева и справа
 
trimmed_with_spaces (str_piece pattern) const
 Получить строку с удалением символов, заданных другой строкой, а также пробельных символов, слева и справа
 
trimmed_left_with_spaces (T &&pattern) const
 Получить строку с удалением символов, заданных строковым литералом, а также пробельных символов, слева
 
trimmed_left_with_spaces (str_piece pattern) const
 Получить строку с удалением символов, заданных другой строкой, а также пробельных символов, слева
 
trimmed_right_with_spaces (T &&pattern) const
 Получить строку с удалением символов, заданных строковым литералом, а также пробельных символов, справа
 
trimmed_right_with_spaces (str_piece pattern) const
 Получить строку с удалением символов, заданных другой строкой, а также пробельных символов, справа
 

Подробное описание

template<typename K>
struct simstr::simple_str_nt< K >

Класс, заявляющий, что ссылается на нуль-терминированную строку.

Параметры шаблона
K- тип символов строки

Служит для показа того, что функция параметром хочет получить строку с нулем в конце, например, ей надо дальше передавать его в стороннее API. Без этого ей надо было бы либо указывать параметром конкретный класс строки, что лишает универсальности, либо приводило бы к постоянным накладным расходам на излишнее копирование строк во временный буфер. Источником нуль-терминированных строк могут быть строковые литералы при компиляции, либо классы, хранящие строки.

Конструктор(ы)

◆ simple_str_nt()

template<typename K>
template<typename T>
requires std::is_same_v<std::remove_const_t<std::remove_pointer_t<std::remove_cvref_t<T>>>, K>
simstr::simple_str_nt< K >::simple_str_nt ( T && p)
inlineexplicitnoexcept

Явный конструктор из С-строки.

Аргументы
p- указатель на C-строку (нуль-терминированная строка)

Это единственный конструктор из всех строковых объектов, принимающий C-строку. Вычисляет её длину при инициализации. Все остальные строковые объекты не инициализируются C-строками. Это для того, чтобы strlen вызывалась только в одном месте библиотеки, длина C-строки вычислялась только один раз и далее не терялась случайно при передаче между разными типами строковых объектов.

Методы

◆ as_int()

T simstr::str_algs< K, simple_str< K >, simple_str< K >, Mutable >::as_int ( ) const
inlinenoexceptinherited

Преобразовать строку в число заданного типа

Параметры шаблона
T- желаемый тип числа
CheckOverflow- проверять на переполнение
Base- основание счисления числа, от -1 до 36, кроме 1.
  • Если 0: то пытается определить основание по префиксу 0[xX] как 16, 0 как 8, иначе 10
  • Если -1: то пытается определить основание по префиксам:
    • 0 или 0[oO]: 8
    • 0[bB]: 2
    • 0[xX]: 16
    • в остальных случаях 10.
SkipWs- пропускать пробельные символы в начале строки
AllowSign- допустим ли знак '+' перед числом
Возвращает
T - число, результат преобразования, насколько оно получилось, или 0 при переполнении.

◆ as_number() [1/2]

void simstr::str_algs< K, simple_str< K >, simple_str< K >, Mutable >::as_number ( double & t)
inlineinherited

Преобразовать строку в double.

Аргументы
t- переменная, в которую записывается результат

◆ as_number() [2/2]

void simstr::str_algs< K, simple_str< K >, simple_str< K >, Mutable >::as_number ( T & t)
inlineinherited

Преобразовать строку в целое число

Параметры шаблона
T- тип числа, выводится из аргумента
Аргументы
t- переменная, в которую записывается результат

◆ at()

K simstr::str_algs< K, simple_str< K >, simple_str< K >, Mutable >::at ( ptrdiff_t idx) const
inlineinherited

Получить символ на заданной позиции

Аргументы
idx- индекс символа. Для отрицательных значений отсчитывается от конца строки.
Возвращает
K - символ

Не производит проверку на выход за границы строки

◆ compare()

int simstr::str_algs< K, simple_str< K >, simple_str< K >, Mutable >::compare ( str_piece o) const
inlineconstexprinherited

Сравнение строк посимвольно

Аргументы
o- другая строка
Возвращает
<0 эта строка меньше, ==0 - строки равны, >0 - эта строка больше

◆ compare_ia()

int simstr::str_algs< K, simple_str< K >, simple_str< K >, Mutable >::compare_ia ( str_piece text) const
inlinenoexceptinherited

Сравнение строк посимвольно без учёта регистра ASCII символов

Аргументы
text- другая строка
Возвращает
<0 эта строка меньше, ==0 - строки равны, >0 - эта строка больше

◆ compare_iu()

int simstr::str_algs< K, simple_str< K >, simple_str< K >, Mutable >::compare_iu ( str_piece text) const
inlinenoexceptinherited

Сравнение строк посимвольно без учёта регистра Unicode символов первой плоскости (<0xFFFF)

Аргументы
text- другая строка
Возвращает
<0 эта строка меньше, ==0 - строки равны, >0 - эта строка больше

◆ contains()

bool simstr::str_algs< K, simple_str< K >, simple_str< K >, Mutable >::contains ( str_piece pattern,
size_t offset = 0 ) const
inlinenoexceptinherited

Содержит ли строка указанную подстроку.

Аргументы
pattern- искомая строка
offset- с какой позиции начинать поиск
Возвращает
bool

◆ copy_to()

void simstr::str_algs< K, simple_str< K >, simple_str< K >, Mutable >::copy_to ( K * buffer,
size_t bufSize )
inlineinherited

Копировать строку в указанный буфер.

Метод добавляет \0 после скопированных символов. Не выходит за границы буфера.

Аргументы
buffer- указатель на буфер
bufSize- размер буфера в символах.

◆ ends_with()

bool simstr::str_algs< K, simple_str< K >, simple_str< K >, Mutable >::ends_with ( str_piece suffix) const
inlineconstexprnoexceptinherited

Заканчивается ли строка указанной подстрокой

Аргументы
suffix- подстрока

◆ ends_with_ia()

bool simstr::str_algs< K, simple_str< K >, simple_str< K >, Mutable >::ends_with_ia ( str_piece suffix) const
inlineconstexprnoexceptinherited

Заканчивается ли строка указанной подстрокой без учёта регистра ASCII символов

Аргументы
suffix- подстрока

◆ ends_with_iu()

bool simstr::str_algs< K, simple_str< K >, simple_str< K >, Mutable >::ends_with_iu ( str_piece suffix) const
inlineconstexprnoexceptinherited

Заканчивается ли строка указанной подстрокой без учёта регистра Unicode символов первой плоскости (<0xFFFF)

Аргументы
suffix- подстрока

◆ equal()

bool simstr::str_algs< K, simple_str< K >, simple_str< K >, Mutable >::equal ( str_piece other) const
inlineconstexprnoexceptinherited

Сравнение строк на равенство

Аргументы
other- другая строка
Возвращает
равны ли строки

◆ equal_ia()

bool simstr::str_algs< K, simple_str< K >, simple_str< K >, Mutable >::equal_ia ( str_piece text) const
inlinenoexceptinherited

Равна ли строка другой строке посимвольно без учёта регистра ASCII символов

Аргументы
text- другая строка
Возвращает
равны ли строки

◆ equal_iu()

bool simstr::str_algs< K, simple_str< K >, simple_str< K >, Mutable >::equal_iu ( str_piece text) const
inlinenoexceptinherited

Равна ли строка другой строке посимвольно без учёта регистра Unicode символов первой плоскости (<0xFFFF)

Аргументы
text- другая строка
Возвращает
равны ли строки

◆ find() [1/2]

size_t simstr::str_algs< K, simple_str< K >, simple_str< K >, Mutable >::find ( K s,
size_t offset = 0 ) const
inlinenoexceptinherited

Найти символ в этой строке.

Аргументы
s- искомый символ
offset- с какой позиции начинать поиск
Возвращает
size_t - позицию найденного символа, или -1, если не найден

◆ find() [2/2]

size_t simstr::str_algs< K, simple_str< K >, simple_str< K >, Mutable >::find ( str_piece pattern,
size_t offset = 0 ) const
inlinenoexceptinherited

Найти начало первого вхождения подстроки в этой строке.

Аргументы
pattern- искомая строка
offset- с какой позиции начинать поиск
Возвращает
size_t - позицию начала вхождения подстроки, или -1, если не найдена

◆ find_all()

std::vector< size_t > simstr::str_algs< K, simple_str< K >, simple_str< K >, Mutable >::find_all ( str_piece pattern,
size_t offset = 0,
size_t maxCount = 0 ) const
inlineinherited

Найти все вхождения подстроки в этой строке

Аргументы
pattern- искомая подстрока
offset- позиция начала поиска
maxCount- максимальное количество обрабатываемых вхождений, 0 - без ограничений
Возвращает
std::vector<size_t> - вектор с позициями начал найденных вхождений

◆ find_end()

size_t simstr::str_algs< K, simple_str< K >, simple_str< K >, Mutable >::find_end ( str_piece pattern,
size_t offset = 0 ) const
inlinenoexceptinherited

Найти конец вхождения подстроки в этой строке.

Аргументы
pattern- искомая строка
offset- с какой позиции начинать поиск
Возвращает
size_t - позицию сразу за вхождением подстроки, или -1, если не найдена

◆ find_end_of_last()

size_t simstr::str_algs< K, simple_str< K >, simple_str< K >, Mutable >::find_end_of_last ( str_piece pattern,
size_t offset = -1 ) const
inlinenoexceptinherited

Найти конец последнего вхождения подстроки в этой строке.

Аргументы
pattern- искомая строка
offset- c какой позиции вести поиск в обратную сторону, -1 - с самого конца
Возвращает
size_t - позицию сразу за последним вхождением подстроки, или -1, если не найдена

◆ find_end_of_last_or_all()

size_t simstr::str_algs< K, simple_str< K >, simple_str< K >, Mutable >::find_end_of_last_or_all ( str_piece pattern,
size_t offset = -1 ) const
inlinenoexceptinherited

Найти конец последнего вхождения подстроки в этой строке или конец строки.

Аргументы
pattern- искомая строка
offset- c какой позиции вести поиск в обратную сторону, -1 - с самого конца
Возвращает
size_t - позицию сразу за последним вхождением подстроки, или длину строки, если не найдена

◆ find_end_or_all()

size_t simstr::str_algs< K, simple_str< K >, simple_str< K >, Mutable >::find_end_or_all ( str_piece pattern,
size_t offset = 0 ) const
inlinenoexceptinherited

Найти конец первого вхождения подстроки в этой строке или конец строки.

Аргументы
pattern- искомая строка
offset- с какой позиции начинать поиск
Возвращает
size_t - позицию сразу за вхождением подстроки, или длину строки, если не найдена

◆ find_first_not_of()

size_t simstr::str_algs< K, simple_str< K >, simple_str< K >, Mutable >::find_first_not_of ( str_piece pattern,
size_t offset = 0 ) const
inlinenoexceptinherited

Найти первое вхождение символа не из заданного набора символов

Аргументы
pattern- строка, задающая набор символов
offset- позиция начала поиска
Возвращает
size_t - позицию найденного вхождения, или -1, если не найден

◆ find_first_of()

size_t simstr::str_algs< K, simple_str< K >, simple_str< K >, Mutable >::find_first_of ( str_piece pattern,
size_t offset = 0 ) const
inlinenoexceptinherited

Найти первое вхождение символа из заданного набора символов

Аргументы
pattern- строка, задающая набор искомых символов
offset- позиция начала поиска
Возвращает
size_t - позицию найденного вхождения, или -1, если не найден

◆ find_first_of_idx()

std::pair< size_t, size_t > simstr::str_algs< K, simple_str< K >, simple_str< K >, Mutable >::find_first_of_idx ( str_piece pattern,
size_t offset = 0 ) const
inlinenoexceptinherited

Найти первое вхождение символа из заданного набора символов

Аргументы
pattern- строка, задающая набор искомых символов
offset- позиция начала поиска
Возвращает
std::pair<size_t, size_t> - пару из позиции найденного вхождения и номера найденного символа в наборе, или -1, если не найден

◆ find_last() [1/2]

size_t simstr::str_algs< K, simple_str< K >, simple_str< K >, Mutable >::find_last ( K s,
size_t offset = -1 ) const
inlinenoexceptinherited

Найти последнее вхождения символа в этой строке

Аргументы
s- искомый символ
offset- c какой позиции вести поиск в обратную сторону, -1 - с самого конца
Возвращает
size_t - позицию найденного символа, или -1, если не найден

◆ find_last() [2/2]

size_t simstr::str_algs< K, simple_str< K >, simple_str< K >, Mutable >::find_last ( str_piece pattern,
size_t offset = -1 ) const
inlinenoexceptinherited

Найти начало последнего вхождения подстроки в этой строке.

Аргументы
pattern- искомая строка
offset- c какой позиции вести поиск в обратную сторону, -1 - с самого конца
Возвращает
size_t - позицию начала вхождения подстроки, или -1, если не найдена

◆ find_last_not_of()

size_t simstr::str_algs< K, simple_str< K >, simple_str< K >, Mutable >::find_last_not_of ( str_piece pattern,
size_t offset = str::npos ) const
inlinenoexceptinherited

Найти последнее вхождение символа не из заданного набора символов

Аргументы
pattern- строка, задающая набор символов
offset- позиция начала поиска
Возвращает
size_t - позицию найденного вхождения, или -1, если не найден

◆ find_last_of()

size_t simstr::str_algs< K, simple_str< K >, simple_str< K >, Mutable >::find_last_of ( str_piece pattern,
size_t offset = str::npos ) const
inlinenoexceptinherited

Найти последнее вхождение символа из заданного набора символов

Аргументы
pattern- строка, задающая набор искомых символов
offset- позиция начала поиска
Возвращает
size_t - позицию найденного вхождения, или -1, если не найден

◆ find_last_of_idx()

std::pair< size_t, size_t > simstr::str_algs< K, simple_str< K >, simple_str< K >, Mutable >::find_last_of_idx ( str_piece pattern,
size_t offset = str::npos ) const
inlinenoexceptinherited

Найти последнее вхождение символа из заданного набора символов

Аргументы
pattern- строка, задающая набор искомых символов
offset- позиция начала поиска
Возвращает
std::pair<size_t, size_t> - пару из позиции найденного вхождения и номера найденного символа в наборе, или -1, если не найден

◆ find_last_or_all()

size_t simstr::str_algs< K, simple_str< K >, simple_str< K >, Mutable >::find_last_or_all ( str_piece pattern,
size_t offset = -1 ) const
inlinenoexceptinherited

Найти начало последнего вхождения подстроки в этой строке или конец строки.

Аргументы
pattern- искомая строка
offset- c какой позиции вести поиск в обратную сторону, -1 - с самого конца
Возвращает
size_t - позицию начала вхождения подстроки, или длину строки, если не найдена

◆ find_or_all() [1/2]

size_t simstr::str_algs< K, simple_str< K >, simple_str< K >, Mutable >::find_or_all ( K s,
size_t offset = 0 ) const
inlinenoexceptinherited

Найти символ в этой строке или конец строки.

Аргументы
s- искомый символ
offset- с какой позиции начинать поиск
Возвращает
size_t - позицию найденного символа, или длину строки, если не найден

◆ find_or_all() [2/2]

size_t simstr::str_algs< K, simple_str< K >, simple_str< K >, Mutable >::find_or_all ( str_piece pattern,
size_t offset = 0 ) const
inlinenoexceptinherited

Найти начало первого вхождения подстроки в этой строке или конец строки.

Аргументы
pattern- искомая строка
offset- с какой позиции начинать поиск
Возвращает
size_t - позицию начала вхождения подстроки, или длину строки, если не найдена

◆ find_or_throw()

size_t simstr::str_algs< K, simple_str< K >, simple_str< K >, Mutable >::find_or_throw ( str_piece pattern,
size_t offset = 0,
Args &&... args ) const
inlinenoexceptinherited

Найти начало первого вхождения подстроки в этой строке или выкинуть исключение.

Параметры шаблона
Exc- тип исключения
Args...- типы параметров для конструирования исключения, выводятся из аргументов
Аргументы
pattern- искомая строка
offset- с какой позиции начинать поиск
Возвращает
size_t - позицию начала вхождения подстроки, или выбрасывает исключение Exc, если не найдена

◆ for_all_finded()

void simstr::str_algs< K, simple_str< K >, simple_str< K >, Mutable >::for_all_finded ( const Op & op,
str_piece pattern,
size_t offset = 0,
size_t maxCount = 0 ) const
inlineinherited

Вызвать функтор для всех найденных вхождений подстроки в этой строке

Аргументы
op- функтор, принимающий строку
pattern- искомая подстрока
offset- позиция начала поиска
maxCount- максимальное количество обрабатываемых вхождений, 0 - без ограничений

◆ from_to()

str_piece simstr::str_algs< K, simple_str< K >, simple_str< K >, Mutable >::from_to ( size_t from,
size_t to ) const
inlineconstexprnoexceptinherited

Получить подстроку simple_str с позиции от from до позиции to (не включая её)

Для производительности метод никак не проверяет выходы за границы строки, используйте в сценариях, когда точно знаете, что это позиции внутри строки и to >= from.

Аргументы
from- начальная позиция
to- конечная позиция (не входит в результат)
Возвращает
Подстроку, simple_str.

◆ is_part_of()

template<typename K>
bool simstr::simple_str< K >::is_part_of ( simple_str< K > other) const
inlinenoexceptinherited

Проверить, не является ли строка частью другой строки

Аргументы
other- другая строка

◆ is_same()

template<typename K>
bool simstr::simple_str< K >::is_same ( simple_str< K > other) const
inlinenoexceptinherited

Проверить, не указывают ли два объекта на одну строку

Аргументы
other- другая строка

◆ less_ia()

bool simstr::str_algs< K, simple_str< K >, simple_str< K >, Mutable >::less_ia ( str_piece text) const
inlinenoexceptinherited

Меньше ли строка другой строки посимвольно без учёта регистра ASCII символов

Аргументы
text- другая строка
Возвращает
меньше ли строка

◆ less_iu()

bool simstr::str_algs< K, simple_str< K >, simple_str< K >, Mutable >::less_iu ( str_piece text) const
inlinenoexceptinherited

Меньше ли строка другой строки посимвольно без учёта регистра Unicode символов первой плоскости (<0xFFFF)

Аргументы
text- другая строка
Возвращает
меньше ли строка

◆ lowered()

R simstr::str_algs< K, simple_str< K >, simple_str< K >, Mutable >::lowered ( ) const
inlineinherited

Получить копию строки в нижнем регистре Unicode символов первой плоскости (<0xFFFF)

Параметры шаблона
R- желаемый тип строки, по умолчанию тот же, чей метод вызывался.
Возвращает
R - копию строки в нижнем регистре

◆ lowered_only_ascii()

R simstr::str_algs< K, simple_str< K >, simple_str< K >, Mutable >::lowered_only_ascii ( ) const
inlineinherited

Получить копию строки в нижнем регистре ASCII символов

Параметры шаблона
R- желаемый тип строки, по умолчанию тот же, чей метод вызывался.
Возвращает
R - копию строки в нижнем регистре

◆ mid()

str_piece simstr::str_algs< K, simple_str< K >, simple_str< K >, Mutable >::mid ( size_t from,
size_t len = -1 ) const
inlineconstexprnoexceptinherited

Получить часть строки как "кусок строки".

Аргументы
from- количество символов от начала строки. При превышении размера строки вернёт пустую строку.
len- количество символов в получаемом "куске". При выходе за пределы строки вернёт всё до конца строки.
Возвращает
Подстроку, simple_str.

◆ operator const K *()

template<typename K>
simstr::simple_str_nt< K >::operator const K * ( ) const
inlinenoexcept

Оператор преобразования в нуль-терминированную C-строку

Возвращает
const K* - указатель на начало строки

◆ operator str_piece()

simstr::str_algs< K, simple_str< K >, simple_str< K >, Mutable >::operator str_piece ( ) const
inlineconstexprnoexceptinherited

Преобразовать себя в "кусок строки", включающий всю строку

Возвращает
str_piece

◆ operator()()

str_piece simstr::str_algs< K, simple_str< K >, simple_str< K >, Mutable >::operator() ( ptrdiff_t from,
ptrdiff_t len = 0 ) const
inlineconstexprnoexceptinherited

Получить часть строки как "simple_str".

Аргументы
from- количество символов от начала строки.
len- количество символов в получаемом "куске".
Возвращает
Подстроку, simple_str.

Если from меньше нуля, то отсчитывается -from символов от конца строки в сторону начала. Если len меньше или равно нулю, то отсчитать -len символов от конца строки

"0123456789"_ss(5, 2) == "56";
"0123456789"_ss(5) == "56789";
"0123456789"_ss(5, -1) == "5678";
"0123456789"_ss(-3) == "789";
"0123456789"_ss(-3, 2) == "78";
"0123456789"_ss(-4, -1) == "678";

◆ operator<=>() [1/2]

auto simstr::str_algs< K, simple_str< K >, simple_str< K >, Mutable >::operator<=> ( const base & other) const
inlineconstexprnoexceptinherited

Оператор сравнения строк

Аргументы
other- другая строка

◆ operator<=>() [2/2]

auto simstr::str_algs< K, simple_str< K >, simple_str< K >, Mutable >::operator<=> ( T && other) const
inlinenoexceptinherited

Оператор сравнения строки и строкового литерала

Аргументы
other- строковый литерал

◆ operator==() [1/2]

bool simstr::str_algs< K, simple_str< K >, simple_str< K >, Mutable >::operator== ( const base & other) const
inlineconstexprnoexceptinherited

Оператор сравнение строк на равенство

Аргументы
other- другая строка
Возвращает
равны ли строки

◆ operator==() [2/2]

bool simstr::str_algs< K, simple_str< K >, simple_str< K >, Mutable >::operator== ( T && other) const
inlinenoexceptinherited

Оператор сравнения строки и строкового литерала на равенство

Аргументы
other- строковый литерал

◆ operator[]()

template<typename K>
K simstr::simple_str< K >::operator[] ( size_t idx) const
inlineinherited

Получить символ из указанной позиции. Проверка границ не выполняется.

Аргументы
idx- позиция символа
Возвращает
K - символ

◆ place()

K * simstr::str_algs< K, simple_str< K >, simple_str< K >, Mutable >::place ( K * ptr) const
inlineconstexprnoexceptinherited

Копировать строку в указанный буфер.

Метод предполагает, что размер выделенного буфера достаточен для всей строки, т.е. предварительно была запрошена length(). Не добавляет \0.

Аргументы
ptr- указатель на буфер
Возвращает
указатель на символ после конца размещённой в буфере строки

◆ prefix_in()

bool simstr::str_algs< K, simple_str< K >, simple_str< K >, Mutable >::prefix_in ( str_piece text) const
inlineconstexprnoexceptinherited

Является ли эта строка началом другой строки

Аргументы
text- другая строка

◆ remove_prefix()

template<typename K>
my_type & simstr::simple_str< K >::remove_prefix ( size_t delta)
inlineinherited

Сдвигает начало строки на заданное количество символов

Аргументы
delta- количество символов
Возвращает
my_type&

◆ remove_suffix()

template<typename K>
my_type & simstr::simple_str< K >::remove_suffix ( size_t delta)
inlineinherited

Укорачивает строку на заданное количество символов

Аргументы
delta- количество символов
Возвращает
my_type&

◆ replace_init()

expr_replaces< K, N - 1, L - 1 > simstr::str_algs< K, simple_str< K >, simple_str< K >, Mutable >::replace_init ( T && pattern,
M && repl ) const
inlineinherited

Получить строковое выражение, которое выдает строку с заменёнными подстроками, заданными строковыми литералами.

Аргументы
pattern- строковый литерал, подстрока, которую меняем
repl- строковый литерал, подстрока, на которую меняем
Возвращает
строковое выражение, заменяющее подстроки

◆ replaced()

R simstr::str_algs< K, simple_str< K >, simple_str< K >, Mutable >::replaced ( str_piece pattern,
str_piece repl,
size_t offset = 0,
size_t maxCount = 0 ) const
inlineinherited

Получить копию строки с заменёнными вхождениями подстрок

Параметры шаблона
R- желаемый тип строки, по умолчанию тот же, чей метод вызывался.
Аргументы
pattern- искомая подстрока
repl- строка, на которую заменять
offset- начальная позиция поиска
maxCount- максимальное количество замен, 0 - без ограничений
Возвращает
R строку заданного типа, по умолчанию того же, чей метод вызывался.

◆ size()

size_t simstr::str_algs< K, simple_str< K >, simple_str< K >, Mutable >::size ( ) const
inlineinherited

Размер строки в символах.

Возвращает
size_t

◆ split()

T simstr::str_algs< K, simple_str< K >, simple_str< K >, Mutable >::split ( str_piece delimeter,
size_t offset = 0 ) const
inlineinherited

Разделить строку на подстроки по заданному разделителю

Параметры шаблона
T- тип контейнера для результата
Аргументы
delimeter- разделитель
offset- позиция начала поиска разделителя
Возвращает
T - контейнер с результатом

◆ splitf()

T simstr::str_algs< K, simple_str< K >, simple_str< K >, Mutable >::splitf ( str_piece delimeter,
const Op & beforeFunc,
size_t offset = 0 ) const
inlineinherited

Разделить строку на части по заданному разделителю, с возможным применением функтора к каждой подстроке

Параметры шаблона
T- тип контейнера для складывания подстрок.
Аргументы
delimeter- подстрока разделитель
beforeFunc- функтор для применения к найденным подстрокам, перед помещением их в результат
offset- позиция начала поиска разделителя
Возвращает
T - результат.

Для каждой найденной подстроки, если функтор может принять её, вызывается функтор, и подстрока присваивается результату функтора. Далее подстрока пытается добавиться в результат, вызывая один из его методов - emplace_back, push_back, operator[]. Если ни одного этого метода нет, ничего не делается, только вызов функтора. operator[] пытается применится, если у результата можно получить размер через std::size и мы не выходим за этот размер. При этом, если найденная подстрока получается совпадающей со всей строкой - в результат пытается поместить не подстроку, а весь объект строки, что позволяет, например, эффективно копировать sstring.

◆ splitter()

Splitter< K > simstr::str_algs< K, simple_str< K >, simple_str< K >, Mutable >::splitter ( str_piece delimeter) const
inherited

Получить объект Splitter по заданному разделителю, который позволяет последовательно получать подстроки методом next(), пока is_done() false.

Аргументы
delimeter- разделитель
Возвращает
Splitter<K>

◆ starts_with()

bool simstr::str_algs< K, simple_str< K >, simple_str< K >, Mutable >::starts_with ( str_piece prefix) const
inlineconstexprnoexceptinherited

Начинается ли строка с заданной подстроки

Аргументы
prefix- подстрока

◆ starts_with_ia()

bool simstr::str_algs< K, simple_str< K >, simple_str< K >, Mutable >::starts_with_ia ( str_piece prefix) const
inlineconstexprnoexceptinherited

Начинается ли строка с заданной подстроки без учёта регистра ASCII символов

Аргументы
prefix- подстрока

◆ starts_with_iu()

bool simstr::str_algs< K, simple_str< K >, simple_str< K >, Mutable >::starts_with_iu ( str_piece prefix) const
inlinenoexceptinherited

Начинается ли строка с заданной подстроки без учёта регистра Unicode символов первой плоскости (<0xFFFF)

Аргументы
prefix- подстрока

◆ str_mid()

my_type simstr::str_algs< K, simple_str< K >, simple_str< K >, Mutable >::str_mid ( size_t from,
size_t len = -1 ) const
inlineinherited

Получить часть строки объектом того же типа, к которому применён метод, аналогично mid.

Аргументы
from- количество символов от начала строки. При превышении размера строки вернёт пустую строку.
len- количество символов в получаемом "куске". При выходе за пределы строки вернёт всё до конца строки.
Возвращает
Строку того же типа, к которому применён метод.

◆ strcmp()

int simstr::str_algs< K, simple_str< K >, simple_str< K >, Mutable >::strcmp ( const K * text) const
inlineconstexprinherited

Сравнение с C-строкой посимвольно

Аргументы
o- другая строка
Возвращает
<0 эта строка меньше, ==0 - строки равны, >0 - эта строка больше

◆ substr()

my_type simstr::str_algs< K, simple_str< K >, simple_str< K >, Mutable >::substr ( ptrdiff_t from,
ptrdiff_t len = 0 ) const
inlineinherited

Получить подстроку. Работает аналогично operator(), только результат выдает того же типа, к которому применён метод

Аргументы
from- количество символов от начала строки. Если меньше нуля, отсчитывается от конца строки в сторону начала.
len- количество символов в получаемом "куске". Если меньше или равно нулю, то отсчитать len символов от конца строки
Возвращает
my_type - подстроку, объект того же типа, к которому применён метод

◆ to_double()

double simstr::str_algs< K, simple_str< K >, simple_str< K >, Mutable >::to_double ( ) const
inlinenoexceptinherited

Преобразовать строку в double.

Возвращает
double. Пока работает только для строк из char, wchar_t и типов, совместимых с wchar_t по размеру.

◆ to_int()

std::tuple< T, IntConvertResult, size_t > simstr::str_algs< K, simple_str< K >, simple_str< K >, Mutable >::to_int ( ) const
inlinenoexceptinherited

Преобразовать строку в число заданного типа

Параметры шаблона
T- желаемый тип числа
CheckOverflow- проверять на переполнение
Base- основание счисления числа, от -1 до 36, кроме 1.
  • Если 0: то пытается определить основание по префиксу 0[xX] как 16, 0 как 8, иначе 10
  • Если -1: то пытается определить основание по префиксам:
    • 0 или 0[oO]: 8
    • 0[bB]: 2
    • 0[xX]: 16
    • в остальных случаях 10.
SkipWs- пропускать пробельные символы в начале строки. Пропускаются все символы с ASCII кодами <= 32.
AllowSign- допустим ли знак '+' перед числом
Возвращает
std::tuple<T, IntConvertResult, size_t> - кортеж из полученного числа, успешности преобразования и количестве обработанных символов

◆ to_nts()

template<typename K>
my_type simstr::simple_str_nt< K >::to_nts ( size_t from)
inline

Получить нуль-терминированную строку, сдвинув начало на заданное количество символов

Аргументы
from- на сколько символов сдвинуть начало строки
Возвращает
my_type

◆ to_str()

str_piece simstr::str_algs< K, simple_str< K >, simple_str< K >, Mutable >::to_str ( ) const
inlinenoexceptinherited

Преобразовать себя в "кусок строки", включающий всю строку

Возвращает
str_piece

◆ to_string()

std::string simstr::str_algs< K, simple_str< K >, simple_str< K >, Mutable >::to_string ( ) const
inlinenoexceptinherited

Конвертировать в std::string.

Возвращает
std::string

◆ to_sv()

std::string_view simstr::str_algs< K, simple_str< K >, simple_str< K >, Mutable >::to_sv ( ) const
inlinenoexceptinherited

Конвертировать в std::string_view.

Возвращает
std::string_view

◆ trimmed() [1/3]

R simstr::str_algs< K, simple_str< K >, simple_str< K >, Mutable >::trimmed ( ) const
inlineinherited

Получить строку с удалением пробельных символов слева и справа

Параметры шаблона
R- желаемый тип строки, по умолчанию simple_str
Возвращает
R - строка, с удалёнными в начале и в конце пробельными символами

◆ trimmed() [2/3]

R simstr::str_algs< K, simple_str< K >, simple_str< K >, Mutable >::trimmed ( str_piece pattern) const
inlineinherited

Получить строку с удалением символов, заданных другой строкой, слева и справа

Параметры шаблона
R- желаемый тип строки, по умолчанию simple_str
Аргументы
pattern- строка, задающая символы, которые будут обрезаться
Возвращает
R - строка, с удалёнными в начале и в конце символами, содержащимися в шаблоне

◆ trimmed() [3/3]

R simstr::str_algs< K, simple_str< K >, simple_str< K >, Mutable >::trimmed ( T && pattern) const
inlineinherited

Получить строку с удалением символов, заданных строковым литералом, слева и справа

Параметры шаблона
R- желаемый тип строки, по умолчанию simple_str
Аргументы
pattern- строковый литерал, задающий символы, которые будут обрезаться
Возвращает
R - строка, с удалёнными в начале и в конце символами, содержащимися в литерале

◆ trimmed_left() [1/3]

R simstr::str_algs< K, simple_str< K >, simple_str< K >, Mutable >::trimmed_left ( ) const
inlineinherited

Получить строку с удалением пробельных символов слева

Параметры шаблона
R- желаемый тип строки, по умолчанию simple_str
Возвращает
R - строка, с удалёнными в начале пробельными символами

◆ trimmed_left() [2/3]

R simstr::str_algs< K, simple_str< K >, simple_str< K >, Mutable >::trimmed_left ( str_piece pattern) const
inlineinherited

Получить строку с удалением символов, заданных другой строкой, слева

Параметры шаблона
R- желаемый тип строки, по умолчанию simple_str
Аргументы
pattern- строка, задающая символы, которые будут обрезаться
Возвращает
R - строка, с удалёнными в начале символами, содержащимися в шаблоне

◆ trimmed_left() [3/3]

R simstr::str_algs< K, simple_str< K >, simple_str< K >, Mutable >::trimmed_left ( T && pattern) const
inlineinherited

Получить строку с удалением символов, заданных строковым литералом, слева

Параметры шаблона
R- желаемый тип строки, по умолчанию simple_str
Аргументы
pattern- строковый литерал, задающий символы, которые будут обрезаться
Возвращает
R - строка, с удалёнными в начале символами, содержащимися в литерале

◆ trimmed_left_with_spaces() [1/2]

R simstr::str_algs< K, simple_str< K >, simple_str< K >, Mutable >::trimmed_left_with_spaces ( str_piece pattern) const
inlineinherited

Получить строку с удалением символов, заданных другой строкой, а также пробельных символов, слева

Параметры шаблона
R- желаемый тип строки, по умолчанию simple_str
Аргументы
pattern- строка, задающая символы, которые будут обрезаться
Возвращает
R - строка, с удалёнными в начале символами, содержащимися в шаблоне и пробельными символами

◆ trimmed_left_with_spaces() [2/2]

R simstr::str_algs< K, simple_str< K >, simple_str< K >, Mutable >::trimmed_left_with_spaces ( T && pattern) const
inlineinherited

Получить строку с удалением символов, заданных строковым литералом, а также пробельных символов, слева

Параметры шаблона
R- желаемый тип строки, по умолчанию simple_str
Аргументы
pattern- строковый литерал, задающий символы, которые будут обрезаться
Возвращает
R - строка, с удалёнными в начале символами, содержащимися в литерале и пробельными символами

◆ trimmed_right() [1/3]

R simstr::str_algs< K, simple_str< K >, simple_str< K >, Mutable >::trimmed_right ( ) const
inlineinherited

Получить строку с удалением пробельных символов справа

Параметры шаблона
R- желаемый тип строки, по умолчанию simple_str
Возвращает
R - строка, с удалёнными в конце пробельными символами

◆ trimmed_right() [2/3]

R simstr::str_algs< K, simple_str< K >, simple_str< K >, Mutable >::trimmed_right ( str_piece pattern) const
inlineinherited

Получить строку с удалением символов, заданных другой строкой, справа

Параметры шаблона
R- желаемый тип строки, по умолчанию simple_str
Аргументы
pattern- строка, задающая символы, которые будут обрезаться
Возвращает
R - строка, с удалёнными в конце символами, содержащимися в шаблоне

◆ trimmed_right() [3/3]

R simstr::str_algs< K, simple_str< K >, simple_str< K >, Mutable >::trimmed_right ( T && pattern) const
inlineinherited

Получить строку с удалением символов, заданных строковым литералом, справа

Параметры шаблона
R- желаемый тип строки, по умолчанию simple_str
Аргументы
pattern- строковый литерал, задающий символы, которые будут обрезаться
Возвращает
R - строка, с удалёнными в конце символами, содержащимися в литерале

◆ trimmed_right_with_spaces() [1/2]

R simstr::str_algs< K, simple_str< K >, simple_str< K >, Mutable >::trimmed_right_with_spaces ( str_piece pattern) const
inlineinherited

Получить строку с удалением символов, заданных другой строкой, а также пробельных символов, справа

Параметры шаблона
R- желаемый тип строки, по умолчанию simple_str
Аргументы
pattern- строка, задающая символы, которые будут обрезаться
Возвращает
R - строка, с удалёнными в конце символами, содержащимися в шаблоне и пробельными символами

◆ trimmed_right_with_spaces() [2/2]

R simstr::str_algs< K, simple_str< K >, simple_str< K >, Mutable >::trimmed_right_with_spaces ( T && pattern) const
inlineinherited

Получить строку с удалением символов, заданных строковым литералом, а также пробельных символов, справа

Параметры шаблона
R- желаемый тип строки, по умолчанию simple_str
Аргументы
pattern- строковый литерал, задающий символы, которые будут обрезаться
Возвращает
R - строка, с удалёнными в конце символами, содержащимися в литерале и пробельными символами

◆ trimmed_with_spaces() [1/2]

R simstr::str_algs< K, simple_str< K >, simple_str< K >, Mutable >::trimmed_with_spaces ( str_piece pattern) const
inlineinherited

Получить строку с удалением символов, заданных другой строкой, а также пробельных символов, слева и справа

Параметры шаблона
R- желаемый тип строки, по умолчанию simple_str
Аргументы
pattern- строка, задающая символы, которые будут обрезаться
Возвращает
R - строка, с удалёнными в начале и в конце символами, содержащимися в шаблоне и пробельными символами

◆ trimmed_with_spaces() [2/2]

R simstr::str_algs< K, simple_str< K >, simple_str< K >, Mutable >::trimmed_with_spaces ( T && pattern) const
inlineinherited

Получить строку с удалением символов, заданных строковым литералом, а также пробельных символов, слева и справа

Параметры шаблона
R- желаемый тип строки, по умолчанию simple_str
Аргументы
pattern- строковый литерал, задающий символы, которые будут обрезаться
Возвращает
R - строка, с удалёнными в начале и в конце символами, содержащимися в литерале и пробельными символами

◆ uppered()

R simstr::str_algs< K, simple_str< K >, simple_str< K >, Mutable >::uppered ( ) const
inlineinherited

Получить копию строки в верхнем регистре Unicode символов первой плоскости (<0xFFFF)

Параметры шаблона
R- желаемый тип строки, по умолчанию тот же, чей метод вызывался.
Возвращает
R - копию строки в верхнем регистре

◆ uppered_only_ascii()

R simstr::str_algs< K, simple_str< K >, simple_str< K >, Mutable >::uppered_only_ascii ( ) const
inlineinherited

Получить копию строки в верхнем регистре ASCII символов

Параметры шаблона
R- желаемый тип строки, по умолчанию тот же, чей метод вызывался.
Возвращает
R - копию строки в верхнем регистре

Объявления и описания членов структуры находятся в файле: