(file) Return to target.mk CVS log (file) (dir) Up to [Development] / JSOC

 1 arta  1.1 # This is used to jump from a source directory to a target directory.
 2           
 3           .SUFFIXES:
 4           
 5           
 6           # Find the target directory(ies).
 7           #
 8           ifndef JSOC_MACHINE
 9             JSOC_MACHINE := $(shell build/jsoc_machine.csh)
10             export JSOC_MACHINE
11           endif
12           
13 arta  1.13 ifeq ($(MACH),)
14            MACH = $(JSOC_MACHINE)
15            endif
16            
17            OBJDIR 		:= _$(MACH)
18 arta  1.5  PROJOBJDIR	:= $(OBJDIR)/proj
19 arta  1.1  
20            all:    $(PROJOBJDIR) $(OBJDIR)
21            
22            # Define the rules to build in the target subdirectories.
23            #
24            MAKETARGET = $(MAKE) --no-print-directory -C $@ -f $(CURDIR)/Makefile \
25 jsoc  1.11 		SRCDIR=$(WORKINGDIR) $(MAKECMDGOALS)
26 arta  1.1  
27            .PHONY: $(PROJOBJDIR) $(OBJDIR) 
28            
29            # Create the project-specific directories too, if they exist.
30 arta  1.5  -include $(CURDIR)/proj/target.mk
31 arta  1.1  
32            $(OBJDIR):
33 arta  1.13 	+@[ -d bin/$(MACH) ] || mkdir -p bin/$(MACH)
34            	+@[ -d lib/$(MACH) ] || mkdir -p lib/$(MACH)
35 arta  1.1  	+@[ -d $@ ] || mkdir -p $@
36 arta  1.5  	+@[ -d $@/base/drms/apps ] || mkdir -p $@/base/drms/apps
37            	+@[ -d $@/base/drms/libs/api/client ] || mkdir -p $@/base/drms/libs/api/client
38            	+@[ -d $@/base/drms/libs/api/client_fpic ] || mkdir -p $@/base/drms/libs/api/client_fpic
39            	+@[ -d $@/base/drms/libs/api/server ] || mkdir -p $@/base/drms/libs/api/server
40            	+@[ -d $@/base/drms/libs/main/c ] || mkdir -p $@/base/drms/libs/main/c
41            	+@[ -d $@/base/drms/libs/main/f ] || mkdir -p $@/base/drms/libs/main/f
42            	+@[ -d $@/base/drms/libs/main/idl ] || mkdir -p $@/base/drms/libs/main/idl
43            	+@[ -d $@/base/drms/libs/meta ] || mkdir -p $@/base/drms/libs/meta
44            	+@[ -d $@/base/libs/cmdparams/fpic ] || mkdir -p $@/base/libs/cmdparams/fpic
45            	+@[ -d $@/base/libs/db/client ] || mkdir -p $@/base/libs/db/client
46            	+@[ -d $@/base/libs/db/client_fpic ] || mkdir -p $@/base/libs/db/client_fpic
47            	+@[ -d $@/base/libs/db/server ] || mkdir -p $@/base/libs/db/server
48 arta  1.10 	+@[ -d $@/base/libs/defs/fpic ] || mkdir -p $@/base/libs/defs/fpic
49 arta  1.5  	+@[ -d $@/base/libs/dstruct/fpic ] || mkdir -p $@/base/libs/dstruct/fpic
50            	+@[ -d $@/base/libs/inthandles ] || mkdir -p $@/base/libs/inthandles
51            	+@[ -d $@/base/libs/threads/fpic ] || mkdir -p $@/base/libs/threads/fpic
52            	+@[ -d $@/base/libs/timeio/fpic ] || mkdir -p $@/base/libs/timeio/fpic
53            	+@[ -d $@/base/libs/misc/fpic ] || mkdir -p $@/base/libs/misc/fpic
54 arta  1.6  	+@[ -d $@/base/libs/fitsrw/fpic ] || mkdir -p $@/base/libs/fitsrw/fpic
55 arta  1.8  	+@[ -d $@/base/libs/errlog ] || mkdir -p $@/base/libs/errlog
56 arta  1.5  	+@[ -d $@/base/local/libs/dsds ] || mkdir -p $@/base/local/libs/dsds
57            	+@[ -d $@/base/local/libs/soi ] || mkdir -p $@/base/local/libs/soi
58            	+@[ -d $@/base/sums/apps ] || mkdir -p $@/base/sums/apps
59            	+@[ -d $@/base/sums/libs/api ] || mkdir -p $@/base/sums/libs/api
60 karen 1.7  	+@[ -d $@/base/sums/libs/api/perl ] || mkdir -p $@/base/sums/libs/api/perl
61 arta  1.5  	+@[ -d $@/base/sums/libs/pg ] || mkdir -p $@/base/sums/libs/pg
62            	+@[ -d $@/base/util/apps ] || mkdir -p $@/base/util/apps
63            	+@[ -d $@/proj/example/apps ] || mkdir -p $@/proj/example/apps
64            	+@[ -d $@/proj/myproj/apps ] || mkdir -p $@/proj/myproj/apps
65 arta  1.1  	+@$(MAKETARGET)
66            
67            # These rules keep make from trying to use the match-anything rule below to
68            # rebuild the makefiles--ouch!  Obviously, if you don't follow my convention
69            # of using a `.mk' suffix on all non-standard makefiles you'll need to change
70            # the pattern rule.
71            #
72            Makefile : ;
73            %.mk :: ;
74            
75            
76            # Anything we don't know how to build will use this rule.  The command is a
77            # do-nothing command, but the prerequisites ensure that the appropriate
78            # recursive invocations of make will occur.
79            #
80            % :: $(PROJOBJDIR) $(OBJDIR) ; :
81            
82            
83            # The clean rule is best handled from the source directory: since we're
84            # rigorous about keeping the target directories containing only target files
85            # and the source directory containing only source files, `clean' is as trivial
86 arta  1.1  # as removing the target directories!
87            #
88            .PHONY: clean
89            clean:
90 arta  1.13 	rm -rf $(OBJDIR); rm -rf bin/$(MACH); rm -rf lib/$(MACH)
91 arta  1.1  

Karen Tian
Powered by
ViewCVS 0.9.4