X-Git-Url: https://plomlompom.com/repos/?a=blobdiff_plain;f=src%2Fmap_objects.c;h=747b7180a52e905111885d3b224ce8af7e92022c;hb=2e690e2500e66535018bb6e01222442c074cb298;hp=731d830df716864932571d14a245e8e52f7bbfe3;hpb=00a66e3c7cbcad13b5c29162e6c1c33235be9f07;p=plomrogue diff --git a/src/map_objects.c b/src/map_objects.c index 731d830..747b718 100644 --- a/src/map_objects.c +++ b/src/map_objects.c @@ -1,15 +1,53 @@ #include "map_objects.h" #include #include +#include #include "readwrite.h" #include "misc.h" #include "main.h" static struct MapObj * get_next_map_obj (void *, char *, size_t, struct MapObj *); -extern void readwrite_map_objects_dummy (void * dummy, FILE * file) { -// Dummy function for calls of (write|read)_map_objects on map objects without specific attributes. - ; } +extern void init_map_object_defs (struct World * world, char * filename) { +// Initialize map object definitions from file at path "filename". + world->item_def = 0; + world->monster_def = 0; + FILE * file = fopen(filename, "r"); + uint16_t linemax; + textfile_sizes (file, &linemax, NULL); + struct MapObjDef mod; + struct ItemDef id; + struct MonsterDef md; + struct ItemDef * * p_p_id = &world->item_def; + struct MonsterDef * * p_p_md = &world->monster_def; + char * defline = malloc(linemax); + char * line_p; + char m_or_i; + while (fgets (defline, linemax, file)) { + mod.next = 0; + mod.id = atoi(defline); + line_p = strchr(defline, ' ') + 1; + m_or_i = * line_p; + mod.mapchar = * (line_p + 2); + if ('i' == m_or_i) + line_p = line_p + 5; + else { + md.hitpoints_start = atoi (line_p + 4); + line_p = strchr (line_p + 4, ' ') + 1; } + mod.desc = calloc (strlen (line_p), sizeof(char)); + memcpy (mod.desc, line_p, strlen(line_p) - 1); + if ('i' == m_or_i) { + id.map_obj_def = mod; + * p_p_id = malloc (sizeof (struct ItemDef)); + * * p_p_id = id; + p_p_id = (struct ItemDef * *) * p_p_id; } + else { + md.map_obj_def = mod; + * p_p_md = malloc (sizeof (struct MonsterDef)); + * * p_p_md = md; + p_p_md = (struct MonsterDef * *) * p_p_md; } } + free(defline); + fclose(file); }; extern void write_map_objects_monsterdata (void * start, FILE * file) { // Write to file data specific to map objects of type monster. @@ -23,7 +61,8 @@ extern void write_map_objects (void * start, FILE * file, void (* w_typedata) (v write_uint16_bigendian(map_obj->pos.y + 1, file); write_uint16_bigendian(map_obj->pos.x + 1, file); fputc(map_obj->type, file); - w_typedata (map_obj, file); } + if (w_typedata) + w_typedata (map_obj, file); } write_uint16_bigendian(0, file); } extern void read_map_objects_monsterdata (void * start, FILE * file) { @@ -56,7 +95,8 @@ extern void read_map_objects (void * start, FILE * file, size_t size, void (* r_ map_obj->pos.y = test - 1; map_obj->pos.x = read_uint16_bigendian(file) - 1; map_obj->type = fgetc(file); - r_typedata (map_obj, file); } + if (r_typedata) + r_typedata (map_obj, file); } if (!first) map_obj->next = 0; }