Blame vdo/base/slabIterator.h

Packit Service 693862
/*
Packit Service 693862
 * Copyright (c) 2020 Red Hat, Inc.
Packit Service 693862
 *
Packit Service 693862
 * This program is free software; you can redistribute it and/or
Packit Service 693862
 * modify it under the terms of the GNU General Public License
Packit Service 693862
 * as published by the Free Software Foundation; either version 2
Packit Service 693862
 * of the License, or (at your option) any later version.
Packit Service 693862
 * 
Packit Service 693862
 * This program is distributed in the hope that it will be useful,
Packit Service 693862
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
Packit Service 693862
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
Packit Service 693862
 * GNU General Public License for more details.
Packit Service 693862
 * 
Packit Service 693862
 * You should have received a copy of the GNU General Public License
Packit Service 693862
 * along with this program; if not, write to the Free Software
Packit Service 693862
 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
Packit Service 693862
 * 02110-1301, USA. 
Packit Service 693862
 *
Packit Service 693862
 * $Id: //eng/vdo-releases/aluminum/src/c++/vdo/base/slabIterator.h#1 $
Packit Service 693862
 */
Packit Service 693862
Packit Service 693862
#ifndef SLAB_ITERATOR_H
Packit Service 693862
#define SLAB_ITERATOR_H
Packit Service 693862
Packit Service 693862
#include "slab.h"
Packit Service 693862
#include "types.h"
Packit Service 693862
Packit Service 693862
/**
Packit Service 693862
 * SlabIterator is a structure for iterating over a set of slabs.
Packit Service 693862
 **/
Packit Service 693862
typedef struct {
Packit Service 693862
  Slab      **slabs;
Packit Service 693862
  Slab       *next;
Packit Service 693862
  SlabCount   end;
Packit Service 693862
  SlabCount   stride;
Packit Service 693862
} SlabIterator;
Packit Service 693862
Packit Service 693862
/**
Packit Service 693862
 * Return a SlabIterator initialized to iterate over an array of slabs
Packit Service 693862
 * with a given stride. Iteration always occurs from higher to lower numbered
Packit Service 693862
 * slabs.
Packit Service 693862
 *
Packit Service 693862
 * @param slabs  The array of slabs
Packit Service 693862
 * @param start  The number of the slab to start iterating from
Packit Service 693862
 * @param end    The number of the last slab which may be returned
Packit Service 693862
 * @param stride The difference in slab number between successive slabs
Packit Service 693862
 *
Packit Service 693862
 * @return an initialized iterator structure
Packit Service 693862
 **/
Packit Service 693862
static inline SlabIterator iterateSlabs(Slab      **slabs,
Packit Service 693862
                                        SlabCount   start,
Packit Service 693862
                                        SlabCount   end,
Packit Service 693862
                                        SlabCount   stride)
Packit Service 693862
{
Packit Service 693862
  return (SlabIterator) {
Packit Service 693862
    .slabs  = slabs,
Packit Service 693862
    .next   = (((slabs == NULL) || (start < end)) ? NULL : slabs[start]),
Packit Service 693862
    .end    = end,
Packit Service 693862
    .stride = stride,
Packit Service 693862
  };
Packit Service 693862
}
Packit Service 693862
Packit Service 693862
/**
Packit Service 693862
 * Check whether another Slab would be returned by the iterator.
Packit Service 693862
 *
Packit Service 693862
 * @param iterator  The iterator to poll
Packit Service 693862
 *
Packit Service 693862
 * @return true if the next call to nextSlab
Packit Service 693862
 *         will return a Slab
Packit Service 693862
 **/
Packit Service 693862
static inline bool hasNextSlab(const SlabIterator *iterator)
Packit Service 693862
{
Packit Service 693862
  return (iterator->next != NULL);
Packit Service 693862
}
Packit Service 693862
Packit Service 693862
/**
Packit Service 693862
 * Get the next Slab, advancing the iterator.
Packit Service 693862
 *
Packit Service 693862
 * @param iterator  The iterator over the Slab chain
Packit Service 693862
 *
Packit Service 693862
 * @return the next Slab or NULL if the array of slabs is empty
Packit Service 693862
 *         or if all the appropriate Slabs have been returned
Packit Service 693862
 **/
Packit Service 693862
static inline Slab *nextSlab(SlabIterator *iterator)
Packit Service 693862
{
Packit Service 693862
  Slab *slab = iterator->next;
Packit Service 693862
  if ((slab == NULL)
Packit Service 693862
      || (slab->slabNumber < iterator->end + iterator->stride)) {
Packit Service 693862
    iterator->next = NULL;
Packit Service 693862
  } else {
Packit Service 693862
    iterator->next = iterator->slabs[slab->slabNumber - iterator->stride];
Packit Service 693862
  }
Packit Service 693862
  return slab;
Packit Service 693862
}
Packit Service 693862
Packit Service 693862
#endif // SLAB_ITERATOR_H