mirror of
https://github.com/Xahau/xahaud.git
synced 2025-12-06 17:27:52 +00:00
* New tools for completion handlers: - wrap_handler provides composed io_service execution guarantees. - bind_handler rebinds arguments to handlers. - shared_handler type-erases any completion handler. - buffer_sequence type-erases templated BufferSequences - abstract_socket replaces Socket - socket_wrapper replaces SocketWrapper - beast::asio placeholders to work with std::bind * Removed obsolete classes and functions - AbstractHandler - ComposedAsyncOperation - SharedFunction - SharedHandler - SharedHandlerAllocator - SharedHandlerPtr - SharedHandlerType - SocketBase - SocketWrapperStrand - wrapHandler * Refactored classes to use new tools - abstract_socket - socket_wrapper - HandshakeDetector - HttpClientType * Miscellanous tidying - socket classes moved to beast::asio namespace - beast asio files provide their own namespace declaration. - Fix IsCallPossible conflicting template parameter name - Use <boost/get_pointer.hpp> for C++11 compatibility. - Remove extraneous include path from build environment.
76 lines
2.4 KiB
C++
76 lines
2.4 KiB
C++
//------------------------------------------------------------------------------
|
|
/*
|
|
This file is part of Beast: https://github.com/vinniefalco/Beast
|
|
Copyright 2013, Vinnie Falco <vinnie.falco@gmail.com>
|
|
|
|
Permission to use, copy, modify, and/or distribute this software for any
|
|
purpose with or without fee is hereby granted, provided that the above
|
|
copyright notice and this permission notice appear in all copies.
|
|
|
|
THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
|
|
WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
|
|
MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
|
|
ANY SPECIAL , DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
|
|
WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
|
|
ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
|
|
OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
|
*/
|
|
//==============================================================================
|
|
|
|
#ifndef BEAST_ASIO_HTTPHEADERS_H_INCLUDED
|
|
#define BEAST_ASIO_HTTPHEADERS_H_INCLUDED
|
|
|
|
namespace beast {
|
|
|
|
/** A set of HTTP headers. */
|
|
class HTTPHeaders
|
|
{
|
|
public:
|
|
/** Construct an empty set of headers. */
|
|
HTTPHeaders ();
|
|
|
|
/** Construct headers taking ownership of a field array.
|
|
The callers value is overwritten.
|
|
*/
|
|
HTTPHeaders (StringPairArray& fields);
|
|
|
|
/** Construct a copy of headers from an array.*/
|
|
HTTPHeaders (StringPairArray const& fields);
|
|
|
|
/** Construct a copy of headers. */
|
|
HTTPHeaders (HTTPHeaders const& other);
|
|
|
|
/** Assign a copy of headers. */
|
|
HTTPHeaders& operator= (HTTPHeaders const& other);
|
|
|
|
/** Returns `true` if the container is empty. */
|
|
bool empty () const;
|
|
|
|
/** Returns the number of fields in the container. */
|
|
std::size_t size () const;
|
|
|
|
/** Random access to fields by index. */
|
|
/** @{ */
|
|
HTTPField at (std::size_t index) const;
|
|
HTTPField operator[] (std::size_t index) const;
|
|
/** @} */
|
|
|
|
/** Associative access to fields by name.
|
|
If the field is not present, an empty string is returned.
|
|
*/
|
|
/** @{ */
|
|
String get (String const& field) const;
|
|
String operator[] (String const& field) const;
|
|
/** @} */
|
|
|
|
/** Outputs all the headers into one string. */
|
|
String toString () const;
|
|
|
|
private:
|
|
StringPairArray m_fields;
|
|
};
|
|
|
|
}
|
|
|
|
#endif
|