summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorBjörn Stenberg <bjorn@haxx.se>2002-04-25 08:06:38 +0000
committerBjörn Stenberg <bjorn@haxx.se>2002-04-25 08:06:38 +0000
commit6365574ea0f85ca5e2cd559ab6bf20b07f68f531 (patch)
treeafaca8f6653614c05c0b21e7e00bcadd2a4ce6c4
parent8c0a6010bb2e44396d1148b52b0047dcad260668 (diff)
downloadrockbox-6365574ea0f85ca5e2cd559ab6bf20b07f68f531.zip
rockbox-6365574ea0f85ca5e2cd559ab6bf20b07f68f531.tar.gz
rockbox-6365574ea0f85ca5e2cd559ab6bf20b07f68f531.tar.bz2
rockbox-6365574ea0f85ca5e2cd559ab6bf20b07f68f531.tar.xz
Added Rob's dependency generation script
git-svn-id: svn://svn.rockbox.org/rockbox/trunk@223 a1c6a512-1295-4272-9138-f99709370657
-rw-r--r--uisimulator/Makefile53
1 files changed, 32 insertions, 21 deletions
diff --git a/uisimulator/Makefile b/uisimulator/Makefile
index fb5a0c0..a2212e0 100644
--- a/uisimulator/Makefile
+++ b/uisimulator/Makefile
@@ -19,53 +19,64 @@
TARGET = rockboxui
-FIRMWAREDIR=../firmware
-DRIVERS=$(FIRMWAREDIR)/drivers
+FIRMWAREDIR = ../firmware
+DRIVERS = $(FIRMWAREDIR)/drivers
CC = gcc
-RM = rm
-
-CFLAGS = -g
-CPPFLAGS = -DHAVE_CONFIG_H -DGETTIMEOFDAY_TWO_ARGS -DSIMULATOR -DHAVE_LCD_BITMAP -I$(FIRMWAREDIR)
+RM = rm -f
+DEBUG = -g
+DEFINES = -DHAVE_CONFIG_H -DGETTIMEOFDAY_TWO_ARGS -DSIMULATOR -DHAVE_LCD_BITMAP
LDFLAGS = -lX11 -lm -lXt -lXmu -lnsl
+
+
UNAME := $(shell uname)
ifeq ($(UNAME),Linux)
- INCLUDES = -I/usr/X11R6/include -I$(DRIVERS)
+ INCLUDES = -I/usr/X11R6/include -I$(DRIVERS) -I$(FIRMWAREDIR)
LIBDIRS = -L/usr/X11R6/lib
else
- INCLUDES =
+ INCLUDES = -I$(FIRMWAREDIR)
LIBDIRS =
endif
-OBJS= screenhack.o uibasic.o resources.o visual.o lcd.o lcd-x11.o button-x11.o chartables.o tetris.o
+CFLAGS = $(DEBUG) $(DEFINES) $(INCLUDES)
-SRCS = $(OBJS:%.o=%.c)
-HDRS = $(OBJS:%.o=%.h)
+#SRCS = $(wildcard *.c)
+
+SRCS = screenhack.c uibasic.c resources.c visual.c lcd.c lcd-x11.c \
+ button-x11.c chartables.c tetris.c
+
+OBJS := $(SRCS:c=o)
all: $(TARGET)
clean:
- $(RM) -f $(OBJS) *~ core $(TARGET) $(CLIENTS)
+ $(RM) $(OBJS) *~ core $(TARGET) $(CLIENTS)
+ $(RM) -r $(DEPS)
distclean: clean
$(RM) config.cache
lcd.o: $(DRIVERS)/lcd.c
- $(CC) $(CPPFLAGS) $(INCLUDES) $(CFLAGS) -c $< -o $@
+ $(CC) $(CFLAGS) -c $< -o $@
chartables.o: $(FIRMWAREDIR)/chartables.c
- $(CC) $(CPPFLAGS) $(INCLUDES) $(CFLAGS) -c $< -o $@
+ $(CC) $(CFLAGS) -c $< -o $@
.c.o:
- $(CC) $(CPPFLAGS) $(INCLUDES) $(CFLAGS) -c $<
+ $(CC) $(CFLAGS) -c $<
$(TARGET): $(OBJS)
$(CC) -o $(TARGET) $(LIBDIRS) $(LDFLAGS) $(OBJS)
+DEPS:=.deps
+
+$(DEPS)/%.d: %.c
+ @$(SHELL) -c 'if [ ! -d $(DEPS) ]; then \
+ echo Creating the dependency directory: $(DEPS); \
+ mkdir $(DEPS); fi'
+ @echo "Updating Dependencies for $<"
+ @$(SHELL) -ec '$(CC) -MM $(CFLAGS) $< \
+ |sed '\''s/\($*\)\.o[ :]*/\1.o $(<:%.c=%.d) : /g'\'' > $@; \
+ [ -s $@ ] || rm -f $@'
-lcd-x11.o: lcd-x11.c screenhack.h config.h resources.h visual.h lcd-x11.h
-resources.o: resources.c utils.h resources.h
-screenhack.o: screenhack.c xmu.h screenhack.h config.h resources.h \
- visual.h version.h vroot.h
-uibasic.o: uibasic.c screenhack.h config.h resources.h visual.h version.h
-visual.o: visual.c utils.h resources.h visual.h
+-include $(SRCS:%.c=$(DEPS)/%.d)