File: map.h

package info (click to toggle)
qtcurve 1.9-9
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 12,460 kB
  • sloc: cpp: 70,269; perl: 123; sh: 122; xml: 46; makefile: 15
file content (101 lines) | stat: -rw-r--r-- 3,516 bytes parent folder | download | duplicates (5)
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
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
/*****************************************************************************
 *   Copyright 2013 - 2015 Yichao Yu <yyc1992@gmail.com>                     *
 *                                                                           *
 *   This program is free software; you can redistribute it and/or modify    *
 *   it under the terms of the GNU Lesser General Public License as          *
 *   published by the Free Software Foundation; either version 2.1 of the    *
 *   License, or (at your option) version 3, or any later version accepted   *
 *   by the membership of KDE e.V. (or its successor approved by the         *
 *   membership of KDE e.V.), which shall act as a proxy defined in          *
 *   Section 6 of version 3 of the license.                                  *
 *                                                                           *
 *   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       *
 *   Lesser General Public License for more details.                         *
 *                                                                           *
 *   You should have received a copy of the GNU Lesser General Public        *
 *   License along with this library. If not,                                *
 *   see <http://www.gnu.org/licenses/>.                                     *
 *****************************************************************************/

#ifndef _QTC_UTILS_MAP_H_
#define _QTC_UTILS_MAP_H_

#include "utils.h"

#include <vector>
#include <algorithm>

namespace QtCurve {

// C++14 integer sequence
template<int...>
struct seq {
};

template<int N, int... S>
struct gens : gens<N - 1, N - 1, S...> {
};

template<int ...S>
struct gens<0, S...> {
    typedef seq<S...> type;
};

template<int N>
using gens_t = typename gens<N>::type;

template<typename Val=int, bool case_sens=true>
class StrMap : std::vector<std::pair<const char*, Val> > {
    typedef std::pair<const char*, Val> pair_type;
    static int
    strcmp_func(const char *a, const char *b)
    {
        if (case_sens) {
            return strcmp(a, b);
        } else {
            return strcasecmp(a, b);
        }
    }
    template<typename... Ts, int ...S>
    StrMap(seq<S...>, Ts&&... ts)
        : StrMap{{ts, Val(S)}...}
    {
    }
public:
    StrMap(std::initializer_list<pair_type> &&ts)
        : std::vector<pair_type>(std::move(ts))
    {
        std::sort(this->begin(), this->end(),
                  [] (const pair_type &a, const pair_type &b) {
                      return strcmp_func(a.first, b.first) < 0;
                  });
    }
    template<typename... Ts>
    StrMap(Ts&&... ts)
        : StrMap(gens_t<sizeof...(Ts)>(), std::forward<Ts>(ts)...)
    {
    }
    Val
    search(const char *key, Val def=Val(-1), bool *is_def=nullptr) const
    {
        QTC_RET_IF_FAIL(key, def);
        auto lower_it = std::lower_bound(
            this->begin(), this->end(), key, [] (const pair_type &a,
                                                 const char *key) {
                return strcmp_func(a.first, key) < 0;
            });
        if (lower_it == this->end() ||
            strcmp_func(lower_it->first, key) != 0) {
            qtcAssign(is_def, true);
            return def;
        }
        qtcAssign(is_def, false);
        return lower_it->second;
    }
};

}

#endif