LCOV - code coverage report
Current view: top level - include/boost/http - response_parser.hpp (source / functions) Coverage Total Hit
Test: coverage_remapped.info Lines: 100.0 % 6 6
Test Date: 2026-06-13 19:44:58 Functions: 100.0 % 4 4

           TLA  Line data    Source code
       1                 : //
       2                 : // Copyright (c) 2019 Vinnie Falco (vinnie.falco@gmail.com)
       3                 : // Copyright (c) 2025 Mohammad Nejati
       4                 : //
       5                 : // Distributed under the Boost Software License, Version 1.0. (See accompanying
       6                 : // file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
       7                 : //
       8                 : // Official repository: https://github.com/cppalliance/http
       9                 : //
      10                 : 
      11                 : #ifndef BOOST_HTTP_RESPONSE_PARSER_HPP
      12                 : #define BOOST_HTTP_RESPONSE_PARSER_HPP
      13                 : 
      14                 : #include <boost/http/detail/config.hpp>
      15                 : #include <boost/http/error.hpp>
      16                 : #include <boost/http/parser.hpp>
      17                 : #include <boost/http/static_response.hpp>
      18                 : #include <boost/http/status.hpp>
      19                 : 
      20                 : #include <memory>
      21                 : 
      22                 : namespace boost {
      23                 : namespace http {
      24                 : 
      25                 : /// @copydoc parser
      26                 : /// @brief A parser for HTTP/1 responses.
      27                 : /// @see @ref request_parser.
      28                 : class response_parser
      29                 :     : public parser
      30                 : {
      31                 : public:
      32                 :     /** Destructor.
      33                 : 
      34                 :         Any views or buffers obtained from this
      35                 :         parser become invalid.
      36                 :     */
      37 HIT        1056 :     ~response_parser() = default;
      38                 : 
      39                 :     /** Default constructor.
      40                 : 
      41                 :         Constructs a parser with no allocated state.
      42                 :         The parser must be assigned from a valid
      43                 :         parser before use.
      44                 : 
      45                 :         @par Postconditions
      46                 :         The parser has no allocated state.
      47                 :     */
      48               6 :     response_parser() = default;
      49                 : 
      50                 :     /** Constructor.
      51                 : 
      52                 :         Constructs a parser with the provided configuration.
      53                 : 
      54                 :         The parser will allocate the required space on
      55                 :         startup based on the config parameters, and will
      56                 :         not perform any further allocations.
      57                 : 
      58                 :         @par Example
      59                 :         @code
      60                 :         auto cfg = make_parser_config(parser_config{false});
      61                 :         response_parser pr(cfg);
      62                 :         @endcode
      63                 : 
      64                 :         @par Complexity
      65                 :         Constant.
      66                 : 
      67                 :         @par Exception Safety
      68                 :         Calls to allocate may throw.
      69                 : 
      70                 :         @param cfg Shared pointer to parser configuration.
      71                 : 
      72                 :         @see @ref make_parser_config, @ref parser_config.
      73                 :     */
      74                 :     BOOST_HTTP_DECL
      75                 :     explicit
      76                 :     response_parser(
      77                 :         std::shared_ptr<parser_config_impl const> cfg);
      78                 : 
      79                 :     /** Constructor.
      80                 : 
      81                 :         The states of `other` are transferred
      82                 :         to the newly constructed object,
      83                 :         including the allocated buffer.
      84                 :         After construction, the only valid
      85                 :         operations on the moved-from object
      86                 :         are destruction and assignment.
      87                 : 
      88                 :         Buffer sequences previously obtained
      89                 :         using @ref prepare or @ref pull_body
      90                 :         remain valid.
      91                 : 
      92                 :         @par Complexity
      93                 :         Constant.
      94                 : 
      95                 :         @param other The parser to move from.
      96                 :     */
      97               1 :     response_parser(
      98                 :         response_parser&& other) noexcept = default;
      99                 : 
     100                 :     /** Assignment.
     101                 :         The states of `other` are transferred
     102                 :         to this object, including the allocated
     103                 :         buffer.
     104                 :         After assignment, the only valid
     105                 :         operations on the moved-from object
     106                 :         are destruction and assignment.
     107                 :         Buffer sequences previously obtained
     108                 :         using @ref prepare or @ref pull_body
     109                 :         remain valid.
     110                 :         @par Complexity
     111                 :         Constant.
     112                 :         @param other The parser to move from.
     113                 :     */
     114                 :     response_parser&
     115               2 :     operator=(response_parser&& other) noexcept
     116                 :     {
     117               2 :         assign(std::move(other));
     118               2 :         return *this;
     119                 :     }
     120                 : 
     121                 :     /** Prepare for the next message on the stream.
     122                 : 
     123                 :         This informs the parser not to read a
     124                 :         payload for the next message, regardless
     125                 :         of the presence or absence of certain
     126                 :         fields such as Content-Length or a chunked
     127                 :         Transfer-Encoding. Depending on the request,
     128                 :         some responses do not carry a body. For
     129                 :         example, a 200 response to a CONNECT
     130                 :         request from a tunneling proxy, or a
     131                 :         response to a HEAD request. In these
     132                 :         cases, callers may use this function
     133                 :         inform the parser that no body is
     134                 :         expected. The parser will consider the
     135                 :         message complete after the header has
     136                 :         been received.
     137                 : 
     138                 :         @par Preconditions
     139                 :         No previous call to @ref start for the new message.
     140                 : 
     141                 :         @see
     142                 :             https://datatracker.ietf.org/doc/html/rfc7230#section-3.3
     143                 :     */
     144                 :     void
     145                 :     start_head_response()
     146                 :     {
     147                 :         start_impl(true);
     148                 :     }
     149                 : 
     150                 :     /** Return a reference to the parsed response headers.
     151                 : 
     152                 :         The returned reference remains valid until:
     153                 :         @li @ref start or @ref start_head_response is called
     154                 :         @li @ref reset is called
     155                 :         @li The parser instance is destroyed
     156                 : 
     157                 :         @par Preconditions
     158                 :         @code
     159                 :         this->got_header() == true
     160                 :         @endcode
     161                 : 
     162                 :         @par Exception Safety
     163                 :         Strong guarantee.
     164                 : 
     165                 :         @see
     166                 :             @ref got_header.
     167                 :     */
     168                 :     BOOST_HTTP_DECL
     169                 :     static_response const&
     170                 :     get() const;
     171                 : };
     172                 : 
     173                 : } // http
     174                 : } // boost
     175                 : 
     176                 : #endif
        

Generated by: LCOV version 2.3