1 1.2 jruoho /* $NetBSD: h_servent.c,v 1.2 2011/04/07 18:14:09 jruoho Exp $ */ 2 1.1 pgoyette 3 1.1 pgoyette /*- 4 1.1 pgoyette * Copyright (c) 2011 The NetBSD Foundation, Inc. 5 1.1 pgoyette * All rights reserved. 6 1.1 pgoyette * 7 1.1 pgoyette * Redistribution and use in source and binary forms, with or without 8 1.1 pgoyette * modification, are permitted provided that the following conditions 9 1.1 pgoyette * are met: 10 1.1 pgoyette * 1. Redistributions of source code must retain the above copyright 11 1.1 pgoyette * notice, this list of conditions and the following disclaimer. 12 1.1 pgoyette * 2. Redistributions in binary form must reproduce the above copyright 13 1.1 pgoyette * notice, this list of conditions and the following disclaimer in the 14 1.1 pgoyette * documentation and/or other materials provided with the distribution. 15 1.1 pgoyette * 16 1.1 pgoyette * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS 17 1.1 pgoyette * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED 18 1.1 pgoyette * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR 19 1.1 pgoyette * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS 20 1.1 pgoyette * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 21 1.1 pgoyette * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 22 1.1 pgoyette * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 23 1.1 pgoyette * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 24 1.1 pgoyette * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 25 1.1 pgoyette * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 26 1.1 pgoyette * POSSIBILITY OF SUCH DAMAGE. 27 1.1 pgoyette */ 28 1.1 pgoyette 29 1.1 pgoyette #include <netdb.h> 30 1.1 pgoyette #include <stdint.h> 31 1.1 pgoyette #include <stdlib.h> 32 1.1 pgoyette #include <unistd.h> 33 1.1 pgoyette #include <netinet/in.h> 34 1.1 pgoyette #include <sys/types.h> 35 1.1 pgoyette #include <stdio.h> 36 1.1 pgoyette 37 1.1 pgoyette static void 38 1.1 pgoyette pserv(const struct servent *svp) 39 1.1 pgoyette { 40 1.1 pgoyette char **pp; 41 1.1 pgoyette 42 1.1 pgoyette printf("name=%s, port=%d, proto=%s, aliases=", 43 1.1 pgoyette svp->s_name, ntohs((uint16_t)svp->s_port), svp->s_proto); 44 1.1 pgoyette for (pp = svp->s_aliases; *pp; pp++) 45 1.1 pgoyette printf("%s ", *pp); 46 1.1 pgoyette printf("\n"); 47 1.1 pgoyette } 48 1.1 pgoyette 49 1.1 pgoyette static void 50 1.1 pgoyette usage(void) 51 1.1 pgoyette { 52 1.1 pgoyette (void)fprintf(stderr, "Usage: %s\n" 53 1.1 pgoyette "\t%s -p <port> [-P <proto>]\n" 54 1.1 pgoyette "\t%s -n <name> [-P <proto>]\n", getprogname(), getprogname(), 55 1.1 pgoyette getprogname()); 56 1.1 pgoyette exit(1); 57 1.1 pgoyette } 58 1.1 pgoyette 59 1.1 pgoyette int 60 1.1 pgoyette main(int argc, char *argv[]) 61 1.1 pgoyette { 62 1.1 pgoyette struct servent *svp; 63 1.1 pgoyette const char *port = NULL, *proto = NULL, *name = NULL; 64 1.1 pgoyette int c; 65 1.1 pgoyette 66 1.1 pgoyette while ((c = getopt(argc, argv, "p:n:P:")) != -1) { 67 1.1 pgoyette switch (c) { 68 1.1 pgoyette case 'n': 69 1.1 pgoyette name = optarg; 70 1.1 pgoyette break; 71 1.1 pgoyette case 'p': 72 1.1 pgoyette port = optarg; 73 1.1 pgoyette break; 74 1.1 pgoyette case 'P': 75 1.1 pgoyette proto = optarg; 76 1.1 pgoyette break; 77 1.1 pgoyette default: 78 1.1 pgoyette usage(); 79 1.1 pgoyette } 80 1.1 pgoyette } 81 1.1 pgoyette 82 1.1 pgoyette if (port && name) 83 1.1 pgoyette usage(); 84 1.1 pgoyette if (port) { 85 1.1 pgoyette if ((svp = getservbyport(htons(atoi(port)), proto)) != NULL) 86 1.1 pgoyette pserv(svp); 87 1.1 pgoyette return 0; 88 1.1 pgoyette } 89 1.1 pgoyette if (name) { 90 1.1 pgoyette if ((svp = getservbyname(name, proto)) != NULL) 91 1.1 pgoyette pserv(svp); 92 1.1 pgoyette return 0; 93 1.1 pgoyette } 94 1.1 pgoyette 95 1.1 pgoyette setservent(0); 96 1.1 pgoyette while ((svp = getservent()) != NULL) 97 1.1 pgoyette pserv(svp); 98 1.1 pgoyette endservent(); 99 1.1 pgoyette return 0; 100 1.1 pgoyette } 101