From b53ea34b123721f70ae6e4ff4eb96e90e0664ba4 Mon Sep 17 00:00:00 2001 From: Vegard Storheil Eriksen Date: Sun, 2 Jan 2011 21:41:56 +0100 Subject: Move HTTP::Connection::parse_request into new file. --- http_connection.cpp | 35 ----------------------------------- 1 file changed, 35 deletions(-) (limited to 'http_connection.cpp') diff --git a/http_connection.cpp b/http_connection.cpp index d940b2f..6567f81 100644 --- a/http_connection.cpp +++ b/http_connection.cpp @@ -3,10 +3,6 @@ #include "http.h" #include -#include -#include - -namespace qi = boost::spirit::qi; HTTP::Connection::Connection(boost::asio::io_service& io_service) : socket(io_service) { } @@ -43,37 +39,6 @@ void print(char c) { std::cout << "Char: " << int(c) << std::endl; } -bool HTTP::Connection::parse_request(boost::asio::streambuf& buf) { - std::string data(boost::asio::buffers_begin(buf.data()), boost::asio::buffers_end(buf.data())); - - typedef std::string::const_iterator Iterator; - - Iterator begin = data.begin(); - Iterator end = data.end(); - - qi::rule word_p = +(qi::char_ - ' ' - '\r'); - - qi::rule urlchar_p = (qi::char_ - '%') | ('%' >> qi::uint_parser()); - - qi::rule path_p = *(+qi::lit('/') >> +(urlchar_p - '/' - '?' - ' ')) >> *qi::lit('/'); - - qi::rule()> pair_p = +(urlchar_p - '=') >> '=' >> +(urlchar_p - '&' - ' '); - qi::rule()> args_p = '?' >> pair_p >> *('&' >> pair_p); - - qi::rule()> header_p = +(qi::char_ - ':') >> ": " >> +(qi::char_ - '\r'); - qi::rule()> headers_p = *(header_p >> "\r\n"); - - return qi::parse(begin, end, - // Method, path, args, version: - word_p >> ' ' >> path_p >> -args_p >> ' ' >> word_p >> "\r\n" >> - // Headers: - headers_p >> - // End of headers: - "\r\n", - // Store into: - method, path, args, version, headers); -} - void HTTP::Connection::read_request(Handler callback) { boost::asio::async_read_until(socket, buf, "\r\n\r\n", boost::bind(&Connection::handle_read, shared_from_this(), boost::asio::placeholders::error, boost::asio::placeholders::bytes_transferred, callback)); -- cgit v1.2.3