Skip to content

Commit

Permalink
Merge remote-tracking branch 'augustus/master' into dynamic-scenario-…
Browse files Browse the repository at this point in the history
…objects
  • Loading branch information
crudelios committed Aug 1, 2024
2 parents 2dea765 + 626ea78 commit cc2ba87
Show file tree
Hide file tree
Showing 18 changed files with 1,389 additions and 158 deletions.
12 changes: 6 additions & 6 deletions src/core/buffer.c
Original file line number Diff line number Diff line change
Expand Up @@ -134,8 +134,8 @@ int8_t buffer_read_i8(buffer *buf)
int16_t buffer_read_i16(buffer *buf)
{
if (check_size(buf, 2)) {
uint8_t b0 = buf->data[buf->index++];
uint8_t b1 = buf->data[buf->index++];
uint16_t b0 = buf->data[buf->index++];
uint16_t b1 = buf->data[buf->index++];
return (int16_t) (b0 | (b1 << 8));
} else {
return 0;
Expand All @@ -145,10 +145,10 @@ int16_t buffer_read_i16(buffer *buf)
int32_t buffer_read_i32(buffer *buf)
{
if (check_size(buf, 4)) {
uint8_t b0 = buf->data[buf->index++];
uint8_t b1 = buf->data[buf->index++];
uint8_t b2 = buf->data[buf->index++];
uint8_t b3 = buf->data[buf->index++];
uint32_t b0 = buf->data[buf->index++];
uint32_t b1 = buf->data[buf->index++];
uint32_t b2 = buf->data[buf->index++];
uint32_t b3 = buf->data[buf->index++];
return (int32_t) (b0 | (b1 << 8) | (b2 << 16) | (b3 << 24));
} else {
return 0;
Expand Down
2 changes: 2 additions & 0 deletions src/figure/action.c
Original file line number Diff line number Diff line change
Expand Up @@ -123,6 +123,8 @@ static void (*figure_action_callbacks[])(figure *f) = {
figure_soldier_action,
figure_beggar_action,
figure_soldier_action,
figure_enemy_catapult_action,
figure_catapult_missile_action,
};

void figure_action_handle(void)
Expand Down
6 changes: 4 additions & 2 deletions src/figure/combat.c
Original file line number Diff line number Diff line change
Expand Up @@ -110,10 +110,10 @@ static void hit_opponent(figure *f)
if (!attack_is_same_direction(opponent->attack_direction, opponent_formation->direction)) {
opponent_defense -= 2; // opponent not attacking in coordinated formation
} else if (opponent_formation->layout == FORMATION_COLUMN) {
opponent_defense += 4;
opponent_defense += 3;
} else if (opponent_formation->layout == FORMATION_DOUBLE_LINE_1 ||
opponent_formation->layout == FORMATION_DOUBLE_LINE_2) {
opponent_defense += 2;
opponent_defense += 1;
}
}

Expand Down Expand Up @@ -230,6 +230,7 @@ int figure_combat_get_target_for_wolf(int x, int y, int max_distance)
case FIGURE_JAVELIN:
case FIGURE_BOLT:
case FIGURE_BALLISTA:
case FIGURE_CATAPULT_MISSILE:
case FIGURE_FRIENDLY_ARROW:
case FIGURE_WATCHTOWER_ARCHER:
case FIGURE_CREATURE:
Expand Down Expand Up @@ -359,6 +360,7 @@ int figure_combat_get_missile_target_for_enemy(figure *enemy, int max_distance,
case FIGURE_BOLT:
case FIGURE_BALLISTA:
case FIGURE_FRIENDLY_ARROW:
case FIGURE_CATAPULT_MISSILE:
case FIGURE_WATCHTOWER_ARCHER:
case FIGURE_CREATURE:
case FIGURE_FISH_GULLS:
Expand Down
3 changes: 2 additions & 1 deletion src/figure/figure.c
Original file line number Diff line number Diff line change
Expand Up @@ -137,6 +137,7 @@ void figure_delete(figure *f)
case FIGURE_JAVELIN:
case FIGURE_FRIENDLY_ARROW:
case FIGURE_BOLT:
case FIGURE_CATAPULT_MISSILE:
case FIGURE_SPEAR:
case FIGURE_FISH_GULLS:
case FIGURE_SHEEP:
Expand Down Expand Up @@ -213,7 +214,7 @@ int figure_is_dead(const figure *f)

int figure_is_enemy(const figure *f)
{
return f->type >= FIGURE_ENEMY43_SPEAR && f->type <= FIGURE_ENEMY_CAESAR_LEGIONARY;
return (f->type >= FIGURE_ENEMY43_SPEAR && f->type <= FIGURE_ENEMY_CAESAR_LEGIONARY) || f->type == FIGURE_ENEMY_CATAPULT;
}

int figure_is_legion(const figure *f)
Expand Down
1 change: 1 addition & 0 deletions src/figure/name.c
Original file line number Diff line number Diff line change
Expand Up @@ -161,6 +161,7 @@ int figure_name_get(figure_type type, enemy_type_t enemy)
case FIGURE_ENEMY51_SPEAR:
case FIGURE_ENEMY52_MOUNTED_ARCHER:
case FIGURE_ENEMY53_AXE:
case FIGURE_ENEMY_CATAPULT:
switch (enemy) {
case ENEMY_8_GREEK:
return get_next_name(&data.enemy_greek, 463, 32);
Expand Down
2 changes: 1 addition & 1 deletion src/figure/phrase.c
Original file line number Diff line number Diff line change
Expand Up @@ -257,7 +257,7 @@ static const int FIGURE_TYPE_TO_SOUND_TYPE[] = {
-1, -1, -1, -1, 30, -1, 31, -1, -1, -1, // 60-69
-1, -1, -1, 19, 19, 2, 1, 19, 8, 11, // 70-79
11, -1, 1, -1, -1, 19, 20, 20, 19, 19, // 80-89
19, -1, -1, 22, -1, -1, -1, -1, -1, -1, // 90-99
19, -1, -1, 22, 25, -1, -1, -1, -1, -1, // 90-99
};

enum {
Expand Down
14 changes: 12 additions & 2 deletions src/figure/properties.c
Original file line number Diff line number Diff line change
Expand Up @@ -383,7 +383,7 @@ static const figure_properties properties[FIGURE_TYPE_MAX] = {
},
[FIGURE_MESS_HALL_SUPPLIER] = {
.category = FIGURE_CATEGORY_ARMED,
.max_damage = 70, .attack_value = 8, .defense_value = 0,
.max_damage = 70, .attack_value = 8, .defense_value = 1,
.missile_defense_value = 0, .missile_attack_value = 0, .missile_delay = 0
},
[FIGURE_MESS_HALL_COLLECTOR] = {
Expand Down Expand Up @@ -463,7 +463,7 @@ static const figure_properties properties[FIGURE_TYPE_MAX] = {
},
[FIGURE_FORT_INFANTRY] = {
.category = FIGURE_CATEGORY_ARMED,
.max_damage = 110, .attack_value = 8, .defense_value = 0,
.max_damage = 110, .attack_value = 8, .defense_value = 1,
.missile_defense_value = 2, .missile_attack_value = 0, .missile_delay = 0
},
[FIGURE_BEGGAR] = {
Expand All @@ -476,6 +476,16 @@ static const figure_properties properties[FIGURE_TYPE_MAX] = {
.max_damage = 80, .attack_value = 6, .defense_value = 0,
.missile_defense_value = 0, .missile_attack_value = 4, .missile_delay = 50
},
[FIGURE_ENEMY_CATAPULT] = {
.category = FIGURE_CATEGORY_HOSTILE,
.max_damage = 200, .attack_value = 1, .defense_value = 0,
.missile_defense_value = 20, .missile_attack_value = 100, .missile_delay = 200
},
[FIGURE_CATAPULT_MISSILE] = {
.category = FIGURE_CATEGORY_INACTIVE,
.max_damage = 100, .attack_value = 0, .defense_value = 0,
.missile_defense_value = 0, .missile_attack_value = 200, .missile_delay = 0
},

};

Expand Down
4 changes: 3 additions & 1 deletion src/figure/type.h
Original file line number Diff line number Diff line change
Expand Up @@ -106,7 +106,9 @@ typedef enum {
FIGURE_FORT_INFANTRY = 92,
FIGURE_BEGGAR = 93,
FIGURE_FORT_ARCHER = 94,
FIGURE_TYPE_MAX = 95
FIGURE_ENEMY_CATAPULT = 95,
FIGURE_CATAPULT_MISSILE = 96,
FIGURE_TYPE_MAX = 97
} figure_type;

typedef enum {
Expand Down
29 changes: 28 additions & 1 deletion src/figuretype/enemy.c
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
#include "enemy.h"

#include "assets/assets.h"
#include "city/figures.h"
#include "city/sound.h"
#include "core/calc.h"
Expand Down Expand Up @@ -46,7 +47,8 @@ static void enemy_initial(figure *f, formation *m)
}
}
if (f->type == FIGURE_ENEMY43_SPEAR || f->type == FIGURE_ENEMY46_CAMEL ||
f->type == FIGURE_ENEMY51_SPEAR || f->type == FIGURE_ENEMY52_MOUNTED_ARCHER) {
f->type == FIGURE_ENEMY51_SPEAR || f->type == FIGURE_ENEMY52_MOUNTED_ARCHER ||
f->type == FIGURE_ENEMY_CATAPULT) {
// missile throwers
f->wait_ticks_missile++;
map_point tile = { 0, 0 };
Expand All @@ -68,6 +70,8 @@ static void enemy_initial(figure *f, formation *m)
case ENEMY_10_CARTHAGINIAN:
missile_type = FIGURE_ARROW;
break;
case FIGURE_ENEMY_CATAPULT:
missile_type = FIGURE_CATAPULT_MISSILE;
default:
missile_type = FIGURE_SPEAR;
break;
Expand Down Expand Up @@ -679,3 +683,26 @@ void figure_enemy_caesar_legionary_action(figure *f)
break;
}
}

void figure_enemy_catapult_action(figure *f)
{
formation *m = formation_get(f->formation_id);
figure_image_increase_offset(f, 12);
f->cart_image_id = 0;
enemy_action(f, m);

int dir = get_missile_direction(f, m);

if (f->action_state == FIGURE_ACTION_149_CORPSE) {
f->image_id = assets_get_image_id("Warriors", "catapult_death_01") + figure_image_corpse_offset(f);
} else if (f->direction == DIR_FIGURE_ATTACK) {
f->image_id = assets_get_image_id("Warriors", "catapult_ne_01") + dir;
} else if (f->action_state == FIGURE_ACTION_150_ATTACK) {
f->image_id = assets_get_image_id("Warriors", "catapult_ne_01") + dir;
} else if (f->action_state == FIGURE_ACTION_151_ENEMY_INITIAL) {
f->image_id = f->image_id = assets_get_image_id("Warriors", "catapult_fe_e_01") + dir * 8 + figure_image_missile_launcher_offset(f);
} else {
f->image_id = assets_get_image_id("Warriors", "catapult_ne_01") + dir;
}

}
2 changes: 2 additions & 0 deletions src/figuretype/enemy.h
Original file line number Diff line number Diff line change
Expand Up @@ -29,4 +29,6 @@ void figure_enemy_gladiator_action(figure *f);

void figure_enemy_caesar_legionary_action(figure *f);

void figure_enemy_catapult_action(figure *f);

#endif // FIGURETYPE_ENEMY_H
21 changes: 21 additions & 0 deletions src/figuretype/missile.c
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
#include "missile.h"

#include "assets/assets.h"
#include "city/view.h"
#include "core/image.h"
#include "figure/formation.h"
Expand Down Expand Up @@ -271,3 +272,23 @@ void figure_bolt_action(figure *f)
int dir = (16 + f->direction - 2 * city_view_orientation()) % 16;
f->image_id = image_group(GROUP_FIGURE_MISSILE) + 32 + dir;
}

void figure_catapult_missile_action(figure *f)
{
f->use_cross_country = 1;
f->progress_on_tile++;
if (f->progress_on_tile > 120) {
f->state = FIGURE_STATE_DEAD;
}
int should_die = figure_movement_move_ticks_cross_country(f, 4);
int target_id = get_citizen_on_tile(f->grid_offset);
if (target_id) {
missile_hit_target(f, target_id, FIGURE_NONE);
sound_effect_play(SOUND_EFFECT_BALLISTA_HIT_GROUND);
} else if (should_die) {
f->state = FIGURE_STATE_DEAD;
}
int dir = (16 + f->direction - 2 * city_view_orientation()) % 16;
f->image_id = assets_get_image_id("Warriors", "catapult_rock_ne_01") + dir;
}

2 changes: 2 additions & 0 deletions src/figuretype/missile.h
Original file line number Diff line number Diff line change
Expand Up @@ -19,4 +19,6 @@ void figure_javelin_action(figure *f);

void figure_bolt_action(figure *f);

void figure_catapult_missile_action(figure *f);

#endif // FIGURETYPE_MISSILE_H
1 change: 1 addition & 0 deletions src/figuretype/soldier.c
Original file line number Diff line number Diff line change
Expand Up @@ -288,6 +288,7 @@ static void update_image_archer(figure *f, int dir)
} else {
f->image_id = assets_get_image_id("Warriors", "auxarch_ne_01") + dir * 12 + f->image_offset;
}

}


Expand Down
1 change: 1 addition & 0 deletions src/translation/english.c
Original file line number Diff line number Diff line change
Expand Up @@ -1511,6 +1511,7 @@ static translation_string all_strings[] = {
{TR_USER_DIRECTORIES_USER_PATH_CHANGED_OVERWRITE, "Overwrite existing files"},
{TR_FIGURE_TYPE_ARMORY_CARTPUSHER, "Armory deliveryman"},
{TR_TOOLTIP_BUTTON_CAN_GO_TO_ADVISORS, "Display the relevant advisor for this building." },
{TR_FIGURE_ENEMY_CATAPULT, "Catapult"},
};

void translation_english(const translation_string **strings, int *num_strings)
Expand Down
Loading

0 comments on commit cc2ba87

Please sign in to comment.