2 * Copyright (c) 1999 - 2000 Kungliga Tekniska Högskolan
3 * (Royal Institute of Technology, Stockholm, Sweden).
6 * Redistribution and use in source and binary forms, with or without
7 * modification, are permitted provided that the following conditions
10 * 1. Redistributions of source code must retain the above copyright
11 * notice, this list of conditions and the following disclaimer.
13 * 2. Redistributions in binary form must reproduce the above copyright
14 * notice, this list of conditions and the following disclaimer in the
15 * documentation and/or other materials provided with the distribution.
17 * 3. Neither the name of the Institute nor the names of its contributors
18 * may be used to endorse or promote products derived from this software
19 * without specific prior written permission.
21 * THIS SOFTWARE IS PROVIDED BY THE INSTITUTE AND CONTRIBUTORS ``AS IS'' AND
22 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
23 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
24 * ARE DISCLAIMED. IN NO EVENT SHALL THE INSTITUTE OR CONTRIBUTORS BE LIABLE
25 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
26 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
27 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
28 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
29 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
30 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
41 #include <sys/types.h>
52 main(int argc
, char *argv
[])
58 setprogname (argv
[0]);
60 fd1
= open("foo", O_RDWR
|O_CREAT
, 0666);
64 ret
= fstat (fd1
, &sb1
);
68 if (sb1
.st_nlink
!= 1)
69 errx (1, "foo.st_nlink != 1");
71 ret
= link ("foo", "bar");
73 err (1, "link foo, bar");
75 ret
= fstat (fd1
, &sb1
);
79 ret
= lstat ("bar", &sb2
);
83 if (sb1
.st_nlink
!= 2)
84 errx (1, "foo.st_nlink != 2");
86 if (sb2
.st_nlink
!= 2)
87 errx (1, "bar.st_nlink != 2");
89 if (sb1
.st_dev
!= sb2
.st_dev
90 || sb1
.st_ino
!= sb2
.st_ino
)
91 errx (1, "dev and ino differ");
93 fd2
= open("bar", O_RDONLY
, 0);
97 ret
= fstat (fd2
, &sb2
);
101 if (sb2
.st_nlink
!= 2)
102 errx (1, "bar.st_nlink != 2");
104 if (write (fd1
, "hej", 3) != 3)
105 errx (1, "write to foo");
107 ret
= fstat (fd1
, &sb1
);
111 if (sb1
.st_size
!= 3)
112 errx (1, "foo.st_size != 3");
116 err (1, "close foo");
118 ret
= fstat (fd2
, &sb2
);
120 err (1, "fstat bar");
122 if (sb2
.st_size
!= 3)
123 errx (1, "bar.st_size != 3");
125 if (unlink ("foo") < 0)
126 err (1, "unlink foo");
128 ret
= fstat (fd2
, &sb2
);
130 err (1, "fstat bar");
132 if (sb2
.st_nlink
!= 1)
133 errx (1, "bar.st_nlink != 1");
135 if (unlink ("bar") < 0)
136 err (1, "unlink bar");
138 ret
= fstat (fd2
, &sb2
);
140 err (1, "fstat bar");
142 if (sb2
.st_nlink
!= 0)
143 errx (1, "bar.st_nlink != 0");
147 err (1, "close bar");