#
# Enter the target system here
-SYS = c64
+SYS = c64
+
+ifneq ($(shell echo),)
+ CMD_EXE = 1
+endif
+
+ifdef CMD_EXE
+ NULLDEV = nul:
+ DEL = -del /f
+else
+ NULLDEV = /dev/null
+ DEL = $(RM)
+endif
# Determine the path to the executables and libraries. If the samples
# directory is part of a complete source tree, use the stuff from that
# source tree; otherwise, use the "install" directories.
ifeq "$(wildcard ../src)" ""
# No source tree
-MOUS = /usr/lib/cc65/mou/$(SYS)*.mou
-TGI = /usr/lib/cc65/tgi/$(SYS)*.tgi
+installdir = /usr/lib/cc65
ifneq "$(wildcard /usr/local/lib/cc65)" ""
-MOUS = /usr/local/lib/cc65/mou/$(SYS)*.mou
-TGI = /usr/local/lib/cc65/tgi/$(SYS)*.tgi
+installdir = /usr/local/lib/cc65
+endif
+ifneq "$(wildcard /opt/local/share/cc65)" ""
+installdir = /opt/local/share/cc65
endif
ifdef CC65_HOME
-MOUS = $(CC65_HOME)/mou/$(SYS)*.mou
-TGI = $(CC65_HOME)/tgi/$(SYS)*.tgi
+installdir = $(CC65_HOME)
endif
+
+MOUS := $(wildcard $(installdir)/target/$(SYS)/drv/mou/$(SYS)*.mou)
+TGI := $(wildcard $(installdir)/target/$(SYS)/drv/tgi/$(SYS)*.tgi)
CLIB = --lib $(SYS).lib
CL = cl65
CC = cc65
else
# "samples/" is a part of a complete source tree.
-CA65_INC = ../asminc
-CC65_INC = ../include
-LD65_CFG = ../src/ld65/cfg
-LD65_LIB = ../libsrc
-LD65_OBJ = ../libsrc
-MOUS = ../libsrc/$(SYS)*.mou
-TGI = ../libsrc/$(SYS)*.tgi
-CLIB = ../libsrc/$(SYS).lib
-CL = ../src/cl65/cl65
-CC = ../src/cc65/cc65
-AS = ../src/ca65/ca65
-LD = ../src/ld65/ld65
-
-MY_INC = --forget-inc-paths -I . -I $(CC65_INC)
-MY_ASM = --forget-inc-paths -I . -I $(CA65_INC)
+export CC65_HOME := $(abspath ..)
+MOUS := $(wildcard ../target/$(SYS)/drv/mou/$(SYS)*.mou)
+TGI := $(wildcard ../target/$(SYS)/drv/tgi/$(SYS)*.tgi)
+CLIB = ../lib/$(SYS).lib
+CL = ../bin/cl65
+CC = ../bin/cc65
+AS = ../bin/ca65
+LD = ../bin/ld65
endif
# This one comes with VICE
-C1541 = c1541
+C1541 ?= c1541
+
+# --------------------------------------------------------------------------
+# System-dependent settings
+# The Apple machines need the start address adjusted when using TGI
+LDFLAGS_mandelbrot_apple2 = --start-addr 0x4000
+LDFLAGS_tgidemo_apple2 = --start-addr 0x4000
+LDFLAGS_mandelbrot_apple2enh = --start-addr 0x4000
+LDFLAGS_tgidemo_apple2enh = --start-addr 0x4000
+
+# The Apple ][ needs the start address adjusted for the mousetest
+LDFLAGS_mousetest_apple2 = --start-addr 0x4000
+
+# The atarixl target needs the start address adjusted when using TGI
+LDFLAGS_mandelbrot_atarixl = --start-addr 0x4000
+LDFLAGS_tgidemo_atarixl = --start-addr 0x4000
+
+# The atari target needs to reserve some memory when using TGI
+LDFLAGS_mandelbrot_atari = -D __RESERVED_MEMORY__=0x2000
+LDFLAGS_tgidemo_atari = -D __RESERVED_MEMORY__=0x2000
# --------------------------------------------------------------------------
# Generic rules
+.PHONY: all mostlyclean clean install zip samples d64
+
+%: %.c
+%: %.s
+
.c.o:
- @echo $<
- @$(CC) $(MY_INC) -Oirs --codesize 500 -T -g -t $(SYS) $<
- @$(AS) $(basename $<).s
+ $(CC) $(CFLAGS) -Oirs --codesize 500 -T -g -t $(SYS) $<
+ $(AS) $(<:.c=.s)
.s.o:
- @echo $<
- @$(AS) $(MY_ASM) -t $(SYS) $<
+ $(AS) $(AFLAGS) -t $(SYS) $<
-.o:
- @$(LD) -o $@ -t $(SYS) -m $(basename $@).map $^ $(CLIB)
+.PRECIOUS: %.o
+.o:
+ $(LD) $(LDFLAGS_$(@F)_$(SYS)) -o $@ -t $(SYS) -m $@.map $^ $(CLIB)
# --------------------------------------------------------------------------
-# List of executables. This list could be made target dependent by checking
+# List of executables. This list could be made target-dependent by checking
# $(SYS).
-EXELIST = ascii \
- diodemo \
- enumdevdir \
- fire \
- gunzip65 \
- hello \
- mandelbrot \
- mousedemo \
- multdemo \
- nachtm \
- ovrldemo \
- plasma \
- sieve \
- tgidemo
+EXELIST = ascii \
+ diodemo \
+ enumdevdir \
+ fire \
+ gunzip65 \
+ hello \
+ mandelbrot \
+ mousetest \
+ multdemo \
+ nachtm \
+ ovrldemo \
+ plasma \
+ sieve \
+ tgidemo
# --------------------------------------------------------------------------
-# Rules how to make each one of the binaries
-
-.PHONY: all
-all: $(EXELIST)
+# Rules to make the binaries
-ascii: ascii.o
+all:
-diodemo: diodemo.o
+samples: $(EXELIST)
-fire: fire.o
-
-gunzip65: gunzip65.o
+# --------------------------------------------------------------------------
+# Overlay rules. Overlays need special ld65 configuration files. Also, the
+# overlay file-names are shortenned to fit the Atari's 8.3-character limit.
-hello: hello.o
+multdemo: multidemo.o
+ $(LD) -o $@ -C $(SYS)-overlay.cfg -m $@.map $^ $(CLIB)
-# The Apple machines need the start address adjusted for the mandelbrot demo
-ifeq "$(SYS)" "apple2"
-mandelbrot: mandelbrot.o
- @$(LD) -t $(SYS) -m $(basename $@).map --start-addr 0x4000 -o $@ $^ $(CLIB)
-else
-ifeq "$(SYS)" "apple2enh"
-mandelbrot: mandelbrot.o
- @$(LD) -t $(SYS) -m $(basename $@).map --start-addr 0x4000 -o $@ $^ $(CLIB)
-else
-mandelbrot: mandelbrot.o
-endif
-endif
+ovrldemo: overlaydemo.o
+ $(LD) -o $@ -C $(SYS)-overlay.cfg -m $@.map $^ $(CLIB)
-# The Apple ][ needs the start address adjusted for the mousedemo
-ifeq "$(SYS)" "apple2"
-mousedemo: mousedemo.o
- @$(LD) -t $(SYS) -m $(basename $@).map --start-addr 0x4000 -o $@ $^ $(CLIB)
-else
-mousedemo: mousedemo.o
-endif
+OVERLAYLIST := $(foreach I,1 2 3,multdemo.$I ovrldemo.$I)
-multdemo: multidemo.o
- @$(LD) -t $(SYS) -m $(basename $@).map -C $(SYS)-overlay.cfg -o $@ $^ $(CLIB)
+# --------------------------------------------------------------------------
+# Rule to make a CBM disk with all samples. Needs the c1541 program that comes
+# with the VICE emulator.
-nachtm: nachtm.o
+d64: samples.d64
-ovrldemo: overlaydemo.o
- @$(LD) -t $(SYS) -m $(basename $@).map -C $(SYS)-overlay.cfg -o $@ $^ $(CLIB)
+define D64_WRITE_recipe
-plasma: plasma.o
+$(C1541) -attach $@ -write $(file) $(notdir $(file)) >$(NULLDEV)
-sieve: sieve.o
+endef # D64_WRITE_recipe
-# The Apple machines need the start address adjusted for the tgidemo
-ifeq "$(SYS)" "apple2"
-tgidemo: tgidemo.o
- @$(LD) -t $(SYS) -m $(basename $@).map --start-addr 0x4000 -o $@ $^ $(CLIB)
-else
-ifeq "$(SYS)" "apple2enh"
-tgidemo: tgidemo.o
- @$(LD) -t $(SYS) -m $(basename $@).map --start-addr 0x4000 -o $@ $^ $(CLIB)
-else
-tgidemo: tgidemo.o
-endif
-endif
+samples.d64: samples
+ @$(C1541) -format samples,AA d64 $@ >$(NULLDEV)
+ $(foreach file,$(EXELIST),$(D64_WRITE_recipe))
+ $(foreach file,$(OVERLAYLIST),$(D64_WRITE_recipe))
+ $(foreach file,$(TGI) $(MOUS),$(D64_WRITE_recipe))
# --------------------------------------------------------------------------
-# Rule to make a disk with all samples. Needs the c1541 program that comes
-# with the VICE emulator.
+# Installation rules
+
+INSTALL = install
+samplesdir = $(prefix)/share/cc65
+
+install:
+ $(if $(prefix),,$(error variable `prefix' must be set))
+ $(INSTALL) -d $(DESTDIR)$(samplesdir)
+ $(INSTALL) -d $(DESTDIR)$(samplesdir)/geos
+ $(INSTALL) -d $$(DESTDIR)$(samplesdir)/tutorial
+ $(INSTALL) -m0644 *.* $(DESTDIR)$(samplesdir)
+ $(INSTALL) -m0644 README $(DESTDIR)$(samplesdir)
+ $(INSTALL) -m0644 Makefile $(DESTDIR)$(samplesdir)
+ $(INSTALL) -m0644 geos/*.* $(DESTDIR)$(samplesdir)/geos
+ $(INSTALL) -m0644 tutorial/*.* $(DESTDIR)$(samplesdir)/tutorial
-.PHONY: disk
-disk: samples.d64
+# --------------------------------------------------------------------------
+# Packaging rules
-samples.d64: all
- @$(C1541) -format samples,AA d64 $@ > /dev/null
- @for exe in $(EXELIST); do\
- $(C1541) -attach $@ -write $$exe > /dev/null || exit $$?;\
- done
- @for mod in $(TGI) $(MOUS); do\
- $(C1541) -attach $@ -write $$mod > /dev/null || exit $$?;\
- done
+zip:
+ @cd .. && zip -r cc65 samples/
# --------------------------------------------------------------------------
-# Cleanup rules
+# Clean-up rules
-.PHONY: clean
-clean:
- $(RM) *~ *.map *.o *.s *.lbl
+mostlyclean:
+ @$(DEL) *.map *.o *.s 2>$(NULLDEV)
-.PHONY: zap
-zap: clean
- $(RM) $(EXELIST) samples.d64
+clean: mostlyclean
+ @$(DEL) $(EXELIST) samples.d64 2>$(NULLDEV)
+ @$(DEL) multdemo.? ovrldemo.? 2>$(NULLDEV)