pvjc24/cv9/snake.c

60 lines
1.1 KiB
C
Raw Normal View History

2024-04-09 14:01:49 +00:00
#include "snake.h"
#include <stdlib.h>
struct snake* add_snake(struct snake* snake,int x,int y){
2024-04-09 14:40:49 +00:00
struct snake* hlavicka = calloc(1,sizeof(struct snake));
2024-04-09 14:50:26 +00:00
2024-04-09 14:36:36 +00:00
hlavicka->x = x;
hlavicka->y = y;
hlavicka->next = snake;
return hlavicka;
2024-04-09 14:01:49 +00:00
}
struct snake* remove_snake(struct snake* snake){
2024-04-09 15:28:01 +00:00
if (snake == NULL || snake->next == NULL) {
2024-04-09 15:04:30 +00:00
return NULL;
2024-04-09 15:02:39 +00:00
}
2024-04-09 15:12:20 +00:00
2024-04-09 15:29:13 +00:00
struct snake* predtym = NULL;
struct snake* teraz = snake;
while (teraz->next != NULL) {
predtym = teraz;
teraz = teraz->next;
2024-04-09 15:02:39 +00:00
}
2024-04-09 15:12:20 +00:00
2024-04-09 15:29:13 +00:00
free(teraz);
predtym->next = NULL;
2024-04-09 15:28:01 +00:00
return snake;
2024-04-09 14:01:49 +00:00
}
void free_snake(struct snake* sn){
}
int is_snake(struct snake* snake,int x,int y){
2024-04-10 18:57:12 +00:00
if(snake == NULL){
return NULL;
}
struct snake* pozicia = snake;
while(pozicia != NULL){
if(pozicia->x == x && pozicia->y == y){
return 1;
}
else{
return 0;
}
}
2024-04-09 14:01:49 +00:00
}
int step_state(struct state* st){
int nx = (st->snake->x + st->sx);
int ny = (st->snake->y + st->sy);
return END_CONTINUE;
}