Skip to content

Commit 587d494

Browse files
Merge branch 'porymap-6' into generate-map-constants
2 parents 94b8dc7 + b10c2f7 commit 587d494

File tree

101 files changed

+822
-986
lines changed

Some content is hidden

Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.

101 files changed

+822
-986
lines changed

Makefile

+50-58
Original file line numberDiff line numberDiff line change
@@ -150,12 +150,20 @@ ifneq (,$(MAKECMDGOALS))
150150
endif
151151
endif
152152

153+
.SHELLSTATUS ?= 0
154+
153155
ifeq ($(SETUP_PREREQS),1)
154156
# If set on: Default target or a rule requiring a scan
155157
# Forcibly execute `make tools` since we need them for what we are doing.
156-
$(call infoshell, $(MAKE) -f make_tools.mk)
158+
$(foreach line, $(shell $(MAKE) -f make_tools.mk | sed "s/ /__SPACE__/g"), $(info $(subst __SPACE__, ,$(line))))
159+
ifneq ($(.SHELLSTATUS),0)
160+
$(error Errors occurred while building tools. See error messages above for more details)
161+
endif
157162
# Oh and also generate mapjson sources before we use `SCANINC`.
158-
$(call infoshell, $(MAKE) generated)
163+
$(foreach line, $(shell $(MAKE) generated | sed "s/ /__SPACE__/g"), $(info $(subst __SPACE__, ,$(line))))
164+
ifneq ($(.SHELLSTATUS),0)
165+
$(error Errors occurred while generating map-related sources. See error messages above for more details)
166+
endif
159167
endif
160168

161169
# Collect sources
@@ -237,7 +245,10 @@ include spritesheet_rules.mk
237245
include json_data_rules.mk
238246
include audio_rules.mk
239247

248+
# NOTE: Tools must have been built prior (FIXME)
249+
# so you can't really call this rule directly
240250
generated: $(AUTO_GEN_TARGETS)
251+
@: # Silence the "Nothing to be done for `generated'" message, which some people were confusing for an error.
241252

242253
%.s: ;
243254
%.png: ;
@@ -252,8 +263,6 @@ generated: $(AUTO_GEN_TARGETS)
252263
%.lz: % ; $(GFX) $< $@
253264
%.rl: % ; $(GFX) $< $@
254265

255-
# NOTE: Tools must have been built prior (FIXME)
256-
generated: tools $(AUTO_GEN_TARGETS)
257266
clean-generated:
258267
@rm -f $(AUTO_GEN_TARGETS)
259268
@echo "rm -f <AUTO_GEN_TARGETS>"
@@ -288,71 +297,52 @@ endif
288297
# As a side effect, they're evaluated immediately instead of when the rule is invoked.
289298
# It doesn't look like $(shell) can be deferred so there might not be a better way (Icedude_907: there is soon).
290299

291-
# For C dependencies.
292-
# Args: $1 = Output file without extension (build/assets/src/data), $2 = Input file (src/data.c)
293-
define C_DEP
294-
$(call C_DEP_IMPL,$1,$2,$1)
295-
endef
296-
# Internal implementation details.
297-
# $1: Output file without extension, $2 input file, $3 temp path (if keeping)
298-
define C_DEP_IMPL
299-
$1.o: $2
300+
$(C_BUILDDIR)/%.o: $(C_SUBDIR)/%.c
300301
ifneq ($(KEEP_TEMPS),1)
301-
@echo "$$(CC1) <flags> -o $$@ $$<"
302-
@$$(CPP) $$(CPPFLAGS) $$< | $$(PREPROC) -i $$< charmap.txt | $$(CC1) $$(CFLAGS) -o - - | cat - <(echo -e ".text\n\t.align\t2, 0") | $$(AS) $$(ASFLAGS) -o $$@ -
302+
@echo "$(CC1) <flags> -o $@ $<"
303+
@$(CPP) $(CPPFLAGS) $< | $(PREPROC) -i $< charmap.txt | $(CC1) $(CFLAGS) -o - - | cat - <(echo -e ".text\n\t.align\t2, 0") | $(AS) $(ASFLAGS) -o $@ -
303304
else
304-
@$$(CPP) $$(CPPFLAGS) $$< -o $3.i
305-
@$$(PREPROC) $3.i charmap.txt | $$(CC1) $$(CFLAGS) -o $3.s
306-
@echo -e ".text\n\t.align\t2, 0 @ Don't pad with nop\n" >> $3.s
307-
$$(AS) $$(ASFLAGS) -o $$@ $3.s
305+
@$(CPP) $(CPPFLAGS) $< -o $*.i
306+
@$(PREPROC) $*.i charmap.txt | $(CC1) $(CFLAGS) -o $*.s
307+
@echo -e ".text\n\t.align\t2, 0\n" >> $*.s
308+
$(AS) $(ASFLAGS) -o $@ $*.s
308309
endif
309-
$1.d: $2
310-
$(SCANINC) -M $1.d $(INCLUDE_SCANINC_ARGS) -I tools/agbcc/include $2
310+
311+
$(C_BUILDDIR)/%.d: $(C_SUBDIR)/%.c
312+
$(SCANINC) -M $@ $(INCLUDE_SCANINC_ARGS) -I tools/agbcc/include $<
313+
311314
ifneq ($(NODEP),1)
312-
$1.o: $1.d
313-
-include $1.d
315+
-include $(addprefix $(OBJ_DIR)/,$(C_SRCS:.c=.d))
314316
endif
315-
endef
316317

317-
# Create generic rules if no dependency scanning, else create the real rules
318-
ifeq ($(NODEP),1)
319-
$(eval $(call C_DEP,$(C_BUILDDIR)/%,$(C_SUBDIR)/%.c))
320-
else
321-
$(foreach src,$(C_SRCS),$(eval $(call C_DEP,$(OBJ_DIR)/$(basename $(src)),$(src))))
318+
$(ASM_BUILDDIR)/%.o: $(ASM_SUBDIR)/%.s
319+
$(AS) $(ASFLAGS) -o $@ $<
320+
321+
$(ASM_BUILDDIR)/%.d: $(ASM_SUBDIR)/%.s
322+
$(SCANINC) -M $@ $(INCLUDE_SCANINC_ARGS) -I "" $<
323+
324+
ifneq ($(NODEP),1)
325+
-include $(addprefix $(OBJ_DIR)/,$(ASM_SRCS:.s=.d))
322326
endif
323327

324-
# Similar methodology for Assembly files
325-
# $1: Output path without extension, $2: Input file (`*.s`)
326-
define ASM_DEP
327-
$1.o: $2
328-
$$(AS) $$(ASFLAGS) -o $$@ $$<
329-
$(call ASM_SCANINC,$1,$2)
330-
endef
331-
# As above but first doing a preprocessor pass
332-
define ASM_DEP_PREPROC
333-
$1.o: $2
334-
$$(PREPROC) $$< charmap.txt | $$(CPP) $(INCLUDE_SCANINC_ARGS) - | $$(PREPROC) -ie $$< charmap.txt | $$(AS) $$(ASFLAGS) -o $$@
335-
$(call ASM_SCANINC,$1,$2)
336-
endef
337-
338-
define ASM_SCANINC
328+
$(C_BUILDDIR)/%.o: $(C_SUBDIR)/%.s
329+
$(PREPROC) $< charmap.txt | $(CPP) $(INCLUDE_SCANINC_ARGS) - | $(PREPROC) -ie $< charmap.txt | $(AS) $(ASFLAGS) -o $@
330+
331+
$(C_BUILDDIR)/%.d: $(C_SUBDIR)/%.s
332+
$(SCANINC) -M $@ $(INCLUDE_SCANINC_ARGS) -I "" $<
333+
339334
ifneq ($(NODEP),1)
340-
$1.o: $1.d
341-
$1.d: $2
342-
$(SCANINC) -M $1.d $(INCLUDE_SCANINC_ARGS) -I "" $2
343-
-include $1.d
335+
-include $(addprefix $(OBJ_DIR)/,$(C_ASM_SRCS:.s=.d))
344336
endif
345-
endef
346337

347-
# Dummy rules or real rules
348-
ifeq ($(NODEP),1)
349-
$(eval $(call ASM_DEP,$(ASM_BUILDDIR)/%,$(ASM_SUBDIR)/%.s))
350-
$(eval $(call ASM_DEP_PREPROC,$(C_BUILDDIR)/%,$(C_SUBDIR)/%.s))
351-
$(eval $(call ASM_DEP_PREPROC,$(DATA_ASM_BUILDDIR)/%,$(DATA_ASM_SUBDIR)/%.s))
352-
else
353-
$(foreach src, $(ASM_SRCS), $(eval $(call ASM_DEP,$(src:%.s=$(OBJ_DIR)/%),$(src))))
354-
$(foreach src, $(C_ASM_SRCS), $(eval $(call ASM_DEP_PREPROC,$(src:%.s=$(OBJ_DIR)/%),$(src))))
355-
$(foreach src, $(REGULAR_DATA_ASM_SRCS), $(eval $(call ASM_DEP_PREPROC,$(src:%.s=$(OBJ_DIR)/%),$(src))))
338+
$(DATA_ASM_BUILDDIR)/%.o: $(DATA_ASM_SUBDIR)/%.s
339+
$(PREPROC) $< charmap.txt | $(CPP) $(INCLUDE_SCANINC_ARGS) - | $(PREPROC) -ie $< charmap.txt | $(AS) $(ASFLAGS) -o $@
340+
341+
$(DATA_ASM_BUILDDIR)/%.d: $(DATA_ASM_SUBDIR)/%.s
342+
$(SCANINC) -M $@ $(INCLUDE_SCANINC_ARGS) -I "" $<
343+
344+
ifneq ($(NODEP),1)
345+
-include $(addprefix $(OBJ_DIR)/,$(REGULAR_DATA_ASM_SRCS:.s=.d))
356346
endif
357347

358348
$(OBJ_DIR)/sym_bss.ld: sym_bss.txt
@@ -376,8 +366,10 @@ endif
376366
# Final rules
377367

378368
# Elf from object files
369+
LDFLAGS = -Map ../../$(MAP)
379370
$(ELF): $(LD_SCRIPT) $(LD_SCRIPT_DEPS) $(OBJS)
380371
@cd $(OBJ_DIR) && $(LD) $(LDFLAGS) -T ../../$< --print-memory-usage -o ../../$@ $(OBJS_REL) $(LIB) | cat
372+
@echo "cd $(OBJ_DIR) && $(LD) $(LDFLAGS) -T ../../$< --print-memory-usage -o ../../$@ <objs> <libs> | cat"
381373
$(FIX) $@ -t"$(TITLE)" -c$(GAME_CODE) -m$(MAKER_CODE) -r$(GAME_REVISION) --silent
382374

383375
# Builds the rom from the elf file

common_syms/AgbRfu_LinkManager.txt

-1
This file was deleted.

common_syms/agb_flash.txt

-10
This file was deleted.

common_syms/battle_anim_special.txt

-3
This file was deleted.

common_syms/battle_controller_pokedude.txt

-1
This file was deleted.

common_syms/battle_main.txt

-9
This file was deleted.

common_syms/berry_fix_program.txt

-4
This file was deleted.

common_syms/bg.txt

-1
This file was deleted.

common_syms/cable_club.txt

-1
This file was deleted.

common_syms/ereader_screen.txt

-1
This file was deleted.

common_syms/event_data.txt

-1
This file was deleted.

common_syms/evolution_scene.txt

-1
This file was deleted.

common_syms/fame_checker.txt

-2
This file was deleted.

common_syms/field_camera.txt

-3
This file was deleted.

common_syms/field_control_avatar.txt

-1
This file was deleted.

common_syms/field_specials.txt

-2
This file was deleted.

common_syms/fieldmap.txt

-1
This file was deleted.

common_syms/help_system.txt

-2
This file was deleted.

common_syms/help_system_util.txt

-1
This file was deleted.

common_syms/image_processing_effects.txt

-10
This file was deleted.

common_syms/librfu_rfu.txt

-5
This file was deleted.

common_syms/librfu_sio32id.txt

-1
This file was deleted.

common_syms/librfu_stwi.txt

-1
This file was deleted.

common_syms/link.txt

-35
This file was deleted.

common_syms/link_rfu_2.txt

-3
This file was deleted.

common_syms/list_menu.txt

-2
This file was deleted.

common_syms/load_save.txt

-4
This file was deleted.

common_syms/m4a.txt

-12
This file was deleted.

common_syms/main.txt

-12
This file was deleted.

common_syms/overworld.txt

-8
This file was deleted.

common_syms/party_menu.txt

-1
This file was deleted.

common_syms/quest_log.txt

-4
This file was deleted.

common_syms/random.txt

-1
This file was deleted.

common_syms/save.txt

-12
This file was deleted.

common_syms/save_failed_screen.txt

-1
This file was deleted.

common_syms/scrcmd.txt

-2
This file was deleted.

common_syms/sound.txt

-1
This file was deleted.

common_syms/sprite.txt

-2
This file was deleted.

common_syms/task.txt

-1
This file was deleted.

common_syms/text.txt

-1
This file was deleted.

common_syms/text_printer.txt

-2
This file was deleted.

common_syms/window.txt

-2
This file was deleted.

include/constants/.gitignore

+1
Original file line numberDiff line numberDiff line change
@@ -1,4 +1,5 @@
11
# Will be moved to build/ eventually
22
map_groups.h
33
layouts.h
4+
region_map_sections.h
45
map_event_ids.h

0 commit comments

Comments
 (0)