annotate foosdk/sdk/pfc/fixed_map.h @ 1:20d02a178406 default tip

*: check in everything else yay
author Paper <paper@tflc.us>
date Mon, 05 Jan 2026 02:15:46 -0500
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
1
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
1 #pragma once
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
2
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
3 #include <map>
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
4 #include <algorithm>
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
5 #include <vector>
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
6
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
7 template<typename key_t, typename value_t> class fixed_map {
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
8 public:
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
9 typedef std::map<key_t, value_t> source_t;
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
10
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
11 void initialize(source_t&& src) {
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
12 const size_t size = src.size();
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
13 m_keys.resize(size); m_values.resize(size);
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
14 size_t walk = 0;
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
15 for (auto iter = src.begin(); iter != src.end(); ++iter) {
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
16 m_keys[walk] = iter->first;
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
17 m_values[walk] = std::move(iter->second);
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
18 ++walk;
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
19 }
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
20 src.clear();
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
21 }
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
22
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
23 value_t query(key_t key) const {
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
24 auto iter = std::lower_bound(m_keys.begin(), m_keys.end(), key);
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
25 if (iter == m_keys.end() || *iter != key) return 0;
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
26 return m_values[iter - m_keys.begin()];
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
27 }
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
28
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
29 const value_t* query_ptr(key_t key) const {
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
30 auto iter = std::lower_bound(m_keys.begin(), m_keys.end(), key);
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
31 if (iter == m_keys.end() || *iter != key) return nullptr;
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
32 return &m_values[iter - m_keys.begin()];
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
33 }
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
34 private:
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
35 std::vector<key_t> m_keys;
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
36 std::vector<value_t> m_values;
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
37 };