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
d75e6a31
Commit
d75e6a31
authored
Aug 02, 2013
by
Kenton Varda
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Fix GCC issues.
parent
baa3ee3c
Hide whitespace changes
Inline
Side-by-side
Showing
13 changed files
with
146 additions
and
79 deletions
+146
-79
compiler.c++
c++/src/capnp/compiler/compiler.c++
+2
-1
node-translator.c++
c++/src/capnp/compiler/node-translator.c++
+39
-38
encoding-test.c++
c++/src/capnp/encoding-test.c++
+1
-1
arena-test.c++
c++/src/kj/arena-test.c++
+10
-10
arena.c++
c++/src/kj/arena.c++
+1
-1
common-test.c++
c++/src/kj/common-test.c++
+4
-4
common.c++
c++/src/kj/common.c++
+8
-0
common.h
c++/src/kj/common.h
+12
-0
function-test.c++
c++/src/kj/function-test.c++
+1
-1
function.h
c++/src/kj/function.h
+44
-2
main.c++
c++/src/kj/main.c++
+3
-0
main.h
c++/src/kj/main.h
+5
-5
mutex-test.c++
c++/src/kj/mutex-test.c++
+16
-16
No files found.
c++/src/capnp/compiler/compiler.c++
View file @
d75e6a31
...
@@ -465,7 +465,8 @@ const Compiler::Node::Content& Compiler::Node::getContent(Content::State minimum
...
@@ -465,7 +465,8 @@ const Compiler::Node::Content& Compiler::Node::getContent(Content::State minimum
builder
.
setScopeId
(
p
->
id
);
builder
.
setScopeId
(
p
->
id
);
}
}
auto
nestedIter
=
builder
.
initNestedNodes
(
locked
->
orderedNestedNodes
.
size
()).
begin
();
auto
nestedNodes
=
builder
.
initNestedNodes
(
locked
->
orderedNestedNodes
.
size
());
auto
nestedIter
=
nestedNodes
.
begin
();
for
(
auto
node
:
locked
->
orderedNestedNodes
)
{
for
(
auto
node
:
locked
->
orderedNestedNodes
)
{
nestedIter
->
setName
(
node
->
declaration
.
getName
().
getValue
());
nestedIter
->
setName
(
node
->
declaration
.
getName
().
getValue
());
nestedIter
->
setId
(
node
->
id
);
nestedIter
->
setId
(
node
->
id
);
...
...
c++/src/capnp/compiler/node-translator.c++
View file @
d75e6a31
...
@@ -1297,31 +1297,31 @@ class NodeTranslator::DynamicSlot {
...
@@ -1297,31 +1297,31 @@ class NodeTranslator::DynamicSlot {
public
:
public
:
DynamicSlot
(
DynamicStruct
::
Builder
structBuilder
,
StructSchema
::
Member
member
)
DynamicSlot
(
DynamicStruct
::
Builder
structBuilder
,
StructSchema
::
Member
member
)
:
type
(
FIELD
),
struct
Builder
(
structBuilder
),
member
(
member
)
{}
:
type
(
FIELD
),
struct
_
{
structBuilder
,
member
}
{}
DynamicSlot
(
DynamicList
::
Builder
listBuilder
,
uint
index
)
DynamicSlot
(
DynamicList
::
Builder
listBuilder
,
uint
index
)
:
type
(
ELEMENT
),
list
Builder
(
listBuilder
),
index
(
index
)
{}
:
type
(
ELEMENT
),
list
{
listBuilder
,
index
}
{}
DynamicSlot
(
DynamicUnion
::
Builder
unionBuilder
,
StructSchema
::
Member
unionMember
)
DynamicSlot
(
DynamicUnion
::
Builder
unionBuilder
,
StructSchema
::
Member
unionMember
)
:
type
(
UNION_MEMBER
),
union
Builder
(
unionBuilder
),
unionMember
(
unionMember
)
{}
:
type
(
UNION_MEMBER
),
union
_
{
unionBuilder
,
unionMember
}
{}
DynamicSlot
(
DynamicUnion
::
Builder
unionBuilder
,
StructSchema
::
Member
unionMember
,
DynamicSlot
(
DynamicUnion
::
Builder
unionBuilder
,
StructSchema
::
Member
unionMember
,
StructSchema
structMemberSchema
)
StructSchema
structMemberSchema
)
:
type
(
STRUCT_OBJECT_UNION_MEMBER
),
union
Builder
(
unionBuilder
),
unionMember
(
unionMember
)
,
:
type
(
STRUCT_OBJECT_UNION_MEMBER
),
union
_
{
unionBuilder
,
unionMember
}
,
structMemberSchema
(
structMemberSchema
)
{}
structMemberSchema
(
structMemberSchema
)
{}
DynamicSlot
(
DynamicUnion
::
Builder
unionBuilder
,
StructSchema
::
Member
unionMember
,
DynamicSlot
(
DynamicUnion
::
Builder
unionBuilder
,
StructSchema
::
Member
unionMember
,
ListSchema
listMemberSchema
)
ListSchema
listMemberSchema
)
:
type
(
LIST_OBJECT_UNION_MEMBER
),
union
Builder
(
unionBuilder
),
unionMember
(
unionMember
)
,
:
type
(
LIST_OBJECT_UNION_MEMBER
),
union
_
{
unionBuilder
,
unionMember
}
,
listMemberSchema
(
listMemberSchema
)
{}
listMemberSchema
(
listMemberSchema
)
{}
DynamicSlot
(
DynamicUnion
::
Builder
unionBuilder
,
StructSchema
::
Member
unionMember
,
DynamicSlot
(
DynamicUnion
::
Builder
unionBuilder
,
StructSchema
::
Member
unionMember
,
EnumSchema
enumMemberSchema
)
EnumSchema
enumMemberSchema
)
:
type
(
ENUM_UNION_MEMBER
),
union
Builder
(
unionBuilder
),
unionMember
(
unionMember
)
,
:
type
(
ENUM_UNION_MEMBER
),
union
_
{
unionBuilder
,
unionMember
}
,
enumMemberSchema
(
enumMemberSchema
)
{}
enumMemberSchema
(
enumMemberSchema
)
{}
DynamicStruct
::
Builder
initStruct
()
{
DynamicStruct
::
Builder
initStruct
()
{
switch
(
type
)
{
switch
(
type
)
{
case
FIELD
:
return
struct
Builder
.
init
(
member
).
as
<
DynamicStruct
>
();
case
FIELD
:
return
struct
_
.
builder
.
init
(
struct_
.
member
).
as
<
DynamicStruct
>
();
case
ELEMENT
:
return
list
Builder
[
index
].
as
<
DynamicStruct
>
();
case
ELEMENT
:
return
list
.
builder
[
list
.
index
].
as
<
DynamicStruct
>
();
case
UNION_MEMBER
:
return
union
Builder
.
init
(
unionM
ember
).
as
<
DynamicStruct
>
();
case
UNION_MEMBER
:
return
union
_
.
builder
.
init
(
union_
.
m
ember
).
as
<
DynamicStruct
>
();
case
STRUCT_OBJECT_UNION_MEMBER
:
case
STRUCT_OBJECT_UNION_MEMBER
:
return
union
Builder
.
initObject
(
unionM
ember
,
structMemberSchema
);
return
union
_
.
builder
.
initObject
(
union_
.
m
ember
,
structMemberSchema
);
case
LIST_OBJECT_UNION_MEMBER
:
KJ_FAIL_REQUIRE
(
"Type mismatch."
);
case
LIST_OBJECT_UNION_MEMBER
:
KJ_FAIL_REQUIRE
(
"Type mismatch."
);
case
ENUM_UNION_MEMBER
:
KJ_FAIL_REQUIRE
(
"Type mismatch."
);
case
ENUM_UNION_MEMBER
:
KJ_FAIL_REQUIRE
(
"Type mismatch."
);
}
}
...
@@ -1330,12 +1330,12 @@ public:
...
@@ -1330,12 +1330,12 @@ public:
DynamicList
::
Builder
initList
(
uint
size
)
{
DynamicList
::
Builder
initList
(
uint
size
)
{
switch
(
type
)
{
switch
(
type
)
{
case
FIELD
:
return
struct
Builder
.
init
(
member
,
size
).
as
<
DynamicList
>
();
case
FIELD
:
return
struct
_
.
builder
.
init
(
struct_
.
member
,
size
).
as
<
DynamicList
>
();
case
ELEMENT
:
return
list
Builder
.
init
(
index
,
size
).
as
<
DynamicList
>
();
case
ELEMENT
:
return
list
.
builder
.
init
(
list
.
index
,
size
).
as
<
DynamicList
>
();
case
UNION_MEMBER
:
return
union
Builder
.
init
(
unionM
ember
,
size
).
as
<
DynamicList
>
();
case
UNION_MEMBER
:
return
union
_
.
builder
.
init
(
union_
.
m
ember
,
size
).
as
<
DynamicList
>
();
case
STRUCT_OBJECT_UNION_MEMBER
:
KJ_FAIL_REQUIRE
(
"Type mismatch."
);
case
STRUCT_OBJECT_UNION_MEMBER
:
KJ_FAIL_REQUIRE
(
"Type mismatch."
);
case
LIST_OBJECT_UNION_MEMBER
:
case
LIST_OBJECT_UNION_MEMBER
:
return
union
Builder
.
initObject
(
unionM
ember
,
listMemberSchema
,
size
);
return
union
_
.
builder
.
initObject
(
union_
.
m
ember
,
listMemberSchema
,
size
);
case
ENUM_UNION_MEMBER
:
KJ_FAIL_REQUIRE
(
"Type mismatch."
);
case
ENUM_UNION_MEMBER
:
KJ_FAIL_REQUIRE
(
"Type mismatch."
);
}
}
KJ_FAIL_ASSERT
(
"can't get here"
);
KJ_FAIL_ASSERT
(
"can't get here"
);
...
@@ -1343,9 +1343,9 @@ public:
...
@@ -1343,9 +1343,9 @@ public:
DynamicUnion
::
Builder
getUnion
()
{
DynamicUnion
::
Builder
getUnion
()
{
switch
(
type
)
{
switch
(
type
)
{
case
FIELD
:
return
struct
Builder
.
get
(
member
).
as
<
DynamicUnion
>
();
case
FIELD
:
return
struct
_
.
builder
.
get
(
struct_
.
member
).
as
<
DynamicUnion
>
();
case
ELEMENT
:
KJ_FAIL_REQUIRE
(
"Type mismatch."
);
case
ELEMENT
:
KJ_FAIL_REQUIRE
(
"Type mismatch."
);
case
UNION_MEMBER
:
return
union
Builder
.
init
(
unionM
ember
).
as
<
DynamicUnion
>
();
case
UNION_MEMBER
:
return
union
_
.
builder
.
init
(
union_
.
m
ember
).
as
<
DynamicUnion
>
();
case
STRUCT_OBJECT_UNION_MEMBER
:
KJ_FAIL_REQUIRE
(
"Type mismatch."
);
case
STRUCT_OBJECT_UNION_MEMBER
:
KJ_FAIL_REQUIRE
(
"Type mismatch."
);
case
LIST_OBJECT_UNION_MEMBER
:
KJ_FAIL_REQUIRE
(
"Type mismatch."
);
case
LIST_OBJECT_UNION_MEMBER
:
KJ_FAIL_REQUIRE
(
"Type mismatch."
);
case
ENUM_UNION_MEMBER
:
KJ_FAIL_REQUIRE
(
"Type mismatch."
);
case
ENUM_UNION_MEMBER
:
KJ_FAIL_REQUIRE
(
"Type mismatch."
);
...
@@ -1355,13 +1355,13 @@ public:
...
@@ -1355,13 +1355,13 @@ public:
void
set
(
DynamicValue
::
Reader
value
)
{
void
set
(
DynamicValue
::
Reader
value
)
{
switch
(
type
)
{
switch
(
type
)
{
case
FIELD
:
struct
Builder
.
set
(
member
,
value
);
return
;
case
FIELD
:
struct
_
.
builder
.
set
(
struct_
.
member
,
value
);
return
;
case
ELEMENT
:
list
Builder
.
set
(
index
,
value
);
return
;
case
ELEMENT
:
list
.
builder
.
set
(
list
.
index
,
value
);
return
;
case
UNION_MEMBER
:
union
Builder
.
set
(
unionM
ember
,
value
);
return
;
case
UNION_MEMBER
:
union
_
.
builder
.
set
(
union_
.
m
ember
,
value
);
return
;
case
STRUCT_OBJECT_UNION_MEMBER
:
union
Builder
.
set
(
unionM
ember
,
value
);
return
;
case
STRUCT_OBJECT_UNION_MEMBER
:
union
_
.
builder
.
set
(
union_
.
m
ember
,
value
);
return
;
case
LIST_OBJECT_UNION_MEMBER
:
union
Builder
.
set
(
unionM
ember
,
value
);
return
;
case
LIST_OBJECT_UNION_MEMBER
:
union
_
.
builder
.
set
(
union_
.
m
ember
,
value
);
return
;
case
ENUM_UNION_MEMBER
:
case
ENUM_UNION_MEMBER
:
union
Builder
.
set
(
unionM
ember
,
value
.
as
<
DynamicEnum
>
().
getRaw
());
union
_
.
builder
.
set
(
union_
.
m
ember
,
value
.
as
<
DynamicEnum
>
().
getRaw
());
return
;
return
;
}
}
KJ_FAIL_ASSERT
(
"can't get here"
);
KJ_FAIL_ASSERT
(
"can't get here"
);
...
@@ -1373,14 +1373,14 @@ public:
...
@@ -1373,14 +1373,14 @@ public:
// This is really ugly.
// This is really ugly.
switch
(
type
)
{
switch
(
type
)
{
case
FIELD
:
return
enumIdForMember
(
member
);
case
FIELD
:
return
enumIdForMember
(
struct_
.
member
);
case
ELEMENT
:
{
case
ELEMENT
:
{
if
(
list
B
uilder
.
getSchema
().
whichElementType
()
==
schema
::
Type
::
Body
::
ENUM_TYPE
)
{
if
(
list
.
b
uilder
.
getSchema
().
whichElementType
()
==
schema
::
Type
::
Body
::
ENUM_TYPE
)
{
return
list
B
uilder
.
getSchema
().
getEnumElementType
().
getProto
().
getId
();
return
list
.
b
uilder
.
getSchema
().
getEnumElementType
().
getProto
().
getId
();
}
}
return
nullptr
;
return
nullptr
;
}
}
case
UNION_MEMBER
:
return
enumIdForMember
(
union
M
ember
);
case
UNION_MEMBER
:
return
enumIdForMember
(
union
_
.
m
ember
);
case
STRUCT_OBJECT_UNION_MEMBER
:
return
nullptr
;
case
STRUCT_OBJECT_UNION_MEMBER
:
return
nullptr
;
case
LIST_OBJECT_UNION_MEMBER
:
return
nullptr
;
case
LIST_OBJECT_UNION_MEMBER
:
return
nullptr
;
case
ENUM_UNION_MEMBER
:
return
enumMemberSchema
.
getProto
().
getId
();
case
ENUM_UNION_MEMBER
:
return
enumMemberSchema
.
getProto
().
getId
();
...
@@ -1397,22 +1397,23 @@ private:
...
@@ -1397,22 +1397,23 @@ private:
union
{
union
{
struct
{
struct
{
DynamicStruct
::
Builder
structB
uilder
;
DynamicStruct
::
Builder
b
uilder
;
StructSchema
::
Member
member
;
StructSchema
::
Member
member
;
};
}
struct_
;
struct
{
struct
{
DynamicList
::
Builder
listB
uilder
;
DynamicList
::
Builder
b
uilder
;
uint
index
;
uint
index
;
};
}
list
;
struct
{
struct
{
DynamicUnion
::
Builder
unionBuilder
;
DynamicUnion
::
Builder
builder
;
StructSchema
::
Member
unionMember
;
StructSchema
::
Member
member
;
union
{
}
union_
;
StructSchema
structMemberSchema
;
};
ListSchema
listMemberSchema
;
EnumSchema
enumMemberSchema
;
union
{
};
StructSchema
structMemberSchema
;
};
ListSchema
listMemberSchema
;
EnumSchema
enumMemberSchema
;
};
};
static
kj
::
Maybe
<
uint64_t
>
enumIdForMember
(
StructSchema
::
Member
member
)
{
static
kj
::
Maybe
<
uint64_t
>
enumIdForMember
(
StructSchema
::
Member
member
)
{
...
...
c++/src/capnp/encoding-test.c++
View file @
d75e6a31
...
@@ -1378,7 +1378,7 @@ TEST(Encoding, Threads) {
...
@@ -1378,7 +1378,7 @@ TEST(Encoding, Threads) {
// Check that none of the values were corrupted.
// Check that none of the values were corrupted.
for
(
auto
item
:
list
.
getReader
())
{
for
(
auto
item
:
list
.
getReader
())
{
ASSERT_EQ
(
4
,
item
.
size
());
ASSERT_EQ
(
4
u
,
item
.
size
());
EXPECT_EQ
(
me
,
item
[
0
]);
EXPECT_EQ
(
me
,
item
[
0
]);
EXPECT_EQ
(
me
+
1
,
item
[
1
]);
EXPECT_EQ
(
me
+
1
,
item
[
1
]);
EXPECT_EQ
(
me
+
2
,
item
[
2
]);
EXPECT_EQ
(
me
+
2
,
item
[
2
]);
...
...
c++/src/kj/arena-test.c++
View file @
d75e6a31
...
@@ -115,8 +115,8 @@ TEST(Arena, Array) {
...
@@ -115,8 +115,8 @@ TEST(Arena, Array) {
Arena
arena
;
Arena
arena
;
ArrayPtr
<
TestObject
>
arr1
=
arena
.
allocateArray
<
TestObject
>
(
4
);
ArrayPtr
<
TestObject
>
arr1
=
arena
.
allocateArray
<
TestObject
>
(
4
);
ArrayPtr
<
TestObject
>
arr2
=
arena
.
allocateArray
<
TestObject
>
(
2
);
ArrayPtr
<
TestObject
>
arr2
=
arena
.
allocateArray
<
TestObject
>
(
2
);
EXPECT_EQ
(
4
,
arr1
.
size
());
EXPECT_EQ
(
4
u
,
arr1
.
size
());
EXPECT_EQ
(
2
,
arr2
.
size
());
EXPECT_EQ
(
2
u
,
arr2
.
size
());
EXPECT_LE
(
arr1
.
end
(),
arr2
.
begin
());
EXPECT_LE
(
arr1
.
end
(),
arr2
.
begin
());
EXPECT_EQ
(
6
,
TestObject
::
count
);
EXPECT_EQ
(
6
,
TestObject
::
count
);
}
}
...
@@ -142,8 +142,8 @@ TEST(Arena, OwnArray) {
...
@@ -142,8 +142,8 @@ TEST(Arena, OwnArray) {
{
{
Array
<
TestObject
>
arr1
=
arena
.
allocateOwnArray
<
TestObject
>
(
4
);
Array
<
TestObject
>
arr1
=
arena
.
allocateOwnArray
<
TestObject
>
(
4
);
Array
<
TestObject
>
arr2
=
arena
.
allocateOwnArray
<
TestObject
>
(
2
);
Array
<
TestObject
>
arr2
=
arena
.
allocateOwnArray
<
TestObject
>
(
2
);
EXPECT_EQ
(
4
,
arr1
.
size
());
EXPECT_EQ
(
4
u
,
arr1
.
size
());
EXPECT_EQ
(
2
,
arr2
.
size
());
EXPECT_EQ
(
2
u
,
arr2
.
size
());
EXPECT_LE
(
arr1
.
end
(),
arr2
.
begin
());
EXPECT_LE
(
arr1
.
end
(),
arr2
.
begin
());
EXPECT_EQ
(
6
,
TestObject
::
count
);
EXPECT_EQ
(
6
,
TestObject
::
count
);
}
}
...
@@ -191,9 +191,9 @@ TEST(Arena, Alignment) {
...
@@ -191,9 +191,9 @@ TEST(Arena, Alignment) {
char
&
c2
=
arena
.
allocate
<
char
>
();
char
&
c2
=
arena
.
allocate
<
char
>
();
ArrayPtr
<
char
>
arr
=
arena
.
allocateArray
<
char
>
(
8
);
ArrayPtr
<
char
>
arr
=
arena
.
allocateArray
<
char
>
(
8
);
EXPECT_EQ
(
alignof
(
long
)
+
sizeof
(
long
),
&
c2
-
&
c
);
EXPECT_EQ
(
alignof
(
long
)
+
sizeof
(
long
),
implicitCast
<
size_t
>
(
&
c2
-
&
c
)
);
EXPECT_EQ
(
alignof
(
long
),
reinterpret_cast
<
char
*>
(
&
l
)
-
&
c
);
EXPECT_EQ
(
alignof
(
long
),
implicitCast
<
size_t
>
(
reinterpret_cast
<
char
*>
(
&
l
)
-
&
c
)
);
EXPECT_EQ
(
sizeof
(
char
),
arr
.
begin
()
-
&
c2
);
EXPECT_EQ
(
sizeof
(
char
),
implicitCast
<
size_t
>
(
arr
.
begin
()
-
&
c2
)
);
}
}
TEST
(
Arena
,
EndOfChunk
)
{
TEST
(
Arena
,
EndOfChunk
)
{
...
@@ -285,7 +285,7 @@ TEST(Arena, MultiSegment) {
...
@@ -285,7 +285,7 @@ TEST(Arena, MultiSegment) {
TEST
(
Arena
,
Constructor
)
{
TEST
(
Arena
,
Constructor
)
{
Arena
arena
;
Arena
arena
;
EXPECT_EQ
(
123
,
arena
.
allocate
<
uint64_t
>
(
123
));
EXPECT_EQ
(
123
u
,
arena
.
allocate
<
uint64_t
>
(
123
));
EXPECT_EQ
(
"foo"
,
arena
.
allocate
<
StringPtr
>
(
"foo"
,
3
));
EXPECT_EQ
(
"foo"
,
arena
.
allocate
<
StringPtr
>
(
"foo"
,
3
));
}
}
...
@@ -366,10 +366,10 @@ TEST(Arena, Threads) {
...
@@ -366,10 +366,10 @@ TEST(Arena, Threads) {
// allowing all the threads to start running. We'll then join each thread.
// allowing all the threads to start running. We'll then join each thread.
}
}
EXPECT_EQ
(
0
,
ThreadTestObject
::
destructorCount
);
EXPECT_EQ
(
0
u
,
ThreadTestObject
::
destructorCount
);
}
}
EXPECT_EQ
(
400000
,
ThreadTestObject
::
destructorCount
);
EXPECT_EQ
(
400000
u
,
ThreadTestObject
::
destructorCount
);
}
}
}
// namespace
}
// namespace
...
...
c++/src/kj/arena.c++
View file @
d75e6a31
...
@@ -69,7 +69,7 @@ void Arena::State::cleanup() {
...
@@ -69,7 +69,7 @@ void Arena::State::cleanup() {
namespace
{
namespace
{
constexpr
bool
isPowerOfTwo
(
size_t
value
)
{
constexpr
bool
isPowerOfTwo
(
size_t
value
)
{
return
(
value
&
value
-
1
)
==
0
;
return
(
value
&
(
value
-
1
)
)
==
0
;
}
}
inline
byte
*
alignTo
(
byte
*
p
,
uint
alignment
)
{
inline
byte
*
alignTo
(
byte
*
p
,
uint
alignment
)
{
...
...
c++/src/kj/common-test.c++
View file @
d75e6a31
...
@@ -254,13 +254,13 @@ TEST(Common, Defer) {
...
@@ -254,13 +254,13 @@ TEST(Common, Defer) {
{
{
KJ_DEFER
(
++
i
);
KJ_DEFER
(
++
i
);
KJ_DEFER
(
j
+=
3
;
k
=
true
);
KJ_DEFER
(
j
+=
3
;
k
=
true
);
EXPECT_EQ
(
0
,
i
);
EXPECT_EQ
(
0
u
,
i
);
EXPECT_EQ
(
1
,
j
);
EXPECT_EQ
(
1
u
,
j
);
EXPECT_FALSE
(
k
);
EXPECT_FALSE
(
k
);
}
}
EXPECT_EQ
(
1
,
i
);
EXPECT_EQ
(
1
u
,
i
);
EXPECT_EQ
(
4
,
j
);
EXPECT_EQ
(
4
u
,
j
);
EXPECT_TRUE
(
k
);
EXPECT_TRUE
(
k
);
}
}
...
...
c++/src/kj/common.c++
View file @
d75e6a31
...
@@ -23,6 +23,7 @@
...
@@ -23,6 +23,7 @@
#include "common.h"
#include "common.h"
#include "debug.h"
#include "debug.h"
#include <stdlib.h>
namespace
kj
{
namespace
kj
{
namespace
_
{
// private
namespace
_
{
// private
...
@@ -38,5 +39,12 @@ void inlineRequireFailure(const char* file, int line, const char* expectation,
...
@@ -38,5 +39,12 @@ void inlineRequireFailure(const char* file, int line, const char* expectation,
}
}
}
}
void
unreachable
()
{
KJ_FAIL_ASSERT
(
"Supposendly-unreachable branch executed."
);
// Really make sure we abort.
abort
();
}
}
// namespace _ (private)
}
// namespace _ (private)
}
// namespace kj
}
// namespace kj
c++/src/kj/common.h
View file @
d75e6a31
...
@@ -134,6 +134,8 @@ void inlineRequireFailure(
...
@@ -134,6 +134,8 @@ void inlineRequireFailure(
const
char
*
file
,
int
line
,
const
char
*
expectation
,
const
char
*
macroArgs
,
const
char
*
file
,
int
line
,
const
char
*
expectation
,
const
char
*
macroArgs
,
const
char
*
message
=
nullptr
)
KJ_NORETURN
;
const
char
*
message
=
nullptr
)
KJ_NORETURN
;
void
unreachable
()
KJ_NORETURN
;
}
// namespace _ (private)
}
// namespace _ (private)
#ifdef NDEBUG
#ifdef NDEBUG
...
@@ -148,6 +150,16 @@ void inlineRequireFailure(
...
@@ -148,6 +150,16 @@ void inlineRequireFailure(
// whether libkj is.
// whether libkj is.
#endif
#endif
#define KJ_UNREACHABLE ::kj::_::unreachable();
// Put this on code paths that cannot be reached to suppress compiler warnings about missing
// returns.
#if __clang__
#define KJ_CLANG_KNOWS_THIS_IS_UNREACHABLE_BUT_GCC_DOESNT
#else
#define KJ_CLANG_KNOWS_THIS_IS_UNREACHABLE_BUT_GCC_DOESNT KJ_UNREACHABLE
#endif
// #define KJ_STACK_ARRAY(type, name, size, minStack, maxStack)
// #define KJ_STACK_ARRAY(type, name, size, minStack, maxStack)
//
//
// Allocate an array, preferably on the stack, unless it is too big. On GCC this will use
// Allocate an array, preferably on the stack, unless it is too big. On GCC this will use
...
...
c++/src/kj/function-test.c++
View file @
d75e6a31
...
@@ -59,7 +59,7 @@ TEST(Function, Method) {
...
@@ -59,7 +59,7 @@ TEST(Function, Method) {
EXPECT_EQ
(
123
+
456
,
f
(
123
,
456
));
EXPECT_EQ
(
123
+
456
,
f
(
123
,
456
));
EXPECT_EQ
(
7
+
8
+
1
,
f
(
7
,
8
));
EXPECT_EQ
(
7
+
8
+
1
,
f
(
7
,
8
));
EXPECT_EQ
(
9
+
2
+
2
,
f2
(
2
,
9
));
EXPECT_EQ
(
9
u
+
2u
+
2u
,
f2
(
2
,
9
));
EXPECT_EQ
(
3
,
obj
.
callCount
);
EXPECT_EQ
(
3
,
obj
.
callCount
);
...
...
c++/src/kj/function.h
View file @
d75e6a31
...
@@ -117,7 +117,7 @@ private:
...
@@ -117,7 +117,7 @@ private:
Own
<
Iface
>
impl
;
Own
<
Iface
>
impl
;
};
};
namespace
_
{
namespace
_
{
// private
template
<
typename
T
>
template
<
typename
T
>
T
rvalueOrRef
(
T
&&
);
T
rvalueOrRef
(
T
&&
);
...
@@ -128,7 +128,47 @@ T rvalueOrRef(T&&);
...
@@ -128,7 +128,47 @@ T rvalueOrRef(T&&);
// decltype(rvalueOrRef(i)) i2(i); // i2 has type int&.
// decltype(rvalueOrRef(i)) i2(i); // i2 has type int&.
// decltype(rvalueOrRef(kj::mv(i)) i3(kj::mv(i)); // i3 has type int.
// decltype(rvalueOrRef(kj::mv(i)) i3(kj::mv(i)); // i3 has type int.
}
// namespace _
}
// namespace _ (private)
#if 1
namespace
_
{
// private
template
<
typename
T
,
typename
Signature
,
Signature
method
>
class
BoundMethod
;
template
<
typename
T
,
typename
Return
,
typename
...
Params
,
Return
(
Decay
<
T
>::*
method
)(
Params
...)
>
class
BoundMethod
<
T
,
Return
(
Decay
<
T
>::*
)(
Params
...),
method
>
{
public
:
BoundMethod
(
T
&&
t
)
:
t
(
kj
::
fwd
<
T
>
(
t
))
{}
Return
operator
()(
Params
&&
...
params
)
{
return
(
t
.
*
method
)(
kj
::
fwd
<
Params
>
(
params
)...);
}
private
:
T
t
;
};
}
// namespace _ (private)
#define KJ_BIND_METHOD(obj, method) \
::kj::_::BoundMethod<decltype(::kj::_::rvalueOrRef(obj)), \
decltype(&::kj::Decay<decltype(obj)>::method), \
&::kj::Decay<decltype(obj)>::method>(obj)
// Macro that produces a functor object which forwards to the method `obj.name`. If `obj` is an
// lvalue, the functor will hold a reference to it. If `obj` is an rvalue, the functor will
// contain a copy (by move) of it.
//
// The current implementation requires that the method is not overloaded.
//
// TODO(someday): C++14's generic lambdas may be able to simplify this code considerably, and
// probably make it work with overloaded methods.
#else
// Here's a better implementation of the above that doesn't work with GCC (but does with Clang)
// because it uses a local class with a template method. Sigh. This implementation supports
// overloaded methods.
#define KJ_BIND_METHOD(obj, method) \
#define KJ_BIND_METHOD(obj, method) \
({ \
({ \
...
@@ -150,6 +190,8 @@ T rvalueOrRef(T&&);
...
@@ -150,6 +190,8 @@ T rvalueOrRef(T&&);
// lvalue, the functor will hold a reference to it. If `obj` is an rvalue, the functor will
// lvalue, the functor will hold a reference to it. If `obj` is an rvalue, the functor will
// contain a copy (by move) of it.
// contain a copy (by move) of it.
#endif
}
// namespace kj
}
// namespace kj
#endif // KJ_FUNCTION_H_
#endif // KJ_FUNCTION_H_
c++/src/kj/main.c++
View file @
d75e6a31
...
@@ -161,6 +161,7 @@ int runMainAndExit(ProcessContext& context, MainFunc&& func, int argc, char* arg
...
@@ -161,6 +161,7 @@ int runMainAndExit(ProcessContext& context, MainFunc&& func, int argc, char* arg
return
e
.
exitCode
;
return
e
.
exitCode
;
}
}
#endif
#endif
KJ_CLANG_KNOWS_THIS_IS_UNREACHABLE_BUT_GCC_DOESNT
}
}
// =======================================================================================
// =======================================================================================
...
@@ -520,6 +521,7 @@ void MainBuilder::MainImpl::usageError(StringPtr programName, StringPtr message)
...
@@ -520,6 +521,7 @@ void MainBuilder::MainImpl::usageError(StringPtr programName, StringPtr message)
impl
->
context
.
exitError
(
kj
::
str
(
impl
->
context
.
exitError
(
kj
::
str
(
programName
,
": "
,
message
,
programName
,
": "
,
message
,
"
\n
Try '"
,
programName
,
" --help' for more information."
));
"
\n
Try '"
,
programName
,
" --help' for more information."
));
KJ_CLANG_KNOWS_THIS_IS_UNREACHABLE_BUT_GCC_DOESNT
}
}
class
MainBuilder
::
Impl
::
OptionDisplayOrder
{
class
MainBuilder
::
Impl
::
OptionDisplayOrder
{
...
@@ -662,6 +664,7 @@ void MainBuilder::MainImpl::printHelp(StringPtr programName) {
...
@@ -662,6 +664,7 @@ void MainBuilder::MainImpl::printHelp(StringPtr programName) {
text
.
add
(
'\0'
);
text
.
add
(
'\0'
);
impl
->
context
.
exitInfo
(
String
(
text
.
releaseAsArray
()));
impl
->
context
.
exitInfo
(
String
(
text
.
releaseAsArray
()));
KJ_CLANG_KNOWS_THIS_IS_UNREACHABLE_BUT_GCC_DOESNT
}
}
void
MainBuilder
::
MainImpl
::
wrapText
(
Vector
<
char
>&
output
,
StringPtr
indent
,
StringPtr
text
)
{
void
MainBuilder
::
MainImpl
::
wrapText
(
Vector
<
char
>&
output
,
StringPtr
indent
,
StringPtr
text
)
{
...
...
c++/src/kj/main.h
View file @
d75e6a31
...
@@ -84,11 +84,11 @@ public:
...
@@ -84,11 +84,11 @@ public:
// are easily confused by quick_exit().
// are easily confused by quick_exit().
StringPtr
getProgramName
()
override
;
StringPtr
getProgramName
()
override
;
void
exit
()
KJ_NORETURN
override
;
void
exit
()
override
KJ_NORETURN
;
void
warning
(
StringPtr
message
)
override
;
void
warning
(
StringPtr
message
)
override
;
void
error
(
StringPtr
message
)
override
;
void
error
(
StringPtr
message
)
override
;
void
exitError
(
StringPtr
message
)
KJ_NORETURN
override
;
void
exitError
(
StringPtr
message
)
override
KJ_NORETURN
;
void
exitInfo
(
StringPtr
message
)
KJ_NORETURN
override
;
void
exitInfo
(
StringPtr
message
)
override
KJ_NORETURN
;
void
increaseLoggingVerbosity
()
override
;
void
increaseLoggingVerbosity
()
override
;
private
:
private
:
...
@@ -192,8 +192,8 @@ public:
...
@@ -192,8 +192,8 @@ public:
class
OptionName
{
class
OptionName
{
public
:
public
:
OptionName
()
=
default
;
OptionName
()
=
default
;
inline
constexpr
OptionName
(
char
shortName
)
:
isLong
(
false
),
shortName
(
shortName
)
{}
inline
OptionName
(
char
shortName
)
:
isLong
(
false
),
shortName
(
shortName
)
{}
inline
constexpr
OptionName
(
const
char
*
longName
)
:
isLong
(
true
),
longName
(
longName
)
{}
inline
OptionName
(
const
char
*
longName
)
:
isLong
(
true
),
longName
(
longName
)
{}
private
:
private
:
bool
isLong
;
bool
isLong
;
...
...
c++/src/kj/mutex-test.c++
View file @
d75e6a31
...
@@ -38,32 +38,32 @@ TEST(Mutex, MutexGuarded) {
...
@@ -38,32 +38,32 @@ TEST(Mutex, MutexGuarded) {
{
{
Locked
<
uint
>
lock
=
value
.
lockExclusive
();
Locked
<
uint
>
lock
=
value
.
lockExclusive
();
EXPECT_EQ
(
123
,
*
lock
);
EXPECT_EQ
(
123
u
,
*
lock
);
Thread
thread
([
&
]()
{
Thread
thread
([
&
]()
{
Locked
<
uint
>
threadLock
=
value
.
lockExclusive
();
Locked
<
uint
>
threadLock
=
value
.
lockExclusive
();
EXPECT_EQ
(
456
,
*
threadLock
);
EXPECT_EQ
(
456
u
,
*
threadLock
);
*
threadLock
=
789
;
*
threadLock
=
789
;
});
});
delay
();
delay
();
EXPECT_EQ
(
123
,
*
lock
);
EXPECT_EQ
(
123
u
,
*
lock
);
*
lock
=
456
;
*
lock
=
456
;
auto
earlyRelease
=
kj
::
mv
(
lock
);
auto
earlyRelease
=
kj
::
mv
(
lock
);
}
}
EXPECT_EQ
(
789
,
*
value
.
lockExclusive
());
EXPECT_EQ
(
789
u
,
*
value
.
lockExclusive
());
{
{
auto
rlock1
=
value
.
lockShared
();
auto
rlock1
=
value
.
lockShared
();
{
{
auto
rlock2
=
value
.
lockShared
();
auto
rlock2
=
value
.
lockShared
();
EXPECT_EQ
(
789
,
*
rlock2
);
EXPECT_EQ
(
789
u
,
*
rlock2
);
auto
rlock3
=
value
.
lockShared
();
auto
rlock3
=
value
.
lockShared
();
EXPECT_EQ
(
789
,
*
rlock3
);
EXPECT_EQ
(
789
u
,
*
rlock3
);
auto
rlock4
=
value
.
lockShared
();
auto
rlock4
=
value
.
lockShared
();
EXPECT_EQ
(
789
,
*
rlock4
);
EXPECT_EQ
(
789
u
,
*
rlock4
);
}
}
Thread
thread2
([
&
]()
{
Thread
thread2
([
&
]()
{
...
@@ -80,24 +80,24 @@ TEST(Mutex, MutexGuarded) {
...
@@ -80,24 +80,24 @@ TEST(Mutex, MutexGuarded) {
// but we'll leave this test here until then to make sure we notice the change.
// but we'll leave this test here until then to make sure we notice the change.
delay
();
delay
();
EXPECT_EQ
(
789
,
*
rlock1
);
EXPECT_EQ
(
789
u
,
*
rlock1
);
{
{
auto
rlock2
=
value
.
lockShared
();
auto
rlock2
=
value
.
lockShared
();
EXPECT_EQ
(
789
,
*
rlock2
);
EXPECT_EQ
(
789
u
,
*
rlock2
);
auto
rlock3
=
value
.
lockShared
();
auto
rlock3
=
value
.
lockShared
();
EXPECT_EQ
(
789
,
*
rlock3
);
EXPECT_EQ
(
789
u
,
*
rlock3
);
auto
rlock4
=
value
.
lockShared
();
auto
rlock4
=
value
.
lockShared
();
EXPECT_EQ
(
789
,
*
rlock4
);
EXPECT_EQ
(
789
u
,
*
rlock4
);
}
}
#endif
#endif
delay
();
delay
();
EXPECT_EQ
(
789
,
*
rlock1
);
EXPECT_EQ
(
789
u
,
*
rlock1
);
auto
earlyRelease
=
kj
::
mv
(
rlock1
);
auto
earlyRelease
=
kj
::
mv
(
rlock1
);
}
}
EXPECT_EQ
(
321
,
*
value
.
lockExclusive
());
EXPECT_EQ
(
321
u
,
*
value
.
lockExclusive
());
}
}
TEST
(
Mutex
,
Lazy
)
{
TEST
(
Mutex
,
Lazy
)
{
...
@@ -105,7 +105,7 @@ TEST(Mutex, Lazy) {
...
@@ -105,7 +105,7 @@ TEST(Mutex, Lazy) {
bool
initStarted
=
false
;
bool
initStarted
=
false
;
Thread
thread
([
&
]()
{
Thread
thread
([
&
]()
{
EXPECT_EQ
(
123
,
lazy
.
get
([
&
](
SpaceFor
<
uint
>&
space
)
->
Own
<
uint
>
{
EXPECT_EQ
(
123
u
,
lazy
.
get
([
&
](
SpaceFor
<
uint
>&
space
)
->
Own
<
uint
>
{
__atomic_store_n
(
&
initStarted
,
true
,
__ATOMIC_RELAXED
);
__atomic_store_n
(
&
initStarted
,
true
,
__ATOMIC_RELAXED
);
delay
();
delay
();
return
space
.
construct
(
123
);
return
space
.
construct
(
123
);
...
@@ -117,8 +117,8 @@ TEST(Mutex, Lazy) {
...
@@ -117,8 +117,8 @@ TEST(Mutex, Lazy) {
sched_yield
();
sched_yield
();
}
}
EXPECT_EQ
(
123
,
lazy
.
get
([](
SpaceFor
<
uint
>&
space
)
{
return
space
.
construct
(
456
);
}));
EXPECT_EQ
(
123
u
,
lazy
.
get
([](
SpaceFor
<
uint
>&
space
)
{
return
space
.
construct
(
456
);
}));
EXPECT_EQ
(
123
,
lazy
.
get
([](
SpaceFor
<
uint
>&
space
)
{
return
space
.
construct
(
789
);
}));
EXPECT_EQ
(
123
u
,
lazy
.
get
([](
SpaceFor
<
uint
>&
space
)
{
return
space
.
construct
(
789
);
}));
}
}
}
// namespace
}
// namespace
...
...
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