39 lines
1001 B
C++
39 lines
1001 B
C++
|
/*
|
||
|
* This Source Code Form is subject to the terms of the Mozilla Public
|
||
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
||
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/.
|
||
|
*
|
||
|
* Copyright 2019 Danny Robson <danny@nerdcruft.net>
|
||
|
*/
|
||
|
|
||
|
#pragma once
|
||
|
|
||
|
#include "base.hpp"
|
||
|
|
||
|
#include <cstddef>
|
||
|
|
||
|
|
||
|
///////////////////////////////////////////////////////////////////////////////
|
||
|
namespace cruft::coord {
|
||
|
/// A StrictWeakOrder over coordinate types.
|
||
|
///
|
||
|
/// The comparison operates across successive elements of the two
|
||
|
/// coordinates.
|
||
|
template <typename CoordT>
|
||
|
struct ordering {
|
||
|
bool operator() (
|
||
|
CoordT const &a,
|
||
|
CoordT const &b
|
||
|
) const noexcept {
|
||
|
for (std::size_t i = 0; i < CoordT::elements; ++i) {
|
||
|
if (a[i] < b[i])
|
||
|
return true;
|
||
|
else if (a[i] > b[i])
|
||
|
return false;
|
||
|
}
|
||
|
|
||
|
return false;
|
||
|
}
|
||
|
};
|
||
|
}
|