/**/# $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.
*/
+#if defined(mips) || defined(_AIX) || defined(SOLARIS)
+/*
+ * The MIPS, AIX & SOLARIS loaders don't have the -X flag or its functionality.
+ * Solaris to make it worse does not have -x
+ */
+#if !defined(SOLARIS)
+#define library_obj_rule() @@\
+.c.o: @@\
+ $(CC) PROF_FLAG -c $(CFLAGS) $*.c @@\
+ $(MV) $*.o profiled/$*.o @@\
+ $(CC) -c $(CFLAGS) $*.c @@\
+ -$(LD) -x -r -o a.out $*.o @@\
+ $(MV) a.out $*.o
+#else
+#define library_obj_rule() @@\
+.c.o: @@\
+ $(CC) PROF_FLAG -c $(CFLAGS) $*.c @@\
+ $(MV) $*.o profiled/$*.o @@\
+ $(CC) -c $(CFLAGS) $*.c @@\
+ -$(LD) -r -o a.out $*.o @@\
+ $(MV) a.out $*.o
+#endif
+#else /* ! mips && ! _AIX */
#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 @@\
$(MV) a.out $*.o
-
+#endif /* mips */
/*
* cc -R breaks profiling with -p on 4.3BSD on the VAX
* (and probably elsewhere), so we don't do it for the profiled version.
#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 @@\
-$(LD) -x -r -o $*.o a.out @@\
$(RM) a.out x.c
+#ifdef USELINT
+#define install_library_lint(libname) @@\
+all:: concat3(llib-l,libname,.ln) @@\
+ @@\
+install:: @@\
+ $(INSTALLFILE) concat3(llib-l,libname,.ln) concat4($(DESTDIR)$(LINTLIBDIR)/,llib-l,libname,.ln) @@\
+
+#else
+#define install_library_lint(libname)
+#endif
+
+
#define install_library_target(libname,objs,srcs,lintlibs) @@\
@@\
all:: concat3(lib,libname,.a) concat3(lib,libname,_p.a) @@\
-all:: concat3(llib-l,libname,.ln) @@\
@@\
concat3(lib,libname,.a): objs @@\
+ $(RM) $@.bak @@\
+ -$(MV) $@ $@.bak @@\
$(ARCHIVE) $@ objs @@\
$(RANLIB) $@ @@\
@@\
concat3(lib,libname,_p.a): objs @@\
+ $(RM) $@.bak @@\
+ -$(MV) $@ $@.bak @@\
cd profiled; $(ARCHIVE) ../$@ objs @@\
$(RANLIB) $@ @@\
@@\
lint:: concat3(llib-l,libname,.ln) @@\
@@\
concat3(llib-l,libname,.ln): srcs @@\
- $(LINT) concat(-C,libname) $(CFLAGS) srcs lintlibs @@\
+ $(LINT) concat($(LINTLIBFLAG),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) @@\
+ @@\
+install_library_lint(libname) @@\
+
+#else /* !PROFILED_LIBS */
+/*
+ * Rule for building objects in libraries.
+ */
+
+#ifdef DEBUG_LIBS
+/* When debugging, leave symbols alone (don't do LD) */
+#define library_obj_rule() @@\
+.c.o: @@\
+ $(CC) -c $(CFLAGS) $*.c
+#else
+#define library_obj_rule() @@\
+.c.o: @@\
+ $(CC) -c $(CFLAGS) $*.c @@\
+ -$(LD) -x -r -o a.out $*.o @@\
+ $(MV) a.out $*.o
+#endif
+
+#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
+
+#ifdef USELINT
+#define install_library_lint(libname) @@\
+all:: concat3(llib-l,libname,.ln) @@\
+ @@\
+install:: @@\
+ $(INSTALLFILE) concat3(llib-l,libname,.ln) concat4($(DESTDIR)$(LINTLIBDIR)/,llib-l,libname,.ln) @@\
+
+#else
+#define install_library_lint(libname)
+#endif
+
+#define install_library_target(libname,objs,srcs,lintlibs) @@\
+ @@\
+all:: concat3(lib,libname,.a) @@\
+ @@\
+concat3(lib,libname,.a): objs @@\
+ $(RM) $@.bak @@\
+ -$(MV) $@ $@.bak @@\
+ $(ARCHIVE) $@ objs @@\
+ $(RANLIB) $@ @@\
+ @@\
+lint:: concat3(llib-l,libname,.ln) @@\
+ @@\
+concat3(llib-l,libname,.ln): srcs @@\
+ $(LINT) concat($(LINTLIBFLAG),libname) $(LINTFLAGS) srcs lintlibs @@\
+ @@\
+clean:: @@\
+ $(RM) concat3(lib,libname,.a) @@\
+ $(RM) concat3(llib-l,libname,.ln) @@\
+ $(RM) objs @@\
@@\
install:: @@\
- $(INSTALLFILE) concat3(lib,libname,.a) concat4($(DESTDIR)$(LIBDIR)/,lib,libname,.a) @@\
- $(RANLIB) concat4($(DESTDIR)$(LIBDIR)/,lib,libname,.a) @@\
- $(INSTALLFILE) concat3(lib,libname,_p.a) concat4($(DESTDIR)$(LIBDIR)/,lib,libname,_p.a) @@\
- $(RANLIB) concat4($(DESTDIR)$(LIBDIR)/,lib,libname,_p.a) @@\
- $(INSTALLFILE) concat3(llib-l,libname,.ln) concat4($(DESTDIR)$(LIBDIR)/lint,llib-l,libname,.ln) @@\
+ $(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) @@\
+ @@\
+install_library_lint(libname) @@\
+
+
+#endif /* PROFILED_LIBS */
/*
* Rule for building utilities (binaries which don't get installed)
all:: pgm @@\
@@\
pgm: objs localdeps @@\
- $(CC) $(CFLAGS) -o $@ objs localdeps syslibs @@\
+ $(CC) $(CFLAGS) -o $@ objs syslibs $(OSLIBS) @@\
@@\
clean:: @@\
$(RM) pgm objs @@\
#define generate(file,pgm,libs) @@\
@@\
pgm: concat(pgm,.c) libs @@\
- $(HCC) $(HCFLAGS) -o $@ $@.c libs @@\
+ $(HCC) $(HCFLAGS) -o $@ $@.c libs $(OSLIBS) @@\
@@\
file: pgm @@\
./pgm file @@\
* Rule for building test programs (something which is not installed)
*/
-#define test(pgm,locallibs,syslibs) @@\
+#define test_program(pgm,locallibs,syslibs) @@\
@@\
all:: pgm @@\
@@\
pgm: concat(pgm,.c) locallibs @@\
- $(CC) $(CFLAGS) -o $@ $@.c locallibs syslibs @@\
+ $(CC) $(CFLAGS) -o $@ $@.c locallibs syslibs $(OSLIBS) @@\
@@\
clean:: @@\
$(RM) pgm concat(pgm,.o) @@\
* Rule for compileing files with "et"
*/
-#define comp_et(src) @@\
-concat(src,.h):: concat(src,.et) @@\
- compile_et concat(src,.et) @@\
-concat(src,.o):: concat(src,.et) @@\
- compile_et concat(src,.et) @@\
+#define comp_et(tbl) @@\
+concat(tbl,.h) concat(tbl,.c): concat(tbl,.et) @@\
+ $(COMPILE_ET) concat(tbl,.et) @@\
clean:: @@\
- $(RM) concat(src,.o) concat(src,.h) @@\
+ $(RM) concat(tbl,.c) concat(tbl,.h)
#define comp_et_depend(src) @@\
comp_et(src) @@\
@@\
-depend:: concat(src,.h) @@\
+depend:: concat(src,.h)
/*
* Rule for building some random object module
all:: pgm @@\
@@\
pgm: localdeps objs @@\
- $(CC) $(CFLAGS) -o $@ objs syslibs @@\
+ $(CC) $(CFLAGS) -o $@ objs syslibs $(OSLIBS) @@\
@@\
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 @@\
- @@\
-install:: @@\
- $(INSTALLSUID) pgm ${DESTDIR}installdir/pgm @@\
- @@\
-clean:: @@\
- $(RM) pgm objs @@\
-
/*
* Rule for building a specially installed program
*/
all:: pgm @@\
@@\
pgm: objs localdeps @@\
- $(CC) $(CFLAGS) -o $@ objs localdeps syslibs @@\
+ $(CC) $(CFLAGS) -o $@ objs syslibs $(OSLIBS) @@\
@@\
install:: @@\
$(INSTALLRAW) instopts pgm ${DESTDIR}installdir/pgm @@\
#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 dependencies.
#define depend_target() @@\
depend:: $(SRCS) @@\
@echo "### Now computing dependencies" @@\
- @$(DEPEND) -s "# DO NOT DELETE" $(CFLAGS) $(SRCS) @@\
+ @$(DEPEND) -s "# DO NOT DELETE" -- $(CFLAGS) -- $(SRCS) @@\
#define clean_target() @@\
clean:: @@\
src:: ${CODE} @@\
@@\
${CODE}: @@\
+ $(RM) $@ @@\
-$(LN) ${SRCDIR}/$@ $@
#define do_subdirs_no_imakefile(subdirs) @@\
done
+/* Compile Embeded SQL source */
+#ifdef INGRES
+#define sqlrule() @@\
+.SUFFIXES: .sc .dc @@\
+.dc.sc: @@\
+ $(AWK) -f $(SRCTOP)/util/imake.includes/ingres.awk < $< > $*.sc @@\
+ @@\
+.sc.c: @@\
+ /usr/ingres/bin/esqlc -p $*
+#define sqlfile(file) @@\
+concat(file,.sc): concat(file,.dc) @@\
+concat(file,.c): concat(file,.sc) @@\
+clean:: @@\
+ $(RM) concat(file,.sc) concat(file,.c)
+#endif
+#ifdef INFORMIX
+#define sqlrule() @@\
+.SUFFIXES: .ec .dc @@\
+.dc.ec: @@\
+ $(AWK) -f $(SRCTOP)/util/imake.includes/informix.awk < $< > $*.ec @@\
+ @@\
+.ec.c: @@\
+ /usr/informix/bin/esql -e $*.ec
+#define sqlfile(file) @@\
+concat(file,.ec): concat(file,.dc) @@\
+concat(file,.c): concat(file,.ec) @@\
+clean:: @@\
+ $(RM) concat(file,.ec) concat(file,.c)
+#endif
+#ifdef ORACLE
+/* have to undef these to keep the ORADEFS line from being attacked */
+#undef HESIOD
+#undef ZEPHYR
+#undef GDSS
+#undef ATHENA
+ORADEFS= DEFINE=HESIOD DEFINE=ZEPHYR DEFINE=GDSS DEFINE=ATHENA
+#define sqlrule() @@\
+.SUFFIXES: .pc .dc @@\
+.dc.pc: @@\
+ $(AWK) -f $(SRCTOP)/util/imake.includes/oracle.awk < $< > $*.pc @@\
+ @@\
+.pc.c: @@\
+ /usr/oracle/bin/proc INAME=$*.pc INCLUDE=$(BUILDTOP)/include INCLUDE=$(BUILDTOP)/lib INCLUDE=$(INCLDIR) $(ORADEFS)
+#define sqlfile(file) @@\
+concat(file,.pc): concat(file,.dc) @@\
+concat(file,.c): concat(file,.pc) @@\
+clean:: @@\
+ $(RM) concat(file,.pc) concat(file,.c)
+#endif