Skip to content
GitLab
Menu
Projects
Groups
Snippets
Loading...
Help
Help
Support
Community forum
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
Menu
Open sidebar
gaoqiong
yaml-cpp
Commits
d98ab9f3
Commit
d98ab9f3
authored
Mar 22, 2014
by
Jesse Beder
Browse files
Merge ostream_wrapper fix from core
parents
9583d1ab
0fbeac8f
Changes
4
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
74 additions
and
6 deletions
+74
-6
include/yaml-cpp/ostream_wrapper.h
include/yaml-cpp/ostream_wrapper.h
+1
-1
src/ostream_wrapper.cpp
src/ostream_wrapper.cpp
+5
-3
test/CMakeLists.txt
test/CMakeLists.txt
+2
-2
test/ostream_wrapper_test.cpp
test/ostream_wrapper_test.cpp
+66
-0
No files found.
include/yaml-cpp/ostream_wrapper.h
View file @
d98ab9f3
...
@@ -41,7 +41,7 @@ class ostream_wrapper {
...
@@ -41,7 +41,7 @@ class ostream_wrapper {
private:
private:
mutable
std
::
vector
<
char
>
m_buffer
;
mutable
std
::
vector
<
char
>
m_buffer
;
std
::
ostream
*
m_pStream
;
std
::
ostream
*
const
m_pStream
;
std
::
size_t
m_pos
;
std
::
size_t
m_pos
;
std
::
size_t
m_row
,
m_col
;
std
::
size_t
m_row
,
m_col
;
...
...
src/ostream_wrapper.cpp
View file @
d98ab9f3
...
@@ -4,7 +4,7 @@
...
@@ -4,7 +4,7 @@
namespace
YAML
{
namespace
YAML
{
ostream_wrapper
::
ostream_wrapper
()
ostream_wrapper
::
ostream_wrapper
()
:
m_buffer
(
1
),
:
m_buffer
(
1
,
'\0'
),
m_pStream
(
0
),
m_pStream
(
0
),
m_pos
(
0
),
m_pos
(
0
),
m_row
(
0
),
m_row
(
0
),
...
@@ -24,8 +24,9 @@ void ostream_wrapper::write(const std::string& str) {
...
@@ -24,8 +24,9 @@ void ostream_wrapper::write(const std::string& str) {
std
::
copy
(
str
.
begin
(),
str
.
end
(),
&
m_buffer
[
m_pos
]);
std
::
copy
(
str
.
begin
(),
str
.
end
(),
&
m_buffer
[
m_pos
]);
}
}
for
(
std
::
size_t
i
=
0
;
i
<
str
.
size
();
i
++
)
for
(
std
::
size_t
i
=
0
;
i
<
str
.
size
();
i
++
)
{
update_pos
(
str
[
i
]);
update_pos
(
str
[
i
]);
}
}
}
void
ostream_wrapper
::
write
(
const
char
*
str
,
std
::
size_t
size
)
{
void
ostream_wrapper
::
write
(
const
char
*
str
,
std
::
size_t
size
)
{
...
@@ -36,8 +37,9 @@ void ostream_wrapper::write(const char* str, std::size_t size) {
...
@@ -36,8 +37,9 @@ void ostream_wrapper::write(const char* str, std::size_t size) {
std
::
copy
(
str
,
str
+
size
,
&
m_buffer
[
m_pos
]);
std
::
copy
(
str
,
str
+
size
,
&
m_buffer
[
m_pos
]);
}
}
for
(
std
::
size_t
i
=
0
;
i
<
size
;
i
++
)
for
(
std
::
size_t
i
=
0
;
i
<
size
;
i
++
)
{
update_pos
(
str
[
i
]);
update_pos
(
str
[
i
]);
}
}
}
void
ostream_wrapper
::
update_pos
(
char
ch
)
{
void
ostream_wrapper
::
update_pos
(
char
ch
)
{
...
...
test/CMakeLists.txt
View file @
d98ab9f3
add_subdirectory
(
gtest-1.7.0
)
add_subdirectory
(
gtest-1.7.0
)
include_directories
(
gtest-1.7.0/include
)
include_directories
(
gtest-1.7.0/include
)
file
(
GLOB test_headers [a-z]*.h
)
file
(
GLOB test_headers [a-z
_
]*.h
)
file
(
GLOB test_sources [a-z]*.cpp
)
file
(
GLOB test_sources [a-z
_
]*.cpp
)
file
(
GLOB test_new_api_sources new-api/[a-z]*.cpp
)
file
(
GLOB test_new_api_sources new-api/[a-z]*.cpp
)
list
(
APPEND test_sources
${
test_new_api_sources
}
)
list
(
APPEND test_sources
${
test_new_api_sources
}
)
...
...
test/ostream_wrapper_test.cpp
0 → 100644
View file @
d98ab9f3
#include "yaml-cpp/ostream_wrapper.h"
#include <sstream>
#include "gtest/gtest.h"
namespace
{
TEST
(
OstreamWrapperTest
,
BufferNoWrite
)
{
YAML
::
ostream_wrapper
wrapper
;
EXPECT_STREQ
(
""
,
wrapper
.
str
());
}
TEST
(
OstreamWrapperTest
,
BufferWriteStr
)
{
YAML
::
ostream_wrapper
wrapper
;
wrapper
.
write
(
std
::
string
(
"Hello, world"
));
EXPECT_STREQ
(
"Hello, world"
,
wrapper
.
str
());
}
TEST
(
OstreamWrapperTest
,
BufferWriteCStr
)
{
YAML
::
ostream_wrapper
wrapper
;
wrapper
.
write
(
"Hello, world"
);
EXPECT_STREQ
(
"Hello, world"
,
wrapper
.
str
());
}
TEST
(
OstreamWrapperTest
,
StreamNoWrite
)
{
std
::
stringstream
stream
;
YAML
::
ostream_wrapper
wrapper
(
stream
);
EXPECT_STREQ
(
NULL
,
wrapper
.
str
());
EXPECT_EQ
(
""
,
stream
.
str
());
}
TEST
(
OstreamWrapperTest
,
StreamWriteStr
)
{
std
::
stringstream
stream
;
YAML
::
ostream_wrapper
wrapper
(
stream
);
wrapper
.
write
(
std
::
string
(
"Hello, world"
));
EXPECT_STREQ
(
NULL
,
wrapper
.
str
());
EXPECT_EQ
(
"Hello, world"
,
stream
.
str
());
}
TEST
(
OstreamWrapperTest
,
StreamWriteCStr
)
{
std
::
stringstream
stream
;
YAML
::
ostream_wrapper
wrapper
(
stream
);
wrapper
.
write
(
"Hello, world"
);
EXPECT_STREQ
(
NULL
,
wrapper
.
str
());
EXPECT_EQ
(
"Hello, world"
,
stream
.
str
());
}
TEST
(
OstreamWrapperTest
,
Position
)
{
YAML
::
ostream_wrapper
wrapper
;
wrapper
.
write
(
"Hello, world
\n
"
);
EXPECT_EQ
(
1
,
wrapper
.
row
());
EXPECT_EQ
(
0
,
wrapper
.
col
());
EXPECT_EQ
(
13
,
wrapper
.
pos
());
}
TEST
(
OstreamWrapperTest
,
Comment
)
{
YAML
::
ostream_wrapper
wrapper
;
wrapper
.
write
(
"Hello, world "
);
wrapper
.
set_comment
();
EXPECT_TRUE
(
wrapper
.
comment
());
wrapper
.
write
(
"foo"
);
EXPECT_TRUE
(
wrapper
.
comment
());
wrapper
.
write
(
"
\n
"
);
EXPECT_FALSE
(
wrapper
.
comment
());
}
}
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