Add time formatting and clean up stuff, fix one "feature" where read would block and messages could be delayed

This commit is contained in:
Alex D. 2020-11-04 12:44:32 +01:00
parent 10c2b6f966
commit b669fc1e54
Signed by: caskd
GPG Key ID: F92BA85F61F4C173
4 changed files with 72 additions and 52 deletions

View File

@ -1,10 +1,6 @@
#include <stdio.h>
#include <string.h>
#include "common.h"
#define UIRC_IRCV3
#include "uirc/functions.h"
#include "uirc/types.h"
char* mIRC_COLORS[16] = {"97", "30", "34", "32", "91", "31", "35", "33", "93", "92", "96", "36", "94", "95", "90", "37"};
ssize_t get_buffer_line(char* buf, IRC_Message* parsed)
{
@ -19,3 +15,24 @@ ssize_t get_buffer_line(char* buf, IRC_Message* parsed)
}
return 0;
}
void print_local_time(const char* irc_time)
{
if (irc_time != NULL) {
struct tm time;
char* tz;
char buffer[32];
strptime(irc_time, "%Y-%m-%dT%H:%M:%S", &time);
tz = getenv("TZ");
setenv("TZ", "", 1);
tzset();
time_t ctime = mktime(&time);
if (tz != NULL)
setenv("TZ", tz, 1);
else
unsetenv("TZ");
tzset();
strftime(buffer, sizeof(buffer), "%c", localtime(&ctime));
printf(" " ANSI_COLOR_BLUE "(%s)" ANSI_COLOR_RESET, buffer);
}
}

View File

@ -1,7 +1,23 @@
#include <ctype.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <time.h>
#define UIRC_IRCV3
#include "uirc/functions.h"
#include "uirc/types.h"
#define ANSI_COLOR_RED "\x1b[31m"
#define ANSI_COLOR_GREEN "\x1b[32m"
#define ANSI_COLOR_YELLOW "\x1b[33m"
#define ANSI_COLOR_BLUE "\x1b[34m"
#define ANSI_COLOR_GRAY "\x1b[90m"
#define ANSI_COLOR_RESET "\x1b[0m"
#define UIRC_IRCV3
#include "uirc/types.h"
extern char* mIRC_COLORS[16];
ssize_t get_buffer_line(char* buf, IRC_Message* parsed);
void print_local_time(const char* irc_time);

View File

@ -9,13 +9,6 @@
#include "uirc/mappings.h"
#include "uirc/types.h"
#define ANSI_COLOR_RED "\x1b[31m"
#define ANSI_COLOR_GREEN "\x1b[32m"
#define ANSI_COLOR_YELLOW "\x1b[33m"
#define ANSI_COLOR_BLUE "\x1b[34m"
#define ANSI_COLOR_GRAY "\x1b[90m"
#define ANSI_COLOR_RESET "\x1b[0m"
int main(void)
{
ssize_t bread = 1, tok;
@ -23,28 +16,28 @@ int main(void)
char buffer[513];
IRC_Message out;
for (; bread > 0;) {
if ((tok = get_buffer_line(buffer, &out)) > 0) {
if (out.cmd == PRIVMSG || out.cmd == NOTICE) {
printf((out.name.nick != NULL) ? ANSI_COLOR_RED "%s" ANSI_COLOR_RESET : ANSI_COLOR_GRAY "%s" ANSI_COLOR_RESET,
(out.name.nick != NULL) ? out.name.nick : "unknown");
putchar('/');
if (out.args[0] != NULL) {
printf(ANSI_COLOR_YELLOW "%s" ANSI_COLOR_RESET,
strchr("#+&!", *out.args[0]) != NULL ? out.args[0] : "direct");
}
if (out.args[1] != NULL) printf(": %s", out.args[1]);
print_local_time(out.tags.time.value);
putchar('\n');
}
for (long unsigned int x = 0; x < sizeof(buffer) && *(buffer + tok + x); x++) *(buffer + x) = *(buffer + x + tok);
pos -= (unsigned long)tok;
*(buffer + pos) = '\0';
memset(&out, '\0', sizeof(out));
continue;
}
if ((bread = read(0, buffer + pos, sizeof(buffer) - 1 - pos)) > 0) {
pos += (size_t)bread;
buffer[pos] = '\0';
if ((tok = get_buffer_line(buffer, &out)) > 0) {
if (out.cmd == PRIVMSG || out.cmd == NOTICE) {
printf((out.name.nick != NULL) ? ANSI_COLOR_RED "%s" ANSI_COLOR_RESET : ANSI_COLOR_GRAY "%s" ANSI_COLOR_RESET,
(out.name.nick != NULL) ? out.name.nick : "unknown");
if (out.name.host != NULL) printf("@" ANSI_COLOR_GREEN "%s" ANSI_COLOR_RESET, out.name.host);
putchar('\n');
if (out.args[0] != NULL) {
printf(ANSI_COLOR_YELLOW "%s" ANSI_COLOR_RESET,
strchr("#+&!", *out.args[0]) != NULL ? out.args[0] : "direct");
}
if (out.args[1] != NULL) printf(ANSI_COLOR_GREEN " >" ANSI_COLOR_RESET " %s\n", out.args[1]);
if (out.tags.time.value != NULL) printf(ANSI_COLOR_BLUE "(%s)\n" ANSI_COLOR_RESET, out.tags.time.value);
putchar('\n');
}
for (long unsigned int x = 0; x < sizeof(buffer) && *(buffer + tok + x); x++) *(buffer + x) = *(buffer + x + tok);
pos -= (unsigned long)tok;
*(buffer + pos) = '\0';
memset(&out, '\0', sizeof(out));
}
}
}
return 0;

View File

@ -9,13 +9,6 @@
#include "uirc/mappings.h"
#include "uirc/types.h"
#define ANSI_COLOR_RED "\x1b[31m"
#define ANSI_COLOR_GREEN "\x1b[32m"
#define ANSI_COLOR_YELLOW "\x1b[33m"
#define ANSI_COLOR_BLUE "\x1b[34m"
#define ANSI_COLOR_GRAY "\x1b[90m"
#define ANSI_COLOR_RESET "\x1b[0m"
int main(void)
{
ssize_t bread = 1, tok;
@ -23,10 +16,8 @@ int main(void)
char buffer[513];
IRC_Message out;
for (; bread > 0;) {
if ((bread = read(0, buffer + pos, sizeof(buffer) - 1 - pos)) > 0) {
pos += (size_t)bread;
buffer[pos] = '\0';
if ((tok = get_buffer_line(buffer, &out)) > 0) {
if ((tok = get_buffer_line(buffer, &out)) > 0) {
if (out.cmd == JOIN || out.cmd == PART || out.cmd == QUIT) {
if (out.cmd == JOIN || out.cmd == PART) {
printf((out.cmd == JOIN)
? ANSI_COLOR_GREEN "+++" ANSI_COLOR_RESET " %s " ANSI_COLOR_GREEN "joined" ANSI_COLOR_RESET
@ -34,18 +25,21 @@ int main(void)
: ANSI_COLOR_YELLOW "---" ANSI_COLOR_RESET " %s " ANSI_COLOR_YELLOW "left" ANSI_COLOR_RESET
" " ANSI_COLOR_BLUE "%s" ANSI_COLOR_RESET,
out.name.nick, out.args[0]);
if (out.tags.time.value != NULL) printf(" at %s", out.tags.time.value);
putchar('\n');
} else if (out.cmd == QUIT) {
printf(ANSI_COLOR_RED "***" ANSI_COLOR_RESET " %s " ANSI_COLOR_RED "quit" ANSI_COLOR_RESET, out.name.nick);
if (out.tags.time.value != NULL) printf(" at %s", out.tags.time.value);
putchar('\n');
}
for (long unsigned int x = 0; x < sizeof(buffer) && *(buffer + tok + x); x++) *(buffer + x) = *(buffer + x + tok);
pos -= (unsigned long)tok;
*(buffer + pos) = '\0';
memset(&out, '\0', sizeof(out));
print_local_time(out.tags.time.value);
putchar('\n');
}
for (long unsigned int x = 0; x < sizeof(buffer) && *(buffer + tok + x); x++) *(buffer + x) = *(buffer + x + tok);
pos -= (unsigned long)tok;
*(buffer + pos) = '\0';
memset(&out, '\0', sizeof(out));
continue;
}
if ((bread = read(0, buffer + pos, sizeof(buffer) - 1 - pos)) > 0) {
pos += (size_t)bread;
buffer[pos] = '\0';
}
}
return 0;