mirror of
https://github.com/jbeder/yaml-cpp.git
synced 2025-09-09 04:41:16 +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 <string>
|
||||||
|
#include <vector>
|
||||||
|
|
||||||
namespace YAML
|
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
|
|||||||
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_size;
|
|
||||||
|
|
||||||
|
std::size_t m_pos;
|
||||||
std::size_t m_row, m_col;
|
std::size_t m_row, m_col;
|
||||||
bool m_comment;
|
bool m_comment;
|
||||||
};
|
};
|
||||||
|
@@ -1,37 +1,21 @@
|
|||||||
#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
|
|||||||
|
|
||||||
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
|
|||||||
|
|
||||||
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;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@@ -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";
|
||||||
|
Reference in New Issue
Block a user