mirror of
https://github.com/signalwire/freeswitch.git
synced 2025-04-30 14:06:04 +00:00
- Dialplan examples - New version of commons - Priority of contexts - New K3L install script - getk3l.sh - CLI return in XML - More options in GET and SET commands - Events (ESL) to send/receive SMS. - fax-adjustment-timeout implemented - accountcode and language - Owner destroy - Destroy wait for resources release - static const expression - Hangup cause
150 lines
4.5 KiB
C++
150 lines
4.5 KiB
C++
/*
|
|
KHOMP generic endpoint/channel library.
|
|
Copyright (C) 2007-2009 Khomp Ind. & Com.
|
|
|
|
The contents of this file are subject to the Mozilla Public License Version 1.1
|
|
(the "License"); you may not use this file except in compliance with the
|
|
License. You may obtain a copy of the License at http://www.mozilla.org/MPL/
|
|
|
|
Software distributed under the License is distributed on an "AS IS" basis,
|
|
WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License for
|
|
the specific language governing rights and limitations under the License.
|
|
|
|
Alternatively, the contents of this file may be used under the terms of the
|
|
"GNU Lesser General Public License 2.1" license (the “LGPL" License), in which
|
|
case the provisions of "LGPL License" are applicable instead of those above.
|
|
|
|
If you wish to allow use of your version of this file only under the terms of
|
|
the LGPL License and not to allow others to use your version of this file under
|
|
the MPL, indicate your decision by deleting the provisions above and replace them
|
|
with the notice and other provisions required by the LGPL License. If you do not
|
|
delete the provisions above, a recipient may use your version of this file under
|
|
either the MPL or the LGPL License.
|
|
|
|
The LGPL header follows below:
|
|
|
|
This library is free software; you can redistribute it and/or
|
|
modify it under the terms of the GNU Lesser General Public
|
|
License as published by the Free Software Foundation; either
|
|
version 2.1 of the License, or (at your option) any later version.
|
|
|
|
This library is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
Lesser General Public License for more details.
|
|
|
|
You should have received a copy of the GNU Lesser General Public License
|
|
along with this library; if not, write to the Free Software Foundation, Inc.,
|
|
51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
|
|
|
*/
|
|
|
|
#include <regex.hpp>
|
|
|
|
#include <string.h>
|
|
|
|
void Regex::Expression::initialize(void)
|
|
{
|
|
unsigned int tmplen = strlen(_expression);
|
|
|
|
bool extflag = (_flags & E_EXTENDED);
|
|
|
|
for (unsigned int i = 0; i < tmplen; ++i)
|
|
{
|
|
switch (_expression[i])
|
|
{
|
|
case '\\':
|
|
++i;
|
|
|
|
if (!extflag && i < tmplen)
|
|
if (_expression[i] == '(')
|
|
++_subcounter;
|
|
|
|
break;
|
|
|
|
case '(':
|
|
if (extflag)
|
|
++_subcounter;
|
|
|
|
default:
|
|
break;
|
|
}
|
|
}
|
|
|
|
_errorstate = regcomp(&_comp_regex, _expression, _flags);
|
|
}
|
|
|
|
std::string Regex::Expression::regerror_as_string(void) const
|
|
{
|
|
unsigned int count = regerror(_errorstate, &_comp_regex, 0, 0) + 1;
|
|
|
|
char * msg = new char[count];
|
|
|
|
regerror(_errorstate, &_comp_regex, msg, count);
|
|
|
|
std::string tmp(msg, count);
|
|
|
|
delete[] msg;
|
|
|
|
return tmp;
|
|
}
|
|
|
|
void Regex::Match::initialize(void)
|
|
{
|
|
if (_expression.valid())
|
|
{
|
|
_subcounter = (_expression.subcount() + 2); // 0 + N.. + invalid
|
|
_submatches = new regmatch_t[_subcounter];
|
|
_subcaching = new std::string[_subcounter];
|
|
_have_match = (regexec(_expression.repr(), _basestring.c_str(),
|
|
_subcounter, _submatches, _flags) == 0);
|
|
}
|
|
}
|
|
|
|
std::string Regex::Match::replace(std::string rep, unsigned int index)
|
|
{
|
|
ReplaceMap tmp;
|
|
tmp.insert(ReplacePair(index,rep));
|
|
return replace(tmp);
|
|
}
|
|
|
|
std::string Regex::Match::replace(Regex::ReplaceMap & map)
|
|
{
|
|
if (!_have_match)
|
|
return _basestring;
|
|
|
|
std::string buffer = _basestring;
|
|
|
|
try
|
|
{
|
|
if (_submatches[0].rm_so != 0 && (map.find(0) != map.end()))
|
|
return buffer.replace(_submatches[0].rm_so, _submatches[0].rm_eo - _submatches[0].rm_so, map.find(0)->second);
|
|
|
|
for (unsigned int n = 1; (_submatches[n].rm_so != -1) && (n < _subcounter); n++)
|
|
{
|
|
//// s f RRR s f RRR s f RRRR s f
|
|
//// XXXYYY(ZZZ)AAA(BBB)CCCEEE(FFFF)GGGG
|
|
|
|
bool globalsubs = false;
|
|
|
|
if (map.find(n) == map.end())
|
|
{
|
|
if (map.find(UINT_MAX) == map.end())
|
|
continue;
|
|
|
|
globalsubs = true;
|
|
}
|
|
|
|
buffer = buffer.replace(_submatches[n].rm_so,
|
|
_submatches[n].rm_eo - _submatches[n].rm_so,
|
|
map.find((globalsubs ? UINT_MAX : n))->second);
|
|
}
|
|
}
|
|
catch (std::out_of_range e)
|
|
{
|
|
return "";
|
|
}
|
|
|
|
return buffer;
|
|
}
|