http://www.ousob.com --- Legacy Redefined OuSob - File: /wwwroot/clipx/usr/include/cgicc/HTTPHeader.h

/* -*-c++-*- */ /* * $Id: HTTPHeader.h,v 1.6 2003/07/13 14:20:35 sbooth Exp $ * * Copyright (C) 1996 - 2003 Stephen F. Booth * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation; either * version 2.1 of the License, or (at your option) any later version. * * This library is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this library; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */ #ifndef _HTTPHEADER_H_ #define _HTTPHEADER_H_ 1 #ifdef __GNUG__ # pragma interface #endif /*! \file HTTPHeader.h * \brief Abstract base class for simple HTTP headers * */ #include <string> #include <vector> #include "cgicc/MStreamable.h" #include "cgicc/HTTPCookie.h" namespace cgicc { // ============================================================ // Class HTTPHeader // ============================================================ /*! \class HTTPHeader HTTPHeader.h cgicc/HTTPHeader.h * \brief Abstract base class for all simple HTTP response headers. * */ class CGICC_API HTTPHeader : public MStreamable { public: /*! \name Constructors and Destructor */ //@{ /*! * \brief Constructor. * \param data The header data. */ HTTPHeader(const std::string& data); /*! * \brief Copy constructor. * \param header The HTTPHeader to copy. */ HTTPHeader(const HTTPHeader& header); /*! * \brief Destructor * */ virtual ~HTTPHeader(); //@} // ============================================================ /*! \name Cookie Management */ //@{ /*! * \brief Set a cookie to go out with this HTTPResponseHeader * \param cookie The HTTPCookie to set */ inline HTTPHeader& setCookie(const HTTPCookie& cookie) { fCookies.push_back(cookie); return *this; } /*! * \brief Get a list of all cookies associated with this header * \return All the cookies associated with this header */ inline const std::vector<HTTPCookie>& getCookies() const { return fCookies; } //@} // ============================================================ /*! \name Accessor Method */ //@{ /*! * Get the data contained in this HTTP header. * @return The data contained in this header. */ inline std::string getData() const { return fData; } //@} // ============================================================ /*! \name Subclass Methods */ //@{ /*! * \brief Write this HTTPHeader to a stream. * * Subclasses must implement this function. * \param out The ostream to which to write. */ virtual void render(std::ostream& out) const = 0; //@} private: HTTPHeader(); std::string fData; std::vector<HTTPCookie> fCookies; }; } // namespace cgicc #endif /* ! _HTTPHEADER_H_ */