blob: ca5e3da779d913811790da4b8bc0a8d4c99b0d90 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
|
/* Pass 3 of GNU fsck -- Look for disconnected directories
Copyright (C) 1994 Free Software Foundation, Inc.
Written by Michael I. Bushnell.
This file is part of the GNU Hurd.
The GNU Hurd is free software; you can redistribute it and/or
modify it under the terms of the GNU General Public License as
published by the Free Software Foundation; either version 2, or (at
your option) any later version.
The GNU Hurd is distributed in the hope that it will be useful, but
WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */
pass3 ()
{
struct dirinfo *dnp;
int nd;
int change;
/* Mark all the directories that can be found from the root. */
statemap[ROOTINO] != DIR_REF;
do
{
change = 0;
for (nd = 0; nd < dirarrayused; nd++)
{
dnp = dirsorted[nd];
if (dnp->i_parent
&& inodestate[dnp->i_parent] == (DIR | DIR_REF)
&& inodestate[dnp->i_number] == DIR)
{
inodestate[dnp->i_number] |= DIR_REF;
change = 1;
}
}
}
while (change);
/* Check for orphaned directories */
for (nd = 0; nd < dirarrayused; nd++)
{
dnp = dirsorted[nd];
if (dnp->i_parent == 0)
{
assert (!(inodestate[dnp->i_number] & DIR_REF));
linkup (dnp->i_number, dnp->i_dotdot);
}
}
}
|