Skip to content
Projects
Groups
Snippets
Help
Loading...
Sign in / Register
Toggle navigation
C
capnproto
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
Packages
Packages
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
submodule
capnproto
Commits
449f4b23
Commit
449f4b23
authored
May 11, 2013
by
Kenton Varda
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Allow automatic conversions between numeric types in DynamicValue.
parent
4b771dcd
Expand all
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
115 additions
and
20 deletions
+115
-20
dynamic.c++
c++/src/capnproto/dynamic.c++
+115
-20
dynamic.h
c++/src/capnproto/dynamic.h
+0
-0
No files found.
c++/src/capnproto/dynamic.c++
View file @
449f4b23
...
@@ -85,12 +85,28 @@ void SchemaPool::addNoCopy(schema::Node::Reader node) {
...
@@ -85,12 +85,28 @@ void SchemaPool::addNoCopy(schema::Node::Reader node) {
// TODO(soon): Check if node is in base.
// TODO(soon): Check if node is in base.
// TODO(soon): Check if existing node came from generated code.
// TODO(soon): Check if existing node came from generated code.
auto
entry
=
std
::
make_pair
(
node
.
getId
(),
node
);
uint64_t
id
=
node
.
getId
();
auto
entry
=
std
::
make_pair
(
id
,
node
);
auto
ins
=
impl
->
nodeMap
.
insert
(
entry
);
auto
ins
=
impl
->
nodeMap
.
insert
(
entry
);
if
(
!
ins
.
second
)
{
if
(
!
ins
.
second
)
{
// TODO(soon): Check for compatibility.
// TODO(soon): Check for compatibility.
FAIL_CHECK
(
"TODO: Check schema compatibility when adding."
);
FAIL_CHECK
(
"TODO: Check schema compatibility when adding."
);
}
}
switch
(
node
.
getBody
().
which
())
{
case
schema
:
:
Node
::
Body
::
STRUCT_NODE
:
for
(
auto
member
:
node
.
getBody
().
getStructNode
().
getMembers
())
{
impl
->
memberMap
[
std
::
pair
<
uint64_t
,
Text
::
Reader
>
(
id
,
member
.
getName
())]
=
member
;
}
break
;
case
schema
:
:
Node
::
Body
::
ENUM_NODE
:
for
(
auto
enumerant
:
node
.
getBody
().
getEnumNode
().
getEnumerants
())
{
impl
->
enumerantMap
[
std
::
pair
<
uint64_t
,
Text
::
Reader
>
(
id
,
enumerant
.
getName
())]
=
enumerant
;
}
break
;
default
:
break
;
}
}
}
Maybe
<
schema
::
Node
::
Reader
>
SchemaPool
::
tryGetNode
(
uint64_t
id
)
const
{
Maybe
<
schema
::
Node
::
Reader
>
SchemaPool
::
tryGetNode
(
uint64_t
id
)
const
{
...
@@ -645,7 +661,7 @@ void DynamicStruct::Builder::setFieldImpl(
...
@@ -645,7 +661,7 @@ void DynamicStruct::Builder::setFieldImpl(
case schema::Type::Body::discrim##_TYPE: \
case schema::Type::Body::discrim##_TYPE: \
builder.setDataField<type>( \
builder.setDataField<type>( \
field.getOffset() * ELEMENTS, value.as<type>(), \
field.getOffset() * ELEMENTS, value.as<type>(), \
bitCast<internal::Mask<type> >(dval.get##titleCase##Value()));
bitCast<internal::Mask<type> >(dval.get##titleCase##Value()));
\
break;
break;
HANDLE_TYPE
(
BOOL
,
Bool
,
bool
)
HANDLE_TYPE
(
BOOL
,
Bool
,
bool
)
...
@@ -1133,16 +1149,104 @@ void DynamicList::Builder::verifySchema(internal::ListSchema schema) {
...
@@ -1133,16 +1149,104 @@ void DynamicList::Builder::verifySchema(internal::ListSchema schema) {
// =======================================================================================
// =======================================================================================
namespace
{
template
<
typename
T
>
T
signedToUnsigned
(
long
long
value
)
{
VALIDATE_INPUT
(
value
>=
0
&&
T
(
value
)
==
value
,
"Value out-of-range for requested type."
,
value
)
{
// Use it anyway.
}
return
value
;
}
template
<>
uint64_t
signedToUnsigned
<
uint64_t
>
(
long
long
value
)
{
VALIDATE_INPUT
(
value
>=
0
,
"Value out-of-range for requested type."
,
value
)
{
// Use it anyway.
}
return
value
;
}
template
<
typename
T
>
T
unsignedToSigned
(
unsigned
long
long
value
)
{
VALIDATE_INPUT
(
T
(
value
)
>=
0
&&
(
unsigned
long
long
)
T
(
value
)
==
value
,
"Value out-of-range for requested type."
,
value
)
{
// Use it anyway.
}
return
value
;
}
template
<>
int64_t
unsignedToSigned
<
int64_t
>
(
unsigned
long
long
value
)
{
VALIDATE_INPUT
(
int64_t
(
value
)
>=
0
,
"Value out-of-range for requested type."
,
value
)
{
// Use it anyway.
}
return
value
;
}
template
<
typename
T
,
typename
U
>
T
checkRoundTrip
(
U
value
)
{
VALIDATE_INPUT
(
T
(
value
)
==
value
,
"Value out-of-range for requested type."
,
value
)
{
// Use it anyway.
}
return
value
;
}
}
// namespace
#define HANDLE_NUMERIC_TYPE(typeName, ifInt, ifUint, ifFloat) \
typeName DynamicValue::Reader::AsImpl<typeName>::apply(Reader reader) { \
switch (reader.type) { \
case INT: \
return ifInt<typeName>(reader.intValue); \
case UINT: \
return ifUint<typeName>(reader.uintValue); \
case FLOAT: \
return ifFloat<typeName>(reader.floatValue); \
default: \
FAIL_VALIDATE_INPUT("Type mismatch when using DynamicValue::Reader::as()."); \
return 0; \
} \
} \
typeName DynamicValue::Builder::AsImpl<typeName>::apply(Builder builder) { \
switch (builder.type) { \
case INT: \
return ifInt<typeName>(builder.intValue); \
case UINT: \
return ifUint<typeName>(builder.uintValue); \
case FLOAT: \
return ifFloat<typeName>(builder.floatValue); \
default: \
FAIL_VALIDATE_INPUT("Type mismatch when using DynamicValue::Builder::as()."); \
return 0; \
} \
}
HANDLE_NUMERIC_TYPE
(
int8_t
,
checkRoundTrip
,
unsignedToSigned
,
checkRoundTrip
)
HANDLE_NUMERIC_TYPE
(
int16_t
,
checkRoundTrip
,
unsignedToSigned
,
checkRoundTrip
)
HANDLE_NUMERIC_TYPE
(
int32_t
,
checkRoundTrip
,
unsignedToSigned
,
checkRoundTrip
)
HANDLE_NUMERIC_TYPE
(
int64_t
,
implicit_cast
,
unsignedToSigned
,
checkRoundTrip
)
HANDLE_NUMERIC_TYPE
(
uint8_t
,
signedToUnsigned
,
checkRoundTrip
,
checkRoundTrip
)
HANDLE_NUMERIC_TYPE
(
uint16_t
,
signedToUnsigned
,
checkRoundTrip
,
checkRoundTrip
)
HANDLE_NUMERIC_TYPE
(
uint32_t
,
signedToUnsigned
,
checkRoundTrip
,
checkRoundTrip
)
HANDLE_NUMERIC_TYPE
(
uint64_t
,
signedToUnsigned
,
implicit_cast
,
checkRoundTrip
)
HANDLE_NUMERIC_TYPE
(
float
,
implicit_cast
,
implicit_cast
,
implicit_cast
)
HANDLE_NUMERIC_TYPE
(
double
,
implicit_cast
,
implicit_cast
,
implicit_cast
)
#undef HANDLE_NUMERIC_TYPE
#define HANDLE_TYPE(name, discrim, typeName) \
#define HANDLE_TYPE(name, discrim, typeName) \
ReaderFor<typeName> DynamicValue::Reader::
a
sImpl<typeName>::apply(Reader reader) { \
ReaderFor<typeName> DynamicValue::Reader::
A
sImpl<typeName>::apply(Reader reader) { \
VALIDATE_INPUT(reader.type ==
schema::Type::Body::discrim##_TYPE
, \
VALIDATE_INPUT(reader.type ==
discrim
, \
"Type mismatch when using DynamicValue::Reader::as().") { \
"Type mismatch when using DynamicValue::Reader::as().") { \
return ReaderFor<typeName>(); \
return ReaderFor<typeName>(); \
} \
} \
return reader.name##Value; \
return reader.name##Value; \
} \
} \
BuilderFor<typeName> DynamicValue::Builder::
a
sImpl<typeName>::apply(Builder builder) { \
BuilderFor<typeName> DynamicValue::Builder::
A
sImpl<typeName>::apply(Builder builder) { \
VALIDATE_INPUT(builder.type ==
schema::Type::Body::discrim##_TYPE
, \
VALIDATE_INPUT(builder.type ==
discrim
, \
"Type mismatch when using DynamicValue::Builder::as().") { \
"Type mismatch when using DynamicValue::Builder::as().") { \
return BuilderFor<typeName>(); \
return BuilderFor<typeName>(); \
} \
} \
...
@@ -1151,16 +1255,6 @@ BuilderFor<typeName> DynamicValue::Builder::asImpl<typeName>::apply(Builder buil
...
@@ -1151,16 +1255,6 @@ BuilderFor<typeName> DynamicValue::Builder::asImpl<typeName>::apply(Builder buil
//HANDLE_TYPE(void, VOID, Void)
//HANDLE_TYPE(void, VOID, Void)
HANDLE_TYPE
(
bool
,
BOOL
,
bool
)
HANDLE_TYPE
(
bool
,
BOOL
,
bool
)
HANDLE_TYPE
(
int8
,
INT8
,
int8_t
)
HANDLE_TYPE
(
int16
,
INT16
,
int16_t
)
HANDLE_TYPE
(
int32
,
INT32
,
int32_t
)
HANDLE_TYPE
(
int64
,
INT64
,
int64_t
)
HANDLE_TYPE
(
uint8
,
UINT8
,
uint8_t
)
HANDLE_TYPE
(
uint16
,
UINT16
,
uint16_t
)
HANDLE_TYPE
(
uint32
,
UINT32
,
uint32_t
)
HANDLE_TYPE
(
uint64
,
UINT64
,
uint64_t
)
HANDLE_TYPE
(
float32
,
FLOAT32
,
float
)
HANDLE_TYPE
(
float64
,
FLOAT64
,
double
)
HANDLE_TYPE
(
text
,
TEXT
,
Text
)
HANDLE_TYPE
(
text
,
TEXT
,
Text
)
HANDLE_TYPE
(
data
,
DATA
,
Data
)
HANDLE_TYPE
(
data
,
DATA
,
Data
)
...
@@ -1168,19 +1262,20 @@ HANDLE_TYPE(list, LIST, DynamicList)
...
@@ -1168,19 +1262,20 @@ HANDLE_TYPE(list, LIST, DynamicList)
HANDLE_TYPE
(
struct
,
STRUCT
,
DynamicStruct
)
HANDLE_TYPE
(
struct
,
STRUCT
,
DynamicStruct
)
HANDLE_TYPE
(
enum
,
ENUM
,
DynamicEnum
)
HANDLE_TYPE
(
enum
,
ENUM
,
DynamicEnum
)
HANDLE_TYPE
(
object
,
OBJECT
,
DynamicObject
)
HANDLE_TYPE
(
object
,
OBJECT
,
DynamicObject
)
HANDLE_TYPE
(
union
,
UNION
,
DynamicUnion
)
#undef HANDLE_TYPE
#undef HANDLE_TYPE
// As in the header, HANDLE_TYPE(void, VOID, Void) crashes GCC 4.7.
// As in the header, HANDLE_TYPE(void, VOID, Void) crashes GCC 4.7.
Void
DynamicValue
::
Reader
::
a
sImpl
<
Void
>::
apply
(
Reader
reader
)
{
Void
DynamicValue
::
Reader
::
A
sImpl
<
Void
>::
apply
(
Reader
reader
)
{
VALIDATE_INPUT
(
reader
.
type
==
schema
::
Type
::
Body
::
VOID_TYPE
,
VALIDATE_INPUT
(
reader
.
type
==
VOID
,
"Type mismatch when using DynamicValue::Reader::as()."
)
{
"Type mismatch when using DynamicValue::Reader::as()."
)
{
return
Void
();
return
Void
();
}
}
return
reader
.
voidValue
;
return
reader
.
voidValue
;
}
}
Void
DynamicValue
::
Builder
::
a
sImpl
<
Void
>::
apply
(
Builder
builder
)
{
Void
DynamicValue
::
Builder
::
A
sImpl
<
Void
>::
apply
(
Builder
builder
)
{
VALIDATE_INPUT
(
builder
.
type
==
schema
::
Type
::
Body
::
VOID_TYPE
,
VALIDATE_INPUT
(
builder
.
type
==
VOID
,
"Type mismatch when using DynamicValue::Builder::as()."
)
{
"Type mismatch when using DynamicValue::Builder::as()."
)
{
return
Void
();
return
Void
();
}
}
...
...
c++/src/capnproto/dynamic.h
View file @
449f4b23
This diff is collapsed.
Click to expand it.
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