X-Git-Url: http://andersk.mit.edu/gitweb/moira.git/blobdiff_plain/b9be51efdaa02ff6d01fcbf08380d2a4f85707fb..f111b4b2d7c5047a0c87281418a5283b0649987c:/util/imake.includes/Imake.rules diff --git a/util/imake.includes/Imake.rules b/util/imake.includes/Imake.rules index 3f895f78..d54f4a3d 100644 --- a/util/imake.includes/Imake.rules +++ b/util/imake.includes/Imake.rules @@ -1,22 +1,30 @@ +/**/# $Source$ +/**/# $Author$ +/**/# $Header$ +/**/# + #ifdef __STDC__ #define concat(x,y) x##y #define concat3(x,y,z) x##y##z #define concat4(w,x,y,z) w##x##y##z +#define concat5(v,w,x,y,z) v##w##x##y##z #define requote(x) #x #else -#define concat(x,y) x/**/y -#define concat3(x,y,z) x/**/y/**/z -#define concat4(w,x,y,z) w/**/x/**/y/**/z +#define concat(x,y)x/**/y +#define concat3(x,y,z)x/**/y/**/z +#define concat4(w,x,y,z)w/**/x/**/y/**/z +#define concat5(v,w,x,y,z)v/**/w/**/x/**/y/**/z #define requote(x) "x" #endif +#ifdef PROFILED_LIBS /* * Rule for building objects in libraries. */ #define library_obj_rule() @@\ .c.o: @@\ - $(CC) -p -c $(CFLAGS) $*.c @@\ + $(CC) PROF_FLAG -c $(CFLAGS) $*.c @@\ -$(LD) -X -r -o profiled/$*.o $*.o @@\ $(CC) -c $(CFLAGS) $*.c @@\ -$(LD) -x -r -o a.out $*.o @@\ @@ -29,7 +37,7 @@ #define library_ro_object(cfile) @@\ concat(cfile,.o): concat(cfile,.c) @@\ - $(CC) -p -c $(CFLAGS) concat(cfile,.c) @@\ + $(CC) PROF_FLAG -c $(CFLAGS) concat(cfile,.c) @@\ -$(LD) -X -r -o profiled/$*.o $*.o @@\ $(CCRO) -c $(CFLAGS) concat(cfile,.c) @@\ -$(LD) -x -r -o a.out $*.o @@\ @@ -57,33 +65,84 @@ concat3(lib,libname,_p.a): objs @@\ cd profiled; $(ARCHIVE) ../$@ objs @@\ $(RANLIB) $@ @@\ @@\ -lint: concat3(llib-l,libname,.ln) @@\ +lint:: concat3(llib-l,libname,.ln) @@\ @@\ concat3(llib-l,libname,.ln): srcs @@\ - $(LINT) concat(-C,libname) $(CFLAGS) srcs lintlibs @@\ + $(LINT) concat(-C,libname) $(LINTFLAGS) srcs lintlibs @@\ @@\ clean:: @@\ $(RM) concat3(lib,libname,.a) concat3(lib,libname,_p.a) @@\ $(RM) concat3(llib-l,libname,.ln) @@\ $(RM) objs @@\ - $(RM) profiled/*.o @@\ + $(RM) profiled/?*.o @@\ + @@\ +install:: @@\ + $(INSTALLRAW) -c -m 644 concat3(lib,libname,.a) concat4($(DESTDIR)$(LIBDIR)/,lib,libname,.a) @@\ + $(RANLIB) -t concat4($(DESTDIR)$(LIBDIR)/,lib,libname,.a) @@\ + $(CHMOD) 444 concat4($(DESTDIR)$(LIBDIR)/,lib,libname,.a) @@\ + $(INSTALLRAW) -c -m 644 concat3(lib,libname,_p.a) concat4($(DESTDIR)$(LIBDIR)/,lib,libname,_p.a) @@\ + $(RANLIB) -t concat4($(DESTDIR)$(LIBDIR)/,lib,libname,_p.a) @@\ + $(CHMOD) 444 concat4($(DESTDIR)$(LIBDIR)/,lib,libname,_p.a) @@\ + $(INSTALLFILE) concat3(llib-l,libname,.ln) concat4($(DESTDIR)$(LINTLIBDIR)/,llib-l,libname,.ln) @@\ + +#else /* !PROFILED_LIBS */ +/* + * Rule for building objects in libraries. + */ + +#define library_obj_rule() @@\ +.c.o: @@\ + $(CC) -c $(CFLAGS) $*.c @@\ + -$(LD) -x -r -o a.out $*.o @@\ + $(MV) a.out $*.o + +#define library_ro_object(cfile) @@\ +concat(cfile,.o): concat(cfile,.c) @@\ + $(CCRO) -c $(CFLAGS) concat(cfile,.c) @@\ + -$(LD) -x -r -o a.out $*.o @@\ + $(MV) a.out $*.o + +#define library_asm_object(ofile,sfile) @@\ +ofile: sfile @@\ + $(CPP) x.c | $(AS) - @@\ + -$(LD) -x -r -o $*.o a.out @@\ + $(RM) a.out x.c + +#define install_library_target(libname,objs,srcs,lintlibs) @@\ + @@\ +all:: concat3(lib,libname,.a) @@\ +all:: concat3(llib-l,libname,.ln) @@\ + @@\ +concat3(lib,libname,.a): objs @@\ + $(ARCHIVE) $@ objs @@\ + $(RANLIB) $@ @@\ + @@\ +lint:: concat3(llib-l,libname,.ln) @@\ + @@\ +concat3(llib-l,libname,.ln): srcs @@\ + $(LINT) concat(-C,libname) $(LINTFLAGS) srcs lintlibs @@\ + @@\ +clean:: @@\ + $(RM) concat3(lib,libname,.a) @@\ + $(RM) concat3(llib-l,libname,.ln) @@\ + $(RM) objs @@\ @@\ install:: @@\ - $(INSTALLFILE) concat3(lib,libname,.a) $(DESTDIR)/$(LIBDIR) @@\ - $(RANLIB) concat4($(DESTDIR)/$(LIBDIR),lib,libname,.a) @@\ - $(INSTALLFILE) concat3(lib,libname,_p.a) $(DESTDIR)/$(LIBDIR) @@\ - $(RANLIB) concat4($(DESTDIR)/$(LIBDIR),lib,libname,_p.a) @@\ - $(INSTALLFILE) concat3(llib-l,libname,.ln) $(DESTDIR)/$(LIBDIR)/lint + $(INSTALLRAW) -c -m 644 concat3(lib,libname,.a) concat4($(DESTDIR)$(LIBDIR)/,lib,libname,.a) @@\ + $(RANLIB) -t concat4($(DESTDIR)$(LIBDIR)/,lib,libname,.a) @@\ + $(CHMOD) 444 concat4($(DESTDIR)$(LIBDIR)/,lib,libname,.a) @@\ + $(INSTALLFILE) concat3(llib-l,libname,.ln) concat4($(DESTDIR)$(LINTLIBDIR)/,llib-l,libname,.ln) @@\ + +#endif /* PROFILED_LIBS */ /* * Rule for building utilities (binaries which don't get installed) */ - #define genutil(pgm,objs,localdeps,syslibs) @@\ all:: pgm @@\ @@\ pgm: objs localdeps @@\ - $(CC) $(CFLAGS) -o $@ objs localdeps syslibs @@\ + $(CC) $(CFLAGS) -o $@ objs syslibs @@\ @@\ clean:: @@\ $(RM) pgm objs @@\ @@ -98,7 +157,7 @@ pgm: concat(pgm,.c) libs @@\ $(HCC) $(HCFLAGS) -o $@ $@.c libs @@\ @@\ file: pgm @@\ - ./pgm > file @@\ + ./pgm file @@\ @@\ clean:: @@\ $(RM) file pgm concat(pgm,.o) @@ -123,6 +182,41 @@ pgm: concat(pgm,.c) locallibs @@\ clean:: @@\ $(RM) pgm concat(pgm,.o) @@\ +/* + * Rule for compileing files with "et" + */ + +#ifdef PROFILED_LIBS +#define comp_et_prof(tbl) @@\ +concat(tbl,.h) concat(tbl,.o): concat(tbl,.et) @@\ + $(COMPILE_ET) concat(tbl,.et) -n @@\ + $(CC) -c PROF_FLAG concat(tbl,.et.c) @@\ + $(MV) concat(tbl,.et.o) concat3(profiled/,tbl,.o) @@\ + $(COMPILE_ET) concat(tbl,.et) @@\ +clean:: @@\ + $(RM) concat(src,.o) concat(src,.h) @@\ +depend:: concat(src,.h) +#else /* !PROFILED_LIBS */ +#define comp_et_prof(tbl) comp_et(tbl) +#endif /* PROFILED_LIBS */ + +#define comp_et(tbl) @@\ +concat(tbl,.h) concat(tbl,.o): concat(tbl,.et) @@\ + $(COMPILE_ET) concat(tbl,.et) @@\ +clean:: @@\ + $(RM) concat(src,.o) concat(src,.h) + +#define comp_et_depend(src) @@\ + comp_et(src) @@\ + @@\ +depend:: concat(src,.h) + +#define mk_cmds(tbl) @@\ +concat(tbl,.o): concat(tbl,.ct) @@\ + $(MAKE_COMMANDS) concat(tbl,.ct) @@\ +clean:: @@\ + $(RM) concat(src,.o) + /* * Rule for building some random object module */ @@ -141,18 +235,74 @@ obj: src @@\ clean:: @@\ $(RM) obj @@\ +/* + * Rule for building some random object module with compile flags and + * other dependendcies + */ + +#define host_flag_object(obj,src,flags,localdeps) @@\ +obj: src localdeps @@\ + $(HCC) $(HCFLAGS) flags -c src @@\ + @@\ +clean:: @@\ + $(RM) obj @@\ + +#define ro_flag_object(obj,src,flags,localdeps) @@\ +obj: src localdeps @@\ + $(CCRO) $(CFLAGS) flags -c src @@\ + @@\ +clean:: @@\ + $(RM) obj @@\ + +/* + * Rule for building some random object module with compile flags, an + * intermediate output, and some other dependencies + */ + +#define host_cplx_object(obj,interim,src,flags,localdeps) @@\ +obj: interim src localdeps @@\ + $(HCC) $(HCFLAGS) flags -c src @@\ + $(MV) interim obj @@\ + @@\ +clean:: @@\ + $(RM) obj @@\ + +#define ro_cplx_object(obj,interim,src,flags,localdeps) @@\ +obj: src localdeps interim @@\ + $(CCRO) $(CFLAGS) flags -c src @@\ + $(MV) interim obj @@\ + @@\ +clean:: @@\ + $(RM) obj @@\ + /* * Rule for building a program which is to be installed: */ #define program(pgm,objs,localdeps,syslibs,installdir) @@\ +all:: pgm @@\ + @@\ +pgm: localdeps objs @@\ + $(CC) $(CFLAGS) -o $@ objs syslibs @@\ + @@\ +install:: @@\ + $(INSTALLPROG) pgm ${DESTDIR}installdir/pgm @@\ + @@\ +clean:: @@\ + $(RM) pgm objs @@\ + +/* + * Rule for building a program which is to be installed setuid root: + */ + +#define suidprogram(pgm,objs,localdeps,syslibs,installdir) @@\ all:: pgm @@\ @@\ pgm: objs localdeps @@\ - $(CC) $(CFLAGS) -o $@ objs localdeps syslibs @@\ + $(CC) $(CFLAGS) -o $@ objs syslibs @@\ @@\ install:: @@\ - $(INSTALLPROG) pgm ${DESTDIR}installdir @@\ + $(INSTALLSUID) pgm ${DESTDIR}installdir/pgm @@\ @@\ clean:: @@\ $(RM) pgm objs @@\ @@ -165,30 +315,51 @@ clean:: @@\ all:: pgm @@\ @@\ pgm: objs localdeps @@\ - $(CC) $(CFLAGS) -o $@ objs localdeps syslibs @@\ + $(CC) $(CFLAGS) -o $@ objs syslibs @@\ + @@\ +install:: @@\ + $(INSTALLRAW) instopts pgm ${DESTDIR}installdir/pgm @@\ + @@\ +clean:: @@\ + $(RM) pgm objs @@\ + +/* + * Special rule for building and installing a Berkeley r-command + * We need to preserve the original copies upon installation. + */ + +#define ucbprogram(pgm,objs,localdeps,syslibs,installdir) @@\ +all:: pgm @@\ + @@\ +pgm: objs localdeps @@\ + $(CC) $(CFLAGS) -o $@ objs syslibs @@\ @@\ install:: @@\ - $(INSTALLPROG) instopts pgm ${DESTDIR}installdir @@\ + -if [ ! -f concat5(${DESTDIR},installdir,/,pgm,.ucb) -a -f concat4(${DESTDIR},installdir,/,pgm) ]; then \ @@\ + mv concat4(${DESTDIR},installdir,/,pgm) concat5(${DESTDIR},installdir,/,pgm,.ucb); fi; exit 0 @@\ + $(INSTALLSUID) pgm concat4(${DESTDIR},installdir,/,pgm) @@\ @@\ clean:: @@\ $(RM) pgm objs @@\ + /* - * Rule for installing man pages. + * Rule for installing man pages. Section installing into should match + * suffix, or the man page won't show up when using man(1). */ #define manpage(section,page) @@\ all:: @@\ install:: page @@\ - $(INSTALLFILE) page concat3(${DESTDIR}${MANDIR}/man,section,/`basename page`) @@\ + $(INSTALLFILE) page concat4(${DESTDIR}${MANDIR}/man,section,/,`basename page`) @@\ /* - * Rule for building makefile dependancies. + * Rule for building makefile dependencies. */ #define depend_target() @@\ depend:: $(SRCS) @@\ - @echo "### Now computing dependancies" @@\ + @echo "### Now computing dependencies" @@\ @$(DEPEND) -s "# DO NOT DELETE" $(CFLAGS) $(SRCS) @@\ #define clean_target() @@\ @@ -209,7 +380,7 @@ name:: @@\ @for d in subdirs; \ @@\ do \ @@\ (cd $$d; echo "### Making" name "in" `pwd`; \ @@\ - $(MAKE) $(MFLAGS) name ; \ @@\ + $(MAKE) $(MFLAGS) DESTDIR=$(DESTDIR) name ; \ @@\ echo "### Done with" `pwd`); \ @@\ done @@ -221,6 +392,7 @@ print:: ${CODE} @@\ src:: ${CODE} @@\ @@\ ${CODE}: @@\ + $(RM) $@ @@\ -$(LN) ${SRCDIR}/$@ $@ #define do_subdirs_no_imakefile(subdirs) @@\