tty-solitaire/lib/stack.c

60 lines
1.0 KiB
C
Raw Normal View History

2010-04-04 00:44:59 +00:00
#include <malloc.h>
#include <stdbool.h>
#include "card.h"
#include "stack.h"
struct stack *initialize_stack() {
struct stack *stack = NULL;
stack = malloc(sizeof(stack));
stack->card = NULL;
stack->next = NULL;
return(stack);
}
bool empty(struct stack *stack) {
return(stack->card == NULL);
}
int length(struct stack *stack) {
2010-04-04 03:51:14 +00:00
struct stack *iterator = stack;
2010-04-04 00:44:59 +00:00
int length = 0;
if (!empty(stack)) {
length = 1;
2010-04-04 03:51:14 +00:00
while (iterator->next != NULL) {
2010-04-04 00:44:59 +00:00
length++;
2010-04-04 03:51:14 +00:00
iterator = iterator->next;
2010-04-04 00:44:59 +00:00
}
}
return(length);
}
void push(struct stack *stack, struct card *card) {
struct stack *new_stack = NULL;
if (empty(stack)) {
stack->card = card;
} else {
new_stack = malloc(sizeof(new_stack));
new_stack->card = card;
new_stack->next = stack;
stack = new_stack;
}
}
2010-04-04 01:12:42 +00:00
struct stack *pop(struct stack *stack) {
struct stack *popped_entry = NULL;
if(!empty(stack)) {
popped_entry = stack;
popped_entry = NULL;
stack = stack->next;
}
return(popped_entry);
}