You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
170 lines
4.0 KiB
170 lines
4.0 KiB
2 months ago
|
#ifndef STRING_PROCESSOR
|
||
|
#define STRING_PROCESSOR
|
||
|
#include <stdint.h>
|
||
|
#include <stdbool.h>
|
||
|
#include <malloc.h>
|
||
|
#include <ctype.h>
|
||
|
#include <stdio.h>
|
||
|
#include "sort.h"
|
||
|
#define STRING_MAX 512ull
|
||
|
const int32_t get_str(const char const* msg, char* str, const int32_t limit)
|
||
|
{
|
||
|
printf(msg);
|
||
|
char c;
|
||
|
size_t size = 0;
|
||
|
while (size < limit - 1 && (c = getchar()) != EOF && c != '\n')
|
||
|
{
|
||
|
str[size++] = c;
|
||
|
}
|
||
|
str[size] = '\0';
|
||
|
return size;
|
||
|
}
|
||
|
const size_t strlenn(const char* str)
|
||
|
{
|
||
|
size_t cnt;
|
||
|
for (cnt = 0; *str; str++, cnt++)
|
||
|
;
|
||
|
return cnt;
|
||
|
}
|
||
|
void strcopy(char* fStr, char* sStr, size_t until)
|
||
|
{
|
||
|
while (0 < until-- && (*sStr++ = *fStr++))
|
||
|
;
|
||
|
}
|
||
|
int32_t strcmpp(const char* fStr, const char* sStr)
|
||
|
{
|
||
|
while (*fStr)
|
||
|
{
|
||
|
if (*fStr != *sStr)
|
||
|
{
|
||
|
break;
|
||
|
}
|
||
|
fStr++;
|
||
|
sStr++;
|
||
|
}
|
||
|
return *(const unsigned char*)fStr - *(const unsigned char*)sStr;
|
||
|
}
|
||
|
char* strcatt(char* fStr, const char* sStr)
|
||
|
{
|
||
|
char* ptr = fStr + strlenn(fStr);
|
||
|
while (*sStr != '\0')
|
||
|
{
|
||
|
*ptr++ = *sStr++;
|
||
|
}
|
||
|
*ptr = '\0';
|
||
|
return fStr;
|
||
|
}
|
||
|
bool is_string_valid(char* str)
|
||
|
{
|
||
|
bool isThereString = false;
|
||
|
bool isThereColon = false;
|
||
|
const size_t size = strlenn(str);
|
||
|
for (size_t i = 0; i < size; i++)
|
||
|
{
|
||
|
if ((str[i] == ':' || str[i] == ';' || str[i] == ',') && i == 0ull)
|
||
|
{
|
||
|
return false;
|
||
|
}
|
||
|
if (str[i] == ':')
|
||
|
{
|
||
|
isThereColon = true;
|
||
|
}
|
||
|
else if (isThereColon)
|
||
|
{
|
||
|
if (str[i] == ',')
|
||
|
{
|
||
|
if (!isalpha(str[i - 1ull]) && str[i - 1ull] != ' ')
|
||
|
{
|
||
|
return false;
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
isThereString = true;
|
||
|
}
|
||
|
}
|
||
|
if (str[i] == ';')
|
||
|
{
|
||
|
if (!isThereString || (!isalpha(str[i - 1ull]) && str[i - 1ull] != ' '))
|
||
|
{
|
||
|
return false;
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
isThereColon = false;
|
||
|
}
|
||
|
}
|
||
|
if (str[i] == ':')
|
||
|
{
|
||
|
return false;
|
||
|
}
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
isThereString = false;
|
||
|
}
|
||
|
}
|
||
|
return true;
|
||
|
}
|
||
|
char* process_string(char* str)
|
||
|
{
|
||
|
const size_t length = strlenn(str);
|
||
|
char* result = (char*)calloc(length, sizeof(char));
|
||
|
for (size_t i = 0; i < length; i++)
|
||
|
{
|
||
|
if (str[i] != ':')
|
||
|
{
|
||
|
char temp[2] = { str[i], '\0' };
|
||
|
strcatt(result, temp);
|
||
|
continue;
|
||
|
}
|
||
|
if (str[i + 1] != ' ')
|
||
|
{
|
||
|
return NULL;
|
||
|
}
|
||
|
strcatt(result, ": ");
|
||
|
const size_t strsPreCnt = 100;
|
||
|
char** arr = (char**)calloc(strsPreCnt, sizeof(char*));
|
||
|
for (size_t strsCnt = 0; strsCnt < strsPreCnt; strsCnt++)
|
||
|
{
|
||
|
arr[strsCnt] = (char*)calloc(STRING_MAX, sizeof(char));
|
||
|
}
|
||
|
for (size_t j = i + 2ull, strRealCnt = 0ull; j < length; j++)
|
||
|
{
|
||
|
if (str[j] == ',')
|
||
|
{
|
||
|
++strRealCnt;
|
||
|
++j;
|
||
|
}
|
||
|
else if (str[j] == ';')
|
||
|
{
|
||
|
quick_sort(arr, ++strRealCnt);
|
||
|
for (size_t k = 0; k < strRealCnt; k++)
|
||
|
{
|
||
|
strcatt(result, arr[k]);
|
||
|
if (k == strRealCnt - 1ull)
|
||
|
{
|
||
|
strcatt(result, ";");
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
strcatt(result, ", ");
|
||
|
}
|
||
|
}
|
||
|
i = j;
|
||
|
break;
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
char temp[2] = { str[j], '\0' };
|
||
|
strcatt(arr[strRealCnt], temp);
|
||
|
}
|
||
|
}
|
||
|
for (size_t strsCnt = 0; strsCnt < strsPreCnt; strsCnt++)
|
||
|
{
|
||
|
free(arr[strsCnt]);
|
||
|
}
|
||
|
free(arr);
|
||
|
}
|
||
|
return result;
|
||
|
}
|
||
|
#endif
|