home · contact · privacy
Killed monsters evolve into corpse items.
authorChristian Heller <c.heller@plomlompom.de>
Tue, 27 Aug 2013 02:37:23 +0000 (04:37 +0200)
committerChristian Heller <c.heller@plomlompom.de>
Tue, 27 Aug 2013 02:37:23 +0000 (04:37 +0200)
defs
src/map_object_actions.c
src/map_objects.c
src/map_objects.h

diff --git a/defs b/defs
index efa67c22eba297cc9e12b19a0c69b16a86076ff3..5761952c5900ef7a4ff30294d2c71167993b7632 100644 (file)
--- a/defs
+++ b/defs
@@ -1,5 +1,5 @@
-1 m a 1 ANT
-2 m z 3 ZOMBIE
-3 m S 9 SHOGGOTH
-4 i # THING
+1 m a 1 ANT
+2 m z 3 ZOMBIE
+3 m S 9 SHOGGOTH
+4 i # DIRT
 5 i % SKELETON
index a4e186d28b17f0acbd0cb4333fcdb0715efbacb6..53253bca1f096cdcb9bd95642d759ddc533034fe 100644 (file)
@@ -74,7 +74,6 @@ static void player_hits_monster(struct World * world, struct Monster * monster)
     update_log(world, msg);
     free(msg);
     monster->hitpoints--;
-
     if (0 == monster->hitpoints)
     {
         hit_dsc = "You kill the ";
@@ -82,6 +81,12 @@ static void player_hits_monster(struct World * world, struct Monster * monster)
         sprintf(msg, "\n%s%s.", hit_dsc, monster_dsc);
         update_log(world, msg);
         free(msg);
+        struct MonsterDef * md = (struct MonsterDef * ) mod;
+        struct Item * corpse = malloc(sizeof(struct Item));
+        corpse->map_obj.type = md->corpse_id;
+        corpse->map_obj.pos = monster->map_obj.pos;
+        corpse->map_obj.next = world->item;
+        world->item = corpse;
         if (world->monster == monster)
         {
             world->monster = world->monster->map_obj.next;
@@ -211,4 +216,3 @@ extern char is_passable (struct Map * map, struct yx_uint16 pos)
     }
     return passable;
 }
-
index 4beb4fdefa174d412c340fc1309f546b30d77ca1..8cb1fca18b73f41926db759dc17cf7deae66a2b6 100644 (file)
@@ -112,8 +112,9 @@ extern void init_map_object_defs(struct World * world, char * filename)
         }
         else
         {
-            md.hitpoints_start = atoi   (line_p + 4);
-            line_p             = strchr (line_p + 4, ' ') + 1;
+            md.corpse_id       = atoi   (line_p + 4);
+            md.hitpoints_start = atoi   (line_p + 6);
+            line_p             = strchr (line_p + 6, ' ') + 1;
         }
         mod.desc = calloc (strlen (line_p), sizeof(char));
         memcpy (mod.desc, line_p, strlen(line_p) - 1);
index a905b7bc48f4f788729fc886fe6fa9f37d15fc17..4804033d1002fe17499242046fdd5ff804d12f30 100644 (file)
@@ -68,6 +68,7 @@ struct ItemDef
 struct MonsterDef
 {
     struct MapObjDef map_obj_def;
+    uint8_t corpse_id;       /* ID of object type killed monster changes to. */
     uint8_t hitpoints_start; /* Hitpoints each monster starts with. */
 };