/[LeafOK_CVS]/lbbs/include/section_list.h
ViewVC logotype

Annotation of /lbbs/include/section_list.h

Parent Directory Parent Directory | Revision Log Revision Log


Revision 1.34 - (hide annotations)
Wed Nov 5 03:01:14 2025 UTC (4 months, 1 week ago) by sysadm
Branch: MAIN
Changes since 1.33: +9 -6 lines
Content type: text/x-chdr
Use enum / const int instead of macro define constant integers

1 sysadm 1.32 /* SPDX-License-Identifier: GPL-3.0-or-later */
2     /*
3     * section_list
4     * - data models and basic operations of section and article
5     *
6 sysadm 1.33 * Copyright (C) 2004-2025 Leaflet <leaflet@leafok.com>
7 sysadm 1.32 */
8 sysadm 1.1
9 sysadm 1.19 #ifndef _SECTION_LIST_H_
10     #define _SECTION_LIST_H_
11    
12 sysadm 1.22 #include "bbs.h"
13 sysadm 1.1 #include "common.h"
14 sysadm 1.24 #include "menu.h"
15 sysadm 1.15 #include <time.h>
16 sysadm 1.1
17 sysadm 1.34 enum section_list_constant_t
18     {
19     BBS_article_title_max_len = 160,
20     BBS_article_limit_per_section = 50000,
21     BBS_article_limit_per_page = 20,
22 sysadm 1.1
23 sysadm 1.34 BBS_ontop_article_limit_per_section = 10,
24 sysadm 1.23
25 sysadm 1.34 BBS_article_count_per_block = 1000,
26     };
27 sysadm 1.1
28     struct article_t
29     {
30     int32_t aid;
31     int32_t tid;
32 sysadm 1.10 int32_t sid;
33 sysadm 1.1 int32_t cid;
34     int32_t uid;
35 sysadm 1.5 struct article_t *p_prior; // prior article
36     struct article_t *p_next; // next article
37     struct article_t *p_topic_prior; // same topic
38     struct article_t *p_topic_next; // same topic
39 sysadm 1.1 int8_t visible;
40     int8_t excerption;
41     int8_t ontop;
42     int8_t lock;
43 sysadm 1.18 int8_t transship;
44 sysadm 1.1 char username[BBS_username_max_len + 1];
45     char nickname[BBS_nickname_max_len + 1];
46     char title[BBS_article_title_max_len + 1];
47 sysadm 1.15 time_t sub_dt;
48 sysadm 1.1 };
49     typedef struct article_t ARTICLE;
50    
51 sysadm 1.5 struct section_list_t
52 sysadm 1.1 {
53     int32_t sid;
54 sysadm 1.13 int32_t class_id;
55     int8_t enable;
56 sysadm 1.1 char sname[BBS_section_name_max_len + 1];
57     char stitle[BBS_section_title_max_len + 1];
58 sysadm 1.20 char master_list[(BBS_username_max_len + 1) * 3 + 1];
59 sysadm 1.13 int read_user_level;
60     int write_user_level;
61 sysadm 1.1 int32_t article_count;
62 sysadm 1.6 int32_t topic_count;
63     int32_t visible_article_count;
64     int32_t visible_topic_count;
65 sysadm 1.4 ARTICLE *p_article_head;
66     ARTICLE *p_article_tail;
67 sysadm 1.5 ARTICLE *p_page_first_article[BBS_article_limit_per_section / BBS_article_limit_per_page];
68     int32_t page_count;
69 sysadm 1.6 int32_t last_page_visible_article_count;
70 sysadm 1.23 ARTICLE *p_ontop_articles[BBS_ontop_article_limit_per_section];
71     int32_t ontop_article_count;
72 sysadm 1.24 MENU_SET ex_menu_set;
73     time_t ex_menu_tm;
74 sysadm 1.1 };
75 sysadm 1.5 typedef struct section_list_t SECTION_LIST;
76 sysadm 1.1
77 sysadm 1.26 struct section_list_pool_t
78     {
79     int shmid;
80     SECTION_LIST sections[BBS_max_section];
81     int section_count;
82     int semid;
83     TRIE_NODE *p_trie_dict_section_by_name;
84     TRIE_NODE *p_trie_dict_section_by_sid;
85     };
86     typedef struct section_list_pool_t SECTION_LIST_POOL;
87    
88     extern SECTION_LIST_POOL *p_section_list_pool;
89    
90 sysadm 1.34 // article_block_count * BBS_article_count_per_block should be
91 sysadm 1.5 // no less than BBS_article_limit_per_section * BBS_max_section,
92     // in order to allocate enough memory for blocks
93     extern int article_block_init(const char *filename, int block_count);
94     extern void article_block_cleanup(void);
95 sysadm 1.16
96     extern int set_article_block_shm_readonly(void);
97     extern int detach_article_block_shm(void);
98    
99 sysadm 1.5 extern int article_block_reset(void);
100    
101     extern ARTICLE *article_block_find_by_aid(int32_t aid);
102     extern ARTICLE *article_block_find_by_index(int index);
103    
104 sysadm 1.15 extern int32_t article_block_last_aid(void);
105 sysadm 1.17 extern int article_block_article_count(void);
106 sysadm 1.15
107 sysadm 1.10 extern int article_count_of_topic(int32_t aid);
108    
109 sysadm 1.12 extern int section_list_init(const char *filename);
110     extern void section_list_cleanup(void);
111 sysadm 1.9
112 sysadm 1.16 extern int set_section_list_shm_readonly(void);
113     extern int detach_section_list_shm(void);
114    
115 sysadm 1.21 extern SECTION_LIST *section_list_create(int32_t sid, const char *sname, const char *stitle, const char *master_list);
116 sysadm 1.29 extern int section_list_update(SECTION_LIST *p_section, const char *sname, const char *stitle, const char *master_list);
117 sysadm 1.5 extern void section_list_reset_articles(SECTION_LIST *p_section);
118 sysadm 1.28 extern SECTION_LIST *section_list_find_by_name(const char *sname);
119     extern SECTION_LIST *section_list_find_by_sid(int32_t sid);
120 sysadm 1.11 extern int get_section_index(SECTION_LIST *p_section);
121 sysadm 1.31
122     // sname could be NULL, or pointer to char[] in size >= sizeof(SECTION_LIST.sname)
123     // stitle could be NULL, or pointer to char[] in size >= sizeof(SECTION_LIST.stitle)
124     // master_list could be NULL, or pointer to char[] in size >= sizeof(SECTION_LIST.master_list)
125 sysadm 1.30 extern int get_section_info(SECTION_LIST *p_section, char *sname, char *stitle, char *master_list);
126 sysadm 1.1
127 sysadm 1.5 extern int section_list_append_article(SECTION_LIST *p_section, const ARTICLE *p_article_src);
128     extern int section_list_set_article_visible(SECTION_LIST *p_section, int32_t aid, int8_t visible);
129 sysadm 1.7
130 sysadm 1.23 extern int section_list_update_article_ontop(SECTION_LIST *p_section, ARTICLE *p_article);
131     extern int section_list_page_count_with_ontop(SECTION_LIST *p_section);
132     extern int section_list_page_article_count_with_ontop(SECTION_LIST *p_section, int32_t page_id);
133    
134 sysadm 1.7 // *p_page, *p_offset will be set as page / offset of the article with aid in *p_section (including both visible and invisible articles)
135     // *pp_next will be set as pointer to the next article of the article with aid
136     // *pp_next will be set as head article of the section if the article with aid locates at the tail of the section
137 sysadm 1.8 extern ARTICLE *section_list_find_article_with_offset(SECTION_LIST *p_section, int32_t aid, int32_t *p_page, int32_t *p_offset, ARTICLE **pp_next);
138 sysadm 1.7
139 sysadm 1.6 extern int section_list_calculate_page(SECTION_LIST *p_section, int32_t start_aid);
140 sysadm 1.7 extern int section_list_move_topic(SECTION_LIST *p_section_src, SECTION_LIST *p_section_dest, int32_t aid);
141 sysadm 1.11
142     extern int section_list_try_rd_lock(SECTION_LIST *p_section, int wait_sec);
143     extern int section_list_try_rw_lock(SECTION_LIST *p_section, int wait_sec);
144     extern int section_list_rd_unlock(SECTION_LIST *p_section);
145     extern int section_list_rw_unlock(SECTION_LIST *p_section);
146 sysadm 1.14 extern int section_list_rd_lock(SECTION_LIST *p_section);
147     extern int section_list_rw_lock(SECTION_LIST *p_section);
148 sysadm 1.19
149     #endif //_SECTION_LIST_H_

webmaster@leafok.com
ViewVC Help
Powered by ViewVC 1.3.0-beta1