mirror of
https://github.com/jbeder/yaml-cpp.git
synced 2025-09-09 04:41:16 +00:00
Added constructor to the Emitter with a stream, so you can write directly to a stream instead of our temp
This commit is contained in:
@@ -25,6 +25,7 @@ namespace YAML
|
|||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
Emitter();
|
Emitter();
|
||||||
|
explicit Emitter(std::ostream& stream);
|
||||||
~Emitter();
|
~Emitter();
|
||||||
|
|
||||||
// output
|
// output
|
||||||
@@ -114,8 +115,8 @@ namespace YAML
|
|||||||
bool CanEmitNewline() const;
|
bool CanEmitNewline() const;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
ostream_wrapper m_stream;
|
|
||||||
std::auto_ptr<EmitterState> m_pState;
|
std::auto_ptr<EmitterState> m_pState;
|
||||||
|
ostream_wrapper m_stream;
|
||||||
};
|
};
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
|
@@ -15,6 +15,7 @@ namespace YAML
|
|||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
ostream_wrapper();
|
ostream_wrapper();
|
||||||
|
explicit ostream_wrapper(std::ostream& stream);
|
||||||
~ostream_wrapper();
|
~ostream_wrapper();
|
||||||
|
|
||||||
void write(const std::string& str);
|
void write(const std::string& str);
|
||||||
@@ -23,8 +24,12 @@ namespace YAML
|
|||||||
void set_comment() { m_comment = true; }
|
void set_comment() { m_comment = true; }
|
||||||
|
|
||||||
const char *str() const {
|
const char *str() const {
|
||||||
|
if(m_pStream) {
|
||||||
|
return NULL;
|
||||||
|
} else {
|
||||||
m_buffer[m_pos] = NULL;
|
m_buffer[m_pos] = NULL;
|
||||||
return &m_buffer[0];
|
return &m_buffer[0];
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
std::size_t row() const { return m_row; }
|
std::size_t row() const { return m_row; }
|
||||||
@@ -37,6 +42,7 @@ namespace YAML
|
|||||||
|
|
||||||
private:
|
private:
|
||||||
mutable std::vector<char> m_buffer;
|
mutable std::vector<char> m_buffer;
|
||||||
|
std::ostream *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;
|
||||||
|
@@ -11,6 +11,10 @@ namespace YAML
|
|||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Emitter::Emitter(std::ostream& stream): m_pState(new EmitterState), m_stream(stream)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
Emitter::~Emitter()
|
Emitter::~Emitter()
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
@@ -4,7 +4,11 @@
|
|||||||
|
|
||||||
namespace YAML
|
namespace YAML
|
||||||
{
|
{
|
||||||
ostream_wrapper::ostream_wrapper(): m_pos(0), m_row(0), m_col(0), m_comment(false)
|
ostream_wrapper::ostream_wrapper(): m_pStream(0), m_pos(0), m_row(0), m_col(0), m_comment(false)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
ostream_wrapper::ostream_wrapper(std::ostream& stream): m_pStream(&stream), m_pos(0), m_row(0), m_col(0), m_comment(false)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -14,8 +18,12 @@ namespace YAML
|
|||||||
|
|
||||||
void ostream_wrapper::write(const std::string& str)
|
void ostream_wrapper::write(const std::string& str)
|
||||||
{
|
{
|
||||||
|
if(m_pStream) {
|
||||||
|
m_pStream->write(str.c_str(), str.size());
|
||||||
|
} else {
|
||||||
m_buffer.resize(std::max(m_buffer.size(), m_pos + str.size() + 1));
|
m_buffer.resize(std::max(m_buffer.size(), m_pos + str.size() + 1));
|
||||||
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]);
|
||||||
@@ -23,8 +31,12 @@ namespace YAML
|
|||||||
|
|
||||||
void ostream_wrapper::write(const char *str, std::size_t size)
|
void ostream_wrapper::write(const char *str, std::size_t size)
|
||||||
{
|
{
|
||||||
|
if(m_pStream) {
|
||||||
|
m_pStream->write(str, size);
|
||||||
|
} else {
|
||||||
m_buffer.resize(std::max(m_buffer.size(), m_pos + size + 1));
|
m_buffer.resize(std::max(m_buffer.size(), m_pos + size + 1));
|
||||||
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]);
|
||||||
|
@@ -3,12 +3,10 @@
|
|||||||
|
|
||||||
int main()
|
int main()
|
||||||
{
|
{
|
||||||
YAML::Emitter out;
|
YAML::Emitter out(std::cout);
|
||||||
out << YAML::BeginSeq;
|
out << YAML::BeginSeq;
|
||||||
out << "item 1";
|
out << "item 1";
|
||||||
out << YAML::BeginSeq << "foo 1" << "bar 2" << YAML::EndSeq;
|
out << YAML::BeginSeq << "foo 1" << "bar 2" << YAML::EndSeq;
|
||||||
out << YAML::EndSeq;
|
out << YAML::EndSeq;
|
||||||
|
|
||||||
std::cout << out.c_str() << "\n";
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user