summaryrefslogtreecommitdiffstats
path: root/Source/cmRegularExpression.cxx
diff options
context:
space:
mode:
Diffstat (limited to 'Source/cmRegularExpression.cxx')
-rw-r--r--Source/cmRegularExpression.cxx121
1 files changed, 18 insertions, 103 deletions
diff --git a/Source/cmRegularExpression.cxx b/Source/cmRegularExpression.cxx
index f97fc02..bf2b529 100644
--- a/Source/cmRegularExpression.cxx
+++ b/Source/cmRegularExpression.cxx
@@ -1,3 +1,18 @@
+/*=========================================================================
+
+ Program: Insight Segmentation & Registration Toolkit
+ Module: $RCSfile$
+ Language: C++
+ Date: $Date$
+ Version: $Revision$
+
+
+ Copyright (c) 2000 National Library of Medicine
+ All rights reserved.
+
+ See COPYRIGHT.txt for copyright details.
+
+=========================================================================*/
//
// Copyright (C) 1991 Texas Instruments Incorporated.
//
@@ -16,111 +31,12 @@
// Updated: MBN 12/15/89 Sprinkled "const" qualifiers all over the place!
// Updated: DLS 03/22/91 New lite version
//
-// This is the header file for the regular expression class. An object of
-// this class contains a regular expression, in a special "compiled" format.
-// This compiled format consists of several slots all kept as the objects
-// private data. The cmRegularExpression class provides a convenient way to represent
-// regular expressions. It makes it easy to search for the same regular
-// expression in many different strings without having to compile a string to
-// regular expression format more than necessary.
-//
-// A regular expression allows a programmer to specify complex patterns that
-// can be searched for and matched against the character string of a String
-// object. In its simplest case, a regular expression is a sequence of
-// characters with which you can search for exact character matches. However,
-// many times you may not know the exact sequence you want to find, or you may
-// only want to find a match at the beginning or end of a String. The cmRegularExpression
-// object allows specification of such patterns by utilizing the following
-// regular expression meta-characters (note that more one of these
-// meta-characters can be used in a single regular expression in order to
-// create complex search patterns):
-//
-// ^ Match at beginning of line
-// $ Match at end of line
-// . Match any single character
-// [ ] Match any one character inside the brackets
-// [^ ] Match any character NOT inside the brackets
-// - Match any character in range on either side of dash
-// * Match preceding pattern zero or more times
-// + Match preceding pattern one or more times
-// ? Match preceding pattern zero or once only
-// () Save a matched expression and use it in a further match.
-//
-// There are three constructors for cmRegularExpression. One just creates an empty cmRegularExpression
-// object. Another creates a cmRegularExpression object and initializes it with a regular
-// expression that is given in the form of a char*. The third takes a
-// reference to a cmRegularExpression object as an argument and creates an object
-// initialized with the information from the given cmRegularExpression object.
-//
-// The find member function finds the first occurence of the regualr
-// expression of that object in the string given to find as an argument. Find
-// returns a boolean, and if true, mutates the private data appropriately.
-// Find sets pointers to the beginning and end of the thing last found, they
-// are pointers into the actual string that was searched. The start and end
-// member functions return indicies into the searched string that correspond
-// to the beginning and end pointers respectively. The compile member
-// function takes a char* and puts the compiled version of the char* argument
-// into the object's private data fields. The == and != operators only check
-// the to see if the compiled regular expression is the same, and the
-// deep_equal functions also checks to see if the start and end pointers are
-// the same. The is_valid function returns false if program is set to NULL,
-// (i.e. there is no valid compiled exression). The set_invalid function sets
-// the program to NULL (Warning: this deletes the compiled expression). The
-// following examples may help clarify regular expression usage:
-//
-// * The regular expression "^hello" matches a "hello" only at the
-// beginning of a line. It would match "hello there" but not "hi,
-// hello there".
-//
-// * The regular expression "long$" matches a "long" only at the end
-// of a line. It would match "so long\0", but not "long ago".
-//
-// * The regular expression "t..t..g" will match anything that has a
-// "t" then any two characters, another "t", any two characters and
-// then a "g". It will match "testing", or "test again" but would
-// not match "toasting"
-//
-// * The regular expression "[1-9ab]" matches any number one through
-// nine, and the characters "a" and "b". It would match "hello 1"
-// or "begin", but would not match "no-match".
-//
-// * The regular expression "[^1-9ab]" matches any character that is
-// not a number one through nine, or an "a" or "b". It would NOT
-// match "hello 1" or "begin", but would match "no-match".
-//
-// * The regular expression "br* " matches something that begins with
-// a "b", is followed by zero or more "r"s, and ends in a space. It
-// would match "brrrrr ", and "b ", but would not match "brrh ".
-//
-// * The regular expression "br+ " matches something that begins with
-// a "b", is followed by one or more "r"s, and ends in a space. It
-// would match "brrrrr ", and "br ", but would not match "b " or
-// "brrh ".
-//
-// * The regular expression "br? " matches something that begins with
-// a "b", is followed by zero or one "r"s, and ends in a space. It
-// would match "br ", and "b ", but would not match "brrrr " or
-// "brrh ".
-//
-// * The regular expression "(..p)b" matches something ending with pb
-// and beginning with whatever the two characters before the first p
-// encounterd in the line were. It would find "repb" in "rep drepa
-// qrepb". The regular expression "(..p)a" would find "repa qrepb"
-// in "rep drepa qrepb"
-//
-// * The regular expression "d(..p)" matches something ending with p,
-// beginning with d, and having two characters in between that are
-// the same as the two characters before the first p encounterd in
-// the line. It would match "drepa qrepb" in "rep drepa qrepb".
-//
#include "cmRegularExpression.h" // Include class specification
#include "cmStandardIncludes.h"
#include <stdio.h>
-
// cmRegularExpression -- Copies the given regular expression.
-
cmRegularExpression::cmRegularExpression (const cmRegularExpression& rxp) {
int ind;
this->progsize = rxp.progsize; // Copy regular expression size
@@ -144,10 +60,8 @@ cmRegularExpression::cmRegularExpression (const cmRegularExpression& rxp) {
this->regmlen = rxp.regmlen; // Copy remaining private data
}
-
// operator== -- Returns true if two regular expressions have the same
// compiled program for pattern matching.
-
bool cmRegularExpression::operator== (const cmRegularExpression& rxp) const {
if (this != &rxp) { // Same address?
int ind = this->progsize; // Get regular expression size
@@ -918,8 +832,9 @@ void regdump ();
static char* regprop ();
#endif
-bool cmRegularExpression::find (std::string const& s) {
-return find(s.c_str());
+bool cmRegularExpression::find (std::string const& s)
+{
+ return find(s.c_str());
}