summaryrefslogtreecommitdiffstats
path: root/util/boardlist.c
diff options
context:
space:
mode:
authorin2 <in2@63ad8ddf-47c3-0310-b6dd-a9e9d9715204>2004-12-06 18:26:03 +0800
committerin2 <in2@63ad8ddf-47c3-0310-b6dd-a9e9d9715204>2004-12-06 18:26:03 +0800
commit2178431a36c1d444ee05aaeb4fd9ca91c7571a2b (patch)
tree11c191277b0578af603afb4e877afb96e0eb4b61 /util/boardlist.c
parentc876b5327229175e098c2c6490d01c28c71a08b3 (diff)
downloadpttbbs-2178431a36c1d444ee05aaeb4fd9ca91c7571a2b.tar
pttbbs-2178431a36c1d444ee05aaeb4fd9ca91c7571a2b.tar.gz
pttbbs-2178431a36c1d444ee05aaeb4fd9ca91c7571a2b.tar.bz2
pttbbs-2178431a36c1d444ee05aaeb4fd9ca91c7571a2b.tar.lz
pttbbs-2178431a36c1d444ee05aaeb4fd9ca91c7571a2b.tar.xz
pttbbs-2178431a36c1d444ee05aaeb4fd9ca91c7571a2b.tar.zst
pttbbs-2178431a36c1d444ee05aaeb4fd9ca91c7571a2b.zip
discard r2368 due to compilation failure
git-svn-id: http://opensvn.csie.org/pttbbs/trunk/pttbbs@2371 63ad8ddf-47c3-0310-b6dd-a9e9d9715204
Diffstat (limited to 'util/boardlist.c')
-rw-r--r--util/boardlist.c54
1 files changed, 25 insertions, 29 deletions
diff --git a/util/boardlist.c b/util/boardlist.c
index eae2d8ae..606a0192 100644
--- a/util/boardlist.c
+++ b/util/boardlist.c
@@ -5,30 +5,28 @@
static void
load_uidofgid(const int gid, const int type)
{
- boardheader_t *bptr, *currbptr, *parent;
- int bid, n, childcount = 0;
- currbptr = parent = &bcache[gid - 1];
+ boardheader_t *bptr, *currbptr;
+ int n, childcount = 0;
+ currbptr = &bcache[gid - 1];
for (n = 0; n < numboards; ++n) {
- bid = SHM->bsorted[type][n]+1;
- if( bid<=0 || !(bptr = &bcache[bid-1])
- || bptr->brdname[0] == '\0' )
+ if( !(bptr = SHM->bsorted[type][n]) || bptr->brdname[0] == '\0' )
continue;
if (bptr->gid == gid) {
- if (currbptr == parent)
- currbptr->firstchild[type] = bid;
+ if (currbptr == &bcache[gid - 1])
+ currbptr->firstchild[type] = bptr;
else {
- currbptr->next[type] = bid;
- currbptr->parent = gid;
+ currbptr->next[type] = bptr;
+ currbptr->parent = &bcache[gid - 1];
}
childcount++;
currbptr = bptr;
}
}
- parent->childcount = childcount;
- if (currbptr == parent) // no child
- currbptr->firstchild[type] = -1;
- else // the last child
- currbptr->next[type] = -1;
+ bcache[gid - 1].childcount = childcount;
+ if (currbptr == &bcache[gid - 1])
+ currbptr->firstchild[type] = NULL;
+ else
+ currbptr->next[type] = NULL;
}
char *skipEscape(char *s)
@@ -83,36 +81,34 @@ void dumpdetail(void)
}
}
-void dumpclass(int gid)
+void dumpclass(int bid)
{
boardheader_t *bptr;
- int bid;
- bptr = getbcache(gid);
- if (bptr->firstchild[0] == 0 || bptr->childcount <= 0)
- load_uidofgid(gid, 0);
- printf("$db{'class.%d'} = $serializer->serialize([", gid);
- for (bid = bptr->firstchild[0]>0; bid >0 ; bid =bptr->next[0]) {
- bptr = getbcache(bid);
+ bptr = &bcache[bid];
+ if (bptr->firstchild[0] == NULL || bptr->childcount <= 0)
+ load_uidofgid(bid + 1, 0); /* 因為這邊 bid從 0開始, 所以再 +1 回來 */
+ printf("$db{'class.%d'} = $serializer->serialize([", bid);
+ for (bptr = bptr->firstchild[0]; bptr != NULL ; bptr = bptr->next[0]) {
if( (bptr->brdattr & (BRD_HIDE | BRD_TOP)) ||
(bptr->level && !(bptr->brdattr & BRD_POSTMASK) &&
(bptr->level &
~(PERM_BASIC|PERM_CHAT|PERM_PAGE|PERM_POST|PERM_LOGINOK))) )
continue;
- printf("%5d,\t", bid);
+ printf("%5d,\t", bptr - bcache);
}
printf("]);\n");
- bptr = getbcache(gid);
- for (bid = bptr->firstchild[0]>0; bid >0 ; bid =bptr->next[0]) {
- bptr = getbcache(bid);
+ bptr = &bcache[bid];
+ for (bptr = bptr->firstchild[0]; bptr != NULL ; bptr = bptr->next[0]) {
if( (bptr->brdattr & (BRD_HIDE | BRD_TOP)) ||
(bptr->level && !(bptr->brdattr & BRD_POSTMASK) &&
(bptr->level &
~(PERM_BASIC|PERM_CHAT|PERM_PAGE|PERM_POST|PERM_LOGINOK))) )
continue;
+
if( bptr->brdattr & BRD_GROUPBOARD )
- dumpclass(bid);
+ dumpclass(bptr - bcache);
}
}
@@ -155,7 +151,7 @@ int main(int argc, char **argv)
"$serializer = Data::Serializer->new(serializer => 'Storable', digester => 'MD5',compress => 0,);\n"
"tie %%db, 'DB_File', 'boardlist.db', (O_RDWR | O_CREAT), 0666, $DB_HASH;\n"
);
- dumpclass(1);
+ dumpclass(0);
dumpdetail();
dumpallbrdname();
printf("untie %%db;\n");