File: algorithm.hpp

package info (click to toggle)
ares 126-3
  • links: PTS, VCS
  • area: main
  • in suites: bookworm
  • size: 32,600 kB
  • sloc: cpp: 356,508; ansic: 20,394; makefile: 16; sh: 2
file content (26 lines) | stat: -rw-r--r-- 673 bytes parent folder | download
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
#pragma once

#include <nall/traits.hpp>

#undef min
#undef max

namespace nall {

template<typename T, typename U> constexpr auto min(const T& t, const U& u) -> T {
  return t < u ? t : (T)u;
}

template<typename T, typename U, typename... P> constexpr auto min(const T& t, const U& u, P&&... p) -> T {
  return t < u ? min(t, forward<P>(p)...) : min(u, forward<P>(p)...);
}

template<typename T, typename U> constexpr auto max(const T& t, const U& u) -> T {
  return t > u ? t : (T)u;
}

template<typename T, typename U, typename... P> constexpr auto max(const T& t, const U& u, P&&... p) -> T {
  return t > u ? max(t, forward<P>(p)...) : max(u, forward<P>(p)...);
}

}