ensure correct ctor overload resolution on char/pointer range for two pointers vs pointer plus size when passed int (or similar)

master
Daniel Kolesa 2015-08-05 02:09:44 +01:00
parent da4c3a0947
commit 50a8562d20
2 changed files with 18 additions and 2 deletions

View File

@ -815,8 +815,18 @@ NumberRange<T> range(T v) {
template<typename T>
struct PointerRange: InputRange<PointerRange<T>, ContiguousRangeTag, T> {
private:
struct Nat {};
public:
PointerRange(): p_beg(nullptr), p_end(nullptr) {}
PointerRange(T *beg, T *end): p_beg(beg), p_end(end) {}
template<typename U>
PointerRange(T *beg, U end, EnableIf<
(IsPointer<U>::value || IsNullPointer<U>::value) &&
IsConvertible<U, T *>::value, Nat
> = Nat()): p_beg(beg), p_end(end) {}
PointerRange(T *beg, Size n): p_beg(beg), p_end(beg + n) {}
template<typename U, typename = EnableIf<

View File

@ -29,7 +29,13 @@ private:
public:
CharRangeBase(): p_beg(nullptr), p_end(nullptr) {};
CharRangeBase(T *beg, T *end): p_beg(beg), p_end(end) {}
template<typename U>
CharRangeBase(T *beg, U end, EnableIf<
(IsPointer<U>::value || IsNullPointer<U>::value) &&
IsConvertible<U, T *>::value, Nat
> = Nat()): p_beg(beg), p_end(end) {}
CharRangeBase(T *beg, Size n): p_beg(beg), p_end(beg + n) {}
/* TODO: traits for utf-16/utf-32 string lengths, for now assume char */