summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--include/perm.h11
-rw-r--r--include/pttstruct.h2
-rw-r--r--mbbsd/board.c22
-rw-r--r--sample/pttbbs.conf5
-rw-r--r--util/shmctl.c34
5 files changed, 65 insertions, 9 deletions
diff --git a/include/perm.h b/include/perm.h
index bab82ae3..2d676bae 100644
--- a/include/perm.h
+++ b/include/perm.h
@@ -53,4 +53,15 @@
#define HAVE_PERM(x) (cuser.userlevel&(x))
#define PERM_HIDE(u) ((u)->userlevel & PERM_SYSOP && \
(u)->userlevel & PERM_DENYPOST)
+
+#define IS_BOARD(bptr) ((bptr)->brdname[0] && \
+ !((bptr)->brdattr & BRD_GROUPBOARD))
+#define IS_GROUP(bptr) ((bptr)->brdname[0] && \
+ ((bptr)->brdattr & BRD_GROUPBOARD))
+
+#define IS_OPENBRD(bptr) \
+ (!(((bptr)->brdattr & (BRD_HIDE | BRD_TOP)) || \
+ ((bptr)->level && !((bptr)->brdattr & BRD_POSTMASK) && \
+ ((bptr)->level & \
+ ~(PERM_BASIC|PERM_CHAT|PERM_PAGE|PERM_POST|PERM_LOGINOK)))))
#endif
diff --git a/include/pttstruct.h b/include/pttstruct.h
index 550b9437..34becd25 100644
--- a/include/pttstruct.h
+++ b/include/pttstruct.h
@@ -366,7 +366,7 @@ typedef struct {
boardheader_t bcache[MAX_BOARD];
boardheader_t *bsorted[2][MAX_BOARD]; /* 0: by name 1: by class */
#if HOTBOARDCACHE
- char nHOTs;
+ unsigned char nHOTs;
boardheader_t *HBcache[HOTBOARDCACHE];
#endif
#if DIRCACHESIZE
diff --git a/mbbsd/board.c b/mbbsd/board.c
index 9821edc5..3a47b0ed 100644
--- a/mbbsd/board.c
+++ b/mbbsd/board.c
@@ -543,6 +543,14 @@ load_boards(char *key)
byMALLOC = 0;
needREALLOC = (get_data_number(fav) != brdnum);
}
+#if HOTBOARDCACHE
+ else if( class_bid == -1 ){
+ nbrd = (boardstat_t *)malloc(sizeof(boardstat_t) * SHM->nHOTs);
+ for( i = 0 ; i < SHM->nHOTs ; ++i )
+ addnewbrdstat(SHM->HBcache[i] - SHM->bcache,
+ Ben_Perm(SHM->HBcache[i]));
+ }
+#endif
else { // general case
nbrd = (boardstat_t *) MALLOC(sizeof(boardstat_t) * numboards);
for (i = 0; i < numboards; i++) {
@@ -550,10 +558,13 @@ load_boards(char *key)
continue;
n = (int)(bptr - bcache);
if (!bptr->brdname[0] ||
- (bptr->brdattr & BRD_GROUPBOARD) ||
- !((state = Ben_Perm(bptr)) || (currmode & MODE_MENU)) ||
- (key[0] && !strcasestr(bptr->title, key)) ||
- (class_bid == -1 && bptr->nuser < 5))
+ (bptr->brdattr & BRD_GROUPBOARD) ||
+ !((state = Ben_Perm(bptr)) || (currmode & MODE_MENU)) ||
+ (key[0] && !strcasestr(bptr->title, key))
+#ifndef HOTBOARDCACHE
+ || (class_bid == -1 && bptr->nuser < 5)
+#endif
+ )
continue;
addnewbrdstat(n, state);
}
@@ -564,9 +575,10 @@ load_boards(char *key)
#endif
needREALLOC = 1;
}
+#ifndef HOTBOARDCACHE
if (class_bid == -1)
qsort(nbrd, brdnum, sizeof(boardstat_t), cmpboardfriends);
-
+#endif
} else { /* load boards of a subclass */
int childcount = bptr->childcount;
nbrd = (boardstat_t *) malloc(childcount * sizeof(boardstat_t));
diff --git a/sample/pttbbs.conf b/sample/pttbbs.conf
index 2d50c647..f9766815 100644
--- a/sample/pttbbs.conf
+++ b/sample/pttbbs.conf
@@ -142,6 +142,11 @@
則可透過 NO_SYSOP_ACCOUNT 關閉該帳號, 以避免安全問題發生. */
//#define NO_SYSOP_ACCOUNT
+/* 若定義, 則熱門看板列表會改用 shmctl utmpsortd 來計算, 而不是每
+ 個使用者自己算. 在站上會同時有很多人同時跑去看熱門看板的時候用.
+ 若站上並不會一瞬間很多人跑去看熱門看板, 會得到反效果. */
+//#define HOTBOARDCACHE 128
+
/* 前進站畫面 */
#define INSCREEN \
"前進站畫面 (請至 pttbbs.conf 修改您的前進站畫面)"
diff --git a/util/shmctl.c b/util/shmctl.c
index 001fd4eb..8b30c758 100644
--- a/util/shmctl.c
+++ b/util/shmctl.c
@@ -210,6 +210,8 @@ inline void utmpsort(int sortall)
userinfo_t *uentp;
int count, i, ns;
short nusers[MAX_BOARD];
+ boardheader_t *HBcache[HOTBOARDCACHE];
+
SHM->UTMPbusystate = 1;
#ifdef OUTTA_TIMER
@@ -260,9 +262,35 @@ inline void utmpsort(int sortall)
0 < uentp->brc_id && uentp->brc_id < MAX_BOARD)
++nusers[uentp->brc_id - 1];
}
- for (i = 0; i < SHM->Bnumber; ++i)
- if (SHM->bcache[i].brdname[0] != 0)
- SHM->bcache[i].nuser = nusers[i];
+ {
+#if HOTBOARDCACHE
+ int k, r, last = 0, top = 0;
+#endif
+ for (i = 0; i < SHM->Bnumber; ++i)
+ if (SHM->bcache[i].brdname[0] != 0){
+ SHM->bcache[i].nuser = nusers[i];
+#if HOTBOARDCACHE
+ if( nusers[i] > 8 &&
+ (top < HOTBOARDCACHE || nusers[i] > last) &&
+ IS_BOARD(&SHM->bcache[i]) &&
+ IS_OPENBRD(&SHM->bcache[i]) ){
+ for( k = top - 1 ; k >= 0 ; --k )
+ if( nusers[i] < HBcache[k]->nuser )
+ break;
+ if( top < HOTBOARDCACHE )
+ ++top;
+ for( r = top - 1 ; r > (k + 1) ; --r )
+ HBcache[r] = HBcache[r - 1];
+ HBcache[k + 1] = &SHM->bcache[i];
+ last = nusers[(HBcache[top - 1] - SHM->bcache)];
+ }
+#endif
+ }
+#if HOTBOARDCACHE
+ memcpy(SHM->HBcache, HBcache, sizeof(HBcache));
+ SHM->nHOTs = top;
+#endif
+ }
}
SHM->currsorted = ns;