/usr/include/Wt/WStringStream is in libwt-dev 3.3.4+dfsg-6ubuntu1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 | // This may look like C code, but it's really -*- C++ -*-
/*
* Copyright (C) 2011 Emweb bvba, Kessel-Lo, Belgium.
*
* See the LICENSE file for terms of use.
*/
#ifndef WT_WSTRING_STREAM_H_
#define WT_WSTRING_STREAM_H_
#include <Wt/WDllDefs.h>
#include <iostream>
#include <string>
#include <vector>
namespace boost {
namespace asio {
class const_buffer;
}
}
namespace Wt {
/*! \class WStringStream Wt/WStringStream Wt/WStringStream
*
* This is an efficient std::stringstream replacement. It is in
* particular more efficient when a relatively short string is being
* composed from many different pieces (avoiding any memory allocation
* all-together).
*
* Compared to std::stringstream, it also avoids overhead by not
* supporting the formatting options of the latter, and by not making
* use of the std::locale, which apparently hampers std::ostream
* performance (%Wt internally uses UTF-8 encoding throughout).
*/
class WT_API WStringStream
{
public:
/*! \brief An implementation of an output generator for appending data.
*
* \sa back_inserter()
*/
struct iterator {
struct char_proxy {
char_proxy& operator= (char c);
private:
char_proxy(WStringStream& stream);
WStringStream& stream_;
friend struct iterator;
};
iterator();
char_proxy operator * ();
iterator& operator ++ ();
iterator operator ++ (int);
private:
WStringStream *stream_;
iterator(WStringStream& stream);
friend class WStringStream;
};
/*! \brief Default constructor.
*
* Creates a string stream.
*/
WStringStream();
/*! \brief Assignment operator.
*/
WStringStream& operator=(const WStringStream& other);
/*! \brief Constructor with std::ostream sink.
*
* Creates a string stream which flushes contents to an
* std::ostream, instead of relying on internal buffering. The
* output may still be internally buffered (for performance
* reasons), and this buffer is only flushed to the underlying ostream
* when you delete the string stream.
*/
WStringStream(std::ostream& sink);
/*! \brief Destructor.
*/
~WStringStream();
/*! \brief Appends a string.
*
* Appends \p length bytes from the given string.
*/
void append(const char *s, int length);
#ifndef WT_TARGET_JAVA
/*
* Should not be implemented but is needed to support the specialization
* for string literals !
*/
template <typename T>
inline WStringStream& operator<< (T t) {
WStringStream please_cast_to_a_supported_type = t;
please_cast_to_a_supported_type << 'a'; // silence compiler for normal case
return *this;
}
template <std::size_t N>
WStringStream& operator<< (const char (&s)[N]) {
append(s, N-1); return *this;
}
#endif // WT_TARGET_JAVA
/*! \brief Appends a character.
*/
WStringStream& operator<< (char);
/*! \brief Appends a C string.
*/
WStringStream& operator<< (char *s);
/*! \brief Appends a C++ string.
*/
WStringStream& operator<< (const std::string& s);
/*! \brief Appends a boolean.
*
* This is written to the stream as <tt>true</tt> or <tt>false</tt>.
*/
WStringStream& operator<< (bool);
/*! \brief Appends an integer number.
*/
WStringStream& operator<< (int);
/*! \brief Appends an integer number.
*/
WStringStream& operator<< (long long);
/*! \brief Appends a double.
*/
WStringStream& operator<< (double);
/*! \brief Iterator for appending.
*/
iterator back_inserter();
/*! \brief Returns the contents as a null-terminated C string.
*
* The behaviour is only defined for a string stream with internal
* buffering.
*
* \note This is only supported when the length of the total string
* is less than 1024 bytes. Returns 0 if the operation could not
* be completed.
*/
const char *c_str();
/*! \brief Returns the contents as a C++ string.
*
* The behaviour is only defined for a string stream with internal
* buffering.
*/
std::string str() const;
void asioBuffers(std::vector<boost::asio::const_buffer>& result) const;
/*! \brief Returns whether the contents is empty.
*
* The behaviour is only defined for a string stream with internal
* buffering.
*/
bool empty() const;
/*! \brief Returns the total length.
*
* The behaviour is only defined for a string stream with internal
* buffering.
*/
std::size_t length() const;
/*! \brief Clears the contents.
*
* The behaviour is only defined for a string stream with internal
* buffering.
*/
void clear();
// no-op for C++, but needed for Java
void spool(std::ostream& ) { }
private:
WStringStream(const WStringStream& other);
enum {S_LEN = 1024};
enum {D_LEN = 2048};
std::ostream *sink_;
char static_buf_[S_LEN + 1];
char *buf_;
int buf_i_;
int buf_len() const
{ return buf_ == static_buf_ ? static_cast<int>(S_LEN)
: static_cast<int>(D_LEN); }
std::vector<std::pair<char *, int> > bufs_;
void flushSink();
void pushBuf();
};
}
#endif // WT_WSTRING_STREAM_H_
|