Blame lib/i-ring.c

Packit 9e4112
/* a simple ring buffer
Packit 9e4112
   Copyright (C) 2006, 2009-2018 Free Software Foundation, Inc.
Packit 9e4112
Packit 9e4112
   This program is free software: you can redistribute it and/or modify
Packit 9e4112
   it under the terms of the GNU General Public License as published by
Packit 9e4112
   the Free Software Foundation; either version 3 of the License, or
Packit 9e4112
   (at your option) any later version.
Packit 9e4112
Packit 9e4112
   This program is distributed in the hope that it will be useful,
Packit 9e4112
   but WITHOUT ANY WARRANTY; without even the implied warranty of
Packit 9e4112
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
Packit 9e4112
   GNU General Public License for more details.
Packit 9e4112
Packit 9e4112
   You should have received a copy of the GNU General Public License
Packit 9e4112
   along with this program.  If not, see <https://www.gnu.org/licenses/>.  */
Packit 9e4112
Packit 9e4112
/* written by Jim Meyering */
Packit 9e4112
Packit 9e4112
#include <config.h>
Packit 9e4112
#include "i-ring.h"
Packit 9e4112
Packit 9e4112
#include <stdlib.h>
Packit 9e4112
Packit 9e4112
void
Packit 9e4112
i_ring_init (I_ring *ir, int default_val)
Packit 9e4112
{
Packit 9e4112
  int i;
Packit 9e4112
  ir->ir_empty = true;
Packit 9e4112
  ir->ir_front = 0;
Packit 9e4112
  ir->ir_back = 0;
Packit 9e4112
  for (i = 0; i < I_RING_SIZE; i++)
Packit 9e4112
    ir->ir_data[i] = default_val;
Packit 9e4112
  ir->ir_default_val = default_val;
Packit 9e4112
}
Packit 9e4112
Packit 9e4112
bool
Packit 9e4112
i_ring_empty (I_ring const *ir)
Packit 9e4112
{
Packit 9e4112
  return ir->ir_empty;
Packit 9e4112
}
Packit 9e4112
Packit 9e4112
int
Packit 9e4112
i_ring_push (I_ring *ir, int val)
Packit 9e4112
{
Packit 9e4112
  unsigned int dest_idx = (ir->ir_front + !ir->ir_empty) % I_RING_SIZE;
Packit 9e4112
  int old_val = ir->ir_data[dest_idx];
Packit 9e4112
  ir->ir_data[dest_idx] = val;
Packit 9e4112
  ir->ir_front = dest_idx;
Packit 9e4112
  if (dest_idx == ir->ir_back)
Packit 9e4112
    ir->ir_back = (ir->ir_back + !ir->ir_empty) % I_RING_SIZE;
Packit 9e4112
  ir->ir_empty = false;
Packit 9e4112
  return old_val;
Packit 9e4112
}
Packit 9e4112
Packit 9e4112
int
Packit 9e4112
i_ring_pop (I_ring *ir)
Packit 9e4112
{
Packit 9e4112
  int top_val;
Packit 9e4112
  if (i_ring_empty (ir))
Packit 9e4112
    abort ();
Packit 9e4112
  top_val = ir->ir_data[ir->ir_front];
Packit 9e4112
  ir->ir_data[ir->ir_front] = ir->ir_default_val;
Packit 9e4112
  if (ir->ir_front == ir->ir_back)
Packit 9e4112
    ir->ir_empty = true;
Packit 9e4112
  else
Packit 9e4112
    ir->ir_front = ((ir->ir_front + I_RING_SIZE - 1) % I_RING_SIZE);
Packit 9e4112
  return top_val;
Packit 9e4112
}