8354 sync regcomp(3C) with upstream (fix make catalog)
[unleashed/tickless.git] / usr / src / cmd / tsol / atohexlabel / atohexlabel.c
blob882eaef2cfb065f8bbdf659c4971b8197d27ff2f
1 /*
2 * CDDL HEADER START
4 * The contents of this file are subject to the terms of the
5 * Common Development and Distribution License (the "License").
6 * You may not use this file except in compliance with the License.
8 * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
9 * or http://www.opensolaris.org/os/licensing.
10 * See the License for the specific language governing permissions
11 * and limitations under the License.
13 * When distributing Covered Code, include this CDDL HEADER in each
14 * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
15 * If applicable, add the following below this CDDL HEADER, with the
16 * fields enclosed by brackets "[]" replaced with your own identifying
17 * information: Portions Copyright [yyyy] [name of copyright owner]
19 * CDDL HEADER END
23 * Copyright 2009 Sun Microsystems, Inc. All rights reserved.
24 * Use is subject to license terms.
29 * atohexlabel - Convert a human readable label to its internal
30 * equivalent.
33 #include <errno.h>
34 #include <libintl.h>
35 #include <locale.h>
36 #include <stdio.h>
37 #include <stdlib.h>
38 #include <string.h>
39 #include <unistd.h>
40 #include <stropts.h>
42 #include <sys/param.h>
44 #include <tsol/label.h>
46 #if !defined(TEXT_DOMAIN)
47 #define TEXT_DOMAIN "SYS_TEST"
48 #endif /* !defined(TEXT_DOMAIN) */
50 static void
51 label_error(const char *ascii, const int err)
53 if (errno == EINVAL) {
54 switch (err) {
55 case M_BAD_STRING:
56 (void) fprintf(stderr,
57 gettext("atohexlabel: bad string %s\n"), ascii);
58 break;
59 case M_BAD_LABEL:
60 (void) fprintf(stderr,
61 gettext("atohexlabel: bad previous label\n"));
62 break;
63 default:
64 (void) fprintf(stderr,
65 gettext("atohexlabel: parsing error found in "
66 "\"%s\" at position %d\n"), ascii, err);
67 break;
69 } else {
70 perror("atohexlabel");
72 exit(1);
73 /*NOTREACHED*/
76 int
77 main(int argc, char **argv)
79 int cflg = 0; /* true if Clearance only */
80 int errflg = 0; /* true if arg error */
81 m_label_t *label = NULL; /* binary labels */
82 char ascii[PIPE_BUF]; /* human readable label */
83 char *hex = NULL; /* internal label to print */
84 int err = 0; /* label error */
85 int c;
87 (void) setlocale(LC_ALL, "");
88 (void) textdomain(TEXT_DOMAIN);
90 opterr = 0;
91 while ((c = getopt(argc, argv, "c")) != EOF) {
93 switch (c) {
94 case 'c':
95 cflg++;
96 break;
98 default:
99 errflg++;
100 break;
104 argc -= optind - 1;
105 if (errflg || argc > 2) {
107 (void) fprintf(stderr,
108 gettext("usage: %s [-c] [human readable label]\n"),
109 argv[0]);
110 exit(1);
111 /*NOTREACHED*/
114 if (argc == 2) {
115 /* use label on command line */
117 (void) strlcpy(ascii, argv[optind], sizeof (ascii));
118 } else {
119 /* read label from standard input */
120 if ((c = read(STDIN_FILENO, ascii, sizeof (ascii))) <= 0) {
121 perror(gettext("reading ASCII coded label"));
122 exit(1);
123 /*NOTREACHED*/
127 * replace '\n' or (end of buffer) with end of string.
129 ascii[c-1] = '\0';
132 * flush any remaining input past the size of the buffer.
134 (void) ioctl(STDIN_FILENO, I_FLUSH, FLUSHR);
137 if (cflg) {
138 if (str_to_label(ascii, &label, USER_CLEAR, L_NO_CORRECTION,
139 &err) == -1) {
140 label_error(ascii, err);
142 if (label_to_str(label, &hex, M_INTERNAL, DEF_NAMES) != 0) {
143 perror("label_to_str");
144 exit(1);
146 (void) printf("%s\n", hex);
147 m_label_free(label);
148 free(hex);
149 } else {
150 if (str_to_label(ascii, &label, MAC_LABEL, L_NO_CORRECTION,
151 &err) == -1) {
152 label_error(ascii, err);
154 if (label_to_str(label, &hex, M_INTERNAL, DEF_NAMES) != 0) {
155 perror("label_to_str");
156 exit(1);
158 (void) printf("%s\n", hex);
159 m_label_free(label);
160 free(hex);
163 return (0); /* really exit(0); */