μHAL (v2.8.17)
Part of the IPbus software repository
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Modules Pages
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_grammars_HttpResponseGrammar_hpp_
34#define _uhal_grammars_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
48namespace uhal
49{
52 {
54 std::string method;
56 double version;
58 int status;
60 std::string status_string;
62 std::string headers;
64 std::vector< uint8_t > content;
65 };
66
67 std::ostream& operator<< ( std::ostream& aStr , const uhal::HttpResponseType& aHttpResponse );
68}
69
70
71// Call to BOOST_FUSION_ADAPT_STRUCT must be at global scope
75 ( std::string, method )
76 ( double , version )
77 ( int, status )
78 ( std::string, status_string )
79 ( std::string, headers )
80 ( std::vector< uint8_t >, content )
81)
82
83
84namespace uhal
85{
86namespace 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#endif
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 uhal
A boost::fusion adaptive struct used by the boost::qi parser.
std::ostream & operator<<(std::ostream &aStr, const uhal::HttpResponseType &aHttpResponse)
Struct to store an http response received from a server when parsed by boost spirit.
std::string status_string
the response status string
std::string method
the http transport method
std::string headers
parsed headers
int status
the response status
std::vector< uint8_t > content
parsed message content
double version
the http version number