1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
|
/*
* Copyright (C) 2011 Canonical Ltd
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License version 3 as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*
* Authored by: Marco Biscaro <marcobiscaro2112@gmail.com>
*/
#include "DashViewPrivate.h"
#include <vector>
#include <boost/algorithm/string.hpp>
namespace unity
{
namespace dash
{
namespace impl
{
LensFilter parse_lens_uri(std::string const& uri)
{
LensFilter filter;
filter.id = uri;
std::size_t pos = uri.find("?");
// it's a real URI (with parameters)
if (pos != std::string::npos)
{
// id is the uri from begining to the '?' position
filter.id = uri.substr(0, pos);
// the components are from '?' position to the end
std::string components = uri.substr(++pos);
// split components in tokens
std::vector<std::string> tokens;
boost::split(tokens, components, boost::is_any_of("&"));
for (std::string const& token : tokens)
{
// split each token in a pair
std::size_t equals_pos = token.find("=");
if (equals_pos != std::string::npos)
{
std::string key = token.substr(0, equals_pos);
std::string value = token.substr(equals_pos + 1);
// check if it's a filter
if (boost::starts_with(key, "filter_"))
{
filter.filters[key.substr(7)] = value;
}
}
}
}
return filter;
}
} // namespace impl
} // namespace dash
} // namespace unity
|