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 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106
|
/* -*- Mode: C; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*-
* vim:expandtab:autoindent:tabstop=4:shiftwidth=4:filetype=c:cindent:textwidth=0:
*
* Copyright (C) 2005 Dell Inc.
* by Michael Brown <Michael_E_Brown@dell.com>
* Licensed under the Open Software License version 2.1
*
* Alternatively, you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published
* by the Free Software Foundation; either version 2 of the License,
* or (at your option) any later version.
* This program is distributed in the hope that it will be useful, but
* WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
* See the GNU General Public License for more details.
*/
#define LIBSMBIOS_SOURCE
#include "TokenImpl.h"
using namespace std;
namespace smbios
{
TokenTableIteratorBase::TokenTableIteratorBase (const ITokenTable *initialTable, int typeToMatch)
:matchType(typeToMatch), table(initialTable), current(-1)
{
if( table == 0 )
current = -2;
incrementIterator();
}
IToken * TokenTableIteratorBase::dereference () const
{
const TokenTable *CTTable = dynamic_cast<const TokenTable *>(table);
if( current >= 0 && static_cast<unsigned int>(current) >= CTTable->tokenList.size() )
current = -2; // should _never_ get here.
if( current > -1 )
{
return CTTable->tokenList[current] ;
}
throw DerefNullPointerImpl("tried to dereference non-existent token");
}
void TokenTableIteratorBase::incrementIterator()
{
if( current == -2 )
return;
const TokenTable *CTTable = dynamic_cast<const TokenTable *>(table);
size_t size = CTTable->tokenList.size();
do
{
++current;
}
while(
matchType != -1 &&
current >= 0 &&
static_cast<unsigned int>(current) < size &&
CTTable->tokenList[current]->getType() != static_cast<u32>(matchType)
);
// don't overflow the size of the table.
// be careful about signed vs unsigned comparisons.
if( current >= 0 && static_cast<unsigned int>(current) >= size )
current = -2;
return;
}
//Prefix ++
TokenTableIterator & TokenTableIterator::operator ++ ()
{
if( current > -1 )
incrementIterator();
return *this;
}
//Postfix ++
const TokenTableIterator TokenTableIterator::operator ++ (int)
{
const TokenTableIterator oldValue = *this;
++(*this);
return oldValue;
}
//Prefix ++
ConstTokenTableIterator & ConstTokenTableIterator::operator ++ ()
{
if( current > -1 )
incrementIterator();
return *this;
}
//Postfix ++
const ConstTokenTableIterator ConstTokenTableIterator::operator ++ (int)
{
const ConstTokenTableIterator oldValue = *this;
++(*this);
return oldValue;
}
}
|