diff options
Diffstat (limited to 'Source/cmRegularExpression.cxx')
-rw-r--r-- | Source/cmRegularExpression.cxx | 121 |
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()); } |