μHAL (v2.6.5)
Part of the IPbus software repository
URIGrammar.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_URIGrammar_hpp_
34 #define _uhal_grammars_URIGrammar_hpp_
35 
36 
37 
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 #include "uhal/grammars/URI.hpp"
48 
49 
50 // Call to BOOST_FUSION_ADAPT_STRUCT must be at global scope
53  uhal::URI,
54  ( std::string , mProtocol )
55  ( std::string , mHostname )
56  ( std::string , mPort )
57  ( std::string , mPath )
58  ( std::string , mExtension )
59  ( uhal::NameValuePairVectorType, mArguments )
60 )
61 
62 
63 namespace grammars
64 {
66  struct URIGrammar : boost::spirit::qi::grammar<std::string::const_iterator, uhal::URI(), boost::spirit::ascii::space_type>
67  {
69  URIGrammar();
71  boost::spirit::qi::rule< std::string::const_iterator, uhal::URI(), boost::spirit::ascii::space_type > start;
72 
73 
74  boost::spirit::qi::rule< std::string::const_iterator, uhal::URI(), boost::spirit::ascii::space_type > EthernetURI;
75  boost::spirit::qi::rule< std::string::const_iterator, uhal::URI(), boost::spirit::ascii::space_type > PCIeURI;
76 
77 
79  boost::spirit::qi::rule< std::string::const_iterator, std::string(), boost::spirit::ascii::space_type > protocol;
81  boost::spirit::qi::rule< std::string::const_iterator, std::string(), boost::spirit::ascii::space_type > hostname;
83  boost::spirit::qi::rule< std::string::const_iterator, std::string(), boost::spirit::ascii::space_type > port;
85  boost::spirit::qi::rule< std::string::const_iterator, std::string(), boost::spirit::ascii::space_type > path;
87  boost::spirit::qi::rule< std::string::const_iterator, std::string(), boost::spirit::ascii::space_type > extension;
89  boost::spirit::qi::rule< std::string::const_iterator, std::vector< std::pair<std::string, std::string> > (), boost::spirit::ascii::space_type > data_pairs_vector; //NameValuePairVectorType
91  boost::spirit::qi::rule< std::string::const_iterator, std::pair<std::string, std::string>(), boost::spirit::ascii::space_type > data_pairs;
93  boost::spirit::qi::rule< std::string::const_iterator, std::string(), boost::spirit::ascii::space_type > data_pairs_1;
95  boost::spirit::qi::rule< std::string::const_iterator, std::string(), boost::spirit::ascii::space_type > data_pairs_2;
96 
97 
98  boost::spirit::qi::rule< std::string::const_iterator, std::string(), boost::spirit::ascii::space_type > empty_string;
99  };
100 }
101 
102 #endif
std::vector< std::pair< std::string, std::string > > NameValuePairVectorType
boost::fusion requires us to typedef our template types, so typedef a container which can hold key/va...
BOOST_FUSION_ADAPT_STRUCT(uhal::URI,(std::string, mProtocol)(std::string, mHostname)(std::string, mPort)(std::string, mPath)(std::string, mExtension)(uhal::NameValuePairVectorType, mArguments)) namespace grammars
A boost::fusion adaptive struct used by the boost::qi parser.
Definition: URIGrammar.hpp:52
The log_inserter function to add an HttpResponseType object to a log entry.
Struct to store a URI when parsed by boost spirit.
Definition: URI.hpp:49