xref: /trunk/main/tools/source/fsys/wldcrd.cxx (revision cdf0e10c4e3984b49a9502b011690b615761d4a3)
1*cdf0e10cSrcweir /*************************************************************************
2*cdf0e10cSrcweir  *
3*cdf0e10cSrcweir  * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
4*cdf0e10cSrcweir  *
5*cdf0e10cSrcweir  * Copyright 2000, 2010 Oracle and/or its affiliates.
6*cdf0e10cSrcweir  *
7*cdf0e10cSrcweir  * OpenOffice.org - a multi-platform office productivity suite
8*cdf0e10cSrcweir  *
9*cdf0e10cSrcweir  * This file is part of OpenOffice.org.
10*cdf0e10cSrcweir  *
11*cdf0e10cSrcweir  * OpenOffice.org is free software: you can redistribute it and/or modify
12*cdf0e10cSrcweir  * it under the terms of the GNU Lesser General Public License version 3
13*cdf0e10cSrcweir  * only, as published by the Free Software Foundation.
14*cdf0e10cSrcweir  *
15*cdf0e10cSrcweir  * OpenOffice.org is distributed in the hope that it will be useful,
16*cdf0e10cSrcweir  * but WITHOUT ANY WARRANTY; without even the implied warranty of
17*cdf0e10cSrcweir  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
18*cdf0e10cSrcweir  * GNU Lesser General Public License version 3 for more details
19*cdf0e10cSrcweir  * (a copy is included in the LICENSE file that accompanied this code).
20*cdf0e10cSrcweir  *
21*cdf0e10cSrcweir  * You should have received a copy of the GNU Lesser General Public License
22*cdf0e10cSrcweir  * version 3 along with OpenOffice.org.  If not, see
23*cdf0e10cSrcweir  * <http://www.openoffice.org/license.html>
24*cdf0e10cSrcweir  * for a copy of the LGPLv3 License.
25*cdf0e10cSrcweir  *
26*cdf0e10cSrcweir  ************************************************************************/
27*cdf0e10cSrcweir 
28*cdf0e10cSrcweir // MARKER(update_precomp.py): autogen include statement, do not remove
29*cdf0e10cSrcweir #include "precompiled_tools.hxx"
30*cdf0e10cSrcweir #include <tools/wldcrd.hxx>
31*cdf0e10cSrcweir 
32*cdf0e10cSrcweir /*************************************************************************
33*cdf0e10cSrcweir |*
34*cdf0e10cSrcweir |*    WildCard::Match()
35*cdf0e10cSrcweir |*
36*cdf0e10cSrcweir |*    Beschreibung      WLDCRD.SDW
37*cdf0e10cSrcweir |*    Ersterstellung    MA 19.06.91
38*cdf0e10cSrcweir |*    Letzte Aenderung  MA 03.07.91
39*cdf0e10cSrcweir |*
40*cdf0e10cSrcweir *************************************************************************/
41*cdf0e10cSrcweir 
42*cdf0e10cSrcweir /* Diese Methode ueberprueft, ob die Wilde Karte in pWild mit dem String
43*cdf0e10cSrcweir  * in pStr matscht.
44*cdf0e10cSrcweir  * Vertragen sich die beiden, so wird 1 zurueckgegeben, sonst 0.
45*cdf0e10cSrcweir  *
46*cdf0e10cSrcweir  * ein '*' in pWild bedeutet n beliebige Zeichen, mit n>=0
47*cdf0e10cSrcweir  * ein '?' in pWild bedeutet genau ein beliebiges Zeichen
48*cdf0e10cSrcweir  *
49*cdf0e10cSrcweir  */
50*cdf0e10cSrcweir 
51*cdf0e10cSrcweir sal_uInt16 WildCard::ImpMatch( const char *pWild, const char *pStr ) const
52*cdf0e10cSrcweir {
53*cdf0e10cSrcweir     int    pos=0;
54*cdf0e10cSrcweir     int    flag=0;
55*cdf0e10cSrcweir 
56*cdf0e10cSrcweir     while ( *pWild || flag )
57*cdf0e10cSrcweir     {
58*cdf0e10cSrcweir         switch (*pWild)
59*cdf0e10cSrcweir         {
60*cdf0e10cSrcweir             case '?':
61*cdf0e10cSrcweir                 if ( *pStr == '\0' )
62*cdf0e10cSrcweir                     return 0;
63*cdf0e10cSrcweir                 break;
64*cdf0e10cSrcweir 
65*cdf0e10cSrcweir             default:
66*cdf0e10cSrcweir                 if ( (*pWild == '\\') && ((*(pWild+1)=='?') || (*(pWild+1) == '*')) )
67*cdf0e10cSrcweir                     pWild++;
68*cdf0e10cSrcweir                 if ( *pWild != *pStr )
69*cdf0e10cSrcweir                     if ( !pos )
70*cdf0e10cSrcweir                         return 0;
71*cdf0e10cSrcweir                     else
72*cdf0e10cSrcweir                         pWild += pos;
73*cdf0e10cSrcweir                 else
74*cdf0e10cSrcweir                     break;          // ACHTUNG laeuft unter bestimmten
75*cdf0e10cSrcweir                                     // Umstaenden in den nachsten case rein!!
76*cdf0e10cSrcweir             case '*':
77*cdf0e10cSrcweir                 while ( *pWild == '*' )
78*cdf0e10cSrcweir                     pWild++;
79*cdf0e10cSrcweir                 if ( *pWild == '\0' )
80*cdf0e10cSrcweir                     return 1;
81*cdf0e10cSrcweir                 flag = 1;
82*cdf0e10cSrcweir                 pos  = 0;
83*cdf0e10cSrcweir                 if ( *pStr == '\0' )
84*cdf0e10cSrcweir                     return ( *pWild == '\0' );
85*cdf0e10cSrcweir                 while ( *pStr && *pStr != *pWild )
86*cdf0e10cSrcweir                 {
87*cdf0e10cSrcweir                     if ( *pWild == '?' ) {
88*cdf0e10cSrcweir                         pWild++;
89*cdf0e10cSrcweir                         while ( *pWild == '*' )
90*cdf0e10cSrcweir                             pWild++;
91*cdf0e10cSrcweir                     }
92*cdf0e10cSrcweir                     pStr++;
93*cdf0e10cSrcweir                     if ( *pStr == '\0' )
94*cdf0e10cSrcweir                         return ( *pWild == '\0' );
95*cdf0e10cSrcweir                 }
96*cdf0e10cSrcweir                 break;
97*cdf0e10cSrcweir         }
98*cdf0e10cSrcweir         if ( *pWild != '\0' )
99*cdf0e10cSrcweir             pWild++;
100*cdf0e10cSrcweir         if ( *pStr != '\0' )
101*cdf0e10cSrcweir             pStr++;
102*cdf0e10cSrcweir         else
103*cdf0e10cSrcweir             flag = 0;
104*cdf0e10cSrcweir         if ( flag )
105*cdf0e10cSrcweir             pos--;
106*cdf0e10cSrcweir     }
107*cdf0e10cSrcweir     return ( *pStr == '\0' ) && ( *pWild == '\0' );
108*cdf0e10cSrcweir }
109*cdf0e10cSrcweir 
110*cdf0e10cSrcweir /*************************************************************************
111*cdf0e10cSrcweir |*
112*cdf0e10cSrcweir |*    WildCard::Matches()
113*cdf0e10cSrcweir |*
114*cdf0e10cSrcweir |*    Beschreibung      WLDCRD.SDW
115*cdf0e10cSrcweir |*    Ersterstellung    MA 19.06.91
116*cdf0e10cSrcweir |*    Letzte Aenderung  TH 02.02.96
117*cdf0e10cSrcweir |*
118*cdf0e10cSrcweir *************************************************************************/
119*cdf0e10cSrcweir 
120*cdf0e10cSrcweir sal_Bool WildCard::Matches( const String& rString ) const
121*cdf0e10cSrcweir {
122*cdf0e10cSrcweir     ByteString aTmpWild = aWildString;
123*cdf0e10cSrcweir     ByteString aString(rString, osl_getThreadTextEncoding());
124*cdf0e10cSrcweir 
125*cdf0e10cSrcweir     sal_uInt16  nSepPos;
126*cdf0e10cSrcweir 
127*cdf0e10cSrcweir     if ( cSepSymbol != '\0' )
128*cdf0e10cSrcweir     {
129*cdf0e10cSrcweir         while ( (nSepPos = aTmpWild.Search( cSepSymbol )) != STRING_NOTFOUND )
130*cdf0e10cSrcweir         {
131*cdf0e10cSrcweir             // alle getrennten WildCard's pruefen
132*cdf0e10cSrcweir             if ( ImpMatch( aTmpWild.Copy( 0, nSepPos ).GetBuffer(), aString.GetBuffer() ) )
133*cdf0e10cSrcweir                 return sal_True;
134*cdf0e10cSrcweir             aTmpWild.Erase( 0, nSepPos + 1 ); // Trennsymbol entfernen
135*cdf0e10cSrcweir         }
136*cdf0e10cSrcweir         // und noch den hinter dem letzen Trennsymbol bzw. den einzigen
137*cdf0e10cSrcweir     }
138*cdf0e10cSrcweir 
139*cdf0e10cSrcweir     if ( ImpMatch( aTmpWild.GetBuffer(), aString.GetBuffer() ) )
140*cdf0e10cSrcweir         return sal_True;
141*cdf0e10cSrcweir     else
142*cdf0e10cSrcweir         return sal_False;
143*cdf0e10cSrcweir }
144