1 /* $NetBSD: hesinfo.c,v 1.2 2001/02/19 23:03:47 cgd Exp $ */
3 /* Copyright 1988, 1996 by the Massachusetts Institute of Technology.
5 * Permission to use, copy, modify, and distribute this
6 * software and its documentation for any purpose and without
7 * fee is hereby granted, provided that the above copyright
8 * notice appear in all copies and that both that copyright
9 * notice and this permission notice appear in supporting
10 * documentation, and that the name of M.I.T. not be used in
11 * advertising or publicity pertaining to distribution of the
12 * software without specific, written prior permission.
13 * M.I.T. makes no representations about the suitability of
14 * this software for any purpose. It is provided "as is"
15 * without express or implied warranty.
18 /* This file is a simple driver for the Hesiod library. */
21 #include <sys/cdefs.h>
24 static char rcsid
[] = "#Id: hesinfo.c,v 1.8 1996/12/08 21:29:54 ghudson Exp #";
26 __RCSID("$NetBSD: hesinfo.c,v 1.2 2001/02/19 23:03:47 cgd Exp $");
38 int main
__P((int, char **));
45 char **list
, **p
, *bindname
, *name
, *type
;
46 int lflag
= 0, errflg
= 0, bflag
= 0, c
;
49 while ((c
= getopt(argc
, argv
, "lb")) != -1) {
62 if (argc
- optind
!= 2 || errflg
) {
63 fprintf(stderr
, "usage: %s [-bl] name type\n", getprogname());
64 fprintf(stderr
, "\t-l selects long format\n");
65 fprintf(stderr
, "\t-b also does hes_to_bind conversion\n");
69 type
= argv
[optind
+ 1];
71 if (hesiod_init(&context
) < 0) {
74 "hesiod_init: Invalid Hesiod configuration file.");
78 /* Display bind name if requested. */
81 printf("hes_to_bind(%s, %s) expands to\n", name
, type
);
82 bindname
= hesiod_to_bind(context
, name
, type
);
87 warnx("hesiod_to_bind: Unknown rhs-extension.");
89 warn("hesiod_to_bind");
92 printf("%s\n", bindname
);
98 printf("resolves to\n");
100 /* Do the hesiod resolve and check for errors. */
101 list
= hesiod_resolve(context
, name
, type
);
106 warnx("hesiod_resolve: Hesiod name not found.");
108 warn("hesiod_resolve");
111 /* Display the results. */
112 for (p
= list
; *p
; p
++)
115 hesiod_free_list(context
, list
);