ftp.nice.ch/Attic/openStep/developer/resources/MiscKit.2.0.5.s.gnutar.gz#/MiscKit2/Temp/regex/framework/rxgnucomp.h

This is rxgnucomp.h in view mode; [Download] [Up]

/* classes: h_files */

#ifndef RXGNUCOMPH
#define RXGNUCOMPH
/*	Copyright (C) 1992, 1993, 1994, 1995 Free Software Foundation, Inc.
 *
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU Library General Public License as published by
 * the Free Software Foundation; either version 2, or (at your option)
 * any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU Library General Public License for more details.
 *
 * You should have received a copy of the GNU Library General Public License
 * along with this software; see the file COPYING.  If not, write to
 * the Free Software Foundation, 59 Temple Place - Suite 330,
 * Boston, MA 02111-1307, USA.
 */



#include "rxcset.h"
#include "rxnode.h"




/* This is an array of error messages corresponding to the error codes.
 */
extern const char *rx_error_msg[];



/* {Syntax Bits}
 */

/* The following bits are used to determine the regexp syntax we
   recognize.  The set/not-set meanings are chosen so that Emacs syntax
   remains the value 0.  The bits are given in alphabetical order, and
   the definitions shifted by one from the previous bit; thus, when we
   add or remove a bit, only one other definition need change.  */

enum RE_SYNTAX_BITS
{
/* If this bit is not set, then \ inside a bracket expression is literal.
   If set, then such a \ quotes the following character.  */
  RE_BACKSLASH_ESCAPE_IN_LISTS = (1),

/* If this bit is not set, then + and ? are operators, and \+ and \? are
     literals.
   If set, then \+ and \? are operators and + and ? are literals.  */
  RE_BK_PLUS_QM = (RE_BACKSLASH_ESCAPE_IN_LISTS << 1),

/* If this bit is set, then character classes are supported.  They are:
     [:alpha:], [:upper:], [:lower:],  [:digit:], [:alnum:], [:xdigit:],
     [:space:], [:print:], [:punct:], [:graph:], and [:cntrl:].
   If not set, then character classes are not supported.  */
  RE_CHAR_CLASSES = (RE_BK_PLUS_QM << 1),

/* If this bit is set, then ^ and $ are always anchors (outside bracket
     expressions, of course).
   If this bit is not set, then it depends:
        ^  is an anchor if it is at the beginning of a regular
           expression or after an open-group or an alternation operator;
        $  is an anchor if it is at the end of a regular expression, or
           before a close-group or an alternation operator.

   This bit could be (re)combined with RE_CONTEXT_INDEP_OPS, because
   POSIX draft 11.2 says that * etc. in leading positions is undefined.
   We already implemented a previous draft which made those constructs
   invalid, though, so we haven't changed the code back.  */
  RE_CONTEXT_INDEP_ANCHORS = (RE_CHAR_CLASSES << 1),

/* If this bit is set, then special characters are always special
     regardless of where they are in the pattern.
   If this bit is not set, then special characters are special only in
     some contexts; otherwise they are ordinary.  Specifically,
     * + ? and intervals are only special when not after the beginning,
     open-group, or alternation operator.  */
  RE_CONTEXT_INDEP_OPS = (RE_CONTEXT_INDEP_ANCHORS << 1),

/* If this bit is set, then *, +, ?, and { cannot be first in an re or
     immediately after an alternation or begin-group operator.  */
  RE_CONTEXT_INVALID_OPS = (RE_CONTEXT_INDEP_OPS << 1),

/* If this bit is set, then . matches newline.
   If not set, then it doesn't.  */
  RE_DOT_NEWLINE = (RE_CONTEXT_INVALID_OPS << 1),

/* If this bit is set, then . doesn't match NUL.
   If not set, then it does.  */
  RE_DOT_NOT_NULL = (RE_DOT_NEWLINE << 1),

/* If this bit is set, nonmatching lists [^...] do not match newline.
   If not set, they do.  */
  RE_HAT_LISTS_NOT_NEWLINE = (RE_DOT_NOT_NULL << 1),

/* If this bit is set, either \{...\} or {...} defines an
     interval, depending on RE_NO_BK_BRACES.
   If not set, \{, \}, {, and } are literals.  */
  RE_INTERVALS = (RE_HAT_LISTS_NOT_NEWLINE << 1),

/* If this bit is set, +, ? and | aren't recognized as operators.
   If not set, they are.  */
  RE_LIMITED_OPS = (RE_INTERVALS << 1),

/* If this bit is set, newline is an alternation operator.
   If not set, newline is literal.  */
  RE_NEWLINE_ALT = (RE_LIMITED_OPS << 1),

/* If this bit is set, then `{...}' defines an interval, and \{ and \}
     are literals.
  If not set, then `\{...\}' defines an interval.  */
  RE_NO_BK_BRACES = (RE_NEWLINE_ALT << 1),

/* If this bit is set, (...) defines a group, and \( and \) are literals.
   If not set, \(...\) defines a group, and ( and ) are literals.  */
  RE_NO_BK_PARENS = (RE_NO_BK_BRACES << 1),

/* If this bit is set, then \<digit> matches <digit>.
   If not set, then \<digit> is a back-reference.  */
  RE_NO_BK_REFS = (RE_NO_BK_PARENS << 1),

/* If this bit is set, then | is an alternation operator, and \| is literal.
   If not set, then \| is an alternation operator, and | is literal.  */
  RE_NO_BK_VBAR = (RE_NO_BK_REFS << 1),

/* If this bit is set, then an ending range point collating higher
     than the starting range point, as in [z-a], is invalid.
   If not set, then when ending range point collates higher than the
     starting range point, the range is ignored.  */
  RE_NO_EMPTY_RANGES = (RE_NO_BK_VBAR << 1),

/* If this bit is set, then an unmatched ) is ordinary.
   If not set, then an unmatched ) is invalid.  */
  RE_UNMATCHED_RIGHT_PAREN_ORD = (RE_NO_EMPTY_RANGES << 1),

  RE_SYNTAX_EMACS = 0,

  RE_SYNTAX_AWK = (RE_BACKSLASH_ESCAPE_IN_LISTS | RE_DOT_NOT_NULL
		   | RE_NO_BK_PARENS            | RE_NO_BK_REFS
		   | RE_NO_BK_VBAR               | RE_NO_EMPTY_RANGES
		   | RE_UNMATCHED_RIGHT_PAREN_ORD),

  RE_SYNTAX_GREP = (RE_BK_PLUS_QM              | RE_CHAR_CLASSES
		    | RE_HAT_LISTS_NOT_NEWLINE | RE_INTERVALS
		    | RE_NEWLINE_ALT),

  RE_SYNTAX_EGREP = (RE_CHAR_CLASSES        | RE_CONTEXT_INDEP_ANCHORS
		     | RE_CONTEXT_INDEP_OPS | RE_HAT_LISTS_NOT_NEWLINE
		     | RE_NEWLINE_ALT       | RE_NO_BK_PARENS
		     | RE_NO_BK_VBAR),

  RE_SYNTAX_POSIX_EGREP = (RE_SYNTAX_EGREP | RE_INTERVALS | RE_NO_BK_BRACES),

  /* Syntax bits common to both basic and extended POSIX regex syntax.  */
  _RE_SYNTAX_POSIX_COMMON = (RE_CHAR_CLASSES | RE_DOT_NEWLINE      | RE_DOT_NOT_NULL
			     | RE_INTERVALS  | RE_NO_EMPTY_RANGES),

  RE_SYNTAX_POSIX_BASIC = (_RE_SYNTAX_POSIX_COMMON | RE_BK_PLUS_QM),

  /* Differs from ..._POSIX_BASIC only in that RE_BK_PLUS_QM becomes
     RE_LIMITED_OPS, i.e., \? \+ \| are not recognized.  */

  RE_SYNTAX_POSIX_MINIMAL_BASIC = (_RE_SYNTAX_POSIX_COMMON | RE_LIMITED_OPS),

  RE_SYNTAX_POSIX_EXTENDED = (_RE_SYNTAX_POSIX_COMMON | RE_CONTEXT_INDEP_ANCHORS
			      | RE_CONTEXT_INDEP_OPS  | RE_NO_BK_BRACES
			      | RE_NO_BK_PARENS       | RE_NO_BK_VBAR
			      | RE_UNMATCHED_RIGHT_PAREN_ORD),

  /* Differs from ..._POSIX_EXTENDED in that RE_CONTEXT_INVALID_OPS
     replaces RE_CONTEXT_INDEP_OPS and RE_NO_BK_REFS is added.  */
  RE_SYNTAX_POSIX_MINIMAL_EXTENDED = (_RE_SYNTAX_POSIX_COMMON  | RE_CONTEXT_INDEP_ANCHORS
				      | RE_CONTEXT_INVALID_OPS | RE_NO_BK_BRACES
				      | RE_NO_BK_PARENS        | RE_NO_BK_REFS
				      | RE_NO_BK_VBAR	    | RE_UNMATCHED_RIGHT_PAREN_ORD),

  RE_SYNTAX_SED = RE_SYNTAX_POSIX_BASIC,

  RE_SYNTAX_POSIX_AWK = (RE_SYNTAX_POSIX_EXTENDED | RE_BACKSLASH_ESCAPE_IN_LISTS)
};


/* Maximum number of duplicates an interval can allow.  Some systems
   (erroneously) define this in other header files, but we want our
   value, so remove any previous define.  */
#undef RE_DUP_MAX
#define RE_DUP_MAX ((1 << 15) - 1)



#ifdef __STDC__
extern int rx_parse (struct rexp_node ** rexp_p,
			       const char *pattern,
			       int size,
			       unsigned long syntax,
			       int cset_size,
			       unsigned char *translate);

#else /* STDC */
extern int rx_parse ();

#endif /* STDC */


#endif  /* RXGNUCOMPH */

These are the contents of the former NiCE NeXT User Group NeXTSTEP/OpenStep software archive, currently hosted by Netfuture.ch.