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

Diff of /lbbs/src/str_process.c

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

Revision 1.8 by sysadm, Thu May 15 14:17:53 2025 UTC Revision 1.21 by sysadm, Sat Oct 18 12:06:10 2025 UTC
# Line 14  Line 14 
14   *                                                                         *   *                                                                         *
15   ***************************************************************************/   ***************************************************************************/
16    
 #include "str_process.h"  
17  #include "common.h"  #include "common.h"
18  #include "log.h"  #include "log.h"
19    #include "str_process.h"
20  #include <stdio.h>  #include <stdio.h>
21  #include <string.h>  #include <string.h>
22    
23  int split_line(const char *buffer, int max_display_len, int *p_eol, int *p_display_len)  int str_length(const char *str, int skip_ctrl_seq)
24  {  {
25          int i;          int i;
26          *p_eol = 0;          char c;
27          *p_display_len = 0;          int ret = 0;
28    
29          for (i = 0; buffer[i] != '\0'; i++)          for (i = 0; str[i] != '\0'; i++)
30          {          {
31                  char c = buffer[i];                  c = str[i];
32    
33                  if (c == '\r' || c == '\7') // skip                  if (c == '\r' || c == '\7') // skip
34                  {                  {
35                          continue;                          continue;
36                  }                  }
37    
38                  if (c == '\n')                  if (skip_ctrl_seq && c == '\033' && str[i + 1] == '[') // Skip control sequence
39                  {                  {
40                          i++;                          i += 2;
41                          *p_eol = 1;                          while (str[i] != '\0' && str[i] != 'm')
42                          break;                          {
43                                    i++;
44                            }
45                            continue;
46                  }                  }
47    
48                  if (c == '\033' && buffer[i + 1] == '[') // Skip control sequence                  // Process UTF-8 Chinese characters
49                    if (c & 0x80) // head of multi-byte character
50                    {
51                            c = (c & 0x70) << 1;
52                            while (c & 0x80)
53                            {
54                                    i++;
55                                    c = (c & 0x7f) << 1;
56                            }
57    
58                            ret += 2;
59                    }
60                    else
61                    {
62                            ret++;
63                    }
64            }
65    
66            return ret;
67    }
68    
69    int split_line(const char *buffer, int max_display_len, int *p_eol, int *p_display_len, int skip_ctrl_seq)
70    {
71            int i;
72            *p_eol = 0;
73            *p_display_len = 0;
74            char c;
75    
76            for (i = 0; buffer[i] != '\0'; i++)
77            {
78                    c = buffer[i];
79    
80                    if (c == '\r' || c == '\7') // skip
81                    {
82                            continue;
83                    }
84    
85                    if (skip_ctrl_seq && c == '\033' && buffer[i + 1] == '[') // Skip control sequence
86                  {                  {
87                          i += 2;                          i += 2;
88                          while (buffer[i] != '\0' && buffer[i] != 'm')                          while (buffer[i] != '\0' && buffer[i] != 'm')
# Line 52  int split_line(const char *buffer, int m Line 92  int split_line(const char *buffer, int m
92                          continue;                          continue;
93                  }                  }
94    
95                  if (c > 127 && c <= 255) // GBK chinese character                  if (c & 0x80) // head of multi-byte character
96                  {                  {
97                          if (*p_display_len + 2 > max_display_len)                          if (*p_display_len + 2 > max_display_len)
98                          {                          {
                                 *p_eol = 1;  
99                                  break;                                  break;
100                          }                          }
101                          i++;  
102                          *p_display_len += 2;                          c = (c & 0x70) << 1;
103                            while (c & 0x80)
104                            {
105                                    i++;
106                                    c = (c & 0x7f) << 1;
107                            }
108    
109                            (*p_display_len) += 2;
110                  }                  }
111                  else                  else
112                  {                  {
113                          if (*p_display_len + 1 > max_display_len)                          if (*p_display_len + 1 > max_display_len)
114                          {                          {
                                 *p_eol = 1;  
115                                  break;                                  break;
116                          }                          }
117                          (*p_display_len)++;                          (*p_display_len)++;
118    
119                            // \n is regarded as 1 character wide in terminal editor, which is different from Web version
120                            if (c == '\n')
121                            {
122                                    i++;
123                                    *p_eol = 1;
124                                    break;
125                            }
126                  }                  }
127          }          }
128    
129          return i;          return i;
130  }  }
131    
132  int split_data_lines(const char *p_buf, int max_display_len, long *p_line_offsets, int max_line_cnt)  long split_data_lines(const char *p_buf, int max_display_len, long *p_line_offsets, long line_offsets_count,
133                                              int skip_ctrl_seq, int *p_line_widths)
134  {  {
135          int line_cnt = 0;          int line_cnt = 0;
136          int len = 0;          int len;
137          int end_of_line = 0;          int end_of_line = 0;
138          int display_len = 0;          int display_len = 0;
139    
140          p_line_offsets[line_cnt] = 0L;          p_line_offsets[line_cnt] = 0L;
141    
142          while (1)          do
143          {          {
144                  len = split_line(p_buf, max_display_len, &end_of_line, &display_len);                  len = split_line(p_buf, max_display_len, &end_of_line, &display_len, skip_ctrl_seq);
145    
146                  if (len == 0 || !end_of_line) // !end_of_line == EOF                  if (p_line_widths)
147                  {                  {
148                          break;                          p_line_widths[line_cnt] = display_len;
149                  }                  }
150    
151                  // Exceed max_line_cnt                  // Exceed max_line_cnt
152                  if (line_cnt + 1 >= max_line_cnt)                  if (line_cnt + 1 >= line_offsets_count)
153                  {                  {
154                          log_error("File line count %d reaches limit\n", line_cnt + 1);                          // log_error("Line count %d reaches limit %d\n", line_cnt + 1, line_offsets_count);
155                          return line_cnt;                          return line_cnt;
156                  }                  }
157    
158                  p_line_offsets[line_cnt + 1] = p_line_offsets[line_cnt] + len;                  p_line_offsets[line_cnt + 1] = p_line_offsets[line_cnt] + len;
159                  line_cnt++;                  line_cnt++;
160                  p_buf += len;                  p_buf += len;
161          }          } while (p_buf[0] != '\0');
162    
163            return line_cnt;
164    }
165    
166    int str_filter(char *buffer, int skip_ctrl_seq)
167    {
168            int i;
169            int j;
170    
171          if (len > 0 && line_cnt + 1 < max_line_cnt)          for (i = 0, j = 0; buffer[i] != '\0'; i++)
172          {          {
173                  p_line_offsets[line_cnt + 1] = p_line_offsets[line_cnt] + len;                  if (buffer[i] == '\r' || buffer[i] == '\7') // skip
174                  line_cnt++;                  {
175                            continue;
176                    }
177    
178                    if (skip_ctrl_seq && buffer[i] == '\033' && buffer[i + 1] == '[') // Skip control sequence
179                    {
180                            i += 2;
181                            while (buffer[i] != '\0' && buffer[i] != 'm')
182                            {
183                                    i++;
184                            }
185                            continue;
186                    }
187    
188                    buffer[j] = buffer[i];
189                    j++;
190          }          }
191    
192          return line_cnt;          buffer[j] = '\0';
193    
194            return j;
195  }  }


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

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