mirror of
https://github.com/MariaDB/server.git
synced 2025-01-15 19:42:28 +01:00
cleanup: make Name and STRING_WITH_LEN usable in constexpr
This commit is contained in:
parent
15a42a0a18
commit
f3bacd708a
2 changed files with 7 additions and 12 deletions
|
@ -201,7 +201,7 @@ extern ulonglong strtoull(const char *str, char **ptr, int base);
|
|||
|
||||
#ifdef __cplusplus
|
||||
#include <type_traits>
|
||||
template<typename T> inline const char *_swl_check(T s)
|
||||
template<typename T> inline constexpr const char *_swl_check(T s)
|
||||
{
|
||||
static_assert(std::is_same<T, const char (&)[sizeof(T)]>::value
|
||||
|| std::is_same<T, const char [sizeof(T)]>::value,
|
||||
|
|
|
@ -3384,17 +3384,12 @@ public:
|
|||
class Name: private LEX_CSTRING
|
||||
{
|
||||
public:
|
||||
Name(const char *str_arg, uint length_arg)
|
||||
{
|
||||
DBUG_ASSERT(length_arg < UINT_MAX32);
|
||||
LEX_CSTRING::str= str_arg;
|
||||
LEX_CSTRING::length= length_arg;
|
||||
}
|
||||
Name(const LEX_CSTRING &lcs)
|
||||
{
|
||||
LEX_CSTRING::str= lcs.str;
|
||||
LEX_CSTRING::length= lcs.length;
|
||||
}
|
||||
constexpr Name(const char *str_arg, uint length_arg) :
|
||||
LEX_CSTRING({str_arg, length_arg})
|
||||
{ }
|
||||
constexpr Name(const LEX_CSTRING &lcs) :
|
||||
LEX_CSTRING(lcs)
|
||||
{ }
|
||||
const char *ptr() const { return LEX_CSTRING::str; }
|
||||
uint length() const { return (uint) LEX_CSTRING::length; }
|
||||
const LEX_CSTRING &lex_cstring() const { return *this; }
|
||||
|
|
Loading…
Reference in a new issue