/[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.7 by sysadm, Tue Nov 4 13:49:50 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 by Leaflet <leaflet@leafok.com>
7     */
 /***************************************************************************  
  *                                                                         *  
  *   This program 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 3 of the License, or     *  
  *   (at your option) any later version.                                   *  
  *                                                                         *  
  ***************************************************************************/  
8    
9  #include "article_favor.h"  #include "article_favor.h"
10  #include "common.h"  #include "common.h"
# Line 20  Line 12 
12  #include "log.h"  #include "log.h"
13  #include <stdlib.h>  #include <stdlib.h>
14  #include <string.h>  #include <string.h>
15    #include <sys/param.h>
16    
17  ARTICLE_FAVOR BBS_article_favor;  ARTICLE_FAVOR BBS_article_favor;
18    
# Line 147  int article_favor_save_inc(const ARTICLE Line 140  int article_favor_save_inc(const ARTICLE
140                           "DELETE FROM article_favorite WHERE UID = %d AND AID IN (",                           "DELETE FROM article_favorite WHERE UID = %d AND AID IN (",
141                           p_favor->uid);                           p_favor->uid);
142    
143          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;)
144          {          {
145                  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
146                  {                  {
147                          snprintf(tuple_tmp, sizeof(tuple_tmp), "%d, ", p_favor->aid_inc[j]);                          snprintf(tuple_tmp, sizeof(tuple_tmp), "%d, ", p_favor->aid_inc[j]);
148                          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 151  int article_favor_save_inc(const ARTICLE
151                          i++;                          i++;
152                          j++;                          j++;
153                  }                  }
154                  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
155                  {                  {
156                          i++;                          i++;
157                  }                  }
158                  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])
159                  {                  {
160                          snprintf(tuple_tmp, sizeof(tuple_tmp),                          snprintf(tuple_tmp, sizeof(tuple_tmp),
161                                           "(%d, %d), ",                                           "(%d, %d), ",
# Line 227  int article_favor_merge_inc(ARTICLE_FAVO Line 220  int article_favor_merge_inc(ARTICLE_FAVO
220  {  {
221          int32_t aid_new[MAX_FAVOR_AID_BASE_CNT];          int32_t aid_new[MAX_FAVOR_AID_BASE_CNT];
222          int i, j, k;          int i, j, k;
223            int len;
224    
225          if (p_favor == NULL)          if (p_favor == NULL)
226          {          {
# Line 256  int article_favor_merge_inc(ARTICLE_FAVO Line 250  int article_favor_merge_inc(ARTICLE_FAVO
250                  }                  }
251          }          }
252    
253          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);
254            if (len > 0)
255          {          {
256                  aid_new[k++] = p_favor->aid_base[i++];                  memcpy(aid_new + k, p_favor->aid_base + i,
257                               sizeof(int32_t) * (size_t)len);
258                    i += len;
259                    k += len;
260          }          }
261          if (i < p_favor->aid_base_cnt)          if (i < p_favor->aid_base_cnt)
262          {          {
263                  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);
264          }          }
265    
266          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);
267            if (len > 0)
268          {          {
269                  aid_new[k++] = p_favor->aid_inc[j++];                  memcpy(aid_new + k, p_favor->aid_inc + j,
270                               sizeof(int32_t) * (size_t)len);
271                    j += len;
272                    k += len;
273          }          }
274          if (j < p_favor->aid_inc_cnt)          if (j < p_favor->aid_inc_cnt)
275          {          {
# Line 311  int article_favor_check(int32_t aid, con Line 313  int article_favor_check(int32_t aid, con
313                          mid = (left + right) / 2;                          mid = (left + right) / 2;
314                          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]))
315                          {                          {
316                                  right = mid;                                  right = mid - 1;
317                          }                          }
318                          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]))
319                          {                          {
# Line 362  int article_favor_set(int32_t aid, ARTIC Line 364  int article_favor_set(int32_t aid, ARTIC
364                          mid = (left + right) / 2;                          mid = (left + right) / 2;
365                          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]))
366                          {                          {
367                                  right = mid;                                  right = mid - 1;
368                          }                          }
369                          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]))
370                          {                          {
# Line 388  int article_favor_set(int32_t aid, ARTIC Line 390  int article_favor_set(int32_t aid, ARTIC
390    
391          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
392          {          {
393                  for (i = left; i < p_favor->aid_inc_cnt - 1; i++)                  if (p_favor->aid_inc_cnt > left + 1)
394                  {                  {
395                          p_favor->aid_inc[i] = p_favor->aid_inc[i + 1];                          memmove(p_favor->aid_inc + left,
396                                            p_favor->aid_inc + left + 1,
397                                            sizeof(int32_t) * (size_t)(p_favor->aid_inc_cnt - left - 1));
398                  }                  }
399    
400                  (p_favor->aid_inc_cnt)--;                  (p_favor->aid_inc_cnt)--;
# Line 424  int article_favor_set(int32_t aid, ARTIC Line 428  int article_favor_set(int32_t aid, ARTIC
428                  right = left + 1;                  right = left + 1;
429          }          }
430    
431          for (i = p_favor->aid_inc_cnt - 1; i >= right; i--)          if (p_favor->aid_inc_cnt > right)
432          {          {
433                  p_favor->aid_inc[i + 1] = p_favor->aid_inc[i];                  memmove(p_favor->aid_inc + right + 1,
434                                    p_favor->aid_inc + right,
435                                    sizeof(int32_t) * (size_t)(p_favor->aid_inc_cnt - right));
436          }          }
437    
438          p_favor->aid_inc[right] = aid;          p_favor->aid_inc[right] = aid;
# Line 494  int query_favor_articles(ARTICLE_FAVOR * Line 500  int query_favor_articles(ARTICLE_FAVOR *
500                          return -3;                          return -3;
501                  }                  }
502    
503                  // 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)  
504                  {                  {
505                          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);
506                          return -4;                          return -4;
507                  }                  }
508          }          }


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

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