mirror of
https://github.com/jbeder/yaml-cpp.git
synced 2025-09-08 12:21:17 +00:00
Switched the ostream wrapper to wrap a std::vector<char> instead of our manually managed memory
This commit is contained in:
@@ -7,6 +7,7 @@
|
||||
|
||||
|
||||
#include <string>
|
||||
#include <vector>
|
||||
|
||||
namespace YAML
|
||||
{
|
||||
@@ -16,13 +17,15 @@ namespace YAML
|
||||
ostream_wrapper();
|
||||
~ostream_wrapper();
|
||||
|
||||
void reserve(std::size_t size);
|
||||
void write(const std::string& str);
|
||||
void write(const char *str, std::size_t size);
|
||||
void put(char ch);
|
||||
|
||||
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 col() const { return m_col; }
|
||||
@@ -33,10 +36,9 @@ namespace YAML
|
||||
void update_pos(char ch);
|
||||
|
||||
private:
|
||||
char *m_buffer;
|
||||
mutable std::vector<char> m_buffer;
|
||||
|
||||
std::size_t m_pos;
|
||||
std::size_t m_size;
|
||||
|
||||
std::size_t m_row, m_col;
|
||||
bool m_comment;
|
||||
};
|
||||
|
@@ -1,37 +1,21 @@
|
||||
#include "yaml-cpp/ostream_wrapper.h"
|
||||
#include <cstring>
|
||||
#include <iostream>
|
||||
|
||||
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()
|
||||
{
|
||||
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)
|
||||
{
|
||||
while(m_pos + str.size() + 1 >= m_size)
|
||||
reserve(m_size * 2);
|
||||
|
||||
std::copy(str.begin(), str.end(), m_buffer + m_pos);
|
||||
m_buffer.resize(std::max(m_buffer.size(), m_pos + str.size() + 1));
|
||||
std::copy(str.begin(), str.end(), &m_buffer[m_pos]);
|
||||
|
||||
for(std::size_t i=0;i<str.size();i++)
|
||||
update_pos(str[i]);
|
||||
@@ -39,24 +23,13 @@ namespace YAML
|
||||
|
||||
void ostream_wrapper::write(const char *str, std::size_t size)
|
||||
{
|
||||
while(m_pos + size + 1 >= m_size)
|
||||
reserve(m_size * 2);
|
||||
|
||||
std::copy(str, str + size, m_buffer + m_pos);
|
||||
m_buffer.resize(std::max(m_buffer.size(), m_pos + size + 1));
|
||||
std::copy(str, str + size, &m_buffer[m_pos]);
|
||||
|
||||
for(std::size_t i=0;i<size;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)
|
||||
{
|
||||
m_pos++;
|
||||
@@ -83,7 +56,7 @@ namespace YAML
|
||||
|
||||
ostream_wrapper& operator << (ostream_wrapper& out, char ch)
|
||||
{
|
||||
out.put(ch);
|
||||
out.write(&ch, 1);
|
||||
return out;
|
||||
}
|
||||
}
|
||||
|
@@ -5,7 +5,8 @@ int main()
|
||||
{
|
||||
YAML::Emitter out;
|
||||
out << YAML::BeginSeq;
|
||||
out << ':';
|
||||
out << "item 1";
|
||||
out << YAML::BeginSeq << "foo 1" << "bar 2" << YAML::EndSeq;
|
||||
out << YAML::EndSeq;
|
||||
|
||||
std::cout << out.c_str() << "\n";
|
||||
|
Reference in New Issue
Block a user