gem-graph-client/include/util.h

135 lines
4.1 KiB
C

/* * * * * * * * * * * * * * * * * * * * * * * * * * *
* *
* Gem-graph client *
* *
* Finite State Machine (fsm) header *
* *
* Copyright © 2021 Libre en Communs <contact@a-lec.org> *
* Copyright © 2021 Adrien Bourmault <neox@a-lec.org> *
* Copyright © 2021 Jean Sirmai <jean@a-lec.org> *
* *
* This file is part of Gem-graph. *
* *
* This program is free software: you can redistribute it and/or modify it *
* under the terms of the GNU Affero General Public License *
* as published by the Free Software Foundation, *
* either version 3 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 Affero General Public License for more details. *
* *
* You should have received a copy of the GNU Affero General Public License *
* along with this program. If not, see <http://www.gnu.org/licenses/>. *
* *
* * * * * * * * * * * * * * * * * * * * * * * * * * */
#pragma once
#include <stdbool.h>
#include <stddef.h>
#include <gtk-4.0/gtk/gtk.h>
char *util_read_file(char *filename);
//------------------------------------------------------------------------------
// https://chgi.developpez.com/liste/ < ^c^v
/* Structure représentant un élément de la pile. */
typedef struct pile
{
int valeur;
struct pile *prec;
} pile ;
/* Push empile une valeur sur la pile. */
void util_pile_push(pile **, int);
/* Pop retire la dernière valeur empilée sur la pile. */
int util_pile_pop(pile **);
/* Clear vide la pile. */
void util_pile_clear(pile **);
/* Length retourne le nombre d'éléments de la pile. */
int util_pile_length(pile *p);
/* Affiche la totalité de la pile en commençant par le sommet. */
void util_pile_view(pile *);
//------------------------------------------------------------------------------
void util_pile_test(); // def: scr/util/tests
void util_double_list_test();
//==============================================================================
/* Structure représentant un élément de la liste. */
typedef struct elem
{
int value;
struct elem *prev;
struct elem *next;
} elem ;
/* Structure d'accès à la liste. */
typedef struct
{
elem *first;
elem *last;
}dblist;
/* Initialisation de la liste. */
void Init(dblist *l);
/* Ajout d'une valeur en fin de liste. */
void PushBack(dblist *l, int val);
/* Ajout d'une valeur en début de liste. */
void PushFront(dblist *l, int val);
/* Retrait d'une valeur en fin de liste. */
int PopBack(dblist *l);
/* Retrait d'une valeur en début de liste. */
int PopFront(dblist *l);
/* Affichage de toute la liste. */
void View(dblist l);
/* Vidage de toute la liste. */
void Clear(dblist *l);