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
|