+ifneq ($(shell echo),)
+ CMD_EXE = 1
+endif
+
PROGS = ar65 \
ca65 \
cc65 \
grc65 \
ld65 \
od65 \
+ sim65 \
sp65
-CA65_INC := $(abspath ../asminc)
-CC65_INC := $(abspath ../include)
-LD65_LIB := $(abspath ../lib)
-LD65_OBJ := $(abspath ../lib)
-LD65_CFG := $(abspath ../cfg)
+.PHONY: all mostlyclean clean install zip avail unavail bin $(PROGS)
+
+.SUFFIXES:
+
+bindir := $(prefix)/bin
+datadir := $(if $(prefix),$(prefix)/share/cc65,$(abspath ..))
+
+CA65_INC = $(datadir)/asminc
+CC65_INC = $(datadir)/include
+LD65_LIB = $(datadir)/lib
+LD65_OBJ = $(datadir)/lib
+LD65_CFG = $(datadir)/cfg
+
+CC = $(CROSS_COMPILE)gcc
+AR = $(CROSS_COMPILE)ar
+
+ifdef CROSS_COMPILE
+ $(info CC: $(CC))
+ $(info AR: $(AR))
+endif
-CFLAGS += -MMD -MP -O -std=c89 -I common \
- -Wall -Wextra -Wno-char-subscripts -Werror \
- -DCA65_INC=$(CA65_INC) -DCC65_INC=$(CC65_INC) \
+ifdef USER_CFLAGS
+ $(info USER_CFLAGS: $(USER_CFLAGS))
+endif
+
+ifndef GIT_SHA
+ GIT_SHA := $(if $(wildcard ../.git),$(shell git rev-parse --short HEAD))
+ ifneq ($(words $(GIT_SHA)),1)
+ GIT_SHA := N/A
+ endif
+endif
+$(info GIT_SHA: $(GIT_SHA))
+
+CFLAGS += -MMD -MP -O -I common \
+ -Wall -Wextra -Wno-char-subscripts $(USER_CFLAGS) \
+ -DGIT_SHA=$(GIT_SHA) -DCA65_INC=$(CA65_INC) -DCC65_INC=$(CC65_INC) \
-DLD65_LIB=$(LD65_LIB) -DLD65_OBJ=$(LD65_OBJ) -DLD65_CFG=$(LD65_CFG)
-all: $(PROGS)
+LDLIBS += -lm
+
+ifdef CMD_EXE
+ EXE_SUFFIX=.exe
+endif
+
+ifdef CROSS_COMPILE
+ EXE_SUFFIX=.exe
+endif
+
+ifdef CMD_EXE
+ DIRLIST = $(strip $(foreach dir,$1,$(wildcard $(dir))))
+ MKDIR = mkdir $(subst /,\,$1)
+ RMDIR = $(if $(DIRLIST),rmdir /s /q $(subst /,\,$(DIRLIST)))
+else
+ MKDIR = mkdir -p $1
+ RMDIR = $(RM) -r $1
+endif
+
+all bin: $(PROGS)
mostlyclean:
- $(RM) -r ../wrk
+ $(call RMDIR,../wrk)
-clean: mostlyclean
- $(RM) -r ../bin
+clean:
+ $(call RMDIR,../wrk ../bin)
-.PHONY: all $(PROGS) mostlyclean clean
+ifdef CMD_EXE
-##########
+install avail unavail:
-define OBJS_template =
+else # CMD_EXE
-$(1)_OBJS := $$(addprefix ../wrk/,$$(addsuffix .o,$$(basename $$(wildcard $(1)/*.c))))
+INSTALL = install
-$$($(1)_OBJS): | ../wrk/$(1)
+define AVAIL_recipe
-../wrk/$(1):
- mkdir -p $$@
+ln -s $(abspath ../bin/$(prog)) /usr/local/bin/$(prog)
-DEPS += $$($(1)_OBJS:.o=.d)
+endef # AVAIL_recipe
-endef
+define UNAVAIL_recipe
-##########
+$(RM) /usr/local/bin/$(prog)
-define PROG_template =
+endef # UNAVAIL_recipe
-$$(eval $$(call OBJS_template,$(1)))
+install:
+ $(if $(prefix),,$(error variable `prefix' must be set))
+ $(INSTALL) -d $(DESTDIR)$(bindir)
+ $(INSTALL) ../bin/* $(DESTDIR)$(bindir)
-../bin/$(1): $$($(1)_OBJS) ../wrk/common/common.a | ../bin
- $$(CC) $$(LDFLAGS) -o $$@ $$^
+avail:
+ $(foreach prog,$(PROGS),$(AVAIL_recipe))
-$(1): ../bin/$(1)
+unavail:
+ $(foreach prog,$(PROGS),$(UNAVAIL_recipe))
-endef
+endif # CMD_EXE
-##########
+zip:
+ @cd .. && zip cc65 bin/*
+
+define OBJS_template
+
+$1_OBJS := $$(patsubst %.c,../wrk/%.o,$$(wildcard $1/*.c))
+
+$$($1_OBJS): | ../wrk/$1
+
+../wrk/$1:
+ @$$(call MKDIR,$$@)
+
+DEPS += $$($1_OBJS:.o=.d)
+
+endef # OBJS_template
+
+define PROG_template
+
+$$(eval $$(call OBJS_template,$1))
+
+../bin/$1$(EXE_SUFFIX): $$($1_OBJS) ../wrk/common/common.a | ../bin
+ $$(CC) $$(LDFLAGS) -o $$@ $$^ $$(LDLIBS)
+
+$1: ../bin/$1$(EXE_SUFFIX)
+
+endef # PROG_template
../wrk/%.o: %.c
- @echo $(CC) $<
+ @echo $<
@$(CC) -c $(CFLAGS) -o $@ $<
../bin:
- mkdir $@
+ @$(call MKDIR,$@)
$(eval $(call OBJS_template,common))
+
../wrk/common/common.a: $(common_OBJS)
- $(AR) r $@ $^
+ $(AR) r $@ $?
$(foreach prog,$(PROGS),$(eval $(call PROG_template,$(prog))))