Annotation of src/usr.bin/readlink/readlink.c, Revision 1.13
1.3 kstailey 1: /*
1.13 ! niklas 2: * $OpenBSD: readlink.c,v 1.12 1997/09/23 20:39:11 niklas Exp $
1.3 kstailey 3: *
4: * Copyright (c) 1997
5: * Kenneth Stailey (hereinafter referred to as the author)
6: *
7: * Redistribution and use in source and binary forms, with or without
8: * modification, are permitted provided that the following conditions
9: * are met:
10: * 1. Redistributions of source code must retain the above copyright
11: * notice, this list of conditions and the following disclaimer.
12: * 2. Redistributions in binary form must reproduce the above copyright
13: * notice, this list of conditions and the following disclaimer in the
14: * documentation and/or other materials provided with the distribution.
15: * 3. The name of the author may not be used to endorse or promote products
16: * derived from this software without specific prior written permission.
17: *
18: * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
19: * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
20: * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
21: * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
22: * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
23: * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
24: * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
25: * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
26: * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
27: * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
28: */
29:
1.9 kstailey 30: #include <limits.h>
1.10 niklas 31: #include <errno.h>
1.1 kstailey 32: #include <stdio.h>
1.12 niklas 33: #include <stdlib.h>
1.10 niklas 34: #include <string.h>
1.1 kstailey 35: #include <unistd.h>
36:
37: int
38: main(argc, argv)
1.10 niklas 39: int argc;
40: char **argv;
1.1 kstailey 41: {
42: char buf[PATH_MAX];
1.10 niklas 43: int n, ch, nflag = 0, fflag = 0;
1.8 kstailey 44: extern int optind;
1.1 kstailey 45:
1.10 niklas 46: while ((ch = getopt(argc, argv, "fn")) != -1)
1.8 kstailey 47: switch (ch) {
1.10 niklas 48: case 'f':
49: fflag = 1;
50: break;
1.8 kstailey 51: case 'n':
52: nflag = 1;
53: break;
54: default:
55: (void)fprintf(stderr,
1.10 niklas 56: "usage: readlink [-n] [-f] symlink\n");
1.8 kstailey 57: exit(1);
58: }
59: argc -= optind;
60: argv += optind;
61:
62: if (argc != 1) {
1.10 niklas 63: fprintf(stderr, "usage: readlink [-n] [-f] symlink\n");
1.5 deraadt 64: exit(1);
65: }
1.1 kstailey 66:
1.10 niklas 67: n = strlen(argv[0]);
68: if (n > PATH_MAX - 1)
69: errx(1, "filename longer than PATH_MAX-1 (%d)\n",
70: PATH_MAX - 1);
71:
72: if (fflag)
1.12 niklas 73: realpath(argv[0], buf);
1.10 niklas 74: else if ((n = readlink(argv[0], buf, PATH_MAX)) < 0)
1.1 kstailey 75: exit(1);
1.13 ! niklas 76: buf[n] = '\0';
1.4 grr 77:
78: printf("%s", buf);
1.8 kstailey 79: if (!nflag)
80: putchar('\n');
1.1 kstailey 81: exit(0);
82: }