/* * This file is part of the Poliqarp suite. * * Copyright (C) 2004-2009 by Instytut Podstaw Informatyki Polskiej * Akademii Nauk (IPI PAN; Institute of Computer Science, Polish * Academy of Sciences; cf. www.ipipan.waw.pl). All rights reserved. * * This file may be distributed and/or modified under the terms of the * GNU General Public License version 2 as published by the Free Software * Foundation and appearing in the file gpl.txt included in the packaging * of this file. (See http://www.gnu.org/licenses/translations.html for * unofficial translations.) * * A commercial license is available from IPI PAN (contact * Michal.Ciesiolka@ipipan.waw.pl or ipi@ipipan.waw.pl for more * information). Licensees holding a valid commercial license from IPI * PAN may use this file in accordance with that license. * * This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING * THE WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR * PURPOSE. */ #include <stdlib.h> #include "msgqueue.h" void msgqueue_init(struct msgqueue *queue) { queue->first = queue->last = NULL; } void msgqueue_append(struct msgqueue *queue, string_t str) { struct msgqueue_elem *el = malloc(sizeof(*el)); el->msg = str; el->next = NULL; if (queue->first) { queue->last->next = el; queue->last = el; } else { queue->first = queue->last = el; } } string_t msgqueue_get(struct msgqueue *queue) { if (queue->first) { struct msgqueue_elem *el = queue->first; string_t msg = el->msg; queue->first = el->next; if (el->next == NULL) queue->last = NULL; free(el); return msg; } else return NULL; }