Blob Blame History Raw
/*
  File: sequence.c
  (Linux Access Control List Management)

  Copyright (C) 1999, 2000
  Andreas Gruenbacher, <a.gruenbacher@bestbits.at>
 	
  This program is free software; you can redistribute it and/or
  modify it under the terms of the GNU Lesser General Public
  License as published by the Free Software Foundation; either
  version 2.1 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
  Lesser General Public License for more details.

  You should have received a copy of the GNU Lesser General Public
  License along with this library; if not, write to the Free Software
  Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
*/


#include "config.h"
#include <stdlib.h>
#include "sequence.h"


cmd_t
cmd_init(
	void)
{
	cmd_t cmd;

	cmd = malloc(sizeof(struct cmd_obj));
	if (cmd) {
		cmd->c_tag = ACL_UNDEFINED_TAG;
		cmd->c_perm = 0;
	}
	return cmd;
}


void
cmd_free(
	cmd_t cmd)
{
	free(cmd);
}


seq_t
seq_init(
	void)
{
	seq_t seq = (seq_t)malloc(sizeof(struct seq_obj));
	if (seq == NULL)
		return NULL;
	seq->s_first = seq->s_last = NULL;
	return seq;
}


int
seq_free(
	seq_t seq)
{
	cmd_t cmd = seq->s_first;
	while (cmd) {
		seq->s_first = seq->s_first->c_next;
		cmd_free(cmd);
		cmd = seq->s_first;
	}
	free(seq);
	return 0;
}


int
seq_empty(
	seq_t seq)
{
	return (seq->s_first == NULL);
}


int
seq_append(
	seq_t seq,
	cmd_t cmd)
{
	cmd->c_next = NULL;
	if (seq->s_first == NULL) {
		seq->s_first = seq->s_last = cmd;
	} else {
		seq->s_last->c_next = cmd;
		seq->s_last = cmd;
	}
	return 0;
}


int
seq_append_cmd(
	seq_t seq,
	cmd_tag_t cmd,
	acl_type_t type)
{
	cmd_t cmd_d = cmd_init();
	if (cmd_d == NULL)
		return -1;
	cmd_d->c_cmd = cmd;
	cmd_d->c_type = type;
	if (seq_append(seq, cmd_d) != 0) {
		cmd_free(cmd_d);
		return -1;
	}
	return 0;
}


int
seq_get_cmd(
	seq_t seq,
	int which,
	cmd_t *cmd)
{
	if (which == SEQ_FIRST_CMD) {
		if (seq->s_first == NULL)
			return 0;
		if (cmd)
			*cmd = seq->s_first;
		return 1;
	} else if (which == SEQ_NEXT_CMD) {
		if (cmd == NULL)
			return -1;
		if (*cmd) {
			*cmd = (*cmd)->c_next;
			return (*cmd == NULL) ? 0 : 1;
		}
		return 0;
	} else {
		return -1;
	}
}


int
seq_delete_cmd(
	seq_t seq,
	cmd_t cmd)
{
	cmd_t prev = seq->s_first;

	if (cmd == seq->s_first) {
		seq->s_first = seq->s_first->c_next;
		cmd_free(cmd);
		return 0;
	}
	while (prev != NULL && prev->c_next != cmd)
		prev = prev->c_next;
	if (prev == NULL)
		return -1;
	if (cmd == seq->s_last)
		seq->s_last = prev;
	prev->c_next = cmd->c_next;
	cmd_free(cmd);
	return 0;
}