emacs-diffs
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

[Emacs-diffs] Changes to emacs/src/syntax.c


From: Kenichi Handa
Subject: [Emacs-diffs] Changes to emacs/src/syntax.c
Date: Wed, 23 Apr 2003 21:27:55 -0400

Index: emacs/src/syntax.c
diff -c emacs/src/syntax.c:1.163 emacs/src/syntax.c:1.164
*** emacs/src/syntax.c:1.163    Mon Feb 24 20:36:23 2003
--- emacs/src/syntax.c  Wed Apr 23 21:27:55 2003
***************
*** 1504,1509 ****
--- 1504,1521 ----
      int start_point = PT;
      int pos = PT;
      int pos_byte = PT_BYTE;
+     unsigned char *p = PT_ADDR, *endp, *stop;
+ 
+     if (forwardp)
+       {
+       endp = (XINT (lim) == GPT) ? GPT_ADDR : CHAR_POS_ADDR (XINT (lim));
+       stop = (pos < GPT && GPT < XINT (lim)) ? GPT_ADDR : endp; 
+       }
+     else
+       {
+       endp = CHAR_POS_ADDR (XINT (lim));
+       stop = (pos >= GPT && GPT > XINT (lim)) ? GAP_END_ADDR : endp; 
+       }
  
      immediate_quit = 1;
      if (syntaxp)
***************
*** 1512,1571 ****
        if (forwardp)
          {
            if (multibyte)
!             {
!               if (pos < XINT (lim))
!                 while (fastmap[(int) SYNTAX (FETCH_CHAR (pos_byte))])
!                   {
!                     /* Since we already checked for multibyteness,
!                        avoid using INC_BOTH which checks again.  */
!                     INC_POS (pos_byte);
!                     pos++;
!                     if (pos >= XINT (lim))
!                       break;
!                     UPDATE_SYNTAX_TABLE_FORWARD (pos);
                    }
!             }
            else
!             {
!               while (pos < XINT (lim)
!                      && fastmap[(int) SYNTAX (FETCH_BYTE (pos))])
!                 {
!                   pos++;
!                   UPDATE_SYNTAX_TABLE_FORWARD (pos);
!                 }
!             }
          }
        else
          {
            if (multibyte)
!             {
!               while (pos > XINT (lim))
!                 {
!                   int savepos = pos_byte;
!                   /* Since we already checked for multibyteness,
!                      avoid using DEC_BOTH which checks again.  */
!                   pos--;
!                   DEC_POS (pos_byte);
!                   UPDATE_SYNTAX_TABLE_BACKWARD (pos);
!                   if (!fastmap[(int) SYNTAX (FETCH_CHAR (pos_byte))])
!                     {
!                       pos++;
!                       pos_byte = savepos;
!                       break;
!                     }
!                 }
!             }
            else
!             {
!               if (pos > XINT (lim))
!                 while (fastmap[(int) SYNTAX (FETCH_BYTE (pos - 1))])
                    {
!                     pos--;
!                     if (pos <= XINT (lim))
                        break;
!                     UPDATE_SYNTAX_TABLE_BACKWARD (pos - 1);
                    }
!             }
          }
        }
      else
--- 1524,1608 ----
        if (forwardp)
          {
            if (multibyte)
!             while (1)
!               {
!                 int nbytes;
! 
!                 if (p >= stop)
!                   {
!                     if (p >= endp)
!                       break;
!                     p = GAP_END_ADDR;
!                     stop = endp;
                    }
!                 c = STRING_CHAR_AND_LENGTH (p, MAX_MULTIBYTE_LENGTH, nbytes);
!                 if (! fastmap[(int) SYNTAX (c)])
!                   break;
!                 p += nbytes, pos++, pos_byte += nbytes;
!                 UPDATE_SYNTAX_TABLE_FORWARD (pos);
!               }
            else
!             while (1)
!               {
!                 if (p >= stop)
!                   {
!                     if (p >= endp)
!                       break;
!                     p = GAP_END_ADDR;
!                     stop = endp;
!                   }
!                 if (! fastmap[(int) SYNTAX (*p)])
!                   break;
!                 p++, pos++;
!                 UPDATE_SYNTAX_TABLE_FORWARD (pos);
!               }
          }
        else
          {
            if (multibyte)
!             while (1)
!               {
!                 unsigned char *prev_p;
!                 int nbytes;
! 
!                 if (p <= stop)
!                   {
!                     if (p <= endp)
!                       break;
!                     p = GPT_ADDR;
!                     stop = endp;
!                   }
!                 prev_p = p;
!                 while (--p >= stop && ! CHAR_HEAD_P (*p));
!                 PARSE_MULTIBYTE_SEQ (p, MAX_MULTIBYTE_LENGTH, nbytes);
!                 if (prev_p - p > nbytes)
!                   p = prev_p - 1, c = *p, nbytes = 1;
!                 else
!                   c = STRING_CHAR (p, MAX_MULTIBYTE_LENGTH);
!                 pos--, pos_byte -= nbytes;
!                 UPDATE_SYNTAX_TABLE_BACKWARD (pos);
!                 if (! fastmap[(int) SYNTAX (c)])
!                   {
!                     pos++;
!                     pos_byte += nbytes;
!                     break;
!                   }
!               }
            else
!             while (1)
!               {
!                 if (p <= stop)
                    {
!                     if (p <= endp)
                        break;
!                     p = GPT_ADDR;
!                     stop = endp;
                    }
!                 if (! fastmap[(int) SYNTAX (p[-1])])
!                   break;
!                 p--, pos--;
!                 UPDATE_SYNTAX_TABLE_BACKWARD (pos - 1);
!               }
          }
        }
      else
***************
*** 1573,1581 ****
        if (forwardp)
          {
            if (multibyte)
!             while (pos < XINT (lim))
                {
!                 c = FETCH_MULTIBYTE_CHAR (pos_byte);
                  if (SINGLE_BYTE_CHAR_P (c))
                    {
                      if (!fastmap[c])
--- 1610,1627 ----
        if (forwardp)
          {
            if (multibyte)
!             while (1)
                {
!                 int nbytes;
! 
!                 if (p >= stop)
!                   {
!                     if (p >= endp)
!                       break;
!                     p = GAP_END_ADDR;
!                     stop = endp;
!                   }
!                 c = STRING_CHAR_AND_LENGTH (p, MAX_MULTIBYTE_LENGTH, nbytes);
                  if (SINGLE_BYTE_CHAR_P (c))
                    {
                      if (!fastmap[c])
***************
*** 1598,1618 ****
                      if (!(negate ^ (i < n_char_ranges)))
                        break;
                    }
!                 INC_BOTH (pos, pos_byte);
                }
            else
!             while (pos < XINT (lim) && fastmap[FETCH_BYTE (pos)])
!               pos++;
          }
        else
          {
            if (multibyte)
!             while (pos > XINT (lim))
                {
!                 int prev_pos_byte = pos_byte;
  
!                 DEC_POS (prev_pos_byte);
!                 c = FETCH_MULTIBYTE_CHAR (prev_pos_byte);
                  if (SINGLE_BYTE_CHAR_P (c))
                    {
                      if (!fastmap[c])
--- 1644,1688 ----
                      if (!(negate ^ (i < n_char_ranges)))
                        break;
                    }
!                 p += nbytes, pos++, pos_byte += nbytes;
                }
            else
!             while (1)
!               {
!                 if (p >= stop)
!                   {
!                     if (p >= endp)
!                       break;
!                     p = GAP_END_ADDR;
!                     stop = endp;
!                   }
!                 if (fastmap[*p])
!                   break;
!                 p++, pos++;
!               }
          }
        else
          {
            if (multibyte)
!             while (1)
                {
!                 unsigned char *prev_p;
!                 int nbytes;
  
!                 if (p <= stop)
!                   {
!                     if (p <= endp)
!                       break;
!                     p = GPT_ADDR;
!                     stop = endp;
!                   }
!                 prev_p = p;
!                 while (--p >= stop && ! CHAR_HEAD_P (*p));
!                 PARSE_MULTIBYTE_SEQ (p, MAX_MULTIBYTE_LENGTH, nbytes);
!                 if (prev_p - p > nbytes)
!                   p = prev_p - 1, c = *p, nbytes = 1;
!                 else
!                   c = STRING_CHAR (p, MAX_MULTIBYTE_LENGTH);
                  if (SINGLE_BYTE_CHAR_P (c))
                    {
                      if (!fastmap[c])
***************
*** 1627,1638 ****
                      if (!(negate ^ (i < n_char_ranges)))
                        break;
                    }
!                 pos--;
!                 pos_byte = prev_pos_byte;
                }
            else
!             while (pos > XINT (lim) && fastmap[FETCH_BYTE (pos - 1)])
!               pos--;
          }
        }
  
--- 1697,1718 ----
                      if (!(negate ^ (i < n_char_ranges)))
                        break;
                    }
!                 pos--, pos_byte -= nbytes;
                }
            else
!             while (1)
!               {
!                 if (p <= stop)
!                   {
!                     if (p <= endp)
!                       break;
!                     p = GPT_ADDR;
!                     stop = endp;
!                   }
!                 if (fastmap[p[-1]])
!                   break;
!                 p--, pos--;
!               }
          }
        }
  




reply via email to

[Prev in Thread] Current Thread [Next in Thread]