aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorNatanael Copa <ncopa@alpinelinux.org>2014-08-19 13:03:53 +0000
committerNatanael Copa <ncopa@alpinelinux.org>2014-08-20 08:02:58 +0000
commitb07dc2349d3e60bef40a9974f8b20e8158d989e8 (patch)
tree6ec2d24acc3a3764c77002d0e9629f2d26b2bc32
parentc899e9941b773827ef155a4b42c6b9a950841f80 (diff)
downloadaports-b07dc2349d3e60bef40a9974f8b20e8158d989e8.tar.bz2
aports-b07dc2349d3e60bef40a9974f8b20e8158d989e8.tar.xz
main/kbd: fix build with musl and upgrade to 2.0.2
ref #2977
-rw-r--r--main/kbd/0001-Replace-u_short-with-unsigned-short.patch92
-rw-r--r--main/kbd/0002-Fix-required-header-includes.patch42
-rw-r--r--main/kbd/0003-Only-inluclude-kernel-headers-with-glibc.patch28
-rw-r--r--main/kbd/APKBUILD39
-rw-r--r--main/kbd/error.h20
-rw-r--r--main/kbd/kbd.patch246
6 files changed, 210 insertions, 257 deletions
diff --git a/main/kbd/0001-Replace-u_short-with-unsigned-short.patch b/main/kbd/0001-Replace-u_short-with-unsigned-short.patch
new file mode 100644
index 0000000000..cefcbe8e15
--- /dev/null
+++ b/main/kbd/0001-Replace-u_short-with-unsigned-short.patch
@@ -0,0 +1,92 @@
+From 4c61d59e9c85e26cee306ed1b964030c1e862e00 Mon Sep 17 00:00:00 2001
+From: Natanael Copa <ncopa@alpinelinux.org>
+Date: Wed, 20 Aug 2014 08:44:41 +0200
+Subject: [PATCH 1/4] Replace u_short with unsigned short
+
+u_short is non-standard and causes build failure with musl libc.
+
+Signed-off-by: Natanael Copa <ncopa@alpinelinux.org>
+---
+ src/libkeymap/dump.c | 6 +++---
+ src/libkeymap/kmap.c | 6 +++---
+ src/libkeymap/summary.c | 2 +-
+ 3 files changed, 7 insertions(+), 7 deletions(-)
+
+diff --git a/src/libkeymap/dump.c b/src/libkeymap/dump.c
+index 0262e24..e0c502e 100644
+--- a/src/libkeymap/dump.c
++++ b/src/libkeymap/dump.c
+@@ -69,7 +69,7 @@ lk_dump_bkeymap(struct lk_ctx *ctx, FILE *fd)
+ continue;
+
+ for (j = 0; j < NR_KEYS / 2; j++) {
+- u_short v;
++ unsigned short v;
+ v = lk_get_key(ctx, i, j);
+
+ if (fwrite(&v, sizeof(v), 1, fd) != 1)
+@@ -130,7 +130,7 @@ lk_dump_ctable(struct lk_ctx *ctx, FILE *fd)
+ if (lk_map_exists(ctx, i)) {
+ if (i)
+ fprintf(fd, "static ");
+- fprintf(fd, "u_short %s_map[NR_KEYS] = {", mk_mapname(i));
++ fprintf(fd, "unsigned short %s_map[NR_KEYS] = {", mk_mapname(i));
+ for (j = 0; j < NR_KEYS; j++) {
+ if (!(j % 8))
+ fprintf(fd, "\n");
+@@ -489,7 +489,7 @@ no_shorthands:
+
+ isasexpected = 0;
+ if (isletter) {
+- u_short defs[16];
++ unsigned short defs[16];
+ defs[0] = K(KT_LETTER, val);
+ defs[1] = K(KT_LETTER, val ^ 32);
+ defs[2] = defs[0];
+diff --git a/src/libkeymap/kmap.c b/src/libkeymap/kmap.c
+index 67be81e..8b90654 100644
+--- a/src/libkeymap/kmap.c
++++ b/src/libkeymap/kmap.c
+@@ -173,7 +173,7 @@ lk_add_key(struct lk_ctx *ctx, unsigned int k_table, unsigned int k_index, int k
+ }
+
+ static int
+-do_constant_key(struct lk_ctx *ctx, int i, u_short key)
++do_constant_key(struct lk_ctx *ctx, int i, unsigned short key)
+ {
+ int typ, val;
+ unsigned int j;
+@@ -183,7 +183,7 @@ do_constant_key(struct lk_ctx *ctx, int i, u_short key)
+
+ if ((typ == KT_LATIN || typ == KT_LETTER) &&
+ ((val >= 'a' && val <= 'z') || (val >= 'A' && val <= 'Z'))) {
+- u_short defs[16];
++ unsigned short defs[16];
+ defs[0] = K(KT_LETTER, val);
+ defs[1] = K(KT_LETTER, val ^ 32);
+ defs[2] = defs[0];
+@@ -235,7 +235,7 @@ lk_add_constants(struct lk_ctx *ctx)
+
+ for (i = 0; i < ctx->key_constant->total; i++) {
+ char *constant;
+- u_short key;
++ unsigned short key;
+
+ constant = lk_array_get(ctx->key_constant, i);
+ if (!constant || !(*constant))
+diff --git a/src/libkeymap/summary.c b/src/libkeymap/summary.c
+index 46df90d..44d4e5f 100644
+--- a/src/libkeymap/summary.c
++++ b/src/libkeymap/summary.c
+@@ -30,7 +30,7 @@ valid_type(int fd, int t)
+ return (ioctl(fd, KDSKBENT, (unsigned long) &ke) == 0);
+ }
+
+-static u_char
++static unsigned char
+ maximum_val(int fd, int t)
+ {
+ struct kbentry ke, ke0;
+--
+2.1.0
+
diff --git a/main/kbd/0002-Fix-required-header-includes.patch b/main/kbd/0002-Fix-required-header-includes.patch
new file mode 100644
index 0000000000..dff221ecef
--- /dev/null
+++ b/main/kbd/0002-Fix-required-header-includes.patch
@@ -0,0 +1,42 @@
+From b856e52cd6e76a105aad8ddfcd2b123203b687c1 Mon Sep 17 00:00:00 2001
+From: Natanael Copa <ncopa@alpinelinux.org>
+Date: Wed, 20 Aug 2014 08:47:50 +0200
+Subject: [PATCH 2/4] Fix required header includes
+
+We need fcntl.h for open(2) and limits.h for NAME_MAX for compiling
+with musl libc.
+
+Signed-off-by: Natanael Copa <ncopa@alpinelinux.org>
+---
+ src/kbdrate.c | 1 +
+ src/openvt.c | 2 ++
+ 2 files changed, 3 insertions(+)
+
+diff --git a/src/kbdrate.c b/src/kbdrate.c
+index 2ab8388..aa66622 100644
+--- a/src/kbdrate.c
++++ b/src/kbdrate.c
+@@ -72,6 +72,7 @@ beats rebuilding the kernel!
+ #include <unistd.h>
+ #include <stdlib.h>
+ #include <errno.h>
++#include <fcntl.h>
+ #include <sys/file.h>
+ #include <sys/ioctl.h>
+ #include <linux/kd.h>
+diff --git a/src/openvt.c b/src/openvt.c
+index 075136f..70d37d8 100644
+--- a/src/openvt.c
++++ b/src/openvt.c
+@@ -5,6 +5,8 @@
+ #include <dirent.h>
+ #include <pwd.h>
+ #include <errno.h>
++#include <fcntl.h>
++#include <limits.h>
+ #include <sys/ioctl.h>
+ #include <sys/stat.h>
+ #include <sys/vt.h>
+--
+2.1.0
+
diff --git a/main/kbd/0003-Only-inluclude-kernel-headers-with-glibc.patch b/main/kbd/0003-Only-inluclude-kernel-headers-with-glibc.patch
new file mode 100644
index 0000000000..1b01f3608e
--- /dev/null
+++ b/main/kbd/0003-Only-inluclude-kernel-headers-with-glibc.patch
@@ -0,0 +1,28 @@
+From 3c5c7acc7ef874b919b26583d3892e21b907833f Mon Sep 17 00:00:00 2001
+From: Natanael Copa <ncopa@alpinelinux.org>
+Date: Wed, 20 Aug 2014 09:00:03 +0200
+Subject: [PATCH 3/4] Only inluclude kernel headers with glibc
+
+This fixes compile errors with musl libc
+
+Signed-off-by: Natanael Copa <ncopa@alpinelinux.org>
+---
+ src/resizecons.c | 2 +-
+ 1 file changed, 1 insertion(+), 1 deletion(-)
+
+diff --git a/src/resizecons.c b/src/resizecons.c
+index 5f84845..691dfcc 100644
+--- a/src/resizecons.c
++++ b/src/resizecons.c
+@@ -80,7 +80,7 @@
+ #include <sys/ioctl.h>
+ #if (__GNU_LIBRARY__ >= 6)
+ #include <sys/perm.h>
+-#else
++#elif defined(__GLIBC__)
+ #include <linux/types.h>
+ #include <linux/termios.h>
+ #endif
+--
+2.1.0
+
diff --git a/main/kbd/APKBUILD b/main/kbd/APKBUILD
index 2e88b4e111..e42cf218f0 100644
--- a/main/kbd/APKBUILD
+++ b/main/kbd/APKBUILD
@@ -1,17 +1,22 @@
# Contributor: Natanael Copa <ncopa@alpinelinux.org>
# Maintainer: Natanael Copa <ncopa@alpinelinux.org>
pkgname=kbd
-pkgver=2.0.1
-pkgrel=1
+pkgver=2.0.2
+pkgrel=0
pkgdesc="Tools for configuring the console (keyboard, virtual terminals, etc.)"
url="http://ftp.altlinux.org/pub/people/legion/kbd"
-arch=""
+arch="all"
license="GPL2+"
depends="kbd-misc"
makedepends="bison flex autoconf automake linux-pam-dev check-dev"
install=""
subpackages="$pkgname-misc $pkgname-doc"
-source="ftp://ftp.altlinux.org/pub/people/legion/kbd/kbd-$pkgver.tar.gz"
+source="ftp://ftp.altlinux.org/pub/people/legion/kbd/kbd-$pkgver.tar.gz
+ 0001-Replace-u_short-with-unsigned-short.patch
+ 0002-Fix-required-header-includes.patch
+ 0003-Only-inluclude-kernel-headers-with-glibc.patch
+ error.h
+ "
_builddir="$srcdir"/kbd-$pkgver
prepare() {
@@ -22,14 +27,14 @@ prepare() {
*.patch) msg $i; patch -p1 -i "$srcdir"/$i || return 1;;
esac
done
- aclocal -I m4 && automake --add-missing && autoreconf || return 1
- sed -i '1i#include <stdarg.h>' src/libkeymap/keymap/common.h
+# aclocal -I m4 && automake --add-missing && autoreconf || return 1
+
+ # install our error.h
+ cp "$srcdir"/error.h . || return 1
# fixes from fedora
# 7-bit maps are obsolete; so are non-euro maps
cd "$_builddir"/data/keymaps/i386
- mv qwerty/fi.map qwerty/fi-old.map
- cp qwerty/fi-latin9.map qwerty/fi.map
cp qwerty/pt-latin9.map qwerty/pt.map
cp qwerty/sv-latin1.map qwerty/se-latin1.map
@@ -93,6 +98,18 @@ misc() {
mv "$pkgdir"/lib/kbd "$subpkgdir"/lib/
}
-md5sums="cc0ee9f2537d8636cae85a8c6541ed2e kbd-2.0.1.tar.gz"
-sha256sums="75e78834e60adc1e95a479f9946a836f8a4f1e05bc0332660d3582c44bbc3019 kbd-2.0.1.tar.gz"
-sha512sums="666b5ad251036a69ae32dcac6d436602aa0c8da9adf8babb56ff4489fe61757d3ce10fc749694fbb5d1a5192da0999694ac7643a562fb88ab2a58897e0090dc2 kbd-2.0.1.tar.gz"
+md5sums="f1f75f0dd5f7dde89ce47585274366f8 kbd-2.0.2.tar.gz
+7945e2d7f13cc2896233bf5e1de8e4e2 0001-Replace-u_short-with-unsigned-short.patch
+4e04e0c7307e89193b7dc2cd889be0a5 0002-Fix-required-header-includes.patch
+31027a70335ff0a5e9f3b779d70920ce 0003-Only-inluclude-kernel-headers-with-glibc.patch
+1a5b152db18674deec07ab7c6209267a error.h"
+sha256sums="b1e4c796601039d3b63da908c27431a36e7af06d4d964cd3f8821a880eb3c021 kbd-2.0.2.tar.gz
+d55432213b14d677af73eb5b919327bd9fe03dd6fcad059f5d345901d6029e96 0001-Replace-u_short-with-unsigned-short.patch
+e1e6c482d4c00ace48938f4888a23992ae3cc16674a0d5d1f1f07eb57afac550 0002-Fix-required-header-includes.patch
+e2d49d91309b6b2450de7aa32be1807284958cf66cd9e4ee823dbb0afaf11772 0003-Only-inluclude-kernel-headers-with-glibc.patch
+0124ef103407469af4ea19884e2ed7e4546f08b58c129e1e8ef36569831f4b36 error.h"
+sha512sums="68832bddd6b91693110d1e26d3911bcd3c151003f83905571dcba05480ba484adc5bfe7d31a3b987bd930703d153724fb8eb9ae7cc26cff97be65a4f5ccb547b kbd-2.0.2.tar.gz
+0487a90382201a162405618e983fb2a227c6f07258a498c6850b5ddcd36d5c836446b4c7883a494421a3dc34a60b164bb6ce10350c777bc0cb1f610d4fe6a0ca 0001-Replace-u_short-with-unsigned-short.patch
+c3689db8777566dd92c6d38fadc1d8676d00926c711d5bb8b561547aaeb4d93b67998ac3f2b17faaa475e7c85a9e51c71b87cd92b6099ee118c19de58bc195aa 0002-Fix-required-header-includes.patch
+13af714a54562ebc1ac6b19f24f75704b452faf543705e9e6a8c53e8080f5edffb49ddde26a876da71e6ca34b275c3407525d6d3446c543181d2eff2b784541b 0003-Only-inluclude-kernel-headers-with-glibc.patch
+c66f6b0d8c8b8d285c740bdbe7130dee272ac01cd5e73b35a58cedf1a77fe8d9e062631b804fb58014d8eb9861c8f28aed07bc022ef31662bcc61b5c85a21752 error.h"
diff --git a/main/kbd/error.h b/main/kbd/error.h
new file mode 100644
index 0000000000..5eb8ed5115
--- /dev/null
+++ b/main/kbd/error.h
@@ -0,0 +1,20 @@
+#ifndef ERROR_H
+#define ERROR_H
+
+#include <stdio.h>
+#include <stdarg.h>
+#include <err.h>
+
+static inline void error(int status, int errnum, const char *fmt, ...)
+{
+ va_list ap;
+ void (*errfunc[2])(int, const char *, va_list) = { &verr, &verrx };
+ void (*warnfunc[2])(const char *, va_list) = { &vwarn, &vwarnx };
+ fflush(stdout);
+ va_start(ap, fmt);
+ if (status != 0)
+ errfunc[errnum==0](status, fmt, ap); /* does not return */
+ warnfunc[errnum==0](fmt, ap);
+ va_end(ap);
+}
+#endif
diff --git a/main/kbd/kbd.patch b/main/kbd/kbd.patch
deleted file mode 100644
index 83440ef8f7..0000000000
--- a/main/kbd/kbd.patch
+++ /dev/null
@@ -1,246 +0,0 @@
---- kbd-1.15.3/src/dumpkeys.c 2011-04-26 20:29:35.000000000 +0000
-+++ kbd-1.15.3.patched/src/dumpkeys.c 2012-11-02 20:55:42.405000003 +0000
-@@ -107,7 +107,7 @@
- }
-
- static int
--get_bind(u_char kb_index, u_char kb_table) {
-+get_bind(unsigned char kb_index, unsigned char kb_table) {
- struct kbentry ke;
-
- ke.kb_index = kb_index;
-@@ -169,7 +169,7 @@
- return status;
- }
-
--static u_char
-+static unsigned char
- maximum_val(int t) {
- struct kbentry ke, ke0;
- int i;
-@@ -440,7 +440,7 @@
- (val >= 'a' && val <= 'z')));
- isasexpected = 0;
- if (isletter) {
-- u_short defs[16];
-+ unsigned short defs[16];
- defs[0] = K(KT_LETTER, val);
- defs[1] = K(KT_LETTER, val ^ 32);
- defs[2] = defs[0];
-diff -ur kbd-1.15.3/src/kbdinfo.c kbd-1.15.3.patched/src/kbdinfo.c
---- kbd-1.15.3/src/kbdinfo.c 2011-04-26 20:29:35.000000000 +0000
-+++ kbd-1.15.3.patched/src/kbdinfo.c 2012-11-02 21:22:31.081000003 +0000
-@@ -1,6 +1,5 @@
- #include <stdio.h>
- #include <errno.h>
--#include <error.h>
- #include <unistd.h>
- #include <sys/ioctl.h>
- #include <linux/kd.h>
-@@ -8,10 +7,12 @@
- #include "getfd.h"
- #include "nls.h"
- #include "version.h"
-+#include "error.c"
-
- static const char *action = NULL;
- static const char *value = NULL;
-
-+
- static void attr_noreturn
- usage(int code) {
- fprintf(stderr,
-diff -ur kbd-1.15.3/src/kbdrate.c kbd-1.15.3.patched/src/kbdrate.c
---- kbd-1.15.3/src/kbdrate.c 2011-03-05 14:41:20.000000000 +0000
-+++ kbd-1.15.3.patched/src/kbdrate.c 2012-11-02 20:57:25.869000003 +0000
-@@ -74,6 +74,7 @@
- #include <errno.h>
- #include <sys/file.h>
- #include <sys/ioctl.h>
-+#include <fcntl.h>
-
- #ifdef __sparc__
- #include <asm/param.h>
-diff -ur kbd-1.15.3/src/loadkeys.c kbd-1.15.3.patched/src/loadkeys.c
---- kbd-1.15.3/src/loadkeys.c 2011-05-01 23:22:35.000000000 +0000
-+++ kbd-1.15.3.patched/src/loadkeys.c 2012-11-02 20:55:48.743000003 +0000
-@@ -114,7 +114,7 @@
- int alt_is_meta = 0;
-
- /* the kernel structures we want to set or print */
--u_short *key_map[MAX_NR_KEYMAPS];
-+unsigned short *key_map[MAX_NR_KEYMAPS];
- char *func_table[MAX_NR_FUNC];
-
- accent_entry accent_table[MAX_DIACR];
-@@ -255,7 +255,7 @@
-
- if (!key_map[k_table]) {
- key_map[k_table] =
-- (u_short *) xmalloc(NR_KEYS * sizeof(u_short));
-+ (unsigned short *) xmalloc(NR_KEYS * sizeof(unsigned short));
- for (i = 0; i < NR_KEYS; i++)
- (key_map[k_table])[i] = K_HOLE;
- }
-@@ -566,7 +566,7 @@
- return kd.kb_cnt;
- }
-
--static void do_constant_key(int i, u_short key)
-+static void do_constant_key(int i, unsigned short key)
- {
- int typ, val, j;
-
-@@ -575,7 +575,7 @@
-
- if ((typ == KT_LATIN || typ == KT_LETTER) &&
- ((val >= 'a' && val <= 'z') || (val >= 'A' && val <= 'Z'))) {
-- u_short defs[16];
-+ unsigned short defs[16];
- defs[0] = K(KT_LETTER, val);
- defs[1] = K(KT_LETTER, val ^ 32);
- defs[2] = defs[0];
-@@ -620,7 +620,7 @@
-
- for (i = 0; i < NR_KEYS; i++) {
- if (key_is_constant[i]) {
-- u_short key;
-+ unsigned short key;
-
- if (!key_map[r0])
- lkfatal(_("impossible error in do_constant"));
-@@ -800,7 +800,7 @@
- keymap_count++;
- if (i)
- printf("static ");
-- printf("u_short %s_map[NR_KEYS] = {", mk_mapname(i));
-+ printf("unsigned short %s_map[NR_KEYS] = {", mk_mapname(i));
- for (j = 0; j < NR_KEYS; j++) {
- if (!(j % 8))
- printf("\n");
-@@ -904,7 +904,7 @@
- {
- int i, j;
-
-- //u_char *p;
-+ //unsigned char *p;
- char flag, magic[] = "bkeymap";
- unsigned short v;
-
-diff -ur kbd-1.15.3/src/loadkeys.y kbd-1.15.3.patched/src/loadkeys.y
---- kbd-1.15.3/src/loadkeys.y 2011-05-01 23:19:11.000000000 +0000
-+++ kbd-1.15.3.patched/src/loadkeys.y 2012-11-02 20:55:42.410000003 +0000
-@@ -55,7 +55,7 @@
- int alt_is_meta = 0;
-
- /* the kernel structures we want to set or print */
--u_short *key_map[MAX_NR_KEYMAPS];
-+unsigned short *key_map[MAX_NR_KEYMAPS];
- char *func_table[MAX_NR_FUNC];
-
- accent_entry accent_table[MAX_DIACR];
-@@ -196,7 +196,7 @@
-
- if (!key_map[k_table]) {
- key_map[k_table] =
-- (u_short *) xmalloc(NR_KEYS * sizeof(u_short));
-+ (unsigned short *) xmalloc(NR_KEYS * sizeof(unsigned short));
- for (i = 0; i < NR_KEYS; i++)
- (key_map[k_table])[i] = K_HOLE;
- }
-@@ -507,7 +507,7 @@
- return kd.kb_cnt;
- }
-
--static void do_constant_key(int i, u_short key)
-+static void do_constant_key(int i, unsigned short key)
- {
- int typ, val, j;
-
-@@ -516,7 +516,7 @@
-
- if ((typ == KT_LATIN || typ == KT_LETTER) &&
- ((val >= 'a' && val <= 'z') || (val >= 'A' && val <= 'Z'))) {
-- u_short defs[16];
-+ unsigned short defs[16];
- defs[0] = K(KT_LETTER, val);
- defs[1] = K(KT_LETTER, val ^ 32);
- defs[2] = defs[0];
-@@ -561,7 +561,7 @@
-
- for (i = 0; i < NR_KEYS; i++) {
- if (key_is_constant[i]) {
-- u_short key;
-+ unsigned short key;
-
- if (!key_map[r0])
- lkfatal(_("impossible error in do_constant"));
-@@ -741,7 +741,7 @@
- keymap_count++;
- if (i)
- printf("static ");
-- printf("u_short %s_map[NR_KEYS] = {", mk_mapname(i));
-+ printf("unsigned short %s_map[NR_KEYS] = {", mk_mapname(i));
- for (j = 0; j < NR_KEYS; j++) {
- if (!(j % 8))
- printf("\n");
-@@ -845,7 +845,7 @@
- {
- int i, j;
-
-- //u_char *p;
-+ //unsigned char *p;
- char flag, magic[] = "bkeymap";
- unsigned short v;
-
-diff -ur kbd-1.15.3/src/openvt.c kbd-1.15.3.patched/src/openvt.c
---- kbd-1.15.3/src/openvt.c 2011-05-01 23:27:13.000000000 +0000
-+++ kbd-1.15.3.patched/src/openvt.c 2012-11-02 20:59:45.516000002 +0000
-@@ -10,7 +10,7 @@
- #include <sys/vt.h>
- #include <sys/wait.h>
- #include <sys/file.h>
--
-+#include <fcntl.h>
- #include "version.h"
- #include "xmalloc.h"
- #include "getfd.h"
-diff -ur kbd-1.15.3/src/setvtrgb.c kbd-1.15.3.patched/src/setvtrgb.c
---- kbd-1.15.3/src/setvtrgb.c 2011-04-26 20:29:35.000000000 +0000
-+++ kbd-1.15.3.patched/src/setvtrgb.c 2012-11-02 21:22:50.566000002 +0000
-@@ -5,7 +5,7 @@
- #include <sys/ioctl.h>
- #include <linux/kd.h>
- #include <errno.h>
--#include <error.h>
-+#include "error.c"
- #include "kbd.h"
- #include "getfd.h"
- #include "nls.h"
---- /dev/null 2012-10-16 17:31:41.304000002 +0000
-+++ kbd-1.15.3.patched/src/error.c 2012-11-02 21:22:07.812000002 +0000
-@@ -0,0 +1,24 @@
-+#include <stdio.h>
-+#include <stdarg.h>
-+
-+static void error(int status, int errnum, const char *fmt, ...) {
-+ fflush(stdout);
-+ char dest[4096];
-+ va_list ap;
-+ va_start(ap, fmt);
-+ ssize_t result = vsnprintf(dest, sizeof(dest), fmt, ap);
-+ va_end(ap);
-+ dprintf(2, "program_name: %s", dest);
-+ if(errnum) {
-+ dprintf(2, ": ");
-+ perror(fmt);
-+ exit (status);
-+ } else {
-+ dprintf(2, "\n");
-+ }
-+}
-+
-+
-+
-+
-+