Not sure how to keep Type out of the template while still referencing it from the templated class. i.e. How would I do this: "DualLookup::Type"?
This commit is contained in:
parent
757f877a5b
commit
6e603b412f
14
DualLookup.h
14
DualLookup.h
@ -2,11 +2,8 @@
|
|||||||
#define DVEREB_DUALLOOKUP_H
|
#define DVEREB_DUALLOOKUP_H
|
||||||
|
|
||||||
#include <unordered_map>
|
#include <unordered_map>
|
||||||
template <class T>
|
|
||||||
class DualLookup {
|
|
||||||
public:
|
|
||||||
DualLookup();
|
|
||||||
|
|
||||||
|
struct DualLookupBase {
|
||||||
// NOTE(dev): Used to determine which version of the string you want:
|
// NOTE(dev): Used to determine which version of the string you want:
|
||||||
// 1 / OPPOSITE: The string it maps to, opposite of the one you pass in.
|
// 1 / OPPOSITE: The string it maps to, opposite of the one you pass in.
|
||||||
// 2 / VALUE: The string passed via the first paramater of 'add.'
|
// 2 / VALUE: The string passed via the first paramater of 'add.'
|
||||||
@ -17,6 +14,15 @@ public:
|
|||||||
EQUIVALENT,
|
EQUIVALENT,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
protected:
|
||||||
|
DualLookupBase() {}
|
||||||
|
};
|
||||||
|
|
||||||
|
template <class T>
|
||||||
|
class DualLookup : public DualLookupBase {
|
||||||
|
public:
|
||||||
|
DualLookup();
|
||||||
|
|
||||||
/* Add a mapped pair to the container
|
/* Add a mapped pair to the container
|
||||||
* returns false if it already exists, regardless of direction
|
* returns false if it already exists, regardless of direction
|
||||||
* (i.e. value->equivilent is a duplicate of equivilent->value)
|
* (i.e. value->equivilent is a duplicate of equivilent->value)
|
||||||
|
6
main.cpp
6
main.cpp
@ -65,13 +65,13 @@ TEST_CASE("all tests", "all") {
|
|||||||
REQUIRE(container.get(1, container_result));
|
REQUIRE(container.get(1, container_result));
|
||||||
CHECK(container_result == 2);
|
CHECK(container_result == 2);
|
||||||
container_result = 0;
|
container_result = 0;
|
||||||
REQUIRE(container.get(1, container_result, DualLookup<int>::Type::OPPOSITE));
|
REQUIRE(container.get(1, container_result, DualLookupBase::Type::OPPOSITE));
|
||||||
CHECK(container_result == 2);
|
CHECK(container_result == 2);
|
||||||
container_result = 0;
|
container_result = 0;
|
||||||
REQUIRE(container.get(1, container_result, DualLookup<int>::Type::EQUIVALENT));
|
REQUIRE(container.get(1, container_result, DualLookupBase::Type::EQUIVALENT));
|
||||||
CHECK(container_result == 2);
|
CHECK(container_result == 2);
|
||||||
container_result = 0;
|
container_result = 0;
|
||||||
REQUIRE(container.get(1, container_result, DualLookup<int>::Type::VALUE));
|
REQUIRE(container.get(1, container_result, DualLookupBase::Type::VALUE));
|
||||||
CHECK(container_result == 1);
|
CHECK(container_result == 1);
|
||||||
|
|
||||||
container_result = 0;
|
container_result = 0;
|
||||||
|
Loading…
Reference in New Issue
Block a user