]> git.sur5r.net Git - cc65/blobdiff - libsrc/Makefile
Force warning-free build (and added missing clean target).
[cc65] / libsrc / Makefile
index 71a19a8996dec9c53d338fb6078f0c75bb1d7492..b4393a6ac3ead3cad165c2c3f52257c20b17c0a9 100644 (file)
-#
-# makefile for CC65 runtime library
-#
-
-.SUFFIXES: .o .obj .s .c
-
-# Defines for executables. AR is used within this makefile, the others are
-# passed to the submakes and contain paths relative to the subdirectories
-# handled by the make subprocesses.
-AR = ../src/ar65/ar65
-AS = ../../src/ca65/ca65
-CC = ../../src/cc65/cc65
-LD = ../../src/ld65/ld65
-
-# List of all targets
-ALLTARGETS =           apple2          \
-                       atari           \
-                       atmos           \
-                c16                    \
-                       c128            \
-                       c64             \
-                       cbm510          \
-                       cbm610          \
-                       geos            \
-                nes            \
-                       pet             \
-                       plus4           \
-               supervision     \
-               vic20
-
-#-----------------------------------------------------------------------------
-
-.PHONY:        all
-all:
-       for tgt in $(ALLTARGETS); do            \
-           $(MAKE) clean "$$tgt"lib || exit 1; \
-       done
-
-#-----------------------------------------------------------------------------
-# Apple ][
-
-apple2lib:
-       for i in apple2 common runtime conio dbg em joystick tgi zlib; do \
-           AS=$(AS) \
-           CC=$(CC) \
-           LD=$(LD) \
-           AFLAGS="-t apple2 -I../../asminc" \
-           CFLAGS="-Osir -g -T -t apple2 --forget-inc-paths -I. -I../../include" \
-           $(MAKE) -C $$i || exit 1; \
-           $(AR) a apple2.lib $$i/*.o;\
-       done
-       mv apple2/crt0.o apple2.o
-       cp apple2/apple2-lc.emd a2.lc.emd
-       cp apple2/apple2-280-192-6.tgi a2.hi.tgi
-       cp apple2/apple2-40-40-16.tgi a2.lo.tgi
-       cp apple2/apple2-stdjoy.joy a2.stdjoy.joy
-
-#-----------------------------------------------------------------------------
-# Atari
-
-atarilib:
-       for i in atari common runtime conio dbg em joystick tgi zlib; do \
-           AS=$(AS) \
-           CC=$(CC) \
-           LD=$(LD) \
-           AFLAGS="-t atari -I../../asminc" \
-           CFLAGS="-Osir -g -T -t atari --forget-inc-paths -I. -I../../include" \
-           $(MAKE) -C $$i || exit 1; \
-           $(AR) a atari.lib $$i/*.o;\
-       done
-       mv atari/crt0.o atari.o
-       cp atari/*.joy .
-
-#-----------------------------------------------------------------------------
-# Oric Atmos
-
-atmoslib:
-       for i in atmos common conio runtime em joystick tgi zlib; do \
-           AS=$(AS) \
-           CC=$(CC) \
-           LD=$(LD) \
-           AFLAGS="-t atmos -I../../asminc" \
-           CFLAGS="-Osir -g -T -t atmos --forget-inc-paths -I. -I../../include" \
-           $(MAKE) -C $$i || exit 1; \
-           $(AR) a atmos.lib $$i/*.o;\
-       done
-       mv atmos/crt0.o atmos.o
-
-#-----------------------------------------------------------------------------
-# C16, C116
-
-c16lib:
-       for i in c16 cbm common runtime conio dbg em joystick tgi zlib; do \
-           AS=$(AS) \
-           CC=$(CC) \
-           LD=$(LD) \
-           AFLAGS="-t c16 -I../../asminc" \
-           CFLAGS="-Osir -g -T -t c16 --forget-inc-paths -I. -I../../include" \
-           $(MAKE) -C $$i || exit 1; \
-           $(AR) a c16.lib $$i/*.o;\
-       done
-       mv c16/crt0.o c16.o
-       cp c16/*.joy .
-       cp c16/*.emd .
-
-#-----------------------------------------------------------------------------
-# C64
-
-c64lib:
-       for i in c64 cbm common runtime conio dbg em joystick serial tgi zlib; do \
-           AS=$(AS) \
-           CC=$(CC) \
-           LD=$(LD) \
-           AFLAGS="-t c64 -I../../asminc" \
-           CFLAGS="-Osir -g -T -t c64 --forget-inc-paths -I. -I../../include" \
-           $(MAKE) -C $$i || exit 1; \
-           $(AR) a c64.lib $$i/*.o;\
-       done
-       mv c64/crt0.o c64.o
-       cp c64/*.emd .
-       cp c64/*.joy .
-       cp c64/*.ser .
-       cp c64/c64-320-200-2.tgi c64-hi.tgi
-
-#-----------------------------------------------------------------------------
-# C128
-
-c128lib:
-       for i in c128 cbm common runtime conio dbg em joystick serial tgi zlib; do \
-           AS=$(AS) \
-           CC=$(CC) \
-           LD=$(LD) \
-           AFLAGS="-t c128 -I../../asminc" \
-           CFLAGS="-Osir -g -T -t c128 --forget-inc-paths -I. -I../../include" \
-           $(MAKE) -C $$i || exit 1; \
-           $(AR) a c128.lib $$i/*.o;\
-       done
-       mv c128/crt0.o c128.o
-       cp c128/*.emd .
-       cp c128/*.joy .
-       cp c128/*.ser .
-       cp c128/c128-640-200-2.tgi c128-vdc.tgi
-       cp c128/c128-640-480-2.tgi c128-vdc2.tgi
-
-#-----------------------------------------------------------------------------
-# Commdore P500 / CBM 5x0
-
-cbm510lib:
-       for i in cbm510 cbm common runtime conio dbg em joystick serial tgi zlib; do \
-           CC=$(CC) \
-           AS=$(AS) \
-           LD=$(LD) \
-           AFLAGS="-t cbm510 -I../../asminc" \
-           CFLAGS="-Osir -g -T -t cbm510 --forget-inc-paths -I. -I../../include" \
-           $(MAKE) -C $$i || exit 1; \
-           $(AR) a cbm510.lib $$i/*.o;\
-       done
-       mv cbm510/crt0.o cbm510.o
-       cp cbm510/*.emd .
-       cp cbm510/*.joy .
-       cp cbm510/cbm510-stdser.ser cbm510-std.ser
-
-#-----------------------------------------------------------------------------
-# PET-II series
-
-cbm610lib:
-       for i in cbm610 cbm common runtime conio dbg em joystick serial tgi zlib; do \
-           CC=$(CC) \
-           AS=$(AS) \
-           LD=$(LD) \
-           AFLAGS="-t cbm610 -I../../asminc" \
-           CFLAGS="-Osir -g -T -t cbm610 --forget-inc-paths -I. -I../../include" \
-           $(MAKE) -C $$i || exit 1; \
-           $(AR) a cbm610.lib $$i/*.o;\
-       done
-       mv cbm610/crt0.o cbm610.o
-       cp cbm610/*.emd .
-       cp cbm610/cbm610-stdser.ser cbm610-std.ser
-
-#-----------------------------------------------------------------------------
-# GEOS on the C64/128
-
-geoslib:
-       CC=../$(CC) \
-       AS=../$(AS) \
-       AR=../$(AR) \
-               LD=../$(LD) \
-       AFLAGS="-t geos -I../../../asminc" \
-       CFLAGS="-Osir -g -T -t geos --forget-inc-paths -I. -I../../../include" \
-       $(MAKE) -C geos || exit 1
-       for i in em joystick tgi conio common runtime zlib; do \
-           CC=$(CC) \
-           AS=$(AS) \
-           LD=$(LD) \
-           AR=$(AR) \
-           AFLAGS="-t geos -I../../asminc" \
-           CFLAGS="-Osir -g -T -t geos --forget-inc-paths -I. -I../../include" \
-           $(MAKE) -C $$i || exit 1; \
-           for objfile in $$i/*.o; do \
-               if [ -f geos/$$objfile ]; then \
-                   $(AR) a geos.lib geos/$$objfile; \
-               else \
-                   $(AR) a geos.lib $$objfile; \
-               fi; \
-           done \
-       done
-       cp geos/devel/*.emd .
-       cp geos/devel/*.joy .
-       cp geos/devel/geos-tgi.tgi geos-tgi.tgi
-
-#-----------------------------------------------------------------------------
-# NES
-
-neslib:
-       for i in nes common runtime conio em joystick tgi zlib; do \
-           CC=$(CC) \
-           AS=$(AS) \
-           LD=$(LD) \
-           AFLAGS="-t nes -I../../asminc" \
-           CFLAGS="-Osir -g -T -t nes --forget-inc-paths -I. -I../../include" \
-           $(MAKE) -C $$i || exit 1; \
-           $(AR) a nes.lib $$i/*.o;\
-       done
-       mv nes/crt0.o nes.o
-
-#-----------------------------------------------------------------------------
-# CBM PET machines
-
-petlib:
-       for i in pet cbm common runtime conio dbg em joystick tgi zlib; do \
-           CC=$(CC) \
-           AS=$(AS) \
-           LD=$(LD) \
-           AFLAGS="-t pet -I../../asminc" \
-           CFLAGS="-Osir -g -T -t pet --forget-inc-paths -I. -I../../include" \
-           $(MAKE) -C $$i || exit 1; \
-           $(AR) a pet.lib $$i/*.o;\
-       done
-       mv pet/crt0.o pet.o
-
-#-----------------------------------------------------------------------------
-# Commodore Plus/4
-
-plus4lib:
-       for i in plus4 cbm common runtime conio dbg em joystick serial tgi zlib; do \
-           CC=$(CC) \
-           AS=$(AS) \
-           LD=$(LD) \
-           AFLAGS="-t plus4 -I../../asminc" \
-           CFLAGS="-Osir -g -T -t plus4 --forget-inc-paths -I. -I../../include" \
-           $(MAKE) -C $$i || exit 1; \
-           $(AR) a plus4.lib $$i/*.o;\
-       done
-       mv plus4/crt0.o plus4.o
-       cp plus4/*.joy .
-       cp plus4/*.ser .
-
-#-----------------------------------------------------------------------------
-# Supervision
-
-supervisionlib:
-       for i in supervision common runtime; do \
-           CC=$(CC) \
-           AS=$(AS) \
-           LD=$(LD) \
-           AFLAGS="-t supervision -I../../asminc" \
-           CFLAGS="-Osir -g -T -t supervision --forget-inc-paths -I. -I../../include" \
-           $(MAKE) -C $$i || exit 1; \
-           $(AR) a supervision.lib $$i/*.o;\
-       done
-       mv supervision/crt0.o supervision.o
-
-#-----------------------------------------------------------------------------
-# Vic20
-
-vic20lib:
-       for i in vic20 cbm common runtime conio dbg em joystick tgi zlib; do \
-           AS=$(AS) \
-           CC=$(CC) \
-           LD=$(LD) \
-           AFLAGS="-t vic20 -I../../asminc" \
-           CFLAGS="-Osir -g -T -t vic20 --forget-inc-paths -I. -I../../include" \
-           $(MAKE) -C $$i || exit 1; \
-           $(AR) a vic20.lib $$i/*.o;\
-       done
-       mv vic20/crt0.o vic20.o
-       cp vic20/*.joy .
-
-#-----------------------------------------------------------------------------
-# Dummy targets
-
-.PHONY: clean
+CBMS = c128   \
+       c16    \
+       c64    \
+       cbm510 \
+       cbm610 \
+       pet    \
+       plus4  \
+       vic20
+
+GEOS = geos-apple \
+       geos-cbm
+
+TARGETS = apple2    \
+          apple2enh \
+          atari     \
+          atmos     \
+          $(CBMS)   \
+          $(GEOS)   \
+          lynx      \
+          nes       \
+          supervision
+
+DRVTYPES = emd \
+           joy \
+           mou \
+           ser \
+           tgi
+
+# Every target requires its individual vpath setting but the vpath directive
+# acts globally. Therefore each target is built in a separate make instance.
+
+ifeq ($(words $(MAKECMDGOALS)),1)
+  ifeq ($(MAKECMDGOALS),$(filter $(MAKECMDGOALS),$(TARGETS)))
+    TARGET = $(MAKECMDGOALS)
+  endif
+endif
+
+DIRLIST = $(strip $(foreach dir,$1,$(wildcard $(dir))))
+
+ifeq ($(shell echo),)
+  MKDIR = mkdir -p $1
+  RMDIR = $(RM) -r $1
+else
+  MKDIR = mkdir $(subst /,\,$1)
+  RMDIR = $(if $(DIRLIST),rmdir /s /q $(subst /,\,$(DIRLIST)))
+endif
+
+.SUFFIXES:
+
+.PHONY: all lib $(TARGETS) mostlyclean clean
+
+ifndef TARGET
+
+all lib: $(TARGETS)
+
+$(TARGETS):
+       @$(MAKE) --no-print-directory $@
+
+mostlyclean:
+       $(call RMDIR,../wrk)
+
 clean:
-       @for i in cbm common conio dbg em joystick runtime serial tgi zlib $(ALLTARGETS); do\
-                  $(MAKE) -C $$i clean;                                                \
-       done
+       $(call RMDIR,../wrk ../lib ../targetutil $(addprefix ../,$(DRVTYPES)))
+
+else # TARGET
+
+CFLAGS += -Osir -W error
+
+EXTZP = cbm510 \
+        cbm610 \
+        lynx
+
+MKINC = $(GEOS) \
+        atari   \
+        nes
+
+TARGETUTIL = apple2 \
+             geos-apple
+
+GEOSDIRS = common      \
+           conio       \
+           disk        \
+           dlgbox      \
+           file        \
+           graph       \
+           memory      \
+           menuicon    \
+           mousesprite \
+           process     \
+           runtime     \
+           system
+
+ifeq ($(TARGET),apple2enh)
+  OBJPFX = a2
+  DRVPFX = a2e
+  SRCDIR = apple2
+else
+  SRCDIR = $(TARGET)
+endif
+
+SRCDIRS = $(SRCDIR)
+
+ifeq ($(TARGET),$(filter $(TARGET),$(CBMS)))
+  SRCDIRS += cbm
+endif
+
+ifeq ($(TARGET),$(filter $(TARGET),$(GEOS)))
+  SRCDIRS += $(addprefix $(TARGET)/,  $(GEOSDIRS))
+  SRCDIRS += $(addprefix geos-common/,$(GEOSDIRS))
+endif
+
+SRCDIRS += common   \
+           conio    \
+           dbg      \
+           em       \
+           joystick \
+           mouse    \
+           runtime  \
+           serial   \
+           tgi      \
+           zlib
+
+vpath %.s $(SRCDIRS)
+vpath %.c $(SRCDIRS)
+
+OBJS := $(patsubst %.s,%.o,$(foreach dir,$(SRCDIRS),$(wildcard $(dir)/*.s)))
+OBJS += $(patsubst %.c,%.o,$(foreach dir,$(SRCDIRS),$(wildcard $(dir)/*.c)))
+
+OBJS := $(addprefix ../wrk/$(TARGET)/,$(sort $(notdir $(OBJS))))
+
+DEPS = $(OBJS:.o=.d)
+
+EXTRA_SRCPAT = $(SRCDIR)/extra/%.s
+EXTRA_OBJPAT = ../lib/$(TARGET)-%.o
+EXTRA_OBJS := $(patsubst $(EXTRA_SRCPAT),$(EXTRA_OBJPAT),$(wildcard $(SRCDIR)/extra/*.s))
+
+ZPOBJ = ../wrk/$(TARGET)/zeropage.o
+ifeq ($(TARGET),$(filter $(TARGET),$(EXTZP)))
+  ZPOBJ += ../wrk/$(TARGET)/extzp.o
+endif
+
+ifeq ($(SRCDIR),$(filter $(SRCDIR),$(MKINC)))
+  include $(SRCDIR)/Makefile.inc
+endif
+
+ifeq ($(SRCDIR),$(filter $(SRCDIR),$(TARGETUTIL)))
+  include $(SRCDIR)/targetutil/Makefile.inc
+endif
+
+##########
+
+define DRVTYPE_template
+
+$1_SRCDIR = $$(SRCDIR)/$1
+$1_OBJDIR = ../wrk/$$(TARGET)/$1
+$1_DRVDIR = ../$1
+
+$1_OBJPAT = $$($1_OBJDIR)/$$(OBJPFX)%.o
+$1_DRVPAT = $$($1_DRVDIR)/$$(DRVPFX)%.$1
+$1_STCPAT = ../wrk/$$(TARGET)/$$(DRVPFX)%-$1.o
+
+$1_OBJS := $$(patsubst $$($1_SRCDIR)/%.s,$$($1_OBJDIR)/%.o,$$(wildcard $$($1_SRCDIR)/*.s))
+
+$1_DRVS = $$(patsubst $$($1_OBJPAT),$$($1_DRVPAT),$$($1_OBJS))
+
+$1_STCS = $$(patsubst $$($1_DRVPAT),$$($1_STCPAT),$$($1_DRVS))
+
+$$($1_OBJS): | $$($1_OBJDIR)
+
+$$($1_DRVPAT): $$($1_OBJPAT) $$(ZPOBJ) | $$($1_DRVDIR)
+       @echo $$(TARGET) - $$(@F)
+       @$$(LD) -o $$@ -t module $$^
+
+$$($1_OBJDIR) $$($1_DRVDIR):
+       @$$(call MKDIR,$$@)
+
+$(TARGET): $$($1_DRVS)
+
+$$($1_STCPAT): $$($1_DRVPAT)
+       @echo $$(TARGET) - $$(<F)
+       @$$(CO) -o $$(@:.o=.s) --code-label _$$(subst -,_,$$(subst .,_,$$(<F))) $$<
+       @$$(CA) -t $$(TARGET) -o $$@ $$(@:.o=.s)
+
+OBJS += $$($1_STCS)
+
+DEPS += $$($1_OBJS:.o=.d)
+
+endef
+
+##########
+
+$(foreach drvtype,$(DRVTYPES),$(eval $(call DRVTYPE_template,$(drvtype))))
+
+AR := $(if $(wildcard ../bin/ar65*),../bin/ar65,ar65)
+CA := $(if $(wildcard ../bin/ca65*),../bin/ca65,ca65)
+CC := $(if $(wildcard ../bin/cc65*),../bin/cc65,cc65)
+CO := $(if $(wildcard ../bin/co65*),../bin/co65,co65)
+LD := $(if $(wildcard ../bin/ld65*),../bin/ld65,ld65)
+
+##########
+
+define ASSEMBLE_recipe
+
+@echo $(TARGET) - $<
+@$(CA) -t $(TARGET) $(AFLAGS) --create-dep $(@:.o=.d) -o $@ $<
+
+endef
+
+##########
+
+define COMPILE_recipe
+
+@echo $(TARGET) - $<
+@$(CC) -t $(TARGET) $(CFLAGS) --create-dep $(@:.o=.d) -o $(@:.o=.s) $<
+@$(CA) -t $(TARGET) -o $@ $(@:.o=.s)
+
+endef
+
+##########
+
+../wrk/$(TARGET)/%.o: %.s | ../wrk/$(TARGET)
+       $(ASSEMBLE_recipe)
+
+../wrk/$(TARGET)/%.o: %.c | ../wrk/$(TARGET)
+       $(COMPILE_recipe)
+
+$(EXTRA_OBJPAT): $(EXTRA_SRCPAT) | ../lib
+       @echo $(TARGET) - $<
+       @$(CA) -t $(TARGET) $(AFLAGS) -o $@ $<
+
+../lib/$(TARGET).lib: $(OBJS) | ../lib
+       $(AR) a $@ $?
 
-.PHONY: zap
-zap:   clean
-       @for i in cbm common conio dbg em joystick runtime tgi zlib $(ALLTARGETS); do\
-          $(MAKE) -C $$i zap;                                                  \
-       done
-       @$(RM) *.o *.emd *.joy *.lib *.tgi
+../wrk/$(TARGET) ../lib ../targetutil:
+       @$(call MKDIR,$@)
 
+$(TARGET): $(EXTRA_OBJS) ../lib/$(TARGET).lib
 
+-include $(DEPS)
 
+endif # TARGET