2024-12-13 19:08:05 +08:00
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include "CoreTypes.h"
|
|
|
|
#include "Iterator/Utility.h"
|
|
|
|
#include "Iterator/Sentinel.h"
|
|
|
|
#include "TypeTraits/TypeTraits.h"
|
|
|
|
|
|
|
|
NAMESPACE_REDCRAFT_BEGIN
|
|
|
|
NAMESPACE_MODULE_BEGIN(Redcraft)
|
|
|
|
NAMESPACE_MODULE_BEGIN(Utility)
|
|
|
|
|
|
|
|
#if PLATFORM_COMPILER_GCC
|
|
|
|
# pragma GCC diagnostic push
|
|
|
|
# pragma GCC diagnostic ignored "-Wnon-template-friend"
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/** A concept specifies a type is an input iterator. It is input iterator, incrementable, and sentinel for itself. */
|
|
|
|
template <typename I>
|
|
|
|
concept CForwardIterator = CInputIterator<I> && CIncrementable<I> && CSentinelFor<I, I>;
|
|
|
|
|
|
|
|
/** This is an example of a forward iterator, indicate the traits that define a forward iterator. */
|
2024-12-14 14:12:07 +08:00
|
|
|
template <CReferenceable T>
|
2024-12-14 14:02:26 +08:00
|
|
|
struct IForwardIterator /* : IInputIterator<T>, IIncrementable, ISentinelFor<IForwardIterator> */
|
2024-12-13 19:08:05 +08:00
|
|
|
{
|
2024-12-14 14:02:26 +08:00
|
|
|
// ~Begin CInputIterator.
|
|
|
|
|
2024-12-13 19:08:05 +08:00
|
|
|
using ElementType = TRemoveCVRef<T>;
|
|
|
|
|
2024-12-14 14:02:26 +08:00
|
|
|
// ~End CInputIterator.
|
2024-12-13 19:08:05 +08:00
|
|
|
|
2024-12-14 14:02:26 +08:00
|
|
|
// ~Begin CIncrementable and CSentinelFor<IForwardIterator>.
|
2024-12-13 19:08:05 +08:00
|
|
|
|
2024-12-14 14:02:26 +08:00
|
|
|
IForwardIterator();
|
|
|
|
IForwardIterator(const IForwardIterator&);
|
|
|
|
IForwardIterator(IForwardIterator&&); // Also satisfies IInputIterator.
|
2024-12-13 19:08:05 +08:00
|
|
|
IForwardIterator* operator=(const IForwardIterator&);
|
2024-12-14 14:02:26 +08:00
|
|
|
IForwardIterator* operator=(IForwardIterator&&); // Also satisfies IInputIterator.
|
2024-12-13 19:08:05 +08:00
|
|
|
|
|
|
|
friend bool operator==(const IForwardIterator&, const IForwardIterator&);
|
|
|
|
|
2024-12-14 14:02:26 +08:00
|
|
|
// ~End CIncrementable and CSentinelFor<IForwardIterator>.
|
|
|
|
|
|
|
|
// ~Begin CInputIterator.
|
|
|
|
|
|
|
|
T operator*() const; // Optional satisfies CIndirectlyWritable.
|
|
|
|
|
|
|
|
IForwardIterator& operator++(); // Also satisfies CIncrementable.
|
2024-12-13 19:08:05 +08:00
|
|
|
|
2024-12-14 14:02:26 +08:00
|
|
|
IForwardIterator operator++(int); // Also satisfies CIncrementable.
|
2024-12-13 19:08:05 +08:00
|
|
|
|
2024-12-14 14:02:26 +08:00
|
|
|
// ~End CInputIterator.
|
2024-12-13 19:08:05 +08:00
|
|
|
};
|
|
|
|
|
2024-12-14 14:02:26 +08:00
|
|
|
// Use IForwardIterator<int> represents a forward iterator.
|
2024-12-13 19:08:05 +08:00
|
|
|
static_assert(CForwardIterator<IForwardIterator<int&>>);
|
|
|
|
static_assert( COutputIterator<IForwardIterator<int&>, int>);
|
|
|
|
|
|
|
|
#if PLATFORM_COMPILER_GCC
|
|
|
|
# pragma GCC diagnostic pop
|
|
|
|
#endif
|
|
|
|
|
|
|
|
NAMESPACE_MODULE_END(Utility)
|
|
|
|
NAMESPACE_MODULE_END(Redcraft)
|
|
|
|
NAMESPACE_REDCRAFT_END
|