μHAL (v2.6.5)
Part of the IPbus software repository
HttpResponseGrammar.hpp
Go to the documentation of this file.
1 /*
2 ---------------------------------------------------------------------------
3 
4  This file is part of uHAL.
5 
6  uHAL is a hardware access library and programming framework
7  originally developed for upgrades of the Level-1 trigger of the CMS
8  experiment at CERN.
9 
10  uHAL is free software: you can redistribute it and/or modify
11  it under the terms of the GNU General Public License as published by
12  the Free Software Foundation, either version 3 of the License, or
13  (at your option) any later version.
14 
15  uHAL is distributed in the hope that it will be useful,
16  but WITHOUT ANY WARRANTY; without even the implied warranty of
17  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18  GNU General Public License for more details.
19 
20  You should have received a copy of the GNU General Public License
21  along with uHAL. If not, see <http://www.gnu.org/licenses/>.
22 
23 
24  Andrew Rose, Imperial College, London
25  email: awr01 <AT> imperial.ac.uk
26 
27  Marc Magrans de Abril, CERN
28  email: marc.magrans.de.abril <AT> cern.ch
29 
30 ---------------------------------------------------------------------------
31 */
32 
33 #ifndef _uhal_HttpResponseGrammar_hpp_
34 #define _uhal_HttpResponseGrammar_hpp_
35 
36 
37 #include <iosfwd>
38 #include <string>
39 #include <utility> // for pair
40 #include <vector>
41 
42 #include <boost/fusion/adapted/std_pair.hpp>
43 #include <boost/fusion/adapted/struct/adapt_struct.hpp>
44 #include <boost/spirit/include/qi_char.hpp>
45 #include <boost/spirit/include/qi_grammar.hpp>
46 
47 
48 namespace uhal
49 {
50 
53  {
55  std::string method;
57  double version;
59  int status;
61  std::string status_string;
63  std::string headers;
65  std::vector< uint8_t > content;
66  };
67 
68  std::ostream& operator<< ( std::ostream& aStr , const uhal::HttpResponseType& aHttpResponse );
69 }
70 
71 
72 
73 // Call to BOOST_FUSION_ADAPT_STRUCT must be at global scope
77  ( std::string, method )
78  ( double , version )
79  ( int, status )
80  ( std::string, status_string )
81  ( std::string, headers )
82  ( std::vector< uint8_t >, content )
83 )
84 
85 
86 namespace grammars
87 {
89  struct HttpResponseGrammar : boost::spirit::qi::grammar< std::vector<uint8_t>::iterator , uhal::HttpResponseType() , boost::spirit::ascii::space_type >
90  {
92  HttpResponseGrammar();
94  boost::spirit::qi::rule< std::vector<uint8_t>::iterator, uhal::HttpResponseType(), boost::spirit::ascii::space_type > response;
96  boost::spirit::qi::rule< std::vector<uint8_t>::iterator, std::string(), boost::spirit::ascii::space_type > nospace_sequence;
98  boost::spirit::qi::rule< std::vector<uint8_t>::iterator, std::string(), boost::spirit::ascii::space_type > nonewline_sequence;
100  boost::spirit::qi::rule< std::vector<uint8_t>::iterator, std::string(), boost::spirit::ascii::space_type > noblankline_sequence;
101  };
102 
103 
104 }
105 
106 
107 
108 
109 
110 
111 #endif
int status
the response status
std::string method
the http transport method
std::string headers
parsed headers
double version
the http version number
Struct to store an http response received from a server when parsed by boost spirit.
std::string status_string
the response status string
The log_inserter function to add an HttpResponseType object to a log entry.
BOOST_FUSION_ADAPT_STRUCT(uhal::HttpResponseType,(std::string, method)(double, version)(int, status)(std::string, status_string)(std::string, headers)(std::vector< uint8_t >, content)) namespace grammars
A boost::fusion adaptive struct used by the boost::qi parser.
std::vector< uint8_t > content
parsed message content
std::ostream & operator<<(std::ostream &aStr, const uhal::HttpResponseType &aHttpResponse)