subset_map.hpp
1.64 KB
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
#ifndef SASS_SUBSET_MAP_H
#define SASS_SUBSET_MAP_H
#include <map>
#include <set>
#include <vector>
#include <algorithm>
#include <iterator>
#include "ast_fwd_decl.hpp"
// #include <iostream>
// #include <sstream>
// template<typename T>
// std::string vector_to_string(std::vector<T> v)
// {
// std::stringstream buffer;
// buffer << "[";
// if (!v.empty())
// { buffer << v[0]; }
// else
// { buffer << "]"; }
// if (v.size() == 1)
// { buffer << "]"; }
// else
// {
// for (size_t i = 1, S = v.size(); i < S; ++i) buffer << ", " << v[i];
// buffer << "]";
// }
// return buffer.str();
// }
// template<typename T>
// std::string set_to_string(set<T> v)
// {
// std::stringstream buffer;
// buffer << "[";
// typename std::set<T>::iterator i = v.begin();
// if (!v.empty())
// { buffer << *i; }
// else
// { buffer << "]"; }
// if (v.size() == 1)
// { buffer << "]"; }
// else
// {
// for (++i; i != v.end(); ++i) buffer << ", " << *i;
// buffer << "]";
// }
// return buffer.str();
// }
namespace Sass {
class Subset_Map {
private:
std::vector<SubSetMapPair> values_;
std::map<Simple_Selector_Obj, std::vector<std::pair<Compound_Selector_Obj, size_t> >, OrderNodes > hash_;
public:
void put(const Compound_Selector_Obj& sel, const SubSetMapPair& value);
std::vector<SubSetMapPair> get_kv(const Compound_Selector_Obj& s);
std::vector<SubSetMapPair> get_v(const Compound_Selector_Obj& s);
bool empty() { return values_.empty(); }
void clear() { values_.clear(); hash_.clear(); }
const std::vector<SubSetMapPair> values(void) { return values_; }
};
}
#endif