initial commit for version 1.6.x patch release
[OpenFOAM-1.6.x.git] / applications / test / regex / regexTest.C
blobc6e492d151ff97f4dea838518d26f2d4ac5a05dd
1 /*---------------------------------------------------------------------------*\
2   =========                 |
3   \\      /  F ield         | OpenFOAM: The Open Source CFD Toolbox
4    \\    /   O peration     |
5     \\  /    A nd           | Copyright (C) 1991-2009 OpenCFD Ltd.
6      \\/     M anipulation  |
7 -------------------------------------------------------------------------------
8 License
9     This file is part of OpenFOAM.
11     OpenFOAM is free software; you can redistribute it and/or modify it
12     under the terms of the GNU General Public License as published by the
13     Free Software Foundation; either version 2 of the License, or (at your
14     option) any later version.
16     OpenFOAM is distributed in the hope that it will be useful, but WITHOUT
17     ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
18     FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
19     for more details.
21     You should have received a copy of the GNU General Public License
22     along with OpenFOAM; if not, write to the Free Software Foundation,
23     Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
25 Description
27 \*---------------------------------------------------------------------------*/
29 #include "IOstreams.H"
30 #include "IOobject.H"
31 #include "IFstream.H"
32 #include "regExp.H"
33 #include "List.H"
34 #include "Tuple2.H"
36 using namespace Foam;
38 // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
39 // Main program:
41 int main(int argc, char *argv[])
44     List<Tuple2<string, string> > rawList(IFstream("testRegexps")());
45     Info<< "input list:" << rawList << endl;
46     IOobject::writeDivider(Info) << endl;
48     List<string> groups;
50     // report matches:
51     forAll(rawList, elemI)
52     {
53         const string& pat = rawList[elemI].first();
54         const string& str = rawList[elemI].second();
55         regExp re(pat);
57         Info<< str << " =~ m/" << pat.c_str() << "/ == ";
59         if (re.match(str, groups))
60         {
61             Info<< "true";
62             if (re.ngroups())
63             {
64                 Info<< " groups:" << groups;
65             }
66         }
67         else
68         {
69             Info<< "false";
70             if (re.search(str))
71             {
72                 Info<< " partial match";
73             }
74         }
75         Info<< endl;
76     }
78     Info<<"test regExp(const char*) ..." << endl;
79     string me("Mark");
81     if (regExp("[Mm]ar[ck]").match(me))
82     {
83         Info<< "matched: " << me << endl;
84     }
85     else
86     {
87         Info<< "no match" << endl;
88     }
90     if (regExp("").match(me))
91     {
92         Info<< "matched: " << me << endl;
93     }
94     else
95     {
96         Info<< "no match" << endl;
97     }
99     if (regExp(NULL).match(me))
100     {
101         Info<< "matched: " << me << endl;
102     }
103     else
104     {
105         Info<< "no match" << endl;
106     }
108     Info<< endl;
110     return 0;
114 // ************************************************************************* //