OpenCores
URL https://opencores.org/ocsvn/openrisc/openrisc/trunk

Subversion Repositories openrisc

[/] [openrisc/] [trunk/] [gnu-old/] [gdb-6.8/] [readline/] [parens.c] - Diff between revs 827 and 840

Go to most recent revision | Only display areas with differences | Details | Blame | View Log

Rev 827 Rev 840
/* parens.c -- Implementation of matching parentheses feature. */
/* parens.c -- Implementation of matching parentheses feature. */
 
 
/* Copyright (C) 1987, 1989, 1992 Free Software Foundation, Inc.
/* Copyright (C) 1987, 1989, 1992 Free Software Foundation, Inc.
 
 
   This file is part of the GNU Readline Library, a library for
   This file is part of the GNU Readline Library, a library for
   reading lines of text with interactive input and history editing.
   reading lines of text with interactive input and history editing.
 
 
   The GNU Readline Library is free software; you can redistribute it
   The GNU Readline Library is free software; you can redistribute it
   and/or modify it under the terms of the GNU General Public License
   and/or modify it under the terms of the GNU General Public License
   as published by the Free Software Foundation; either version 2, or
   as published by the Free Software Foundation; either version 2, or
   (at your option) any later version.
   (at your option) any later version.
 
 
   The GNU Readline Library is distributed in the hope that it will be
   The GNU Readline Library is distributed in the hope that it will be
   useful, but WITHOUT ANY WARRANTY; without even the implied warranty
   useful, but WITHOUT ANY WARRANTY; without even the implied warranty
   of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
   of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
   GNU General Public License for more details.
   GNU General Public License for more details.
 
 
   The GNU General Public License is often shipped with GNU software, and
   The GNU General Public License is often shipped with GNU software, and
   is generally kept in a file called COPYING or LICENSE.  If you do not
   is generally kept in a file called COPYING or LICENSE.  If you do not
   have a copy of the license, write to the Free Software Foundation,
   have a copy of the license, write to the Free Software Foundation,
   59 Temple Place, Suite 330, Boston, MA 02111 USA. */
   59 Temple Place, Suite 330, Boston, MA 02111 USA. */
#define READLINE_LIBRARY
#define READLINE_LIBRARY
 
 
#if defined (__TANDEM)
#if defined (__TANDEM)
#  include <floss.h>
#  include <floss.h>
#endif
#endif
 
 
#include "rlconf.h"
#include "rlconf.h"
 
 
#if defined (HAVE_CONFIG_H)
#if defined (HAVE_CONFIG_H)
#  include <config.h>
#  include <config.h>
#endif
#endif
 
 
#include <stdio.h>
#include <stdio.h>
#include <sys/types.h>
#include <sys/types.h>
 
 
#if defined (HAVE_UNISTD_H)
#if defined (HAVE_UNISTD_H)
#  include <unistd.h>
#  include <unistd.h>
#endif
#endif
 
 
#if defined (FD_SET) && !defined (HAVE_SELECT)
#if defined (FD_SET) && !defined (HAVE_SELECT)
#  define HAVE_SELECT
#  define HAVE_SELECT
#endif
#endif
 
 
#if defined (HAVE_SELECT)
#if defined (HAVE_SELECT)
#  include <sys/time.h>
#  include <sys/time.h>
#endif /* HAVE_SELECT */
#endif /* HAVE_SELECT */
#if defined (HAVE_SYS_SELECT_H)
#if defined (HAVE_SYS_SELECT_H)
#  include <sys/select.h>
#  include <sys/select.h>
#endif
#endif
 
 
#if defined (HAVE_STRING_H)
#if defined (HAVE_STRING_H)
#  include <string.h>
#  include <string.h>
#else /* !HAVE_STRING_H */
#else /* !HAVE_STRING_H */
#  include <strings.h>
#  include <strings.h>
#endif /* !HAVE_STRING_H */
#endif /* !HAVE_STRING_H */
 
 
#if !defined (strchr) && !defined (__STDC__)
#if !defined (strchr) && !defined (__STDC__)
extern char *strchr (), *strrchr ();
extern char *strchr (), *strrchr ();
#endif /* !strchr && !__STDC__ */
#endif /* !strchr && !__STDC__ */
 
 
#include "readline.h"
#include "readline.h"
#include "rlprivate.h"
#include "rlprivate.h"
 
 
static int find_matching_open PARAMS((char *, int, int));
static int find_matching_open PARAMS((char *, int, int));
 
 
/* Non-zero means try to blink the matching open parenthesis when the
/* Non-zero means try to blink the matching open parenthesis when the
   close parenthesis is inserted. */
   close parenthesis is inserted. */
#if defined (HAVE_SELECT)
#if defined (HAVE_SELECT)
int rl_blink_matching_paren = 1;
int rl_blink_matching_paren = 1;
#else /* !HAVE_SELECT */
#else /* !HAVE_SELECT */
int rl_blink_matching_paren = 0;
int rl_blink_matching_paren = 0;
#endif /* !HAVE_SELECT */
#endif /* !HAVE_SELECT */
 
 
static int _paren_blink_usec = 500000;
static int _paren_blink_usec = 500000;
 
 
/* Change emacs_standard_keymap to have bindings for paren matching when
/* Change emacs_standard_keymap to have bindings for paren matching when
   ON_OR_OFF is 1, change them back to self_insert when ON_OR_OFF == 0. */
   ON_OR_OFF is 1, change them back to self_insert when ON_OR_OFF == 0. */
void
void
_rl_enable_paren_matching (on_or_off)
_rl_enable_paren_matching (on_or_off)
     int on_or_off;
     int on_or_off;
{
{
  if (on_or_off)
  if (on_or_off)
    {   /* ([{ */
    {   /* ([{ */
      rl_bind_key_in_map (')', rl_insert_close, emacs_standard_keymap);
      rl_bind_key_in_map (')', rl_insert_close, emacs_standard_keymap);
      rl_bind_key_in_map (']', rl_insert_close, emacs_standard_keymap);
      rl_bind_key_in_map (']', rl_insert_close, emacs_standard_keymap);
      rl_bind_key_in_map ('}', rl_insert_close, emacs_standard_keymap);
      rl_bind_key_in_map ('}', rl_insert_close, emacs_standard_keymap);
    }
    }
  else
  else
    {   /* ([{ */
    {   /* ([{ */
      rl_bind_key_in_map (')', rl_insert, emacs_standard_keymap);
      rl_bind_key_in_map (')', rl_insert, emacs_standard_keymap);
      rl_bind_key_in_map (']', rl_insert, emacs_standard_keymap);
      rl_bind_key_in_map (']', rl_insert, emacs_standard_keymap);
      rl_bind_key_in_map ('}', rl_insert, emacs_standard_keymap);
      rl_bind_key_in_map ('}', rl_insert, emacs_standard_keymap);
    }
    }
}
}
 
 
int
int
rl_set_paren_blink_timeout (u)
rl_set_paren_blink_timeout (u)
     int u;
     int u;
{
{
  int o;
  int o;
 
 
  o = _paren_blink_usec;
  o = _paren_blink_usec;
  if (u > 0)
  if (u > 0)
    _paren_blink_usec = u;
    _paren_blink_usec = u;
  return (o);
  return (o);
}
}
 
 
int
int
rl_insert_close (count, invoking_key)
rl_insert_close (count, invoking_key)
     int count, invoking_key;
     int count, invoking_key;
{
{
  if (rl_explicit_arg || !rl_blink_matching_paren)
  if (rl_explicit_arg || !rl_blink_matching_paren)
    _rl_insert_char (count, invoking_key);
    _rl_insert_char (count, invoking_key);
  else
  else
    {
    {
#if defined (HAVE_SELECT)
#if defined (HAVE_SELECT)
      int orig_point, match_point, ready;
      int orig_point, match_point, ready;
      struct timeval timer;
      struct timeval timer;
      fd_set readfds;
      fd_set readfds;
 
 
      _rl_insert_char (1, invoking_key);
      _rl_insert_char (1, invoking_key);
      (*rl_redisplay_function) ();
      (*rl_redisplay_function) ();
      match_point =
      match_point =
        find_matching_open (rl_line_buffer, rl_point - 2, invoking_key);
        find_matching_open (rl_line_buffer, rl_point - 2, invoking_key);
 
 
      /* Emacs might message or ring the bell here, but I don't. */
      /* Emacs might message or ring the bell here, but I don't. */
      if (match_point < 0)
      if (match_point < 0)
        return -1;
        return -1;
 
 
      FD_ZERO (&readfds);
      FD_ZERO (&readfds);
      FD_SET (fileno (rl_instream), &readfds);
      FD_SET (fileno (rl_instream), &readfds);
      timer.tv_sec = 0;
      timer.tv_sec = 0;
      timer.tv_usec = _paren_blink_usec;
      timer.tv_usec = _paren_blink_usec;
 
 
      orig_point = rl_point;
      orig_point = rl_point;
      rl_point = match_point;
      rl_point = match_point;
      (*rl_redisplay_function) ();
      (*rl_redisplay_function) ();
      ready = select (1, &readfds, (fd_set *)NULL, (fd_set *)NULL, &timer);
      ready = select (1, &readfds, (fd_set *)NULL, (fd_set *)NULL, &timer);
      rl_point = orig_point;
      rl_point = orig_point;
#else /* !HAVE_SELECT */
#else /* !HAVE_SELECT */
      _rl_insert_char (count, invoking_key);
      _rl_insert_char (count, invoking_key);
#endif /* !HAVE_SELECT */
#endif /* !HAVE_SELECT */
    }
    }
  return 0;
  return 0;
}
}
 
 
static int
static int
find_matching_open (string, from, closer)
find_matching_open (string, from, closer)
     char *string;
     char *string;
     int from, closer;
     int from, closer;
{
{
  register int i;
  register int i;
  int opener, level, delimiter;
  int opener, level, delimiter;
 
 
  switch (closer)
  switch (closer)
    {
    {
    case ']': opener = '['; break;
    case ']': opener = '['; break;
    case '}': opener = '{'; break;
    case '}': opener = '{'; break;
    case ')': opener = '('; break;
    case ')': opener = '('; break;
    default:
    default:
      return (-1);
      return (-1);
    }
    }
 
 
  level = 1;                    /* The closer passed in counts as 1. */
  level = 1;                    /* The closer passed in counts as 1. */
  delimiter = 0;         /* Delimited state unknown. */
  delimiter = 0;         /* Delimited state unknown. */
 
 
  for (i = from; i > -1; i--)
  for (i = from; i > -1; i--)
    {
    {
      if (delimiter && (string[i] == delimiter))
      if (delimiter && (string[i] == delimiter))
        delimiter = 0;
        delimiter = 0;
      else if (rl_basic_quote_characters && strchr (rl_basic_quote_characters, string[i]))
      else if (rl_basic_quote_characters && strchr (rl_basic_quote_characters, string[i]))
        delimiter = string[i];
        delimiter = string[i];
      else if (!delimiter && (string[i] == closer))
      else if (!delimiter && (string[i] == closer))
        level++;
        level++;
      else if (!delimiter && (string[i] == opener))
      else if (!delimiter && (string[i] == opener))
        level--;
        level--;
 
 
      if (!level)
      if (!level)
        break;
        break;
    }
    }
  return (i);
  return (i);
}
}
 
 

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.