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
e6d4a915
Commit
e6d4a915
authored
May 25, 2012
by
Jesse Beder
Browse files
Switched the ostream wrapper to wrap a std::vector<char> instead of our manually managed memory
parent
7c85e9d5
Changes
3
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
17 additions
and
41 deletions
+17
-41
include/yaml-cpp/ostream_wrapper.h
include/yaml-cpp/ostream_wrapper.h
+8
-6
src/ostream_wrapper.cpp
src/ostream_wrapper.cpp
+7
-34
util/sandbox.cpp
util/sandbox.cpp
+2
-1
No files found.
include/yaml-cpp/ostream_wrapper.h
View file @
e6d4a915
...
@@ -7,6 +7,7 @@
...
@@ -7,6 +7,7 @@
#include <string>
#include <string>
#include <vector>
namespace
YAML
namespace
YAML
{
{
...
@@ -16,13 +17,15 @@ namespace YAML
...
@@ -16,13 +17,15 @@ namespace YAML
ostream_wrapper
();
ostream_wrapper
();
~
ostream_wrapper
();
~
ostream_wrapper
();
void
reserve
(
std
::
size_t
size
);
void
write
(
const
std
::
string
&
str
);
void
write
(
const
std
::
string
&
str
);
void
write
(
const
char
*
str
,
std
::
size_t
size
);
void
write
(
const
char
*
str
,
std
::
size_t
size
);
void
put
(
char
ch
);
void
set_comment
()
{
m_comment
=
true
;
}
void
set_comment
()
{
m_comment
=
true
;
}
const
char
*
str
()
const
{
return
m_buffer
;
}
const
char
*
str
()
const
{
m_buffer
[
m_pos
]
=
NULL
;
return
&
m_buffer
[
0
];
}
std
::
size_t
row
()
const
{
return
m_row
;
}
std
::
size_t
row
()
const
{
return
m_row
;
}
std
::
size_t
col
()
const
{
return
m_col
;
}
std
::
size_t
col
()
const
{
return
m_col
;
}
...
@@ -33,10 +36,9 @@ namespace YAML
...
@@ -33,10 +36,9 @@ namespace YAML
void
update_pos
(
char
ch
);
void
update_pos
(
char
ch
);
private:
private:
char
*
m_buffer
;
mutable
std
::
vector
<
char
>
m_buffer
;
std
::
size_t
m_pos
;
std
::
size_t
m_pos
;
std
::
size_t
m_size
;
std
::
size_t
m_row
,
m_col
;
std
::
size_t
m_row
,
m_col
;
bool
m_comment
;
bool
m_comment
;
};
};
...
...
src/ostream_wrapper.cpp
View file @
e6d4a915
#include "yaml-cpp/ostream_wrapper.h"
#include "yaml-cpp/ostream_wrapper.h"
#include <cstring>
#include <cstring>
#include <iostream>
namespace
YAML
namespace
YAML
{
{
ostream_wrapper
::
ostream_wrapper
()
:
m_
buffer
(
0
),
m_pos
(
0
),
m_size
(
0
),
m_row
(
0
),
m_col
(
0
),
m_comment
(
false
)
ostream_wrapper
::
ostream_wrapper
()
:
m_
pos
(
0
),
m_row
(
0
),
m_col
(
0
),
m_comment
(
false
)
{
{
reserve
(
1024
);
}
}
ostream_wrapper
::~
ostream_wrapper
()
ostream_wrapper
::~
ostream_wrapper
()
{
{
delete
[]
m_buffer
;
}
}
void
ostream_wrapper
::
reserve
(
std
::
size_t
size
)
{
if
(
size
<=
m_size
)
return
;
char
*
newBuffer
=
new
char
[
size
];
std
::
memset
(
newBuffer
,
0
,
size
*
sizeof
(
char
));
std
::
memcpy
(
newBuffer
,
m_buffer
,
m_size
*
sizeof
(
char
));
delete
[]
m_buffer
;
m_buffer
=
newBuffer
;
m_size
=
size
;
}
void
ostream_wrapper
::
write
(
const
std
::
string
&
str
)
void
ostream_wrapper
::
write
(
const
std
::
string
&
str
)
{
{
while
(
m_pos
+
str
.
size
()
+
1
>=
m_size
)
m_buffer
.
resize
(
std
::
max
(
m_buffer
.
size
(),
m_pos
+
str
.
size
()
+
1
));
reserve
(
m_size
*
2
);
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
]);
...
@@ -39,24 +23,13 @@ namespace YAML
...
@@ -39,24 +23,13 @@ namespace YAML
void
ostream_wrapper
::
write
(
const
char
*
str
,
std
::
size_t
size
)
void
ostream_wrapper
::
write
(
const
char
*
str
,
std
::
size_t
size
)
{
{
while
(
m_pos
+
size
+
1
>=
m_size
)
m_buffer
.
resize
(
std
::
max
(
m_buffer
.
size
(),
m_pos
+
size
+
1
));
reserve
(
m_size
*
2
);
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
::
put
(
char
ch
)
{
if
(
m_pos
>=
m_size
-
1
)
// an extra space for the NULL terminator
reserve
(
m_size
*
2
);
m_buffer
[
m_pos
]
=
ch
;
update_pos
(
ch
);
}
void
ostream_wrapper
::
update_pos
(
char
ch
)
void
ostream_wrapper
::
update_pos
(
char
ch
)
{
{
m_pos
++
;
m_pos
++
;
...
@@ -83,7 +56,7 @@ namespace YAML
...
@@ -83,7 +56,7 @@ namespace YAML
ostream_wrapper
&
operator
<<
(
ostream_wrapper
&
out
,
char
ch
)
ostream_wrapper
&
operator
<<
(
ostream_wrapper
&
out
,
char
ch
)
{
{
out
.
put
(
ch
);
out
.
write
(
&
ch
,
1
);
return
out
;
return
out
;
}
}
}
}
util/sandbox.cpp
View file @
e6d4a915
...
@@ -5,7 +5,8 @@ int main()
...
@@ -5,7 +5,8 @@ int main()
{
{
YAML
::
Emitter
out
;
YAML
::
Emitter
out
;
out
<<
YAML
::
BeginSeq
;
out
<<
YAML
::
BeginSeq
;
out
<<
':'
;
out
<<
"item 1"
;
out
<<
YAML
::
BeginSeq
<<
"foo 1"
<<
"bar 2"
<<
YAML
::
EndSeq
;
out
<<
YAML
::
EndSeq
;
out
<<
YAML
::
EndSeq
;
std
::
cout
<<
out
.
c_str
()
<<
"
\n
"
;
std
::
cout
<<
out
.
c_str
()
<<
"
\n
"
;
...
...
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