v4.0.4-rc #7

Merged
lw-everestlinux merged 1 commits from release/v4.0.4-rc into main 2024-12-30 14:31:00 -05:00

View File

@ -18,6 +18,8 @@
#ifndef GLACIERDATA_H_ #ifndef GLACIERDATA_H_
#define GLACIERDATA_H_ #define GLACIERDATA_H_
#include <stdbool.h>
/* /*
* create_node * create_node
* *
@ -58,7 +60,7 @@ void add_child(struct node *parent, struct node *child);
/* /*
* print_tree * print_tree
* *
* DESCRIPTION: Print_tree prints a dependency tree specified at its root node * DESCRIPTION: Print_tree prints a dependency tree specified at its root node.
* PARAMETERS: * PARAMETERS:
* struct node *root -> The tree to print * struct node *root -> The tree to print
* int level -> The number of levels to descend * int level -> The number of levels to descend
@ -74,6 +76,16 @@ void print_tree(struct node *root, int level);
/**************************************************************************************************************/ /**************************************************************************************************************/
/*
* queue
*
* DESCRIPTION: Queue is a type definition for the queue data structure.
*/
typedef struct queue;
/**************************************************************************************************************/
/* /*
* init_queue * init_queue
* *
@ -95,7 +107,7 @@ void init_queue(queue *q);
/* /*
* queue_is_empty * queue_is_empty
* *
* DESCRIPTION: Queue_is_empty checks if queue *q is empty * DESCRIPTION: Queue_is_empty checks if queue *q is empty.
* PARAMETERS: * PARAMETERS:
* queue *q -> The queue to check * queue *q -> The queue to check
* RETURN VALUES: * RETURN VALUES:
@ -116,7 +128,7 @@ bool queue_is_empty(queue *q);
/* /*
* queue_is_full * queue_is_full
* *
* DESCRIPTION: Queue_is_full checks if queue *q is full * DESCRIPTION: Queue_is_full checks if queue *q is full.
* PARAMETERS: * PARAMETERS:
* queue *q -> The queue to check * queue *q -> The queue to check
* RETURN VALUES: * RETURN VALUES:
@ -137,20 +149,80 @@ bool queue_is_full(queue *q);
/* /*
* enqueue * enqueue
* *
* DESCRIPTION: Enqueue enqueues an element at the back of the queue * DESCRIPTION: Enqueue enqueues an element at the back of the queue.
* PARAMETERS: * PARAMETERS:
* queue *q -> The queue to enqueue to * queue *q -> The queue to enqueue to
* int value -> * int value -> The value of the element to enqueue
* RETURN VALUES: * RETURN VALUES:
* true on full, false on not full * None.
* CAVEATS: * CAVEATS:
* None. * None.
* EXAMPLE: * EXAMPLE:
* if (queue_is_full(q)) { * if (! queue_is_full(q)) {
* printf("Queue is full\n"); * enqueue(q, 15);
* return;
* } * }
*/ */
void enqueue(queue *q, int value);
/**************************************************************************************************************/
/*
* dequeue
*
* DESCRIPTION: Dequeue dequeues an element at the front of the queue.
* PARAMETERS:
* queue *q -> The queue to dequeue to
* RETURN VALUES:
* None.
* CAVEATS:
* None.
* EXAMPLE:
* if (! queue_is_empty(q)) {
* dequeue(q);
* }
*/
void dequeue(queue *q);
/**************************************************************************************************************/
/*
* peek
*
* DESCRIPTION: Peek displays the first element in a specified queue.
* PARAMETERS:
* queue *q -> The queue to peek at
* RETURN VALUES:
* -1 on queue is empty, element value (!= -1) on success
* CAVEATS:
* None.
* EXAMPLE:
* if (! queue_is_full(q)) {
* peek(q);
* }
*/
int peek(queue *q);
/**************************************************************************************************************/
/*
* print_queue
*
* DESCRIPTION: Print_queue displays the contents of the queue in order.
* PARAMETERS:
* queue *q -> The queue to print
* RETURN VALUES:
* None.
* CAVEATS:
* None.
* EXAMPLE:
* if (! queue_is_full(q)) {
* print_queue(q);
* }
*/
void print_queue(queue *q);
#endif #endif