#include "sql_string_helpers.h"
#include
#include
void sqlstr::FuzzyString(char *pString, int Size)
{
char *pNewString = new char[Size * 4 - 1];
int OutPos = 0;
for(int i = 0; i < Size; i++)
{
if(!pString[i])
break;
pNewString[OutPos++] = pString[i];
if(pString[i] != '\\' && str_utf8_isstart(pString[i + 1]))
pNewString[OutPos++] = '%';
}
pNewString[OutPos] = '\0';
str_copy(pString, pNewString, Size);
delete[] pNewString;
}
int sqlstr::EscapeLike(char *pDst, const char *pSrc, int DstSize)
{
int Pos = 0;
int DstPos = 0;
while(DstPos + 2 < DstSize)
{
if(pSrc[Pos] == '\0')
break;
if(pSrc[Pos] == '\\' || pSrc[Pos] == '%' || pSrc[Pos] == '_' || pSrc[Pos] == '[')
pDst[DstPos++] = '\\';
pDst[DstPos++] = pSrc[Pos++];
}
pDst[DstPos++] = '\0';
return DstPos;
}
void sqlstr::AgoTimeToString(int AgoTime, char *pAgoString, int Size)
{
if(AgoTime <= 0)
{
str_copy(pAgoString, "moments", Size);
return;
}
char aBuf[20];
int aTimes[7] =
{
60 * 60 * 24 * 365,
60 * 60 * 24 * 30,
60 * 60 * 24 * 7,
60 * 60 * 24,
60 * 60,
60,
1};
char aaNames[7][6] =
{
"year",
"month",
"week",
"day",
"hour",
"min",
"sec"};
int Seconds = 0;
char aName[6];
int Count = 0;
int i = 0;
// finding biggest match
for(i = 0; i < 7; i++)
{
Seconds = aTimes[i];
str_copy(aName, aaNames[i], sizeof(aName));
Count = std::floor((float)AgoTime / (float)Seconds);
if(Count != 0)
{
break;
}
}
if(Count == 1)
{
str_format(aBuf, sizeof(aBuf), "%d %s", 1, aName);
}
else
{
str_format(aBuf, sizeof(aBuf), "%d %ss", Count, aName);
}
str_append(pAgoString, aBuf, Size);
if(i + 1 < 7)
{
// getting second piece now
int Seconds2 = aTimes[i + 1];
char aName2[6];
str_copy(aName2, aaNames[i + 1], sizeof(aName2));
// add second piece if it's greater than 0
int Count2 = std::floor((float)(AgoTime - (Seconds * Count)) / (float)Seconds2);
if(Count2 != 0)
{
if(Count2 == 1)
{
str_format(aBuf, sizeof(aBuf), " and %d %s", 1, aName2);
}
else
{
str_format(aBuf, sizeof(aBuf), " and %d %ss", Count2, aName2);
}
str_append(pAgoString, aBuf, Size);
}
}
}