Blame lib/i-ring.c

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