/*
* This file is part of uIRC. (https://git.redxen.eu/caskd/uIRC)
* Copyright (c) 2019, 2020 Alex-David Denes
*
* uIRC is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* any later version.
*
* uIRC 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 General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with uIRC. If not, see .
*/
#include "public/validators.h"
#include "public/errors.h"
#include "public/types.h"
#include
#include
#include
size_t
Val_type_nocrlf(const char* str)
{
assert(str != NULL);
const char* save = str;
for (; *str; str++) {
if (*str == '\r' || *str == '\n') return 0;
}
return (size_t)(str - save);
}
size_t
Val_type_nospcl(const char* str)
{
assert(str != NULL);
const char* save = str;
for (; *str; str++) {
if (*str == ' ' || *str == ':') return 0;
}
return (size_t)(str - save);
}
size_t
Val_type_noblcm(const char* str)
{
assert(str != NULL);
const char* save = str;
for (; *str; str++) {
if (*str == '\a' || *str == ',') return 0;
}
return (size_t)(str - save);
}
size_t
Val_channame(char* chan)
{
assert(chan != NULL);
if (*chan != '#' && *chan != '+' && *chan != '!' && *chan != '&') return 0;
const char* save = chan;
char* clps = ++chan;
if ((clps = strchr(chan, ':')) != NULL) {
*clps = '\0';
if (Val_type_nospcl(chan) != 1 || Val_type_nocrlf(chan) != 1 || Val_type_noblcm(chan) != 1) {
*clps = ':';
return 0;
}
*clps = ':';
chan = ++clps;
}
if (Val_type_nospcl(chan) != 1 || Val_type_nocrlf(chan) != 1 || Val_type_noblcm(chan) != 1) return 0;
return (size_t)(save - chan);
}
// TODO: Work on the logic for this
signed short
Val_mesg(IRC_Message* mesg)
{
assert(mesg != NULL);
for (unsigned int i = 0; mesg->args[i] != NULL; i++) {
if (Val_type_nocrlf(mesg->args[i]) != 1) return ERR_UIRC_VAL_FAILED;
if (!(mesg->args[i + 1] == NULL && mesg->trailing)) {
if (Val_type_nospcl(mesg->args[i]) != 1) return ERR_UIRC_VAL_FAILED;
}
}
return 1;
}