[BACK]Return to bsd.lib.mk CVS log [TXT][DIR] Up to [cvs.NetBSD.org] / src / share / mk

Please note that diffs are not public domain; they are subject to the copyright notices on the relevant files.

Diff for /src/share/mk/bsd.lib.mk between version 1.237 and 1.257

version 1.237, 2003/10/19 03:00:55 version 1.257, 2004/12/02 00:00:41
Line 8 
Line 8 
 .include <bsd.sys.mk>  .include <bsd.sys.mk>
   
 ##### Basic targets  ##### Basic targets
 .PHONY:         checkver cleanlib libinstall  .PHONY:         checkver libinstall
 realinstall:    checkver libinstall  realinstall:    checkver libinstall
 clean:          cleanlib  clean:          cleanlib
   
Line 20  LDADD+=     ${LDADD.lib${LIB}}
Line 20  LDADD+=     ${LDADD.lib${LIB}}
 LDFLAGS+=   ${LDFLAGS.lib${LIB}}  LDFLAGS+=   ${LDFLAGS.lib${LIB}}
 LDSTATIC+=  ${LDSTATIC.lib${LIB}}  LDSTATIC+=  ${LDSTATIC.lib${LIB}}
   
   ##### Libraries that this may depend upon.
   .if defined(LIBDPLIBS) && ${MKPIC} != "no"                              # {
   .for _lib _dir in ${LIBDPLIBS}
   .if !defined(LIBDO.${_lib})
   LIBDO.${_lib}!= cd ${_dir} && ${PRINTOBJDIR}
   .MAKEOVERRIDES+=LIBDO.${_lib}
   .endif
   LDADD+=         -L${LIBDO.${_lib}} -l${_lib}
   DPADD+=         ${LIBDO.${_lib}}/lib${_lib}.so
   .endfor
   .endif                                                                  # }
   
 ##### Build and install rules  ##### Build and install rules
   MKDEP_SUFFIXES?=        .o .po .so .ln
 CPPFLAGS+=      ${DESTDIR:D-nostdinc ${CPPFLAG_ISYSTEM} ${DESTDIR}/usr/include}  CPPFLAGS+=      ${DESTDIR:D-nostdinc ${CPPFLAG_ISYSTEM} ${DESTDIR}/usr/include}
 CXXFLAGS+=      ${DESTDIR:D-nostdinc++ ${CPPFLAG_ISYSTEMXX} ${DESTDIR}/usr/include/g++}  CXXFLAGS+=      ${DESTDIR:D-nostdinc++ ${CPPFLAG_ISYSTEMXX} ${DESTDIR}/usr/include/g++}
   
 .if !defined(SHLIB_MAJOR) && exists(${SHLIB_VERSION_FILE})  .if !defined(SHLIB_MAJOR) && exists(${SHLIB_VERSION_FILE})              # {
 SHLIB_MAJOR != . ${SHLIB_VERSION_FILE} ; echo $$major  SHLIB_MAJOR != . ${SHLIB_VERSION_FILE} ; echo $$major
 SHLIB_MINOR != . ${SHLIB_VERSION_FILE} ; echo $$minor  SHLIB_MINOR != . ${SHLIB_VERSION_FILE} ; echo $$minor
 SHLIB_TEENY != . ${SHLIB_VERSION_FILE} ; echo $$teeny  SHLIB_TEENY != . ${SHLIB_VERSION_FILE} ; echo $$teeny
Line 34  SHLIB_TEENY != . ${SHLIB_VERSION_FILE} ;
Line 47  SHLIB_TEENY != . ${SHLIB_VERSION_FILE} ;
         exists(${NETBSDSRCDIR}/lib/checkver)          exists(${NETBSDSRCDIR}/lib/checkver)
 checkver:  checkver:
         @(cd ${.CURDIR} && \          @(cd ${.CURDIR} && \
                 sh ${NETBSDSRCDIR}/lib/checkver -v ${SHLIB_VERSION_FILE} \              ${HOST_SH} ${NETBSDSRCDIR}/lib/checkver -v ${SHLIB_VERSION_FILE} \
                     -d ${DESTDIR}${_LIBSODIR} ${LIB})                      -d ${DESTDIR}${_LIBSODIR} ${LIB})
 .endif  .endif
 .endif  .endif                                                                  # }
   
 .if !target(checkver)  .if !target(checkver)
 checkver:  checkver:
Line 64  print-shlib-teeny:
Line 77  print-shlib-teeny:
         @false          @false
 .endif  .endif
   
 .if defined(SHLIB_MAJOR) && !empty(SHLIB_MAJOR)  .if defined(SHLIB_MAJOR) && !empty(SHLIB_MAJOR)                         # {
 .if defined(SHLIB_MINOR) && !empty(SHLIB_MINOR)  .if defined(SHLIB_MINOR) && !empty(SHLIB_MINOR)
 .if defined(SHLIB_TEENY) && !empty(SHLIB_TEENY)  .if defined(SHLIB_TEENY) && !empty(SHLIB_TEENY)
 SHLIB_FULLVERSION=${SHLIB_MAJOR}.${SHLIB_MINOR}.${SHLIB_TEENY}  SHLIB_FULLVERSION=${SHLIB_MAJOR}.${SHLIB_MINOR}.${SHLIB_TEENY}
Line 74  SHLIB_FULLVERSION=${SHLIB_MAJOR}.${SHLIB
Line 87  SHLIB_FULLVERSION=${SHLIB_MAJOR}.${SHLIB
 .else  .else
 SHLIB_FULLVERSION=${SHLIB_MAJOR}  SHLIB_FULLVERSION=${SHLIB_MAJOR}
 .endif  .endif
 .endif  .endif                                                                  # }
   
 # add additional suffixes not exported.  # add additional suffixes not exported.
 # .po is used for profiling object files.  # .po is used for profiling object files.
Line 106  SHLIB_FULLVERSION=${SHLIB_MAJOR}
Line 119  SHLIB_FULLVERSION=${SHLIB_MAJOR}
 #                       (usually just ${CPPPICFLAGS} ${CPICFLAGS})  #                       (usually just ${CPPPICFLAGS} ${CPICFLAGS})
 # APICFLAGS:            flags for ${AS} to assemble .[sS] to .so objects.  # APICFLAGS:            flags for ${AS} to assemble .[sS] to .so objects.
   
 .if ${MACHINE_ARCH} == "alpha"  .if ${MACHINE_ARCH} == "alpha"                                          # {
   
 FPICFLAGS ?= -fPIC  FPICFLAGS ?= -fPIC
 CPICFLAGS ?= -fPIC -DPIC  CPICFLAGS ?= -fPIC -DPIC
Line 115  CAPICFLAGS?= ${CPPPICFLAGS} ${CPICFLAGS}
Line 128  CAPICFLAGS?= ${CPPPICFLAGS} ${CPICFLAGS}
 APICFLAGS ?=  APICFLAGS ?=
   
 .elif (${MACHINE_ARCH} == "sparc" || ${MACHINE_ARCH} == "sparc64") && \  .elif (${MACHINE_ARCH} == "sparc" || ${MACHINE_ARCH} == "sparc64") && \
        ${OBJECT_FMT} == "ELF"         ${OBJECT_FMT} == "ELF"                                           # } {
   
 # If you use -fPIC you need to define BIGPIC to turn on 32-bit  # If you use -fPIC you need to define BIGPIC to turn on 32-bit
 # relocations in asm code  # relocations in asm code
Line 125  CPPPICFLAGS?= -DPIC -DBIGPIC
Line 138  CPPPICFLAGS?= -DPIC -DBIGPIC
 CAPICFLAGS?= ${CPPPICFLAGS} ${CPICFLAGS}  CAPICFLAGS?= ${CPPPICFLAGS} ${CPICFLAGS}
 APICFLAGS ?= -KPIC  APICFLAGS ?= -KPIC
   
 .elif ${MACHINE_ARCH} == "hppa"  .elif ${MACHINE_ARCH} == "ns32k"                                        # } {
   
 FPICFLAGS ?= -fPIC  # XXX no shared libraries yet on ns32k
 CPICFLAGS?= -fPIC -DPIC  FPICFLAGS?=
 CPPPICFLAGS?= -DPIC  CPICFLAGS?=
 CAPICFLAGS?= ${CPPPICFLAGS} ${CPICFLAGS}  CPPPICFLAGS?=
 APICFLAGS?= -k  CAPICFLAGS?=
 # XXX libraries often need the millicode functions in libgcc.a,  APICFLAGS?=
 # so we have to work around the -nostdlib:  
 LDADD+= `${CC} -print-libgcc-file-name`  
   
 .else  .else                                                                   # } {
   
 # Platform-independent flags for NetBSD a.out shared libraries  # Platform-independent flags for NetBSD shared libraries
 SHLIB_SOVERSION=${SHLIB_FULLVERSION}  SHLIB_SOVERSION=${SHLIB_FULLVERSION}
 SHLIB_SHFLAGS=  SHLIB_SHFLAGS=
 FPICFLAGS ?= -fPIC  FPICFLAGS ?= -fPIC
Line 147  CPPPICFLAGS?= -DPIC
Line 158  CPPPICFLAGS?= -DPIC
 CAPICFLAGS?= ${CPPPICFLAGS} ${CPICFLAGS}  CAPICFLAGS?= ${CPPPICFLAGS} ${CPICFLAGS}
 APICFLAGS?= -k  APICFLAGS?= -k
   
 .endif  .endif                                                                  # }
   
 .if ${MKPICLIB} != "no"  .if ${MKPICLIB} != "no"
 CSHLIBFLAGS+= ${CPICFLAGS}  CSHLIBFLAGS+= ${CPICFLAGS}
Line 168  SHLIB_LDENDFILE?= ${_GCC_CRTENDS} ${DEST
Line 179  SHLIB_LDENDFILE?= ${_GCC_CRTENDS} ${DEST
 .endif  .endif
   
 CFLAGS+=        ${COPTS}  CFLAGS+=        ${COPTS}
   AFLAGS+=        ${COPTS}
 FFLAGS+=        ${FOPTS}  FFLAGS+=        ${FOPTS}
   
 .c.o:  .c.o:
         ${_MKMSGCOMPILE}          ${_MKTARGET_COMPILE}
         ${_MKCMD}\  
         ${COMPILE.c} ${COPTS.${.IMPSRC:T}} ${CPUFLAGS.${.IMPSRC:T}} ${CPPFLAGS.${.IMPSRC:T}} ${.IMPSRC} -o ${.TARGET}.tmp          ${COMPILE.c} ${COPTS.${.IMPSRC:T}} ${CPUFLAGS.${.IMPSRC:T}} ${CPPFLAGS.${.IMPSRC:T}} ${.IMPSRC} -o ${.TARGET}.tmp
 .if defined(COPTS) && !empty(COPTS:M*-g*)  .if defined(COPTS) && !empty(COPTS:M*-g*)
         ${_MKCMD}\  
         mv ${.TARGET}.tmp ${.TARGET}          mv ${.TARGET}.tmp ${.TARGET}
 .else  .else
         ${_MKCMD}\  
         ${LD} -x -r ${.TARGET}.tmp -o ${.TARGET}          ${LD} -x -r ${.TARGET}.tmp -o ${.TARGET}
         ${_MKCMD}\  
         rm -f ${.TARGET}.tmp          rm -f ${.TARGET}.tmp
 .endif  .endif
   
 .c.po:  .c.po:
         ${_MKMSGCOMPILE}          ${_MKTARGET_COMPILE}
         ${_MKCMD}\  
         ${COMPILE.c} ${COPTS.${.IMPSRC:T}} ${CPUFLAGS.${.IMPSRC:T}} ${CPPFLAGS.${.IMPSRC:T}} -pg ${.IMPSRC} -o ${.TARGET}.tmp          ${COMPILE.c} ${COPTS.${.IMPSRC:T}} ${CPUFLAGS.${.IMPSRC:T}} ${CPPFLAGS.${.IMPSRC:T}} -pg ${.IMPSRC} -o ${.TARGET}.tmp
 .if defined(COPTS) && !empty(COPTS:M*-g*)  .if defined(COPTS) && !empty(COPTS:M*-g*)
         ${_MKCMD}\  
         mv ${.TARGET}.tmp ${.TARGET}          mv ${.TARGET}.tmp ${.TARGET}
 .else  .else
         ${_MKCMD}\  
         ${LD} -X -r ${.TARGET}.tmp -o ${.TARGET}          ${LD} -X -r ${.TARGET}.tmp -o ${.TARGET}
         ${_MKCMD}\  
         rm -f ${.TARGET}.tmp          rm -f ${.TARGET}.tmp
 .endif  .endif
   
 .c.so:  .c.so:
         ${_MKMSGCOMPILE}          ${_MKTARGET_COMPILE}
         ${_MKCMD}\  
         ${COMPILE.c} ${COPTS.${.IMPSRC:T}} ${CPUFLAGS.${.IMPSRC:T}} ${CPPFLAGS.${.IMPSRC:T}} ${CSHLIBFLAGS} ${.IMPSRC} -o ${.TARGET}.tmp          ${COMPILE.c} ${COPTS.${.IMPSRC:T}} ${CPUFLAGS.${.IMPSRC:T}} ${CPPFLAGS.${.IMPSRC:T}} ${CSHLIBFLAGS} ${.IMPSRC} -o ${.TARGET}.tmp
 .if defined(COPTS) && !empty(COPTS:M*-g*)  .if defined(COPTS) && !empty(COPTS:M*-g*)
         ${_MKCMD}\  
         mv ${.TARGET}.tmp ${.TARGET}          mv ${.TARGET}.tmp ${.TARGET}
 .else  .else
         ${_MKCMD}\  
         ${LD} -x -r ${.TARGET}.tmp -o ${.TARGET}          ${LD} -x -r ${.TARGET}.tmp -o ${.TARGET}
         ${_MKCMD}\  
         rm -f ${.TARGET}.tmp          rm -f ${.TARGET}.tmp
 .endif  .endif
   
 .c.ln:  
         ${_MKMSGCOMPILE}  
         ${_MKCMD}\  
         ${LINT} ${LINTFLAGS} ${CPPFLAGS:M-[IDU]*} ${CPPFLAGS.${.IMPSRC:T}:M-[-IDU]*} -i ${.IMPSRC}  
   
 .cc.o .cpp.o .cxx.o .C.o:  .cc.o .cpp.o .cxx.o .C.o:
         ${_MKMSGCOMPILE}          ${_MKTARGET_COMPILE}
         ${_MKCMD}\  
         ${COMPILE.cc} ${COPTS.${.IMPSRC:T}} ${CPUFLAGS.${.IMPSRC:T}} ${CPPFLAGS.${.IMPSRC:T}} ${.IMPSRC} -o ${.TARGET}.tmp          ${COMPILE.cc} ${COPTS.${.IMPSRC:T}} ${CPUFLAGS.${.IMPSRC:T}} ${CPPFLAGS.${.IMPSRC:T}} ${.IMPSRC} -o ${.TARGET}.tmp
 .if defined(COPTS) && !empty(COPTS:M*-g*)  .if defined(COPTS) && !empty(COPTS:M*-g*)
         ${_MKCMD}\  
         mv ${.TARGET}.tmp ${.TARGET}          mv ${.TARGET}.tmp ${.TARGET}
 .else  .else
         ${_MKCMD}\  
         ${LD} -x -r ${.TARGET}.tmp -o ${.TARGET}          ${LD} -x -r ${.TARGET}.tmp -o ${.TARGET}
         ${_MKCMD}\  
         rm -f ${.TARGET}.tmp          rm -f ${.TARGET}.tmp
 .endif  .endif
   
 .cc.po .cpp.po .cxx.o .C.po:  .cc.po .cpp.po .cxx.o .C.po:
         ${_MKMSGCOMPILE}          ${_MKTARGET_COMPILE}
         ${_MKCMD}\  
         ${COMPILE.cc} ${COPTS.${.IMPSRC:T}} ${CPUFLAGS.${.IMPSRC:T}} ${CPPFLAGS.${.IMPSRC:T}} -pg ${.IMPSRC} -o ${.TARGET}.tmp          ${COMPILE.cc} ${COPTS.${.IMPSRC:T}} ${CPUFLAGS.${.IMPSRC:T}} ${CPPFLAGS.${.IMPSRC:T}} -pg ${.IMPSRC} -o ${.TARGET}.tmp
 .if defined(COPTS) && !empty(COPTS:M*-g*)  .if defined(COPTS) && !empty(COPTS:M*-g*)
         ${_MKCMD}\  
         mv ${.TARGET}.tmp ${.TARGET}          mv ${.TARGET}.tmp ${.TARGET}
 .else  .else
         ${_MKCMD}\  
         ${LD} -X -r ${.TARGET}.tmp -o ${.TARGET}          ${LD} -X -r ${.TARGET}.tmp -o ${.TARGET}
         ${_MKCMD}\  
         rm -f ${.TARGET}.tmp          rm -f ${.TARGET}.tmp
 .endif  .endif
   
 .cc.so .cpp.so .cxx.so .C.so:  .cc.so .cpp.so .cxx.so .C.so:
         ${_MKMSGCOMPILE}          ${_MKTARGET_COMPILE}
         ${_MKCMD}\  
         ${COMPILE.cc} ${COPTS.${.IMPSRC:T}} ${CPUFLAGS.${.IMPSRC:T}} ${CPPFLAGS.${.IMPSRC:T}} ${CSHLIBFLAGS} ${.IMPSRC} -o ${.TARGET}.tmp          ${COMPILE.cc} ${COPTS.${.IMPSRC:T}} ${CPUFLAGS.${.IMPSRC:T}} ${CPPFLAGS.${.IMPSRC:T}} ${CSHLIBFLAGS} ${.IMPSRC} -o ${.TARGET}.tmp
 .if defined(COPTS) && !empty(COPTS:M*-g*)  .if defined(COPTS) && !empty(COPTS:M*-g*)
         ${_MKCMD}\  
         mv ${.TARGET}.tmp ${.TARGET}          mv ${.TARGET}.tmp ${.TARGET}
 .else  .else
         ${_MKCMD}\  
         ${LD} -x -r ${.TARGET}.tmp -o ${.TARGET}          ${LD} -x -r ${.TARGET}.tmp -o ${.TARGET}
         ${_MKCMD}\  
         rm -f ${.TARGET}.tmp          rm -f ${.TARGET}.tmp
 .endif  .endif
   
 .f.o:  .f.o:
         ${_MKMSGCOMPILE}          ${_MKTARGET_COMPILE}
         ${_MKCMD}\  
         ${COMPILE.f} ${.IMPSRC} -o ${.TARGET}.tmp          ${COMPILE.f} ${.IMPSRC} -o ${.TARGET}.tmp
 .if defined(FOPTS) && !empty(FOPTS:M*-g*)  .if defined(FOPTS) && !empty(FOPTS:M*-g*)
         ${_MKCMD}\  
         mv ${.TARGET}.tmp ${.TARGET}          mv ${.TARGET}.tmp ${.TARGET}
 .else  .else
         ${_MKCMD}\  
         ${LD} -x -r ${.TARGET}.tmp -o ${.TARGET}          ${LD} -x -r ${.TARGET}.tmp -o ${.TARGET}
         ${_MKCMD}\  
         rm -f ${.TARGET}.tmp          rm -f ${.TARGET}.tmp
 .endif  .endif
   
 .f.po:  .f.po:
         ${_MKMSGCOMPILE}          ${_MKTARGET_COMPILE}
         ${_MKCMD}\  
         ${COMPILE.f} -pg ${.IMPSRC} -o ${.TARGET}.tmp          ${COMPILE.f} -pg ${.IMPSRC} -o ${.TARGET}.tmp
 .if defined(FOPTS) && !empty(FOPTS:M*-g*)  .if defined(FOPTS) && !empty(FOPTS:M*-g*)
         ${_MKCMD}\  
         mv ${.TARGET}.tmp ${.TARGET}          mv ${.TARGET}.tmp ${.TARGET}
 .else  .else
         ${_MKCMD}\  
         ${LD} -X -r ${.TARGET}.tmp -o ${.TARGET}          ${LD} -X -r ${.TARGET}.tmp -o ${.TARGET}
         ${_MKCMD}\  
         rm -f ${.TARGET}.tmp          rm -f ${.TARGET}.tmp
 .endif  .endif
   
 .f.so:  .f.so:
         ${_MKMSGCOMPILE}          ${_MKTARGET_COMPILE}
         ${_MKCMD}\  
         ${COMPILE.f} ${FPICFLAGS} ${.IMPSRC} -o ${.TARGET}.tmp          ${COMPILE.f} ${FPICFLAGS} ${.IMPSRC} -o ${.TARGET}.tmp
 .if defined(FOPTS) && !empty(FOPTS:M*-g*)  .if defined(FOPTS) && !empty(FOPTS:M*-g*)
         ${_MKCMD}\  
         mv ${.TARGET}.tmp ${.TARGET}          mv ${.TARGET}.tmp ${.TARGET}
 .else  .else
         ${_MKCMD}\  
         ${LD} -x -r ${.TARGET}.tmp -o ${.TARGET}          ${LD} -x -r ${.TARGET}.tmp -o ${.TARGET}
         ${_MKCMD}\  
         rm -f ${.TARGET}.tmp          rm -f ${.TARGET}.tmp
 .endif  .endif
   
 .f.ln:  .f.ln:
         ${_MKMSGCOMPILE}          ${_MKTARGET_COMPILE}
         @echo Skipping lint for Fortran libraries.          @echo Skipping lint for Fortran libraries.
   
 .m.o:  .m.o:
         ${_MKMSGCOMPILE}          ${_MKTARGET_COMPILE}
         ${_MKCMD}\  
         ${COMPILE.m} ${.IMPSRC} -o ${.TARGET}.tmp          ${COMPILE.m} ${.IMPSRC} -o ${.TARGET}.tmp
 .if defined(OBJCFLAGS) && !empty(OBJCFLAGS:M*-g*)  .if defined(OBJCFLAGS) && !empty(OBJCFLAGS:M*-g*)
         ${_MKCMD}\  
         mv ${.TARGET}.tmp ${.TARGET}          mv ${.TARGET}.tmp ${.TARGET}
 .else  .else
         ${_MKCMD}\  
         ${LD} -x -r ${.TARGET}.tmp -o ${.TARGET}          ${LD} -x -r ${.TARGET}.tmp -o ${.TARGET}
         ${_MKCMD}\  
         rm -f ${.TARGET}.tmp          rm -f ${.TARGET}.tmp
 .endif  .endif
   
 .m.po:  .m.po:
         ${_MKMSGCOMPILE}          ${_MKTARGET_COMPILE}
         ${_MKCMD}\  
         ${COMPILE.m} -pg ${.IMPSRC} -o ${.TARGET}.tmp          ${COMPILE.m} -pg ${.IMPSRC} -o ${.TARGET}.tmp
 .if defined(OBJCFLAGS) && !empty(OBJCFLAGS:M*-g*)  .if defined(OBJCFLAGS) && !empty(OBJCFLAGS:M*-g*)
         ${_MKCMD}\  
         mv ${.TARGET}.tmp ${.TARGET}          mv ${.TARGET}.tmp ${.TARGET}
 .else  .else
         ${_MKCMD}\  
         ${LD} -X -r ${.TARGET}.tmp -o ${.TARGET}          ${LD} -X -r ${.TARGET}.tmp -o ${.TARGET}
         ${_MKCMD}\  
         rm -f ${.TARGET}.tmp          rm -f ${.TARGET}.tmp
 .endif  .endif
   
 .m.so:  .m.so:
         ${_MKMSGCOMPILE}          ${_MKTARGET_COMPILE}
         ${_MKCMD}\  
         ${COMPILE.m} ${CSHLIBFLAGS} ${.IMPSRC} -o ${.TARGET}.tmp          ${COMPILE.m} ${CSHLIBFLAGS} ${.IMPSRC} -o ${.TARGET}.tmp
 .if defined(OBJCFLAGS) && !empty(OBJCFLAGS:M*-g*)  .if defined(OBJCFLAGS) && !empty(OBJCFLAGS:M*-g*)
         ${_MKCMD}\  
         mv ${.TARGET}.tmp ${.TARGET}          mv ${.TARGET}.tmp ${.TARGET}
 .else  .else
         ${_MKCMD}\  
         ${LD} -x -r ${.TARGET}.tmp -o ${.TARGET}          ${LD} -x -r ${.TARGET}.tmp -o ${.TARGET}
         ${_MKCMD}\  
         rm -f ${.TARGET}.tmp          rm -f ${.TARGET}.tmp
 .endif  .endif
   
 .S.o .s.o:  .s.o:
         ${_MKMSGCOMPILE}          ${_MKTARGET_COMPILE}
         ${_MKCMD}\          ${COMPILE.s} ${COPTS.${.IMPSRC:T}} ${CPUFLAGS.${.IMPSRC:T}} ${CPPFLAGS.${.IMPSRC:T}} ${.IMPSRC} -o ${.TARGET}.tmp
         ${COMPILE.S} ${CFLAGS:M-[ID]*} ${AINC} ${.IMPSRC} -o ${.TARGET}.tmp          ${LD} -x -r ${.TARGET}.tmp -o ${.TARGET}
         ${_MKCMD}\          rm -f ${.TARGET}.tmp
   
   .S.o:
           ${_MKTARGET_COMPILE}
           ${COMPILE.S} ${COPTS.${.IMPSRC:T}} ${CPUFLAGS.${.IMPSRC:T}} ${CPPFLAGS.${.IMPSRC:T}} ${.IMPSRC} -o ${.TARGET}.tmp
         ${LD} -x -r ${.TARGET}.tmp -o ${.TARGET}          ${LD} -x -r ${.TARGET}.tmp -o ${.TARGET}
         ${_MKCMD}\  
         rm -f ${.TARGET}.tmp          rm -f ${.TARGET}.tmp
   
 .S.po .s.po:  .s.po:
         ${_MKMSGCOMPILE}          ${_MKTARGET_COMPILE}
         ${_MKCMD}\          ${COMPILE.s} -DGPROF -DPROF ${COPTS.${.IMPSRC:T}} ${CPUFLAGS.${.IMPSRC:T}} ${CPPFLAGS.${.IMPSRC:T}} ${.IMPSRC} -o ${.TARGET}.tmp
         ${COMPILE.S} -DGPROF -DPROF ${CFLAGS:M-[ID]*} ${AINC} ${.IMPSRC} -o ${.TARGET}.tmp          ${LD} -X -r ${.TARGET}.tmp -o ${.TARGET}
         ${_MKCMD}\          rm -f ${.TARGET}.tmp
   
   .S.po:
           ${_MKTARGET_COMPILE}
           ${COMPILE.S} -DGPROF -DPROF ${COPTS.${.IMPSRC:T}} ${CPUFLAGS.${.IMPSRC:T}} ${CPPFLAGS.${.IMPSRC:T}} ${.IMPSRC} -o ${.TARGET}.tmp
         ${LD} -X -r ${.TARGET}.tmp -o ${.TARGET}          ${LD} -X -r ${.TARGET}.tmp -o ${.TARGET}
         ${_MKCMD}\  
         rm -f ${.TARGET}.tmp          rm -f ${.TARGET}.tmp
   
 .S.so .s.so:  .s.so:
         ${_MKMSGCOMPILE}          ${_MKTARGET_COMPILE}
         ${_MKCMD}\          ${COMPILE.s} ${CAPICFLAGS} ${COPTS.${.IMPSRC:T}} ${CPUFLAGS.${.IMPSRC:T}} ${CPPFLAGS.${.IMPSRC:T}} ${.IMPSRC} -o ${.TARGET}.tmp
         ${COMPILE.S} ${CAPICFLAGS} ${CFLAGS:M-[ID]*} ${AINC} ${.IMPSRC} -o ${.TARGET}.tmp  
         ${_MKCMD}\  
         ${LD} -x -r ${.TARGET}.tmp -o ${.TARGET}          ${LD} -x -r ${.TARGET}.tmp -o ${.TARGET}
         ${_MKCMD}\  
         rm -f ${.TARGET}.tmp          rm -f ${.TARGET}.tmp
   
 .if defined(LIB)  .S.so:
           ${_MKTARGET_COMPILE}
           ${COMPILE.S} ${CAPICFLAGS} ${COPTS.${.IMPSRC:T}} ${CPUFLAGS.${.IMPSRC:T}} ${CPPFLAGS.${.IMPSRC:T}} ${.IMPSRC} -o ${.TARGET}.tmp
           ${LD} -x -r ${.TARGET}.tmp -o ${.TARGET}
           rm -f ${.TARGET}.tmp
   
   .if defined(LIB)                                                        # {
 .if (${MKPIC} == "no" || (defined(LDSTATIC) && ${LDSTATIC} != "") \  .if (${MKPIC} == "no" || (defined(LDSTATIC) && ${LDSTATIC} != "") \
         || ${MKLINKLIB} != "no") && ${MKSTATICLIB} != "no"          || ${MKLINKLIB} != "no") && ${MKSTATICLIB} != "no"
 _LIBS=lib${LIB}.a  _LIBS=lib${LIB}.a
Line 384  _LIBS=
Line 352  _LIBS=
   
 OBJS+=${SRCS:N*.h:N*.sh:R:S/$/.o/g}  OBJS+=${SRCS:N*.h:N*.sh:R:S/$/.o/g}
   
   STOBJS+=${OBJS}
   
   .if ${MKPRIVATELIB} != "no"
   # No installation is required
   libinstall::
   .else   # ${MKPRIVATELIB} == "no"                                       # {
   
 .if ${MKPROFILE} != "no"  .if ${MKPROFILE} != "no"
 _LIBS+=lib${LIB}_p.a  _LIBS+=lib${LIB}_p.a
 POBJS+=${OBJS:.o=.po}  POBJS+=${OBJS:.o=.po}
 .endif  .endif
   
 .if ${MKPIC} != "no"  .if ${MKPIC} != "no"                                                    # {
 .if ${MKPICLIB} == "no"  .if ${MKPICLIB} == "no"
 .if ${MKSHLIBOBJS} != "no"  .if ${MKSHLIBOBJS} != "no"
 # make _pic.a, which isn't really pic,  # make _pic.a, which isn't really pic,
Line 408  SOBJS+=${OBJS:.o=.so}
Line 383  SOBJS+=${OBJS:.o=.so}
 .if defined(SHLIB_FULLVERSION)  .if defined(SHLIB_FULLVERSION)
 _LIBS+=lib${LIB}.so.${SHLIB_FULLVERSION}  _LIBS+=lib${LIB}.so.${SHLIB_FULLVERSION}
 .endif  .endif
 .endif  .endif                                                                  # }
   
 LOBJS+=${LSRCS:.c=.ln} ${SRCS:M*.c:.c=.ln}  LOBJS+=${LSRCS:.c=.ln} ${SRCS:M*.c:.c=.ln}
 .if ${MKLINT} != "no" && ${MKLINKLIB} != "no" && !empty(LOBJS)  .if ${MKLINT} != "no" && ${MKLINKLIB} != "no" && !empty(LOBJS)
 _LIBS+=llib-l${LIB}.ln  _LIBS+=llib-l${LIB}.ln
 .endif  .endif
   
   .endif  # ${MKPRIVATELIB} == "no"                                       # }
   
 ALLOBJS=  ALLOBJS=
 .if (${MKPIC} == "no" || (defined(LDSTATIC) && ${LDSTATIC} != "") \  .if (${MKPIC} == "no" || (defined(LDSTATIC) && ${LDSTATIC} != "") \
         || ${MKLINKLIB} != "no") && ${MKSTATICLIB} != "no"          || ${MKLINKLIB} != "no") && ${MKSTATICLIB} != "no"
 ALLOBJS+=${OBJS}  ALLOBJS+=${STOBJS}
 .endif  .endif
 ALLOBJS+=${POBJS} ${SOBJS}  ALLOBJS+=${POBJS} ${SOBJS}
 .if ${MKLINT} != "no" && ${MKLINKLIB} != "no" && !empty(LOBJS)  .if ${MKLINT} != "no" && ${MKLINKLIB} != "no" && !empty(LOBJS)
 ALLOBJS+=${LOBJS}  ALLOBJS+=${LOBJS}
 .endif  .endif
 .else  .else   # !defined(LIB)                                                 # } {
 LOBJS=  LOBJS=
 SOBJS=  SOBJS=
 .endif  .endif  # !defined(LIB)                                                 # }
   
 .NOPATH: ${ALLOBJS} ${_LIBS} ${SRCS:M*.[ly]:C/\..$/.c/} ${YHEADER:D${SRCS:M*.y:.y=.h}}  _YLSRCS=        ${SRCS:M*.[ly]:C/\..$/.c/} ${YHEADER:D${SRCS:M*.y:.y=.h}}
   
   .NOPATH: ${ALLOBJS} ${_LIBS} ${_YLSRCS}
   
 realall: ${SRCS} ${ALLOBJS:O} ${_LIBS}  realall: ${SRCS} ${ALLOBJS:O} ${_LIBS}
   
   .if !target(__archivebuild)
 __archivebuild: .USE  __archivebuild: .USE
         ${_MKMSGBUILD}          ${_MKTARGET_BUILD}
         ${_MKCMD}\  
         rm -f ${.TARGET}          rm -f ${.TARGET}
         ${_MKCMD}\  
         ${AR} cq ${.TARGET} `NM=${NM} ${LORDER} ${.ALLSRC:M*o} | ${TSORT}`          ${AR} cq ${.TARGET} `NM=${NM} ${LORDER} ${.ALLSRC:M*o} | ${TSORT}`
         ${_MKCMD}\  
         ${RANLIB} ${.TARGET}          ${RANLIB} ${.TARGET}
   .endif
   
   .if !target(__archiveinstall)
 __archiveinstall: .USE  __archiveinstall: .USE
         ${_MKMSGINSTALL}          ${_MKTARGET_INSTALL}
         ${_MKCMD}\  
         ${INSTALL_FILE} -o ${LIBOWN} -g ${LIBGRP} -m ${LIBMODE} \          ${INSTALL_FILE} -o ${LIBOWN} -g ${LIBGRP} -m ${LIBMODE} \
             ${UPDATE:D:U-a "${RANLIB} -t"} ${SYSPKGTAG} ${.ALLSRC} ${.TARGET}              ${UPDATE:D:U-a "${RANLIB} -t"} ${SYSPKGTAG} ${.ALLSRC} ${.TARGET}
   .endif
   
 __archivesymlinkpic: .USE  __archivesymlinkpic: .USE
         ${_MKMSGINSTALL}          ${_MKTARGET_INSTALL}
         ${_MKCMD}\  
         ${INSTALL_SYMLINK} ${SYSPKGTAG} ${.ALLSRC} ${.TARGET}          ${INSTALL_SYMLINK} ${SYSPKGTAG} ${.ALLSRC} ${.TARGET}
   
 DPSRCS+=        ${SRCS:M*.l:.l=.c} ${SRCS:M*.y:.y=.c}  DPSRCS+=        ${_YLSRCS}
 CLEANFILES+=    ${SRCS:M*.l:.l=.c} ${SRCS:M*.y:.y=.c}  CLEANFILES+=    ${_YLSRCS}
 CLEANFILES+=    ${YHEADER:D${SRCS:M*.y:.y=.h}}  
   
 ${OBJS} ${POBJS} ${SOBJS} ${LOBJS}: ${DPSRCS}  ${STOBJS} ${POBJS} ${SOBJS} ${LOBJS}: ${DPSRCS}
   
 lib${LIB}.a:: ${OBJS} __archivebuild  lib${LIB}.a:: ${STOBJS} __archivebuild
   
 lib${LIB}_p.a:: ${POBJS} __archivebuild  lib${LIB}_p.a:: ${POBJS} __archivebuild
   
Line 478  _LIBLDOPTS+= -Wl,-rpath-link,${DESTDIR}$
Line 455  _LIBLDOPTS+= -Wl,-rpath-link,${DESTDIR}$
   
 lib${LIB}.so.${SHLIB_FULLVERSION}: ${SOLIB} ${DPADD} \  lib${LIB}.so.${SHLIB_FULLVERSION}: ${SOLIB} ${DPADD} \
     ${SHLIB_LDSTARTFILE} ${SHLIB_LDENDFILE}      ${SHLIB_LDSTARTFILE} ${SHLIB_LDENDFILE}
         ${_MKMSGBUILD}          ${_MKTARGET_BUILD}
         ${_MKCMD}\  
         rm -f lib${LIB}.so.${SHLIB_FULLVERSION}          rm -f lib${LIB}.so.${SHLIB_FULLVERSION}
 .if defined(DESTDIR)  .if defined(DESTDIR)
         ${_MKCMD}\  
         ${CC} -Wl,-nostdlib -B${_GCC_CRTDIR}/ -B${DESTDIR}/usr/lib/ \          ${CC} -Wl,-nostdlib -B${_GCC_CRTDIR}/ -B${DESTDIR}/usr/lib/ \
             ${_LIBLDOPTS} \              ${_LIBLDOPTS} \
             -Wl,-x -shared ${SHLIB_SHFLAGS} ${LDFLAGS} -o ${.TARGET} \              -Wl,-x -shared ${SHLIB_SHFLAGS} ${LDFLAGS} -o ${.TARGET} \
Line 490  lib${LIB}.so.${SHLIB_FULLVERSION}: ${SOL
Line 465  lib${LIB}.so.${SHLIB_FULLVERSION}: ${SOL
             -Wl,--no-whole-archive ${LDADD} \              -Wl,--no-whole-archive ${LDADD} \
             -L${_GCC_LIBGCCDIR}              -L${_GCC_LIBGCCDIR}
 .else  .else
         ${_MKCMD}\  
         ${CC} -Wl,-x -shared ${SHLIB_SHFLAGS} ${LDFLAGS} -o ${.TARGET} \          ${CC} -Wl,-x -shared ${SHLIB_SHFLAGS} ${LDFLAGS} -o ${.TARGET} \
             ${_LIBLDOPTS} \              ${_LIBLDOPTS} \
             -Wl,--whole-archive ${SOLIB} -Wl,--no-whole-archive ${LDADD}              -Wl,--whole-archive ${SOLIB} -Wl,--no-whole-archive ${LDADD}
Line 499  lib${LIB}.so.${SHLIB_FULLVERSION}: ${SOL
Line 473  lib${LIB}.so.${SHLIB_FULLVERSION}: ${SOL
 #  We don't use INSTALL_SYMLINK here because this is just  #  We don't use INSTALL_SYMLINK here because this is just
 #  happening inside the build directory/objdir. XXX Why does  #  happening inside the build directory/objdir. XXX Why does
 #  this spend so much effort on libraries that aren't live??? XXX  #  this spend so much effort on libraries that aren't live??? XXX
         ${_MKCMD}\          ${HOST_LN} -sf lib${LIB}.so.${SHLIB_FULLVERSION} lib${LIB}.so.${SHLIB_MAJOR}.tmp
         ln -sf lib${LIB}.so.${SHLIB_FULLVERSION} lib${LIB}.so.${SHLIB_MAJOR}.tmp  
         ${_MKCMD}\  
         mv -f lib${LIB}.so.${SHLIB_MAJOR}.tmp lib${LIB}.so.${SHLIB_MAJOR}          mv -f lib${LIB}.so.${SHLIB_MAJOR}.tmp lib${LIB}.so.${SHLIB_MAJOR}
         ${_MKCMD}\          ${HOST_LN} -sf lib${LIB}.so.${SHLIB_FULLVERSION} lib${LIB}.so.tmp
         ln -sf lib${LIB}.so.${SHLIB_FULLVERSION} lib${LIB}.so.tmp  
         ${_MKCMD}\  
         mv -f lib${LIB}.so.tmp lib${LIB}.so          mv -f lib${LIB}.so.tmp lib${LIB}.so
 .endif  .endif
   
 .if !empty(LOBJS)  .if !empty(LOBJS)                                                       # {
 LLIBS?=         -lc  LLIBS?=         -lc
 llib-l${LIB}.ln: ${LOBJS}  llib-l${LIB}.ln: ${LOBJS}
         ${_MKMSGCOMPILE}          ${_MKTARGET_COMPILE}
         ${_MKCMD}\  
         rm -f llib-l${LIB}.ln          rm -f llib-l${LIB}.ln
 .if defined(DESTDIR)  .if defined(DESTDIR)
         ${_MKCMD}\  
         ${LINT} -C${LIB} ${.ALLSRC} -L${DESTDIR}/usr/libdata ${LLIBS}          ${LINT} -C${LIB} ${.ALLSRC} -L${DESTDIR}/usr/libdata ${LLIBS}
 .else  .else
         ${_MKCMD}\  
         ${LINT} -C${LIB} ${.ALLSRC} ${LLIBS}          ${LINT} -C${LIB} ${.ALLSRC} ${LLIBS}
 .endif  .endif
 .endif  .endif                                                                  # }
   
 cleanlib:  cleanlib: .PHONY
         ${_MKCMD}\  
         rm -f a.out [Ee]rrs mklog core *.core ${CLEANFILES}          rm -f a.out [Ee]rrs mklog core *.core ${CLEANFILES}
         ${_MKCMD}\          rm -f lib${LIB}.a ${STOBJS}
         rm -f lib${LIB}.a ${OBJS}  
         ${_MKCMD}\  
         rm -f lib${LIB}_p.a ${POBJS}          rm -f lib${LIB}_p.a ${POBJS}
         ${_MKCMD}\  
         rm -f lib${LIB}_pic.a lib${LIB}.so.* lib${LIB}.so ${SOBJS}          rm -f lib${LIB}_pic.a lib${LIB}.so.* lib${LIB}.so ${SOBJS}
         ${_MKCMD}\          rm -f ${STOBJS:=.tmp} ${POBJS:=.tmp} ${SOBJS:=.tmp}
         rm -f ${OBJS:=.tmp} ${POBJS:=.tmp} ${SOBJS:=.tmp}  
         ${_MKCMD}\  
         rm -f llib-l${LIB}.ln ${LOBJS}          rm -f llib-l${LIB}.ln ${LOBJS}
   
 .if defined(SRCS)  
 afterdepend: .depend  
         @(TMP=/tmp/_depend$$$$; trap 'rm -f $$TMP ; exit 1' 1 2 3 13 15; \  
             sed -e 's/^\([^\.]*\).o[ ]*:/\1.o \1.po \1.so \1.ln:/' \  
               < .depend > $$TMP && \  
             mv $$TMP .depend)  
 .endif  
   
 .if !target(libinstall)  .if !target(libinstall)                                                 # {
 # Make sure it gets defined, in case MKPIC==no && MKLINKLIB==no  # Make sure it gets defined, in case MKPIC==no && MKLINKLIB==no
 libinstall::  libinstall::
   
Line 624  ${DESTDIR}${_LIBSODIR}/lib${LIB}.so.${SH
Line 578  ${DESTDIR}${_LIBSODIR}/lib${LIB}.so.${SH
 .endif  .endif
 ${DESTDIR}${_LIBSODIR}/lib${LIB}.so.${SHLIB_FULLVERSION}: lib${LIB}.so.${SHLIB_FULLVERSION}  ${DESTDIR}${_LIBSODIR}/lib${LIB}.so.${SHLIB_FULLVERSION}: lib${LIB}.so.${SHLIB_FULLVERSION}
 .endif  .endif
         ${_MKMSGINSTALL}          ${_MKTARGET_INSTALL}
         ${_MKCMD}\  
         ${INSTALL_FILE} -o ${LIBOWN} -g ${LIBGRP} -m ${LIBMODE} \          ${INSTALL_FILE} -o ${LIBOWN} -g ${LIBGRP} -m ${LIBMODE} \
                 ${SYSPKGTAG} ${.ALLSRC} ${.TARGET}                  ${SYSPKGTAG} ${.ALLSRC} ${.TARGET}
 .if ${_LIBSODIR} != ${LIBDIR}  .if ${_LIBSODIR} != ${LIBDIR}
         ${_MKCMD}\  
         ${INSTALL_SYMLINK} ${SYSPKGTAG} \          ${INSTALL_SYMLINK} ${SYSPKGTAG} \
                 ${_LIBSODIR}/lib${LIB}.so.${SHLIB_FULLVERSION} \                  ${_LIBSODIR}/lib${LIB}.so.${SHLIB_FULLVERSION} \
                 ${DESTDIR}${LIBDIR}/lib${LIB}.so.${SHLIB_FULLVERSION}                  ${DESTDIR}${LIBDIR}/lib${LIB}.so.${SHLIB_FULLVERSION}
 .endif  .endif
 .if ${OBJECT_FMT} == "a.out" && !defined(DESTDIR)  .if ${OBJECT_FMT} == "a.out" && !defined(DESTDIR)
         ${_MKCMD}\  
         /sbin/ldconfig -m ${_LIBSODIR} ${LIBDIR}          /sbin/ldconfig -m ${_LIBSODIR} ${LIBDIR}
 .endif  .endif
 .if ${OBJECT_FMT} == "ELF"  .if ${OBJECT_FMT} == "ELF"
         ${_MKCMD}\  
         ${INSTALL_SYMLINK} ${SYSPKGTAG} \          ${INSTALL_SYMLINK} ${SYSPKGTAG} \
                 lib${LIB}.so.${SHLIB_FULLVERSION} \                  lib${LIB}.so.${SHLIB_FULLVERSION} \
                 ${DESTDIR}${_LIBSODIR}/lib${LIB}.so.${SHLIB_MAJOR}                  ${DESTDIR}${_LIBSODIR}/lib${LIB}.so.${SHLIB_MAJOR}
 .if ${_LIBSODIR} != ${LIBDIR}  .if ${_LIBSODIR} != ${LIBDIR}
         ${_MKCMD}\  
         ${INSTALL_SYMLINK} ${SYSPKGTAG} \          ${INSTALL_SYMLINK} ${SYSPKGTAG} \
                 ${_LIBSODIR}/lib${LIB}.so.${SHLIB_FULLVERSION} \                  ${_LIBSODIR}/lib${LIB}.so.${SHLIB_FULLVERSION} \
                 ${DESTDIR}${LIBDIR}/lib${LIB}.so.${SHLIB_MAJOR}                  ${DESTDIR}${LIBDIR}/lib${LIB}.so.${SHLIB_MAJOR}
 .endif  .endif
 .if ${MKLINKLIB} != "no"  .if ${MKLINKLIB} != "no"
         ${_MKCMD}\  
         ${INSTALL_SYMLINK} ${SYSPKGTAG} \          ${INSTALL_SYMLINK} ${SYSPKGTAG} \
                 lib${LIB}.so.${SHLIB_FULLVERSION} \                  lib${LIB}.so.${SHLIB_FULLVERSION} \
                 ${DESTDIR}${_LIBSODIR}/lib${LIB}.so                  ${DESTDIR}${_LIBSODIR}/lib${LIB}.so
 .if ${_LIBSODIR} != ${LIBDIR}  .if ${_LIBSODIR} != ${LIBDIR}
         ${_MKCMD}\  
         ${INSTALL_SYMLINK} ${SYSPKGTAG} \          ${INSTALL_SYMLINK} ${SYSPKGTAG} \
                 ${_LIBSODIR}/lib${LIB}.so.${SHLIB_FULLVERSION} \                  ${_LIBSODIR}/lib${LIB}.so.${SHLIB_FULLVERSION} \
                 ${DESTDIR}${LIBDIR}/lib${LIB}.so                  ${DESTDIR}${LIBDIR}/lib${LIB}.so
Line 679  ${DESTDIR}${LINTLIBDIR}/llib-l${LIB}.ln:
Line 626  ${DESTDIR}${LINTLIBDIR}/llib-l${LIB}.ln:
 .endif  .endif
 ${DESTDIR}${LINTLIBDIR}/llib-l${LIB}.ln: llib-l${LIB}.ln  ${DESTDIR}${LINTLIBDIR}/llib-l${LIB}.ln: llib-l${LIB}.ln
 .endif  .endif
         ${_MKMSGINSTALL}          ${_MKTARGET_INSTALL}
         ${_MKCMD}\  
         ${INSTALL_FILE} -o ${LIBOWN} -g ${LIBGRP} -m ${LIBMODE} \          ${INSTALL_FILE} -o ${LIBOWN} -g ${LIBGRP} -m ${LIBMODE} \
                 ${SYSPKGTAG} ${.ALLSRC} ${DESTDIR}${LINTLIBDIR}                  ${SYSPKGTAG} ${.ALLSRC} ${DESTDIR}${LINTLIBDIR}
 .endif  .endif
 .endif  .endif  # !target(libinstall)                                           # }
   
 ##### Pull in related .mk logic  ##### Pull in related .mk logic
 .include <bsd.man.mk>  .include <bsd.man.mk>

Legend:
Removed from v.1.237  
changed lines
  Added in v.1.257

CVSweb <webmaster@jp.NetBSD.org>