added qse_sed_setexechook()

added qse_strfnmat() and related functions
This commit is contained in:
2011-09-24 08:52:22 +00:00
parent cd1c245670
commit b9e365f148
10 changed files with 1078 additions and 16 deletions

View File

@ -1,5 +1,5 @@
/*
* $Id: str-pbrk.c 556 2011-08-31 15:43:46Z hyunghwan.chung $
* $Id: str-pbrk.c 576 2011-09-23 14:52:22Z hyunghwan.chung $
*
Copyright 2006-2011 Chung, Hyung-Hwan.
This file is part of QSE.
@ -35,6 +35,61 @@ qse_mchar_t* qse_mbspbrk (const qse_mchar_t* str1, const qse_mchar_t* str2)
return QSE_NULL;
}
qse_mchar_t* qse_mbsxpbrk (
const qse_mchar_t* str1, qse_size_t len, const qse_mchar_t* str2)
{
const qse_mchar_t* p1, * p2;
const qse_mchar_t* e1 = str1 + len;
for (p1 = str1; p1 < e1; p1++)
{
for (p2 = str2; *p2 != QSE_MT('\0'); p2++)
{
if (*p2 == *p1) return (qse_mchar_t*)p1;
}
}
return QSE_NULL;
}
qse_mchar_t* qse_mbsrpbrk (const qse_mchar_t* str1, const qse_mchar_t* str2)
{
const qse_mchar_t* p1, * p2;
for (p1 = str1; *p1 != QSE_MT('\0'); p1++);
while (p1 > str1)
{
p1--;
for (p2 = str2; *p2 != QSE_MT('\0'); p2++)
{
if (*p2 == *p1) return (qse_mchar_t*)p1;
}
}
return QSE_NULL;
}
qse_mchar_t* qse_mbsxrpbrk (const qse_mchar_t* str1, qse_size_t len, const qse_mchar_t* str2)
{
const qse_mchar_t* p1, * p2;
p1 = str1 + len;
while (p1 > str1)
{
p1--;
for (p2 = str2; *p2 != QSE_MT('\0'); p2++)
{
if (*p2 == *p1) return (qse_mchar_t*)p1;
}
}
return QSE_NULL;
}
qse_wchar_t* qse_wcspbrk (const qse_wchar_t* str1, const qse_wchar_t* str2)
{
const qse_wchar_t* p1, * p2;
@ -50,3 +105,56 @@ qse_wchar_t* qse_wcspbrk (const qse_wchar_t* str1, const qse_wchar_t* str2)
return QSE_NULL;
}
qse_wchar_t* qse_wcsxpbrk (
const qse_wchar_t* str1, qse_size_t len, const qse_wchar_t* str2)
{
const qse_wchar_t* p1, * p2;
const qse_wchar_t* e1 = str1 + len;
for (p1 = str1; p1 < e1; p1++)
{
for (p2 = str2; *p2 != QSE_WT('\0'); p2++)
{
if (*p2 == *p1) return (qse_wchar_t*)p1;
}
}
return QSE_NULL;
}
qse_wchar_t* qse_wcsrpbrk (const qse_wchar_t* str1, const qse_wchar_t* str2)
{
const qse_wchar_t* p1, * p2;
for (p1 = str1; *p1 != QSE_WT('\0'); p1++);
while (p1 > str1)
{
p1--;
for (p2 = str2; *p2 != QSE_WT('\0'); p2++)
{
if (*p2 == *p1) return (qse_wchar_t*)p1;
}
}
return QSE_NULL;
}
qse_wchar_t* qse_wcsxrpbrk (const qse_wchar_t* str1, qse_size_t len, const qse_wchar_t* str2)
{
const qse_wchar_t* p1, * p2;
p1 = str1 + len;
while (p1 > str1)
{
p1--;
for (p2 = str2; *p2 != QSE_WT('\0'); p2++)
{
if (*p2 == *p1) return (qse_wchar_t*)p1;
}
}
return QSE_NULL;
}