summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorBruno de Oliveira Abinader <bruno@mapbox.com>2018-07-28 14:56:26 +0300
committerBruno de Oliveira Abinader <bruno@mapbox.com>2018-08-08 14:14:34 +0300
commit990b3b11b9427ffd86f693d3f4c3dd351891e5d0 (patch)
tree73c434da712d210459ae771bb83ac18cd56d7e3f
parent83bd4c213583058340d0606f2d24c85489091ccf (diff)
downloadqtlocation-mapboxgl-990b3b11b9427ffd86f693d3f4c3dd351891e5d0.tar.gz
[core] Replace Boost.Spirit with std::regex in CacheControl::parse()
-rw-r--r--src/mbgl/util/http_header.cpp28
-rw-r--r--test/storage/headers.test.cpp9
2 files changed, 16 insertions, 21 deletions
diff --git a/src/mbgl/util/http_header.cpp b/src/mbgl/util/http_header.cpp
index 4d9e2bf84c..da68b4a790 100644
--- a/src/mbgl/util/http_header.cpp
+++ b/src/mbgl/util/http_header.cpp
@@ -2,34 +2,20 @@
#include <mbgl/util/string.hpp>
-#pragma GCC diagnostic push
-#pragma GCC diagnostic ignored "-Wunknown-pragmas"
-#pragma GCC diagnostic ignored "-Wunused-parameter"
-#pragma GCC diagnostic ignored "-Wshadow"
-#pragma clang diagnostic push
-
-#pragma clang diagnostic ignored "-Wshorten-64-to-32"
-#pragma clang diagnostic ignored "-Wunknown-warning-option"
-#pragma clang diagnostic ignored "-Wtautological-constant-compare"
-#include <boost/spirit/include/qi.hpp>
-#include <boost/spirit/include/phoenix_core.hpp>
-#include <boost/spirit/include/phoenix_operator.hpp>
-#pragma clang diagnostic pop
-#pragma GCC diagnostic pop
+#include <regex>
namespace mbgl {
namespace http {
CacheControl CacheControl::parse(const std::string& value) {
- namespace qi = boost::spirit::qi;
- namespace phoenix = boost::phoenix;
+ std::regex maxAgeRegex(R"((?:[^"]*"[^"]*[^\\]")*[^"]*max-age[\s]*=[\s]*([\d]+).*)");
+ std::smatch maxAgeMatch;
CacheControl result;
- qi::phrase_parse(value.begin(), value.end(), (
- (qi::lit("must-revalidate") [ phoenix::ref(result.mustRevalidate) = true ]) |
- (qi::lit("max-age") >> '=' >> qi::ulong_long [ phoenix::ref(result.maxAge) = qi::_1 ]) |
- (*(('"' >> *(('\\' >> qi::char_) | (qi::char_ - '"')) >> '"') | (qi::char_ - '"' - ',')))
- ) % ',', qi::ascii::space);
+ result.mustRevalidate = value.find("must-revalidate") != std::string::npos;
+ if (std::regex_match(value, maxAgeMatch, maxAgeRegex) && maxAgeMatch.size() == 2) {
+ result.maxAge = ::atoll(maxAgeMatch[1].str().c_str());
+ }
return result;
}
diff --git a/test/storage/headers.test.cpp b/test/storage/headers.test.cpp
index b7dcfc025d..613f469b59 100644
--- a/test/storage/headers.test.cpp
+++ b/test/storage/headers.test.cpp
@@ -10,6 +10,10 @@ TEST(HTTPHeader, Parsing) {
ASSERT_FALSE(bool(cc.maxAge));
EXPECT_FALSE(cc.mustRevalidate);
+ cc = http::CacheControl::parse(R"#("max-age=34)#");
+ ASSERT_FALSE(bool(cc.maxAge));
+ EXPECT_FALSE(cc.mustRevalidate);
+
cc = http::CacheControl::parse(R"#(max-age =34)#");
ASSERT_TRUE(bool(cc.maxAge));
EXPECT_EQ(34u, *cc.maxAge);
@@ -38,6 +42,11 @@ TEST(HTTPHeader, Parsing) {
EXPECT_EQ(3u, *cc.maxAge);
EXPECT_FALSE(cc.mustRevalidate);
+ cc = http::CacheControl::parse(R"#(max-age=3,max-age=""34)#");
+ ASSERT_TRUE(bool(cc.maxAge));
+ EXPECT_EQ(3u, *cc.maxAge);
+ EXPECT_FALSE(cc.mustRevalidate);
+
cc = http::CacheControl::parse(R"#(max-age="\",max-age=4,")#");
ASSERT_FALSE(bool(cc.maxAge));
EXPECT_FALSE(cc.mustRevalidate);