/[LeafOK_CVS]/lbbs/src/article_favor.c
ViewVC logotype

Diff of /lbbs/src/article_favor.c

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

Revision 1.2 by sysadm, Wed Oct 15 02:25:13 2025 UTC Revision 1.9 by sysadm, Tue Nov 11 00:28:05 2025 UTC
# Line 1  Line 1 
1  /***************************************************************************  /* SPDX-License-Identifier: GPL-3.0-or-later */
2                                           article_favor.c  -  description  /*
3                                                           -------------------   * article_favor
4          Copyright            : (C) 2004-2025 by Leaflet   *   - data model and basic operations of user favorite articles
5          Email                : leaflet@leafok.com   *
6   ***************************************************************************/   * Copyright (C) 2004-2025  Leaflet <leaflet@leafok.com>
7     */
8  /***************************************************************************  
9   *                                                                         *  #ifdef HAVE_CONFIG_H
10   *   This program is free software; you can redistribute it and/or modify  *  #include "config.h"
11   *   it under the terms of the GNU General Public License as published by  *  #endif
  *   the Free Software Foundation; either version 3 of the License, or     *  
  *   (at your option) any later version.                                   *  
  *                                                                         *  
  ***************************************************************************/  
12    
13  #include "article_favor.h"  #include "article_favor.h"
14  #include "common.h"  #include "common.h"
# Line 20  Line 16 
16  #include "log.h"  #include "log.h"
17  #include <stdlib.h>  #include <stdlib.h>
18  #include <string.h>  #include <string.h>
19    #include <sys/param.h>
20    
21  ARTICLE_FAVOR BBS_article_favor;  ARTICLE_FAVOR BBS_article_favor;
22    
# Line 147  int article_favor_save_inc(const ARTICLE Line 144  int article_favor_save_inc(const ARTICLE
144                           "DELETE FROM article_favorite WHERE UID = %d AND AID IN (",                           "DELETE FROM article_favorite WHERE UID = %d AND AID IN (",
145                           p_favor->uid);                           p_favor->uid);
146    
147          for (i = 0, j = 0; i < p_favor->aid_base_cnt && j < p_favor->aid_inc_cnt;)          for (i = 0, j = 0; j < p_favor->aid_inc_cnt;)
148          {          {
149                  if (p_favor->aid_base[i] == p_favor->aid_inc[j]) // XOR - delete record                  if (i < p_favor->aid_base_cnt && p_favor->aid_base[i] == p_favor->aid_inc[j]) // XOR - delete record
150                  {                  {
151                          snprintf(tuple_tmp, sizeof(tuple_tmp), "%d, ", p_favor->aid_inc[j]);                          snprintf(tuple_tmp, sizeof(tuple_tmp), "%d, ", p_favor->aid_inc[j]);
152                          strncat(sql_del, tuple_tmp, sizeof(sql_del) - 1 - strnlen(sql_del, sizeof(sql_del)));                          strncat(sql_del, tuple_tmp, sizeof(sql_del) - 1 - strnlen(sql_del, sizeof(sql_del)));
# Line 158  int article_favor_save_inc(const ARTICLE Line 155  int article_favor_save_inc(const ARTICLE
155                          i++;                          i++;
156                          j++;                          j++;
157                  }                  }
158                  else if (p_favor->aid_base[i] < p_favor->aid_inc[j]) // skip existing record                  else if (i < p_favor->aid_base_cnt && p_favor->aid_base[i] < p_favor->aid_inc[j]) // skip existing record
159                  {                  {
160                          i++;                          i++;
161                  }                  }
162                  else // if (p_favor->aid_base[i] > p_favor->aid_inc[j])                  else // if (i >= p_favor->aid_base_cnt || p_favor->aid_base[i] > p_favor->aid_inc[j])
163                  {                  {
164                          snprintf(tuple_tmp, sizeof(tuple_tmp),                          snprintf(tuple_tmp, sizeof(tuple_tmp),
165                                           "(%d, %d), ",                                           "(%d, %d), ",
# Line 227  int article_favor_merge_inc(ARTICLE_FAVO Line 224  int article_favor_merge_inc(ARTICLE_FAVO
224  {  {
225          int32_t aid_new[MAX_FAVOR_AID_BASE_CNT];          int32_t aid_new[MAX_FAVOR_AID_BASE_CNT];
226          int i, j, k;          int i, j, k;
227            int len;
228    
229          if (p_favor == NULL)          if (p_favor == NULL)
230          {          {
# Line 256  int article_favor_merge_inc(ARTICLE_FAVO Line 254  int article_favor_merge_inc(ARTICLE_FAVO
254                  }                  }
255          }          }
256    
257          while (i < p_favor->aid_base_cnt && k < MAX_FAVOR_AID_BASE_CNT)          len = MIN(p_favor->aid_base_cnt - i, MAX_FAVOR_AID_BASE_CNT - k);
258            if (len > 0)
259          {          {
260                  aid_new[k++] = p_favor->aid_base[i++];                  memcpy(aid_new + k, p_favor->aid_base + i,
261                               sizeof(int32_t) * (size_t)len);
262                    i += len;
263                    k += len;
264          }          }
265          if (i < p_favor->aid_base_cnt)          if (i < p_favor->aid_base_cnt)
266          {          {
267                  log_error("Too many base aids, %d will be discarded\n", p_favor->aid_base_cnt - i);                  log_error("Too many base aids, %d will be discarded\n", p_favor->aid_base_cnt - i);
268          }          }
269    
270          while (j < p_favor->aid_inc_cnt && k < MAX_FAVOR_AID_BASE_CNT)          len = MIN(p_favor->aid_inc_cnt - j, MAX_FAVOR_AID_BASE_CNT - k);
271            if (len > 0)
272          {          {
273                  aid_new[k++] = p_favor->aid_inc[j++];                  memcpy(aid_new + k, p_favor->aid_inc + j,
274                               sizeof(int32_t) * (size_t)len);
275                    j += len;
276                    k += len;
277          }          }
278          if (j < p_favor->aid_inc_cnt)          if (j < p_favor->aid_inc_cnt)
279          {          {
# Line 311  int article_favor_check(int32_t aid, con Line 317  int article_favor_check(int32_t aid, con
317                          mid = (left + right) / 2;                          mid = (left + right) / 2;
318                          if (aid < (i == 0 ? p_favor->aid_base[mid] : p_favor->aid_inc[mid]))                          if (aid < (i == 0 ? p_favor->aid_base[mid] : p_favor->aid_inc[mid]))
319                          {                          {
320                                  right = mid;                                  right = mid - 1;
321                          }                          }
322                          else if (aid > (i == 0 ? p_favor->aid_base[mid] : p_favor->aid_inc[mid]))                          else if (aid > (i == 0 ? p_favor->aid_base[mid] : p_favor->aid_inc[mid]))
323                          {                          {
# Line 362  int article_favor_set(int32_t aid, ARTIC Line 368  int article_favor_set(int32_t aid, ARTIC
368                          mid = (left + right) / 2;                          mid = (left + right) / 2;
369                          if (aid < (i == 0 ? p_favor->aid_base[mid] : p_favor->aid_inc[mid]))                          if (aid < (i == 0 ? p_favor->aid_base[mid] : p_favor->aid_inc[mid]))
370                          {                          {
371                                  right = mid;                                  right = mid - 1;
372                          }                          }
373                          else if (aid > (i == 0 ? p_favor->aid_base[mid] : p_favor->aid_inc[mid]))                          else if (aid > (i == 0 ? p_favor->aid_base[mid] : p_favor->aid_inc[mid]))
374                          {                          {
# Line 388  int article_favor_set(int32_t aid, ARTIC Line 394  int article_favor_set(int32_t aid, ARTIC
394    
395          if (aid == p_favor->aid_inc[left] && p_favor->aid_inc_cnt > 0) // Unset          if (aid == p_favor->aid_inc[left] && p_favor->aid_inc_cnt > 0) // Unset
396          {          {
397                  for (i = left; i < p_favor->aid_inc_cnt - 1; i++)                  if (p_favor->aid_inc_cnt > left + 1)
398                  {                  {
399                          p_favor->aid_inc[i] = p_favor->aid_inc[i + 1];                          memmove(p_favor->aid_inc + left,
400                                            p_favor->aid_inc + left + 1,
401                                            sizeof(int32_t) * (size_t)(p_favor->aid_inc_cnt - left - 1));
402                  }                  }
403    
404                  (p_favor->aid_inc_cnt)--;                  (p_favor->aid_inc_cnt)--;
# Line 424  int article_favor_set(int32_t aid, ARTIC Line 432  int article_favor_set(int32_t aid, ARTIC
432                  right = left + 1;                  right = left + 1;
433          }          }
434    
435          for (i = p_favor->aid_inc_cnt - 1; i >= right; i--)          if (p_favor->aid_inc_cnt > right)
436          {          {
437                  p_favor->aid_inc[i + 1] = p_favor->aid_inc[i];                  memmove(p_favor->aid_inc + right + 1,
438                                    p_favor->aid_inc + right,
439                                    sizeof(int32_t) * (size_t)(p_favor->aid_inc_cnt - right));
440          }          }
441    
442          p_favor->aid_inc[right] = aid;          p_favor->aid_inc[right] = aid;
# Line 494  int query_favor_articles(ARTICLE_FAVOR * Line 504  int query_favor_articles(ARTICLE_FAVOR *
504                          return -3;                          return -3;
505                  }                  }
506    
507                  // acquire lock of section                  if (get_section_info(p_section, p_snames[i], NULL, NULL) < 0)
                 if (section_list_rd_lock(p_section) < 0)  
                 {  
                         log_error("section_list_rd_lock(sid = %d) error\n", p_section->sid);  
                         return -4;  
                 }  
   
                 memcpy(p_snames[i], p_section->sname, sizeof(p_snames[i]));  
   
                 // release lock of section  
                 if (section_list_rd_unlock(p_section) < 0)  
508                  {                  {
509                          log_error("section_list_rd_unlock(sid = %d) error\n", p_section->sid);                          log_error("get_section_info(sid=%d) error\n", p_section->sid);
510                          return -4;                          return -4;
511                  }                  }
512          }          }


Legend:
Removed lines/characters  
Changed lines/characters
  Added lines/characters

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