summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorPikalaxALT <pikalaxalt@gmail.com>2017-05-20 23:49:47 -0400
committerscnorton <scnorton@biociphers.org>2017-05-24 16:14:45 -0400
commita8d4813e571bb4dcdac5ee1fcf11d1efa4384687 (patch)
treed12df61368defed23949bc3ec435233216a1b28b /src
parent2b8d522c6cf6de600f07e409b9148e6ce92e047d (diff)
A handful more functions related to field map movement patterns
Diffstat (limited to 'src')
-rw-r--r--src/field_map_obj.c43
1 files changed, 41 insertions, 2 deletions
diff --git a/src/field_map_obj.c b/src/field_map_obj.c
index 19d4676cf..a7856ec07 100644
--- a/src/field_map_obj.c
+++ b/src/field_map_obj.c
@@ -1548,13 +1548,14 @@ u8 sub_805C904(struct MapObject *mapObject, struct Sprite *sprite)
return 1;
}
-extern bool8 FieldObjectExecRegularAnim();
+extern u8 FieldObjectExecRegularAnim(struct MapObject *, struct Sprite *);
extern const s16 gUnknown_0837520C[];
extern void sub_8064820(struct Sprite *, s16);
u8 sub_805C930(struct MapObject *mapObject, struct Sprite *sprite)
{
- if (FieldObjectExecRegularAnim(mapObject, sprite) == 0) {
+ if (FieldObjectExecRegularAnim(mapObject, sprite) == 0)
+ {
return 0;
}
sub_8064820(sprite, gUnknown_0837520C[Random() & 3]);
@@ -1562,3 +1563,41 @@ u8 sub_805C930(struct MapObject *mapObject, struct Sprite *sprite)
return 1;
}
+extern u8 sub_8064824(struct Sprite *);
+
+u8 sub_805C96C(struct MapObject *mapObject, struct Sprite *sprite)
+{
+ if (sub_8064824(sprite) != 0)
+ {
+ sprite->data1 = 4;
+ return 1;
+ }
+ return 0;
+}
+
+extern const u8 gUnknown_08375240[4];
+extern u8 sub_805FF20(struct MapObject *, u8);
+
+u8 sub_805C98C(struct MapObject *mapObject, struct Sprite *sprite)
+{
+ u8 direction;
+ u8 directions[4];
+ memcpy(directions, gUnknown_08375240, 4);
+ direction = directions[Random() & 3];
+ FieldObjectSetDirection(mapObject, direction);
+ sprite->data1 = 5;
+ if (sub_805FF20(mapObject, direction) != 0)
+ {
+ sprite->data1 = 1;
+ }
+ return 1;
+}
+
+u8 sub_805C9D8(struct MapObject *mapObject, struct Sprite *sprite)
+{
+ FieldObjectSetRegularAnim(mapObject, sprite, GetGoSpeed0AnimId(mapObject->placeholder18));
+ mapObject->mapobj_bit_1 = 1;
+ sprite->data1 = 6;
+ return 1;
+}
+