include ../../Make.in
include ../Make.in

EXEFILE=$(subst .c,,$(wildcard *.c))
OBJECT=$(subst .c,.o,$(wildcard *.c))
BINDIR = bin/


all: link_machine compile $(addprefix $(BINDIR),$(EXEFILE))

link_machine:
	rm $(MODULEDIR)machine -f;
	ln -s $(MACHINELIBDIR) $(MODULEDIR)machine;

compile:
	cd $(MACHINELIBDIR); make;
	
$(addprefix $(BINDIR),$(EXEFILE)):$(addprefix $(BINDIR),$(OBJECT))
	$(LD) -o $@ $(addsuffix .o,$@) $(CRT0) $(LIBMACHINELIB) $(LIB) $(LIBGCC)

$(BINDIR)%.o:%.S
	$(CC) $(INCLUDE) $(CFLAGS) $(CFLAG_DEF) -c -o $@ $<

$(BINDIR)%.o:%.c
	$(CC) $(INCLUDE) $(CFLAGS) $(CFLAG_DEF) -c -o $@ $<


clean:
	cd $(MACHINELIBDIR); make clean;
	rm $(BINDIR)* -f
