forked from len0rd/rockbox
		
	Make 4.3 and newer doesn't interpret comments in a shell call, whereas Make 4.2 and older do. Escaping the comment directly works on old makes, but on new makes the backslash is passed as well -- which we want to avoid. The safe way to pass a literal "#" character to the shell on both versions is by embedding it in a variable and expanding that. It's ugly, but it works... Change-Id: I1a217c42d747fd5aa83f9990c234e06966ac1a00
		
			
				
	
	
		
			98 lines
		
	
	
	
		
			3.8 KiB
		
	
	
	
		
			Makefile
		
	
	
	
	
	
			
		
		
	
	
			98 lines
		
	
	
	
		
			3.8 KiB
		
	
	
	
		
			Makefile
		
	
	
	
	
	
| #             __________               __   ___.
 | |
| #   Open      \______   \ ____   ____ |  | _\_ |__   _______  ___
 | |
| #   Source     |       _//  _ \_/ ___\|  |/ /| __ \ /  _ \  \/  /
 | |
| #   Jukebox    |    |   (  <_> )  \___|    < | \_\ (  <_> > <  <
 | |
| #   Firmware   |____|_  /\____/ \___  >__|_ \|___  /\____/__/\_ \
 | |
| #                     \/            \/     \/    \/            \/
 | |
| # $Id$
 | |
| #
 | |
| 
 | |
| # preprocess - run preprocessor on a file and return the result as a string
 | |
| #
 | |
| # The weird grep -v thing in here is due to Apple's stupidities and is needed
 | |
| # to make this do right when used on Mac OS X.
 | |
| #
 | |
| # The sed line is to prepend the directory to all source files
 | |
| 
 | |
| # This is needed because GNU Make older than 4.3 treats this as the start
 | |
| # of a comment even within a $(shell) call and requires a backslash escape.
 | |
| # Newer Makes pass the whole "\#" through, making the backslash visible in
 | |
| # the shell. To safely pass a literal "#", it has to go in a variable.
 | |
| _hash_ = \#
 | |
| 
 | |
| preprocess = $(shell $(CC) $(PPCFLAGS) $(2) -E -P -x c -include config.h $(1) | \
 | |
| 		grep -v "^$(_hash_)" | grep -v "^ *$$" | \
 | |
| 		sed -e 's:^..*:$(dir $(1))&:')
 | |
| 
 | |
| preprocess2file = $(shell $(CC) $(PPCFLAGS) $(3) -E -P -x c -include config.h $(1) | \
 | |
| 		grep -v '^$(_hash_)' | grep -v "^$$" > $(2))
 | |
| 
 | |
| asmdefs2file = $(SILENT)$(CC) $(PPCFLAGS) $(3) -S -x c -o - -include config.h $(1) | \
 | |
| 	perl -ne 'if(/^_?AD_(\w+):$$/){$$var=$$1}else{/^\W\.(?:word|long)\W(.*)$$/ && $$var && print "\#define $$var $$1\n";$$var=0}' > $(2)
 | |
| 
 | |
| c2obj = $(addsuffix .o,$(basename $(call full_path_subst,$(ROOTDIR)/%,$(BUILDDIR)/%,$(1))))
 | |
| 
 | |
| a2lnk = $(patsubst lib%.a,-l%,$(notdir $(1)))
 | |
| 
 | |
| # objcopy wrapper that keeps debug symbols in DEBUG builds
 | |
| # handles the $(1) == $(2) case too
 | |
| ifndef APP_TYPE
 | |
| objcopy = $(OC) $(if $(filter yes, $(USE_ELF)), -S -x, -O binary) $(1) $(2)	# objcopy native
 | |
| else ifneq (,$(findstring sdl-sim,$(APP_TYPE)))
 | |
| objcopy = cp $(1) $(1).tmp;mv -f $(1).tmp $(2)		# objcopy simulator
 | |
| else
 | |
|   ifdef DEBUG
 | |
|     objcopy = cp $(1) $(1).tmp;mv -f $(1).tmp $(2)	# objcopy hosted (DEBUG)
 | |
|   else
 | |
|     objcopy = $(OC) -S -x $(1) $(2)					# objcopy hosted (!DEBUG)
 | |
|    endif
 | |
| endif
 | |
| 
 | |
| # calculate dependencies for a list of source files $(2) and output them to $(1)
 | |
| mkdepfile = $(SILENT)perl $(TOOLSDIR)/multigcc.pl $(CC) $(PPCFLAGS) $(OTHER_INC) -MG -MM -include config.h -- $(2) | \
 | |
| 	sed -e "s: lang.h: lang/lang.h:" \
 | |
| 	-e 's:_asmdefs.o:_asmdefs.h:' \
 | |
| 	-e "s: max_language_size.h: lang/max_language_size.h:" | \
 | |
| 	$(TOOLSDIR)/addtargetdir.pl $(ROOTDIR) $(BUILDDIR) \
 | |
| 	>> $(1)
 | |
| 
 | |
| # function to create .bmp dependencies
 | |
| bmpdepfile = $(SILENT) \
 | |
| 	for each in $(2); do \
 | |
| 	    obj=`echo $$each | sed -e 's/\.bmp/.o/' -e 's:$(ROOTDIR):$(BUILDDIR):'`; \
 | |
| 	    src=`echo $$each | sed -e 's/\.bmp/.c/' -e 's:$(ROOTDIR):$(BUILDDIR):'`; \
 | |
| 	    hdr=`echo $$each | sed -e 's/.*\/\(.*\)\..*\.bmp/bitmaps\/\1\.h/'`; \
 | |
| 	    echo $$obj: $$src; \
 | |
| 	    echo $$src: $$each; \
 | |
| 	    echo $(BUILDDIR)/$$hdr: $$src; \
 | |
| 	done \
 | |
| 	>> $(1)
 | |
| 
 | |
| ifndef V
 | |
| SILENT:=@
 | |
| else
 | |
| VERBOSEOPT:=-v
 | |
| endif
 | |
| PRINTS=$(SILENT)$(call info,$(1))
 | |
| 
 | |
| # old 'make' versions don't have the built-in 'info' function
 | |
| info=old$(shell echo >&2 "Consider upgrading to GNU make 3.81+ for optimum build performance.")
 | |
| ifeq ($(call info),old)
 | |
| export info=echo "$$(1)";
 | |
| endif
 | |
| 
 | |
| # path substituion can be surprisingly tricky, indeed the following almost
 | |
| # always work but not quite:
 | |
| #   BMPOBJ = $(BMP:$(ROOTDIR)/%.bmp=$(BUILDDIR)/%.o)
 | |
| # indeed if
 | |
| #   ROOTDIR=/rockbox
 | |
| #   BUILDDIR=/rockbox/build-bla
 | |
| # then:
 | |
| #   /rockbox/apps/bitmaps/rockboxlogo-bla.bmp -> /rockbox/apps/bitmaps/rockbox/build-blalogo.o
 | |
| # this function ensure that this type of problems does not occur
 | |
| #
 | |
| # usage: $(call full_path_subst,patterm,replacement,text)
 | |
| #
 | |
| # example: $(call full_path_subst,$(ROOTDIR)/%.bmp,$(BUILDDIR)/%.o,$(BMP))
 | |
| NO_MATCH=this_string_will_never_match_anything
 | |
| full_path_subst=$(patsubst $(NO_MATCH)/%,%, $(patsubst $(NO_MATCH)/$(1), $(2), $(addprefix $(NO_MATCH)/, $(3))))
 |