1
0
mirror of https://github.com/cc65/cc65.git synced 2025-01-10 03:30:05 +00:00

Replaced whole bunch for Makefiles with a single generic Makefile.

- No complex shell logic.
- "Source file shadowing" for all targets via vpath.
- Dependency handling.
- True incremental build.
- Don't write into source directories.
- Easy cleanup by just removing 'wrk'.
This commit is contained in:
Oliver Schmidt 2013-05-04 22:15:30 +02:00
parent 008b4c4e1d
commit 81e467cdc2
24 changed files with 263 additions and 420 deletions

View File

@ -1,23 +1,100 @@
# -*- make -*-
#
# Makefile for CC65 Libraries
#
CBMS = c128 \
c16 \
c64 \
cbm510 \
cbm610 \
pet \
plus4 \
vic20
.SUFFIXES: .o .obj .s .c
GEOS = geos-apple \
geos-cbm
# 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
CO = ../../src/co65/co65
LD = ../../src/ld65/ld65
TARGETS = $(CBMS) \
$(GEOS) \
apple2 \
apple2enh \
atari \
atmos \
lynx \
nes \
supervision
# List of shared directories
SHAREDDIRS = cbm \
common \
geos-common \
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
.SUFFIXES:
.PHONY: all $(TARGETS) mostlyclean clean
ifndef TARGET
all: $(TARGETS)
$(TARGETS):
@$(MAKE) --no-print-directory $@
mostlyclean:
$(RM) -r ../wrk
clean: mostlyclean
$(RM) -r ../lib $(addprefix ../,$(DRVTYPES))
else # TARGET
CFLAGS += -t $(TARGET) -Osir --create-dep $(@:.o=.d)
EXTZP = cbm510 \
cbm610 \
lynx
MKINC = $(GEOS) \
atari \
nes
GEOSDIRS = common \
conio \
disk \
dlgbox \
file \
graph \
memory \
menuicon \
mousesprite \
process \
runtime \
system
ifeq ($(TARGET),apple2enh)
OBJPFX = a2
DRVPFX = a2e
DIRS = apple2
else
DIRS = $(TARGET)
endif
ifeq ($(TARGET),$(filter $(TARGET),$(CBMS)))
DIRS += cbm
endif
ifeq ($(TARGET),$(filter $(TARGET),$(GEOS)))
DIRS += $(addprefix $(TARGET)/, $(GEOSDIRS))
DIRS += $(addprefix geos-common/,$(GEOSDIRS))
endif
DIRS += common \
conio \
dbg \
em \
@ -28,392 +105,99 @@ SHAREDDIRS = cbm \
tgi \
zlib
# List of all targets
ALLTARGETS = apple2 \
apple2enh \
atari \
atmos \
c128 \
c16 \
c64 \
cbm510 \
cbm610 \
geos-apple \
geos-cbm \
lynx \
nes \
pet \
plus4 \
supervision \
vic20
vpath %.s $(DIRS)
vpath %.c $(DIRS)
#-----------------------------------------------------------------------------
OBJS := $(patsubst %.s,%.o,$(foreach dir,$(DIRS),$(wildcard $(dir)/*.s)))
OBJS += $(patsubst %.c,%.o,$(foreach dir,$(DIRS),$(wildcard $(dir)/*.c)))
.PHONY: all
all:
for tgt in $(ALLTARGETS); do \
$(MAKE) mostly-clean "$$tgt"lib || exit 1; \
done
OBJS := $(addprefix ../wrk/$(TARGET)/,$(sort $(notdir $(OBJS))))
#-----------------------------------------------------------------------------
# Apple ][
DEPS = $(OBJS:.o=.d)
.PHONY: apple2lib
apple2lib:
for i in runtime apple2 common conio dbg em joystick mouse serial tgi zlib; do \
$(MAKE) SYS=apple2 -C $$i || exit 1; \
$(AR) a apple2.lib $$i/*.o || exit 1; \
done
cp apple2/apple2-auxmem.emd a2.auxmem.emd
cp apple2/apple2-stdjoy.joy a2.stdjoy.joy
cp apple2/apple2-stdmou.mou a2.stdmou.mou
cp apple2/apple2-ssc.ser a2.ssc.ser
cp apple2/apple2-280-192-8.tgi a2.hi.tgi
cp apple2/apple2-40-48-16.tgi a2.lo.tgi
if [ -d apple2/extra ]; then \
for i in apple2/extra/*.o; do \
cp $$i apple2-`basename $$i` || exit 1; \
done \
fi
ZPOBJ = ../wrk/$(TARGET)/zeropage.o
ifeq ($(TARGET),$(filter $(TARGET),$(EXTZP)))
ZPOBJ += ../wrk/$(TARGET)/extzp.o
endif
#-----------------------------------------------------------------------------
# enhanced Apple //e
ifeq ($(TARGET),$(filter $(TARGET),$(MKINC)))
include $(TARGET)/Makefile.inc
endif
.PHONY: apple2enhlib
apple2enhlib:
for i in runtime apple2enh common conio dbg em joystick mouse serial tgi zlib; do \
$(MAKE) SYS=apple2enh -C $$i || exit 1; \
$(AR) a apple2enh.lib $$i/*.o || exit 1; \
done
cp apple2enh/apple2-auxmem.emd a2e.auxmem.emd
cp apple2enh/apple2-stdjoy.joy a2e.stdjoy.joy
cp apple2enh/apple2-stdmou.mou a2e.stdmou.mou
cp apple2enh/apple2-ssc.ser a2e.ssc.ser
cp apple2enh/apple2-280-192-8.tgi a2e.hi.tgi
cp apple2enh/apple2-40-48-16.tgi a2e.lo.tgi
if [ -d apple2enh/extra ]; then \
for i in apple2enh/extra/*.o; do \
cp $$i apple2enh-`basename $$i` || exit 1; \
done \
fi
##########
#-----------------------------------------------------------------------------
# Atari
define DRVTYPE_template
.PHONY: atarilib
atarilib:
for i in runtime atari common conio dbg em joystick tgi zlib; do \
$(MAKE) SYS=atari -C $$i || exit 1; \
$(AR) a atari.lib $$i/*.o || exit 1; \
done
cp atari/atari-130xe.emd atr130xe.emd
cp atari/atari-stdjoy.joy ataristd.joy
cp atari/atari-multijoy.joy atarimj8.joy
cp atari/atari-10.tgi atari10.tgi
cp atari/atari-10p2.tgi atr10p2.tgi
cp atari/atari-11.tgi atari11.tgi
cp atari/atari-14.tgi atari14.tgi
cp atari/atari-15.tgi atari15.tgi
cp atari/atari-15p2.tgi atr15p2.tgi
cp atari/atari-3.tgi atari3.tgi
cp atari/atari-4.tgi atari4.tgi
cp atari/atari-5.tgi atari5.tgi
cp atari/atari-6.tgi atari6.tgi
cp atari/atari-7.tgi atari7.tgi
cp atari/atari-8.tgi atari8.tgi
cp atari/atari-8p2.tgi atr8p2.tgi
cp atari/atari-9.tgi atari9.tgi
cp atari/atari-9p2.tgi atr9p2.tgi
if [ -d atari/extra ]; then \
for i in atari/extra/*.o; do \
cp $$i atari-`basename $$i` || exit 1; \
done \
fi
$1_SRCDIR = $$(firstword $$(DIRS))/$1
$1_OBJDIR = ../wrk/$$(TARGET)/$1
$1_DRVDIR = ../$1
#-----------------------------------------------------------------------------
# Oric Atmos
$1_OBJPAT = $$($1_OBJDIR)/$$(OBJPFX)%.o
$1_DRVPAT = $$($1_DRVDIR)/$$(DRVPFX)%.$1
$1_STCPAT = ../wrk/$$(TARGET)/$$(DRVPFX)%-$1.o
.PHONY: atmoslib
atmoslib:
for i in runtime atmos common conio dbg em joystick tgi zlib; do \
$(MAKE) SYS=atmos -C $$i || exit 1; \
$(AR) a atmos.lib $$i/*.o || exit 1; \
done
cp atmos/*.joy .
cp atmos/*.ser .
cp atmos/*.tgi .
if [ -d atmos/extra ]; then \
for i in atmos/extra/*.o; do \
cp $$i atmos-`basename $$i` || exit 1; \
done \
fi
$1_OBJS := $$(patsubst $$($1_SRCDIR)/%.s,$$($1_OBJDIR)/%.o,$$(wildcard $$($1_SRCDIR)/*.s))
#-----------------------------------------------------------------------------
# C16, C116
$1_DRVS = $$(patsubst $$($1_OBJPAT),$$($1_DRVPAT),$$($1_OBJS))
.PHONY: c16lib
c16lib:
for i in runtime c16 cbm common conio dbg em joystick mouse tgi zlib; do \
$(MAKE) SYS=c16 -C $$i || exit 1; \
$(AR) a c16.lib $$i/*.o || exit 1; \
done
cp c16/*.emd .
cp c16/*.joy .
if [ -d c16/extra ]; then \
for i in c16/extra/*.o; do \
cp $$i c16-`basename $$i` || exit 1; \
done \
fi
$1_STCS = $$(patsubst $$($1_DRVPAT),$$($1_STCPAT),$$($1_DRVS))
#-----------------------------------------------------------------------------
# C64
$$($1_OBJS): | $$($1_OBJDIR)
.PHONY: c64lib
c64lib:
for i in runtime c64 cbm common conio dbg em joystick mouse serial tgi zlib; do \
$(MAKE) SYS=c64 -C $$i || exit 1; \
$(AR) a c64.lib $$i/*.o || exit 1; \
done
cp c64/*.emd .
cp c64/*.joy .
cp c64/c64-1351.mou .
cp c64/c64-joymouse.mou c64-joy.mou
cp c64/c64-potmouse.mou c64-pot.mou
cp c64/*.ser .
cp c64/c64-320-200-2.tgi c64-hi.tgi
if [ -d c64/extra ]; then \
for i in c64/extra/*.o; do \
cp $$i c64-`basename $$i` || exit 1; \
done \
fi
$$($1_OBJDIR):
mkdir -p $$@
#-----------------------------------------------------------------------------
# C128
$$($1_DRVPAT): $$($1_OBJPAT) $$(ZPOBJ) | $$($1_DRVDIR)
$$(LD) -o $$@ -t module $$^
.PHONY: c128lib
c128lib:
for i in runtime c128 cbm common conio dbg em joystick mouse serial tgi zlib; do \
$(MAKE) SYS=c128 -C $$i || exit 1; \
$(AR) a c128.lib $$i/*.o || exit 1; \
done
cp c128/*.emd .
cp c128/*.joy .
cp c128/c128-1351.mou .
cp c128/c128-joymouse.mou c128-joy.mou
cp c128/c128-potmouse.mou c128-pot.mou
cp c128/*.ser .
cp c128/c128-640-200-2.tgi c128-vdc.tgi
cp c128/c128-640-480-2.tgi c128-vdc2.tgi
if [ -d cbm/extra ]; then \
for i in cbm/extra/*.o; do \
cp $$i cbm-`basename $$i` || exit 1; \
done \
fi
if [ -d c128/extra ]; then \
for i in c128/extra/*.o; do \
cp $$i c128-`basename $$i` || exit 1; \
done \
fi
$$($1_DRVDIR):
mkdir $$@
#-----------------------------------------------------------------------------
# Commodore P500 / CBM 5x0
$(TARGET): $$($1_DRVS)
.PHONY: cbm510lib
cbm510lib:
for i in runtime cbm510 cbm common conio dbg em joystick mouse serial tgi zlib; do \
$(MAKE) SYS=cbm510 -C $$i || exit 1; \
$(AR) a cbm510.lib $$i/*.o || exit 1; \
done
cp cbm510/*.emd .
cp cbm510/cbm510-stdjoy.joy cbm510-std.joy
cp cbm510/cbm510-stdser.ser cbm510-std.ser
if [ -d cbm510/extra ]; then \
for i in cbm510/extra/*.o; do \
cp $$i cbm510-`basename $$i` || exit 1; \
done \
fi
$$($1_STCPAT): $$($1_DRVPAT)
$$(CO) -o $$(@:.o=.s) --code-label _$$(subst -,_,$$(subst .,_,$$(<F))) $$<
$$(CC) -c -t $$(TARGET) -o $$@ $$(@:.o=.s)
#-----------------------------------------------------------------------------
# PET-II series
OBJS += $$($1_STCS)
.PHONY: cbm610lib
cbm610lib:
for i in runtime cbm610 cbm common conio dbg em joystick serial tgi zlib; do \
$(MAKE) SYS=cbm610 -C $$i || exit 1; \
$(AR) a cbm610.lib $$i/*.o || exit 1; \
done
cp cbm610/*.emd .
cp cbm610/cbm610-stdser.ser cbm610-std.ser
if [ -d cbm610/extra ]; then \
for i in cbm610/extra/*.o; do \
cp $$i cbm610-`basename $$i` || exit 1; \
done \
fi
DEPS += $$($1_OBJS:.o=.d)
#-----------------------------------------------------------------------------
# GEOS on the Apple
endef
.PHONY: geos-applelib
geos-applelib:
for i in geos-apple geos-common; do \
$(MAKE) SYS=geos-apple -C $$i || exit 1; \
TARGET_OBJS="$$TARGET_OBJS`(cd $$i && printf '%s|' *.o)`"; \
$(AR) a geos-apple.lib $$i/*.o || exit 1; \
done; \
TARGET_OBJS="$${TARGET_OBJS%?}"; \
for i in runtime common conio em joystick tgi zlib; do \
$(MAKE) SYS=geos-apple -C $$i || exit 1; \
SHARED_OBJS=`ls $$i/*.o | grep -vwE "$$TARGET_OBJS"`; \
$(AR) a geos-apple.lib $$SHARED_OBJS || exit 1; \
done
if [ -d geos-apple/extra ]; then \
for i in geos-apple/extra/*.o; do \
cp $$i geos-apple-`basename $$i` || exit 1; \
done \
fi
##########
#-----------------------------------------------------------------------------
# GEOS on the C64/128
$(foreach drvtype,$(DRVTYPES),$(eval $(call DRVTYPE_template,$(drvtype))))
.PHONY: geos-cbmlib
geos-cbmlib:
for i in geos-cbm geos-common; do \
$(MAKE) SYS=geos-cbm -C $$i || exit 1; \
TARGET_OBJS="$$TARGET_OBJS`(cd $$i && printf '%s|' *.o)`"; \
$(AR) a geos-cbm.lib $$i/*.o || exit 1; \
done; \
TARGET_OBJS="$${TARGET_OBJS%?}"; \
for i in runtime common conio em joystick tgi zlib; do \
$(MAKE) SYS=geos-cbm -C $$i || exit 1; \
SHARED_OBJS=`ls $$i/*.o | grep -vwE "$$TARGET_OBJS"`; \
$(AR) a geos-cbm.lib $$SHARED_OBJS || exit 1; \
done
cp geos-cbm/*.emd .
cp geos-cbm/*.joy .
cp geos-cbm/*.tgi .
if [ -d geos-cbm/extra ]; then \
for i in geos-cbm/extra/*.o; do \
cp $$i geos-cbm-`basename $$i` || exit 1; \
done \
fi
ifdef CC65_HOME
AR = $(CC65_HOME)/bin/ar65
CC = $(CC65_HOME)/bin/cl65
CO = $(CC65_HOME)/bin/co65
LD = $(CC65_HOME)/bin/ld65
else
AR = ../bin/ar65
CC = ../bin/cl65
CO = ../bin/co65
LD = ../bin/ld65
endif
#-----------------------------------------------------------------------------
# Lynx
../wrk/$(TARGET)/%.o: %.s | ../wrk/$(TARGET)
$(CC) -c $(CFLAGS) -o $@ $<
.PHONY: lynxlib
lynxlib:
for i in runtime lynx common conio em joystick serial tgi zlib; do \
$(MAKE) SYS=lynx -C $$i || exit 1; \
$(AR) a lynx.lib $$i/*.o || exit 1; \
done
cp lynx/*.joy .
cp lynx/*.ser .
cp lynx/*.tgi .
if [ -d lynx/extra ]; then \
for i in lynx/extra/*.o; do \
cp $$i lynx-`basename $$i` || exit 1; \
done \
fi
../wrk/$(TARGET)/%.o: %.c | ../wrk/$(TARGET)
$(CC) -c $(CFLAGS) -o $@ $<
#-----------------------------------------------------------------------------
# NES
../wrk/$(TARGET):
mkdir -p $@
.PHONY: neslib
neslib:
for i in runtime nes common conio em joystick tgi zlib; do \
$(MAKE) SYS=nes -C $$i || exit 1; \
$(AR) a nes.lib $$i/*.o || exit 1; \
done
cp nes/*.joy .
cp nes/*.tgi .
if [ -d nes/extra ]; then \
for i in nes/extra/*.o; do \
cp $$i nes-`basename $$i` || exit 1; \
done \
fi
../lib/$(TARGET).lib: $(OBJS) | ../lib
$(AR) a $@ $?
#-----------------------------------------------------------------------------
# CBM PET machines
../lib:
mkdir $@
.PHONY: petlib
petlib:
for i in runtime pet cbm common conio dbg em joystick tgi zlib; do \
$(MAKE) SYS=pet -C $$i || exit 1; \
$(AR) a pet.lib $$i/*.o || exit 1; \
done
cp pet/*.joy .
if [ -d pet/extra ]; then \
for i in pet/extra/*.o; do \
cp $$i pet-`basename $$i` || exit 1; \
done \
fi
$(TARGET): ../lib/$(TARGET).lib
#-----------------------------------------------------------------------------
# Commodore Plus/4
-include $(DEPS)
.PHONY: plus4lib
plus4lib:
for i in runtime plus4 cbm common conio dbg em joystick mouse serial tgi zlib; do \
$(MAKE) SYS=plus4 -C $$i || exit 1; \
$(AR) a plus4.lib $$i/*.o || exit 1; \
done
cp plus4/*.joy .
cp plus4/*.ser .
if [ -d plus4/extra ]; then \
for i in plus4/extra/*.o; do \
cp $$i plus4-`basename $$i` || exit 1; \
done \
fi
#-----------------------------------------------------------------------------
# Supervision
.PHONY: supervisionlib
supervisionlib:
for i in runtime supervision common; do \
$(MAKE) SYS=supervision -C $$i || exit 1; \
$(AR) a supervision.lib $$i/*.o || exit 1; \
done
if [ -d supervision/extra ]; then \
for i in supervision/extra/*.o; do \
cp $$i supervision-`basename $$i` || exit 1; \
done \
fi
#-----------------------------------------------------------------------------
# Vic20
.PHONY: vic20lib
vic20lib:
for i in runtime vic20 cbm common conio dbg em joystick mouse tgi zlib; do \
$(MAKE) SYS=vic20 -C $$i || exit 1; \
$(AR) a vic20.lib $$i/*.o || exit 1; \
done
cp vic20/*.joy .
if [ -d vic20/extra ]; then \
for i in vic20/extra/*.o; do \
cp $$i vic20-`basename $$i` || exit 1; \
done \
fi
#-----------------------------------------------------------------------------
# Dummy targets
.PHONY: mostly-clean
mostly-clean:
@for i in $(SHAREDDIRS); do \
$(MAKE) --no-print-directory -C $$i clean || exit 1; \
done
.PHONY: clean
clean: mostly-clean
@for i in $(ALLTARGETS); do \
$(MAKE) -C $$i $@ || exit 1; \
done
.PHONY: zap
zap:
@for i in $(SHAREDDIRS) $(ALLTARGETS); do \
$(MAKE) -C $$i $@ || exit 1; \
done
@$(RM) *.lib *.o *.emd *.joy *.mou *.ser *.tgi
endif # TARGET

View File

@ -7,8 +7,16 @@
;
.export _joy_static_stddrv
.import _apple2_stdjoy
.ifdef __APPLE2ENH__
.import _a2e_stdjoy_joy
.else
.import _a2_stdjoy_joy
.endif
.rodata
_joy_static_stddrv := _apple2_stdjoy
.ifdef __APPLE2ENH__
_joy_static_stddrv := _a2e_stdjoy_joy
.else
_joy_static_stddrv := _a2_stdjoy_joy
.endif

View File

@ -7,8 +7,16 @@
;
.export _mouse_static_stddrv
.import _apple2_stdmou
.ifdef __APPLE2ENH__
.import _a2e_stdmou_mou
.else
.import _a2_stdmou_mou
.endif
.rodata
_mouse_static_stddrv := _apple2_stdmou
.ifdef __APPLE2ENH__
_mouse_static_stddrv := _a2e_stdmou_mou
.else
_mouse_static_stddrv := _a2_stdmou_mou
.endif

View File

@ -7,8 +7,16 @@
;
.export _tgi_static_stddrv
.import _apple2_280_192_8
.ifdef __APPLE2ENH__
.import _a2e_hi_tgi
.else
.import _a2_hi_tgi
.endif
.rodata
_tgi_static_stddrv := _apple2_280_192_8
.ifdef __APPLE2ENH__
_tgi_static_stddrv := _a2e_hi_tgi
.else
_tgi_static_stddrv := _a2_hi_tgi
.endif

View File

@ -7,8 +7,8 @@
;
.export _joy_static_stddrv
.import _atari_stdjoy
.import _ataristd_joy
.rodata
_joy_static_stddrv := _atari_stdjoy
_joy_static_stddrv := _ataristd_joy

View File

@ -7,8 +7,8 @@
;
.export _tgi_static_stddrv
.import _atari_8
.import _atari8_tgi
.rodata
_tgi_static_stddrv := _atari_8
_tgi_static_stddrv := _atari8_tgi

View File

@ -7,8 +7,8 @@
;
.export _joy_static_stddrv
.import _atmos_pase
.import _atmos_pase_joy
.rodata
_joy_static_stddrv := _atmos_pase
_joy_static_stddrv := _atmos_pase_joy

View File

@ -7,8 +7,8 @@
;
.export _tgi_static_stddrv
.import _atmos_240_200_2
.import _atmos_240_200_2_tgi
.rodata
_tgi_static_stddrv := _atmos_240_200_2
_tgi_static_stddrv := _atmos_240_200_2_tgi

View File

@ -7,8 +7,8 @@
;
.export _joy_static_stddrv
.import _c128_stdjoy
.import _c128_stdjoy_joy
.rodata
_joy_static_stddrv := _c128_stdjoy
_joy_static_stddrv := _c128_stdjoy_joy

View File

@ -7,8 +7,8 @@
;
.export _mouse_static_stddrv
.import _c128_1351
.import _c128_1351_mou
.rodata
_mouse_static_stddrv := _c128_1351
_mouse_static_stddrv := _c128_1351_mou

View File

@ -7,8 +7,8 @@
;
.export _tgi_static_stddrv
.import _c128_640_200_2
.import _c128_vdc_tgi
.rodata
_tgi_static_stddrv := _c128_640_200_2
_tgi_static_stddrv := _c128_vdc_tgi

View File

@ -7,8 +7,8 @@
;
.export _joy_static_stddrv
.import _c16_stdjoy
.import _c16_stdjoy_joy
.rodata
_joy_static_stddrv := _c16_stdjoy
_joy_static_stddrv := _c16_stdjoy_joy

View File

@ -7,8 +7,8 @@
;
.export _joy_static_stddrv
.import _c64_stdjoy
.import _c64_stdjoy_joy
.rodata
_joy_static_stddrv := _c64_stdjoy
_joy_static_stddrv := _c64_stdjoy_joy

View File

@ -7,8 +7,8 @@
;
.export _mouse_static_stddrv
.import _c64_1351
.import _c64_1351_mou
.rodata
_mouse_static_stddrv := _c64_1351
_mouse_static_stddrv := _c64_1351_mou

View File

@ -7,8 +7,8 @@
;
.export _tgi_static_stddrv
.import _c64_320_200_2
.import _c64_hi_tgi
.rodata
_tgi_static_stddrv := _c64_320_200_2
_tgi_static_stddrv := _c64_hi_tgi

View File

@ -7,8 +7,8 @@
;
.export _joy_static_stddrv
.import _cbm510_stdjoy
.import _cbm510_std_joy
.rodata
_joy_static_stddrv := _cbm510_stdjoy
_joy_static_stddrv := _cbm510_std_joy

View File

@ -80,6 +80,12 @@ static char GetKeyUpdate (void);
# endif
# endif
#endif
#ifndef COLOR_BLACK
# define COLOR_BLACK 0
#endif
#ifndef COLOR_WHITE
# define COLOR_WHITE 1
#endif
/* Screen definitions */
#if defined(__CBM610__)
@ -98,10 +104,39 @@ static char GetKeyUpdate (void);
#endif
/* Replacement key definitions */
#if defined(__APPLE2__)
#if defined(__APPLE2__) || defined(__LYNX__) || defined(__SUPERVISION__)
# define CH_DEL ('H' - 'A' + 1) /* Ctrl+H */
#endif
/* Replacement char definitions */
#ifndef CH_ULCORNER
# define CH_ULCORNER '+'
#endif
#ifndef CH_URCORNER
# define CH_URCORNER '+'
#endif
#ifndef CH_LLCORNER
# define CH_LLCORNER '+'
#endif
#ifndef CH_LRCORNER
# define CH_LRCORNER '+'
#endif
#ifndef CH_TTEE
# define CH_TTEE '+'
#endif
#ifndef CH_LTEE
# define CH_LTEE '+'
#endif
#ifndef CH_RTEE
# define CH_RTEE '+'
#endif
#ifndef CH_BTEE
# define CH_BTEE '+'
#endif
#ifndef CH_CROSS
# define CH_CROSS '+'
#endif
/* Defines for opcodes */
#define OPC_BRK 0x00
#define OPC_BPL 0x10

View File

@ -7,8 +7,8 @@
;
.export _joy_static_stddrv
.import _lynx_stdjoy
.import _lynx_stdjoy_joy
.rodata
_joy_static_stddrv := _lynx_stdjoy
_joy_static_stddrv := _lynx_stdjoy_joy

View File

@ -7,8 +7,8 @@
;
.export _tgi_static_stddrv
.import _lynx_160_102_16
.import _lynx_160_102_16_tgi
.rodata
_tgi_static_stddrv := _lynx_160_102_16
_tgi_static_stddrv := _lynx_160_102_16_tgi

View File

@ -7,8 +7,8 @@
;
.export _joy_static_stddrv
.import _nes_stdjoy
.import _nes_stdjoy_joy
.rodata
_joy_static_stddrv := _nes_stdjoy
_joy_static_stddrv := _nes_stdjoy_joy

View File

@ -7,8 +7,8 @@
;
.export _tgi_static_stddrv
.import _nes_64_56_2
.import _nes_64_56_2_tgi
.rodata
_tgi_static_stddrv := _nes_64_56_2
_tgi_static_stddrv := _nes_64_56_2_tgi

View File

@ -7,8 +7,8 @@
;
.export _joy_static_stddrv
.import _pet_stdjoy
.import _pet_stdjoy_joy
.rodata
_joy_static_stddrv := _pet_stdjoy
_joy_static_stddrv := _pet_stdjoy_joy

View File

@ -7,8 +7,8 @@
;
.export _joy_static_stddrv
.import _plus4_stdjoy
.import _plus4_stdjoy_joy
.rodata
_joy_static_stddrv := _plus4_stdjoy
_joy_static_stddrv := _plus4_stdjoy_joy

View File

@ -7,8 +7,8 @@
;
.export _joy_static_stddrv
.import _vic20_stdjoy
.import _vic20_stdjoy_joy
.rodata
_joy_static_stddrv := _vic20_stdjoy
_joy_static_stddrv := _vic20_stdjoy_joy