2008-02-07 22:36:13 +01:00
|
|
|
# $NetBSD: bsd.pkg.debug.mk,v 1.21 2008/02/07 21:36:13 rillig Exp $
|
2006-07-20 19:10:45 +02:00
|
|
|
#
|
2007-02-05 15:27:34 +01:00
|
|
|
# Public targets:
|
|
|
|
#
|
|
|
|
# debug:
|
|
|
|
# outputs the values of some commonly used variables and the
|
|
|
|
# contents of some files which are useful for tracking bugs,
|
|
|
|
# especially for packages that use the GNU autotools.
|
|
|
|
#
|
2006-07-20 19:10:45 +02:00
|
|
|
|
|
|
|
PRINTF?= printf
|
|
|
|
|
2007-02-19 13:19:49 +01:00
|
|
|
# Note: In the many cases where ${x} is used, the quoting is left out
|
|
|
|
# intentionally, since x is an element of a list of shell words, and
|
|
|
|
# passing such a shell word to the shell should still result in one
|
|
|
|
# word. That way, no extra level of quoting is introduced.
|
|
|
|
#
|
|
|
|
# The only exception is the "<" character in CONFIGURE_ARGS, where it
|
|
|
|
# is often used to redirect the input coming from another source. That
|
|
|
|
# character has to be quoted.
|
|
|
|
|
2006-07-20 19:10:45 +02:00
|
|
|
.PHONY: \
|
|
|
|
debug \
|
|
|
|
_show-dbginfo-file-versions \
|
|
|
|
_show-dbginfo-tools \
|
|
|
|
_show-dbginfo-configure \
|
|
|
|
_show-dbginfo-config.status \
|
|
|
|
_show-dbginfo-config.h \
|
|
|
|
_show-dbginfo-build \
|
|
|
|
_show-dbginfo-install \
|
|
|
|
_show-dbginfo-plist-subst
|
|
|
|
|
|
|
|
debug: \
|
|
|
|
_show-dbginfo-file-versions \
|
|
|
|
_show-dbginfo-tools \
|
|
|
|
_show-dbginfo-configure \
|
|
|
|
_show-dbginfo-config.status \
|
|
|
|
_show-dbginfo-config.h \
|
|
|
|
_show-dbginfo-build \
|
|
|
|
_show-dbginfo-install \
|
|
|
|
_show-dbginfo-plist-subst
|
|
|
|
|
|
|
|
_show-dbginfo-file-versions:
|
|
|
|
@${PRINTF} "File versions:\\n"
|
2008-02-07 22:36:13 +01:00
|
|
|
${RUN} \
|
2007-06-19 15:11:01 +02:00
|
|
|
sedexpr='s,^.*\([$$]NetBSD:[^$$]*\$$\).*,\1,p'; \
|
2006-07-20 19:10:45 +02:00
|
|
|
${FIND} * -type f -print \
|
|
|
|
| while read fname; do \
|
2007-02-19 13:19:49 +01:00
|
|
|
ident=`${SED} -n \
|
2007-06-19 15:11:01 +02:00
|
|
|
-e 's,^.*\\([$$]NetBSD:[^$$]*\\$$\\).*,\\1,p' \
|
|
|
|
-e 's,^.*\\([$$]Id:[^$$]*\\$$\\).*,\\1,p' \
|
2007-09-27 14:49:14 +02:00
|
|
|
"$${fname}" | ${SED} 1q` || continue; \
|
2006-07-20 19:10:45 +02:00
|
|
|
case $${ident} in \
|
|
|
|
*?*) ${PRINTF} "\\t%s: %s\\n" "$${fname}" "$${ident}";; \
|
|
|
|
esac; \
|
|
|
|
done
|
2007-01-08 03:38:42 +01:00
|
|
|
@${PRINTF} "\\n"
|
2006-07-20 19:10:45 +02:00
|
|
|
|
|
|
|
_show-dbginfo-tools:
|
|
|
|
@${PRINTF} "TOOLS:\\n"
|
2006-11-05 17:24:43 +01:00
|
|
|
@${USE_TOOLS:C/:.*//:O:u:@t@${_TOOLS_VARNAME.${t}:D${PRINTF} "\\t%s=%s\\n" ${_TOOLS_VARNAME.${t}} ${${_TOOLS_VARNAME.${t}}:Q};}@}
|
2007-01-08 03:38:42 +01:00
|
|
|
@${PRINTF} "\\n"
|
2006-07-20 19:10:45 +02:00
|
|
|
|
|
|
|
_show-dbginfo-configure:
|
2006-10-26 22:41:56 +02:00
|
|
|
@${PRINTF} "CONFIGURE_DIRS:\\n"; ${CONFIGURE_DIRS:@x@${PRINTF} "\\t%s\\n" ${x};@}
|
2007-01-08 03:38:42 +01:00
|
|
|
@${PRINTF} "\\n"
|
2006-10-26 22:41:56 +02:00
|
|
|
@${PRINTF} "CONFIGURE_ENV (sorted alphabetically):\\n"; ${CONFIGURE_ENV:O:@x@${PRINTF} "\\t%s\\n" ${x};@}
|
2007-01-08 03:38:42 +01:00
|
|
|
@${PRINTF} "\\n"
|
2006-10-26 22:41:56 +02:00
|
|
|
@${PRINTF} "CONFIGURE_SCRIPT:\\n\\t%s\\n" ${CONFIGURE_SCRIPT}
|
2007-01-08 03:38:42 +01:00
|
|
|
@${PRINTF} "\\n"
|
2007-02-19 13:19:49 +01:00
|
|
|
@${PRINTF} "CONFIGURE_ARGS:\\n"; ${CONFIGURE_ARGS:@x@${PRINTF} "\\t%s\\n" ${x:S,<,\<,};@}
|
2007-01-08 03:38:42 +01:00
|
|
|
@${PRINTF} "\\n"
|
2006-07-20 19:10:45 +02:00
|
|
|
|
|
|
|
_show-dbginfo-config.status:
|
|
|
|
.if !empty(CONFIGURE_DIRS:M*)
|
2008-02-07 22:36:13 +01:00
|
|
|
${RUN} \
|
2006-07-20 19:10:45 +02:00
|
|
|
if ${TEST} -d ${WRKSRC:Q}; then cd ${WRKSRC:Q}; \
|
|
|
|
for cs in ${CONFIGURE_DIRS:=/config.status}; do \
|
|
|
|
if ${TEST} ! -f "$${cs}"; then continue; fi; \
|
|
|
|
${PRINTF} "%s:\\n" "$${cs}"; \
|
2006-12-23 15:18:44 +01:00
|
|
|
${SED} -n -e 's,|#_!!_#|,,g' \
|
|
|
|
-e '/s,^\\(\[ #\]\*\\)/d' \
|
|
|
|
-e 's:^s,@\([^@]*\)@,\(.*\),;t t$$: \1=\2:p' \
|
|
|
|
-e 's:^s&@\([^@]*\)@&\(.*\)&;t t$$: \1=\2:p' \
|
|
|
|
-e 's:^s,@\([^@]*\)@,\(.*\),g$$: \1=\2:p' \
|
|
|
|
-e 's:^s%@\([^@]*\)@%\(.*\)%g$$: \1=\2:p' \
|
|
|
|
-e 's:^s&@\([^@]*\)@&\(.*\)&g$$: \1=\2:p' \
|
|
|
|
-e 's:^\(s[^[:alnum:]].*\): &:p' \
|
|
|
|
-e '/:\[FHLC\]/q' \
|
|
|
|
"$${cs}" \
|
2006-07-20 19:10:45 +02:00
|
|
|
| ${SORT}; \
|
2007-01-08 03:38:42 +01:00
|
|
|
${PRINTF} "\\n"; \
|
2006-07-20 19:10:45 +02:00
|
|
|
done; fi
|
|
|
|
.else
|
|
|
|
@${DO_NADA}
|
|
|
|
.endif
|
|
|
|
|
|
|
|
_show-dbginfo-config.h:
|
|
|
|
.if !empty(CONFIGURE_DIRS:M*)
|
2008-02-07 22:36:13 +01:00
|
|
|
${RUN} \
|
2007-01-08 12:06:44 +01:00
|
|
|
[ -d ${WRKSRC} ] || exit 0; \
|
|
|
|
print_config_h() { \
|
|
|
|
printf "%s:\\n" "`pwd`/$$1"; \
|
|
|
|
awk '/^#define / { print "\t"$$0; } /^\/\* #undef / { print "\t" $$2 " " $$3; }' < "$$1"; \
|
|
|
|
printf "\\n"; \
|
|
|
|
}; \
|
2006-07-20 19:10:45 +02:00
|
|
|
for cdir in ${CONFIGURE_DIRS}; do \
|
2007-01-08 12:06:44 +01:00
|
|
|
cd ${WRKSRC}; [ -d "$$cdir" ] || continue; cd "$$cdir"; \
|
|
|
|
[ ! -f config.h ] || { print_config_h config.h; continue; }; \
|
|
|
|
[ ! -f config.status ] || { \
|
|
|
|
: "autoconf 2.59"; \
|
2007-02-08 00:10:23 +01:00
|
|
|
chs=`sed -n 's,^config_headers="\([^:]*\).*".*,\1,p' config.status || true`; \
|
2007-01-08 12:06:44 +01:00
|
|
|
: "autoconf 2.13"; \
|
|
|
|
[ "$$chs" ] || chs=`sed -n 's,^ CONFIG_HEADERS="\([^:"]*\).*,\1,p' config.status || true`; \
|
|
|
|
done=no; \
|
|
|
|
for ch in $$chs; do print_config_h "$$ch"; done=yes; done; \
|
|
|
|
[ $$done = no ] || continue; \
|
|
|
|
}; \
|
|
|
|
printf "WARNING: No config header found in `pwd`.\\n\\n"; \
|
|
|
|
done
|
2006-07-20 19:10:45 +02:00
|
|
|
.else
|
|
|
|
@${DO_NADA}
|
|
|
|
.endif
|
|
|
|
|
|
|
|
_show-dbginfo-build:
|
2006-10-26 22:41:56 +02:00
|
|
|
@${PRINTF} "PKGSRC_MAKE_ENV (sorted alphabetically):\\n"; ${PKGSRC_MAKE_ENV:O:@x@${PRINTF} "\\t%s\\n" ${x};@}
|
2007-01-08 03:38:42 +01:00
|
|
|
@${PRINTF} "\\n"
|
2006-10-26 22:41:56 +02:00
|
|
|
@${PRINTF} "BUILD_DIRS:\\n"; ${BUILD_DIRS:@x@${PRINTF} "\\t%s\\n" ${x};@}
|
2007-01-08 03:38:42 +01:00
|
|
|
@${PRINTF} "\\n"
|
2006-10-26 22:41:56 +02:00
|
|
|
@${PRINTF} "MAKE_ENV (sorted alphabetically):\\n"; ${MAKE_ENV:O:@x@${PRINTF} "\\t%s\\n" ${x};@}
|
2007-01-08 03:38:42 +01:00
|
|
|
@${PRINTF} "\\n"
|
2006-07-20 19:10:45 +02:00
|
|
|
@${PRINTF} "MAKE_PROGRAM:\\n\\t%s\\n" ${MAKE_PROGRAM:Q}
|
2007-01-08 03:38:42 +01:00
|
|
|
@${PRINTF} "\\n"
|
2006-10-26 22:41:56 +02:00
|
|
|
@${PRINTF} "MAKE_FLAGS:\\n"; ${MAKE_FLAGS:@x@${PRINTF} "\\t%s\\n" ${x};@}
|
2007-01-08 03:38:42 +01:00
|
|
|
@${PRINTF} "\\n"
|
2006-10-26 22:41:56 +02:00
|
|
|
@${PRINTF} "BUILD_MAKE_FLAGS:\\n"; ${BUILD_MAKE_FLAGS:@x@${PRINTF} "\\t%s\\n" ${x};@}
|
2007-01-08 03:38:42 +01:00
|
|
|
@${PRINTF} "\\n"
|
2006-07-20 19:10:45 +02:00
|
|
|
|
|
|
|
_show-dbginfo-install:
|
2006-10-26 22:41:56 +02:00
|
|
|
@${PRINTF} "INSTALL_DIRS:\\n"; ${INSTALL_DIRS:@x@${PRINTF} "\\t%s\\n" ${x};@}
|
2007-01-08 03:38:42 +01:00
|
|
|
@${PRINTF} "\\n"
|
2006-10-26 22:41:56 +02:00
|
|
|
@${PRINTF} "INSTALL_MAKE_FLAGS:\\n"; ${INSTALL_MAKE_FLAGS:@x@${PRINTF} "\\t%s\\n" ${x};@}
|
2007-01-08 03:38:42 +01:00
|
|
|
@${PRINTF} "\\n"
|
2006-07-20 19:10:45 +02:00
|
|
|
|
|
|
|
_show-dbginfo-plist-subst:
|
2006-10-26 22:41:56 +02:00
|
|
|
@${PRINTF} "PLIST_SUBST (sorted alphabetically):\\n"; ${PLIST_SUBST:O:@x@${PRINTF} "\\t%s\\n" ${x};@}
|
2007-01-08 03:38:42 +01:00
|
|
|
@${PRINTF} "\\n"
|