Main Page | Alphabetical List | Data Structures | Directories | File List | Data Fields | Globals

pcre.h

Go to the documentation of this file.
00001 /* ==================================================================== 
00002  * The Kannel Software License, Version 1.0 
00003  * 
00004  * Copyright (c) 2001-2008 Kannel Group  
00005  * Copyright (c) 1998-2001 WapIT Ltd.   
00006  * All rights reserved. 
00007  * 
00008  * Redistribution and use in source and binary forms, with or without 
00009  * modification, are permitted provided that the following conditions 
00010  * are met: 
00011  * 
00012  * 1. Redistributions of source code must retain the above copyright 
00013  *    notice, this list of conditions and the following disclaimer. 
00014  * 
00015  * 2. Redistributions in binary form must reproduce the above copyright 
00016  *    notice, this list of conditions and the following disclaimer in 
00017  *    the documentation and/or other materials provided with the 
00018  *    distribution. 
00019  * 
00020  * 3. The end-user documentation included with the redistribution, 
00021  *    if any, must include the following acknowledgment: 
00022  *       "This product includes software developed by the 
00023  *        Kannel Group (http://www.kannel.org/)." 
00024  *    Alternately, this acknowledgment may appear in the software itself, 
00025  *    if and wherever such third-party acknowledgments normally appear. 
00026  * 
00027  * 4. The names "Kannel" and "Kannel Group" must not be used to 
00028  *    endorse or promote products derived from this software without 
00029  *    prior written permission. For written permission, please  
00030  *    contact org@kannel.org. 
00031  * 
00032  * 5. Products derived from this software may not be called "Kannel", 
00033  *    nor may "Kannel" appear in their name, without prior written 
00034  *    permission of the Kannel Group. 
00035  * 
00036  * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED 
00037  * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES 
00038  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE 
00039  * DISCLAIMED.  IN NO EVENT SHALL THE KANNEL GROUP OR ITS CONTRIBUTORS 
00040  * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY,  
00041  * OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT  
00042  * OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR  
00043  * BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,  
00044  * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE  
00045  * OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,  
00046  * EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 
00047  * ==================================================================== 
00048  * 
00049  * This software consists of voluntary contributions made by many 
00050  * individuals on behalf of the Kannel Group.  For more information on  
00051  * the Kannel Group, please see <http://www.kannel.org/>. 
00052  * 
00053  * Portions of this software are based upon software originally written at  
00054  * WapIT Ltd., Helsinki, Finland for the Kannel project.  
00055  */ 
00056 
00057 /*
00058  * pcre.h - Perl compatible regular expressions (PCREs) 
00059  *
00060  * This modules implements wrapper functions to the pcre_foobar() et all
00061  * functions implemented in the libpcre.a library.
00062  * PCRE is a library of functions to support regular expressions whose syntax
00063  * and semantics are as close as possible to those of the Perl 5 language.
00064  *
00065  * See http://www.pcre.org/ for more details on PCRE regular expressions.
00066  *
00067  * Stipe Tolj <stolj@wapme.de>
00068  */
00069 
00070 #ifndef PCRE_H
00071 #define PCRE_H
00072 
00073 #ifdef HAVE_PCRE
00074 
00075 #include <pcre.h>
00076 
00077 
00078 #define PCRE_OVECCOUNT 30    /* should be a multiple of 3 */
00079 
00080 /*
00081  * Compile a regular expression provided by pattern and return
00082  * the regular expression type as function result.
00083  * If the compilation fails, return NULL.
00084  */
00085 pcre *gw_pcre_comp_real(const Octstr *pattern, int cflags, const char *file, 
00086                         long line, const char *func);
00087 #define gw_pcre_comp(pattern, cflags) \
00088     gw_pcre_comp_real(pattern, cflags, __FILE__, __LINE__, __func__)
00089 
00090 
00091 /*
00092  * Execute a previously compile regular expression on a given
00093  * string and provide the matches via nmatch and pmatch[].
00094  */
00095 int gw_pcre_exec_real(const pcre *preg, const Octstr *string, int start, 
00096                       int eflags, int *ovector, int oveccount, 
00097                       const char *file, long line, const char *func);
00098 #define gw_pcre_exec(preg, string, start, eflags, ovector, oveccount) \
00099     gw_pcre_exec_real(preg, string, start, eflags, ovector, oveccount, \
00100                       __FILE__, __LINE__, __func__)
00101 
00102 
00103 /*
00104  * Match directly a given regular expression and a source string. This assumes
00105  * that the RE has not been pre-compiled and hence perform the compile and 
00106  * exec step in this matching step.
00107  * Return 1 if the regular expression is successfully matching, 0 otherwise.
00108  */
00109 int gw_pcre_match_real(const Octstr *re, const Octstr *os, const char *file, 
00110                        long line, const char *func);
00111 #define gw_pcre_match(re, os) \
00112     gw_pcre_match_real(re, os, __FILE__, __LINE__, __func__)
00113 
00114 
00115 /*
00116  * Match directly a given source string against a previously pre-compiled
00117  * regular expression.
00118  * Return 1 if the regular expression is successfully matching, 0 otherwise.
00119  */
00120 int gw_pcre_match_pre_real(const pcre *preg, const Octstr *os, const char *file, 
00121                            long line, const char *func);
00122 #define gw_pcre_match_pre(preg, os) \
00123     gw_pcre_match_pre_real(preg, os, __FILE__, __LINE__, __func__)
00124 
00125 
00126 #endif  /* HAVE_PCRE */
00127 #endif  /* PCRE_H */
00128 
00129 
See file LICENSE for details about the license agreement for using, modifying, copying or deriving work from this software.