2023-08-19 14:18:41 +02:00
|
|
|
#ifndef NPC_H
|
|
|
|
#define NPC_H
|
|
|
|
|
|
|
|
#include "game.h"
|
|
|
|
#include "memory.h"
|
|
|
|
|
2024-07-29 21:04:23 +02:00
|
|
|
#include <stdbool.h>
|
|
|
|
#include <stdint.h>
|
|
|
|
|
2024-07-29 11:36:11 +02:00
|
|
|
enum {
|
2024-07-21 02:42:50 +02:00
|
|
|
|
|
|
|
NPC_NONE = 0,
|
2024-07-29 11:36:11 +02:00
|
|
|
NPC_FRIENDLY = 1, // The player's team
|
|
|
|
NPC_HOSTILE = 2, // to the player
|
2024-07-21 02:42:50 +02:00
|
|
|
NPC_ALL = 3
|
|
|
|
|
2024-07-23 18:17:02 +02:00
|
|
|
};
|
2023-08-19 14:18:41 +02:00
|
|
|
|
2024-08-01 15:05:42 +02:00
|
|
|
/* /!\ Warning /!\
|
|
|
|
* Do not keep hard references to non-static NPCs, as they will likely move
|
|
|
|
* in the stack */
|
|
|
|
|
|
|
|
/* Creates a new NPC in the NPC stack (Needs to be set to valid values !)
|
|
|
|
* Returns NULL on failure */
|
|
|
|
NPC *npc_create();
|
|
|
|
|
|
|
|
/* Pops the NPC from the NPC stack
|
|
|
|
* Consider this as a free */
|
|
|
|
void npc_remove(NPC *npc);
|
|
|
|
|
|
|
|
/* Frees then malloc()s a new path to npc
|
|
|
|
* Useful if you want to safely edit a path */
|
2024-07-23 18:06:42 +02:00
|
|
|
int npc_clear_path(NPC *npc);
|
|
|
|
|
2024-08-01 15:05:42 +02:00
|
|
|
/* Adds point x,y to the path of npc
|
|
|
|
* Won't work on static NPCs, use npc_clear_path before or make them on the
|
|
|
|
* heap */
|
2024-07-23 18:06:42 +02:00
|
|
|
int npc_append_path(uint16_t x, uint16_t y, NPC *npc);
|
|
|
|
|
2024-08-01 15:05:42 +02:00
|
|
|
/* Clears the NPCs path and creates a new one going to dest,
|
|
|
|
* avoiding non-walkable tiles
|
|
|
|
* Returns non-zero on failure */
|
2024-07-27 14:02:04 +02:00
|
|
|
int npc_pathfind(int32_t dest_x, int32_t dest_y, Map *full_map, NPC *npc);
|
|
|
|
|
2023-08-19 14:18:41 +02:00
|
|
|
/* Draws the player player. This function should be called after drawing the
|
|
|
|
* map! */
|
|
|
|
void npc_draw(Game *game);
|
|
|
|
|
2024-08-01 15:05:42 +02:00
|
|
|
/* Updates the static NPCs and the NPC stack */
|
2024-07-21 02:42:50 +02:00
|
|
|
void update_npcs(Game *game);
|
2024-08-01 15:05:42 +02:00
|
|
|
/* Updates the singular NPC npc. Be careful with it ! */
|
2024-07-21 02:42:50 +02:00
|
|
|
void update_npc(NPC *npc);
|
2024-08-01 15:05:42 +02:00
|
|
|
/* Inits/Clears the NPC stack*/
|
|
|
|
void npc_reload(Game *game);
|
2023-08-19 14:18:41 +02:00
|
|
|
|
|
|
|
#endif
|