Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
M
mpd
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Registry
Registry
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Иван Мажукин
mpd
Commits
02314ac7
Commit
02314ac7
authored
Oct 23, 2020
by
Max Kellermann
Committed by
Max Kellermann
Nov 30, 2020
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
util/TemplateString: rewrite as constexpr functions
Hooray C++17!
parent
e7c4e87a
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
99 additions
and
97 deletions
+99
-97
AppendIter.hxx
src/lib/dbus/AppendIter.hxx
+4
-4
Types.hxx
src/lib/dbus/Types.hxx
+21
-17
UdisksNeighborPlugin.cxx
src/neighbor/plugins/UdisksNeighborPlugin.cxx
+2
-2
TemplateString.hxx
src/util/TemplateString.hxx
+72
-74
No files found.
src/lib/dbus/AppendIter.hxx
View file @
02314ac7
...
@@ -103,7 +103,7 @@ public:
...
@@ -103,7 +103,7 @@ public:
template
<
typename
T
>
template
<
typename
T
>
AppendMessageIter
&
AppendEmptyArray
()
{
AppendMessageIter
&
AppendEmptyArray
()
{
return
AppendMessageIter
(
*
this
,
DBUS_TYPE_ARRAY
,
return
AppendMessageIter
(
*
this
,
DBUS_TYPE_ARRAY
,
T
::
TypeAsString
::
value
)
T
::
as_string
.
value
)
.
CloseContainer
(
*
this
);
.
CloseContainer
(
*
this
);
}
}
...
@@ -120,7 +120,7 @@ public:
...
@@ -120,7 +120,7 @@ public:
AppendMessageIter
&
AppendVariant
(
const
T
&
value
)
{
AppendMessageIter
&
AppendVariant
(
const
T
&
value
)
{
typedef
VariantTypeTraits
Traits
;
typedef
VariantTypeTraits
Traits
;
return
AppendMessageIter
(
*
this
,
Traits
::
TYPE
,
return
AppendMessageIter
(
*
this
,
Traits
::
TYPE
,
Traits
::
TypeAsString
::
value
)
Traits
::
as_string
.
value
)
.
Append
(
value
)
.
Append
(
value
)
.
CloseContainer
(
*
this
);
.
CloseContainer
(
*
this
);
}
}
...
@@ -146,7 +146,7 @@ public:
...
@@ -146,7 +146,7 @@ public:
typedef
typename
W
::
ContainedTraits
ContainedTraits
;
typedef
typename
W
::
ContainedTraits
ContainedTraits
;
return
AppendMessageIter
(
*
this
,
Traits
::
TYPE
,
return
AppendMessageIter
(
*
this
,
Traits
::
TYPE
,
ContainedTraits
::
TypeAsString
::
value
)
ContainedTraits
::
as_string
.
value
)
.
Append
(
value
.
value
)
.
Append
(
value
.
value
)
.
CloseContainer
(
*
this
);
.
CloseContainer
(
*
this
);
}
}
...
@@ -158,7 +158,7 @@ public:
...
@@ -158,7 +158,7 @@ public:
typedef
typename
W
::
ContainedTraits
ContainedTraits
;
typedef
typename
W
::
ContainedTraits
ContainedTraits
;
return
AppendMessageIter
(
*
this
,
Traits
::
TYPE
,
return
AppendMessageIter
(
*
this
,
Traits
::
TYPE
,
ContainedTraits
::
TypeAsString
::
value
)
ContainedTraits
::
as_string
.
value
)
.
AppendFixedArray
(
value
.
value
)
.
AppendFixedArray
(
value
.
value
)
.
CloseContainer
(
*
this
);
.
CloseContainer
(
*
this
);
}
}
...
...
src/lib/dbus/Types.hxx
View file @
02314ac7
...
@@ -42,7 +42,7 @@ namespace ODBus {
...
@@ -42,7 +42,7 @@ namespace ODBus {
template
<
int
type
>
template
<
int
type
>
struct
BasicTypeTraits
{
struct
BasicTypeTraits
{
static
constexpr
int
TYPE
=
type
;
static
constexpr
int
TYPE
=
type
;
using
TypeAsString
=
TemplateString
::
CharAsString
<
TYPE
>
;
static
constexpr
auto
as_string
=
TemplateString
::
CharAsString
(
TYPE
)
;
};
};
template
<
typename
T
>
template
<
typename
T
>
...
@@ -73,20 +73,20 @@ struct ArrayTypeTraits {
...
@@ -73,20 +73,20 @@ struct ArrayTypeTraits {
using
ContainedTraits
=
T
;
using
ContainedTraits
=
T
;
static
constexpr
int
TYPE
=
DBUS_TYPE_ARRAY
;
static
constexpr
int
TYPE
=
DBUS_TYPE_ARRAY
;
using
TypeAsS
tring
=
static
constexpr
auto
as_s
tring
=
TemplateString
::
InsertBefore
<
TYPE
,
TemplateString
::
Concat
(
TemplateString
::
CharAsString
(
TYPE
)
,
typename
ContainedTraits
::
TypeAsString
>
;
ContainedTraits
::
as_string
)
;
};
};
template
<
typename
KeyT
,
typename
ValueT
>
template
<
typename
KeyT
,
typename
ValueT
>
struct
DictEntryTypeTraits
{
struct
DictEntryTypeTraits
{
static
constexpr
int
TYPE
=
DBUS_TYPE_DICT_ENTRY
;
static
constexpr
int
TYPE
=
DBUS_TYPE_DICT_ENTRY
;
using
TypeAsS
tring
=
static
constexpr
auto
as_s
tring
=
TemplateString
::
Concat
<
TemplateString
::
CharAsString
<
DBUS_DICT_ENTRY_BEGIN_CHAR
>
,
TemplateString
::
Concat
(
TemplateString
::
CharAsString
(
DBUS_DICT_ENTRY_BEGIN_CHAR
)
,
typename
KeyT
::
TypeAsS
tring
,
KeyT
::
as_s
tring
,
typename
ValueT
::
TypeAsS
tring
,
ValueT
::
as_s
tring
,
TemplateString
::
CharAsString
<
DBUS_DICT_ENTRY_END_CHAR
>>
;
TemplateString
::
CharAsString
(
DBUS_DICT_ENTRY_END_CHAR
))
;
};
};
using
VariantTypeTraits
=
BasicTypeTraits
<
DBUS_TYPE_VARIANT
>
;
using
VariantTypeTraits
=
BasicTypeTraits
<
DBUS_TYPE_VARIANT
>
;
...
@@ -95,21 +95,25 @@ using VariantTypeTraits = BasicTypeTraits<DBUS_TYPE_VARIANT>;
...
@@ -95,21 +95,25 @@ using VariantTypeTraits = BasicTypeTraits<DBUS_TYPE_VARIANT>;
* Concatenate all TypeAsString members to one string.
* Concatenate all TypeAsString members to one string.
*/
*/
template
<
typename
T
,
typename
...
ContainedTraits
>
template
<
typename
T
,
typename
...
ContainedTraits
>
struct
ConcatTypeAsString
struct
ConcatTypeAsString
{
:
TemplateString
::
Concat
<
typename
T
::
TypeAsString
,
static
constexpr
auto
as_string
=
ConcatTypeAsString
<
ContainedTraits
...
>>
{};
TemplateString
::
Concat
(
T
::
as_string
,
ConcatTypeAsString
<
ContainedTraits
...
>::
as_string
);
};
template
<
typename
T
>
template
<
typename
T
>
struct
ConcatTypeAsString
<
T
>
:
T
::
TypeAsString
{};
struct
ConcatTypeAsString
<
T
>
{
static
constexpr
auto
as_string
=
T
::
as_string
;
};
template
<
typename
...
ContainedTraits
>
template
<
typename
...
ContainedTraits
>
struct
StructTypeTraits
{
struct
StructTypeTraits
{
static
constexpr
int
TYPE
=
DBUS_TYPE_STRUCT
;
static
constexpr
int
TYPE
=
DBUS_TYPE_STRUCT
;
using
TypeAsS
tring
=
static
constexpr
auto
as_s
tring
=
TemplateString
::
Concat
<
TemplateString
::
CharAsString
<
DBUS_STRUCT_BEGIN_CHAR
>
,
TemplateString
::
Concat
(
TemplateString
::
CharAsString
(
DBUS_STRUCT_BEGIN_CHAR
)
,
ConcatTypeAsString
<
ContainedTraits
...
>
,
ConcatTypeAsString
<
ContainedTraits
...
>
::
as_string
,
TemplateString
::
CharAsString
<
DBUS_STRUCT_END_CHAR
>>
;
TemplateString
::
CharAsString
(
DBUS_STRUCT_END_CHAR
))
;
};
};
}
/* namespace ODBus */
}
/* namespace ODBus */
...
...
src/neighbor/plugins/UdisksNeighborPlugin.cxx
View file @
02314ac7
...
@@ -245,7 +245,7 @@ UdisksNeighborExplorer::HandleMessage(DBusConnection *, DBusMessage *message) no
...
@@ -245,7 +245,7 @@ UdisksNeighborExplorer::HandleMessage(DBusConnection *, DBusMessage *message) no
if
(
dbus_message_is_signal
(
message
,
DBUS_OM_INTERFACE
,
if
(
dbus_message_is_signal
(
message
,
DBUS_OM_INTERFACE
,
"InterfacesAdded"
)
&&
"InterfacesAdded"
)
&&
dbus_message_has_signature
(
message
,
InterfacesAddedType
::
value
))
{
dbus_message_has_signature
(
message
,
InterfacesAddedType
::
as_string
.
value
))
{
RecurseInterfaceDictEntry
(
ReadMessageIter
(
*
message
),
[
this
](
const
char
*
path
,
auto
&&
i
){
RecurseInterfaceDictEntry
(
ReadMessageIter
(
*
message
),
[
this
](
const
char
*
path
,
auto
&&
i
){
UDisks2
::
Object
o
(
path
);
UDisks2
::
Object
o
(
path
);
UDisks2
::
ParseObject
(
o
,
std
::
forward
<
decltype
(
i
)
>
(
i
));
UDisks2
::
ParseObject
(
o
,
std
::
forward
<
decltype
(
i
)
>
(
i
));
...
@@ -256,7 +256,7 @@ UdisksNeighborExplorer::HandleMessage(DBusConnection *, DBusMessage *message) no
...
@@ -256,7 +256,7 @@ UdisksNeighborExplorer::HandleMessage(DBusConnection *, DBusMessage *message) no
return
DBUS_HANDLER_RESULT_HANDLED
;
return
DBUS_HANDLER_RESULT_HANDLED
;
}
else
if
(
dbus_message_is_signal
(
message
,
DBUS_OM_INTERFACE
,
}
else
if
(
dbus_message_is_signal
(
message
,
DBUS_OM_INTERFACE
,
"InterfacesRemoved"
)
&&
"InterfacesRemoved"
)
&&
dbus_message_has_signature
(
message
,
InterfacesRemovedType
::
value
))
{
dbus_message_has_signature
(
message
,
InterfacesRemovedType
::
as_string
.
value
))
{
Remove
(
ReadMessageIter
(
*
message
).
GetString
());
Remove
(
ReadMessageIter
(
*
message
).
GetString
());
return
DBUS_HANDLER_RESULT_HANDLED
;
return
DBUS_HANDLER_RESULT_HANDLED
;
}
else
}
else
...
...
src/util/TemplateString.hxx
View file @
02314ac7
...
@@ -30,95 +30,93 @@
...
@@ -30,95 +30,93 @@
#ifndef TEMPLATE_STRING_HXX
#ifndef TEMPLATE_STRING_HXX
#define TEMPLATE_STRING_HXX
#define TEMPLATE_STRING_HXX
#include <array> // for std::size()
#include <cstddef>
#include <cstddef>
namespace
TemplateString
{
namespace
TemplateString
{
/**
template
<
std
::
size_t
_size
>
* Construct a null-terminated string from a list of chars.
struct
Buffer
{
*/
static
constexpr
std
::
size_t
size
=
_size
;
template
<
char
...
_value
>
char
value
[
size
+
1
];
struct
Construct
{
static
constexpr
char
value
[]
=
{
_value
...,
0
};
static
constexpr
std
::
size_t
size
=
sizeof
...(
_value
);
};
};
/**
/**
* An empty string.
* An empty string.
*/
*/
struct
Empty
:
Construct
<>
{};
constexpr
auto
Empty
()
noexcept
{
return
Buffer
<
0
>
{};
}
/**
/**
* A string consisting of a single character.
* A string consisting of a single character.
*/
*/
template
<
char
ch
>
constexpr
auto
struct
CharAsString
:
Construct
<
ch
>
{};
CharAsString
(
char
ch
)
noexcept
{
/**
Buffer
<
1
>
result
{};
* Invoke #F, pass all characters in #src from #i to #length
result
.
value
[
0
]
=
ch
;
* as variadic arguments.
return
result
;
*/
}
template
<
template
<
char
...
>
class
F
,
const
char
*
src
,
std
::
size_t
length
,
std
::
size_t
i
,
namespace
detail
{
char
...
_value
>
struct
VariadicChars
:
VariadicChars
<
F
,
src
,
length
-
1
,
i
+
1
,
_value
...,
src
[
i
]
>
{
constexpr
auto
static_assert
(
length
>
0
,
"Wrong length"
);
size
(
const
char
&
)
noexcept
};
{
return
1
;
template
<
template
<
char
...
>
class
F
,
}
const
char
*
src
,
std
::
size_t
length
,
char
...
_value
>
constexpr
const
char
*
struct
VariadicChars
<
F
,
src
,
0
,
length
,
_value
...
>
:
F
<
_value
...
>
{};
data
(
const
char
&
ch
)
noexcept
{
/**
return
&
ch
;
* Like #VariadicChars, but pass an additional argument to #F.
}
*/
template
<
template
<
typename
Arg
,
char
...
>
class
F
,
typename
Arg
,
template
<
std
::
size_t
s
>
const
char
*
src
,
std
::
size_t
length
,
std
::
size_t
i
,
constexpr
auto
char
...
_value
>
size
(
const
Buffer
<
s
>
&
b
)
noexcept
struct
VariadicChars1
:
VariadicChars1
<
F
,
Arg
,
{
src
,
length
-
1
,
i
+
1
,
_value
...,
src
[
i
]
>
{
return
b
.
size
;
static_assert
(
length
>
0
,
"Wrong length"
);
}
};
template
<
std
::
size_t
size
>
template
<
template
<
typename
Arg
,
char
...
>
class
F
,
typename
Arg
,
constexpr
const
char
*
const
char
*
src
,
std
::
size_t
length
,
data
(
const
Buffer
<
size
>
&
b
)
noexcept
char
...
_value
>
{
struct
VariadicChars1
<
F
,
Arg
,
src
,
0
,
length
,
_value
...
>
:
F
<
Arg
,
_value
...
>
{};
return
b
.
value
;
}
constexpr
char
*
copy_n
(
const
char
*
src
,
std
::
size_t
n
,
char
*
dest
)
noexcept
{
for
(
std
::
size_t
i
=
0
;
i
<
n
;
++
i
)
dest
[
i
]
=
src
[
i
];
return
dest
+
n
;
}
}
template
<
const
char
*
src
,
std
::
size_t
length
,
char
...
value
>
struct
_BuildString
:
VariadicChars
<
Construct
,
src
,
length
,
0
,
value
...
>
{};
template
<
char
ch
,
typename
S
>
struct
InsertBefore
:
_BuildString
<
S
::
value
,
S
::
size
,
ch
>
{};
/**
* Concatenate several strings.
*/
template
<
typename
...
Args
>
template
<
typename
...
Args
>
struct
Concat
;
constexpr
auto
Concat
(
Args
...
args
)
noexcept
template
<
typename
First
,
typename
Second
,
typename
...
Args
>
{
struct
_Concat
:
Concat
<
Concat
<
First
,
Second
>
,
Args
...
>
{};
using
std
::
size
;
using
std
::
data
;
template
<
typename
...
Args
>
using
detail
::
size
;
struct
Concat
:
_Concat
<
Args
...
>
{};
using
detail
::
data
;
using
detail
::
copy_n
;
template
<
typename
Second
,
char
...
_value
>
struct
_Concat2
:
_BuildString
<
Second
::
value
,
Second
::
size
,
constexpr
std
::
size_t
total_size
=
(
std
::
size_t
(
0
)
+
...
+
size
(
args
));
_value
...
>
{};
Buffer
<
total_size
>
result
{};
template
<
typename
First
,
typename
Second
>
char
*
p
=
result
.
value
;
struct
Concat
<
First
,
Second
>
((
p
=
copy_n
(
data
(
args
),
size
(
args
),
p
)),
...);
:
VariadicChars1
<
_Concat2
,
Second
,
First
::
value
,
First
::
size
,
0
>
{};
return
result
;
}
template
<
typename
First
>
struct
Concat
<
First
>
:
First
{};
template
<>
struct
Concat
<>
:
Empty
{};
}
// namespace TemplateString
}
// namespace TemplateString
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment