// IndexImpl.h #ifndef INDEX_IMPL_H #define INDEX_IMPL_H #include "Index.h" #include "Node.h" // AbstractIndexEntryIterator class AbstractIndexEntryIterator { public: AbstractIndexEntryIterator(); virtual ~AbstractIndexEntryIterator(); virtual Entry *GetCurrent() = 0; virtual Entry *GetCurrent(uint8 *buffer, size_t *keyLength) = 0; virtual Entry *GetPrevious() = 0; virtual Entry *GetNext() = 0; virtual status_t Suspend(); virtual status_t Resume(); }; // NodeEntryIterator template class NodeEntryIterator : public AbstractIndexEntryIterator { public: NodeEntryIterator(); virtual ~NodeEntryIterator(); void Unset(); virtual Entry *GetCurrent(); virtual Entry *GetCurrent(uint8 *buffer, size_t *keyLength) = 0; virtual Entry *GetPrevious(); virtual Entry *GetNext(); virtual status_t Suspend(); virtual status_t Resume(); Node *GetCurrentNode() const { return fNode; } protected: NodeIterator fIterator; Node *fNode; Entry *fEntry; bool fInitialized; bool fIsNext; bool fSuspended; }; // constructor template NodeEntryIterator::NodeEntryIterator() : AbstractIndexEntryIterator(), fIterator(), fNode(NULL), fEntry(NULL), fInitialized(false), fIsNext(false), fSuspended(false) { } // destructor template NodeEntryIterator::~NodeEntryIterator() { } // Unset template void NodeEntryIterator::Unset() { fNode = NULL; fEntry = NULL; fInitialized = false; fIsNext = false; fSuspended = false; } // GetCurrent template Entry * NodeEntryIterator::GetCurrent() { return fEntry; } // GetPrevious template Entry * NodeEntryIterator::GetPrevious() { return NULL; // backwards iteration not implemented } // GetNext template Entry * NodeEntryIterator::GetNext() { if (!fInitialized || !fNode || fSuspended) return NULL; if (!(fEntry && fIsNext)) { while (fNode) { if (fEntry) fEntry = fNode->GetNextReferrer(fEntry); while (fNode && !fEntry) { fNode = NULL; if (Node **nodeP = fIterator.GetNext()) { fNode = *nodeP; fEntry = fNode->GetFirstReferrer(); } } if (fEntry) break; } } fIsNext = false; return fEntry; } // Suspend template status_t NodeEntryIterator::Suspend() { status_t error = (fInitialized && !fSuspended ? B_OK : B_BAD_VALUE); if (error == B_OK) fSuspended = true; return error; } // Resume template status_t NodeEntryIterator::Resume() { status_t error = (fInitialized && fSuspended ? B_OK : B_BAD_VALUE); if (error == B_OK) fSuspended = false; return error; } #endif // INDEX_IMPL_H