Compare commits

...

2 Commits

Author SHA1 Message Date
964425e7b8 add logger history 2026-05-19 18:43:57 -05:00
fbb618711f add formatting to lLogString 2026-05-19 18:33:37 -05:00
3 changed files with 53 additions and 19 deletions

41
LLog.c
View File

@@ -3,6 +3,7 @@
#include <stdio.h> #include <stdio.h>
#include <stdlib.h> #include <stdlib.h>
#include "time.h" #include "time.h"
#include <stdarg.h>
int timer_array_append(timer_array* array, lTimer timer) { int timer_array_append(timer_array* array, lTimer timer) {
if (array->count >= array->capacity) { if (array->count >= array->capacity) {
@@ -15,6 +16,17 @@ int timer_array_append(timer_array* array, lTimer timer) {
return array->count - 1; return array->count - 1;
} }
int lLogString_array_append(lLogString_array* array, lLogString* string) {
if (array->count >= array->capacity) {
if (array->capacity == 0) array->capacity = 8;
else array->capacity *= 2;
array->items = realloc(array->items, array->capacity * sizeof(*array->items));
}
array->items[array->count++] = string;
return array->count - 1;
}
int create_timer(Logger* logger) { int create_timer(Logger* logger) {
return timer_array_append(&logger->timers, (lTimer){}); return timer_array_append(&logger->timers, (lTimer){});
} }
@@ -29,22 +41,33 @@ void stop_timer(Logger* logger, int timer_id) {
logger->timers.items[timer_id].time.end = time(NULL); logger->timers.items[timer_id].time.end = time(NULL);
} }
lLogString to_lLogString(const char* string) { lLogString* lLogString_new(const char* fmt, ...) {
lLogString str; va_list args;
str.buf = (char *)string; va_start(args, fmt);
if (string == NULL) {
str.len = 0; char temp_string[max_string_len];
} else { vsnprintf(temp_string, max_string_len, fmt, args);
str.len = strlen(string);
va_end(args);
lLogString* str = calloc(1, sizeof(lLogString));
str->len = strlen(temp_string);
str->buf = malloc(str->len + 1);
if (str->buf != NULL) {
strcpy(str->buf, temp_string);
} }
return str; return str;
}; };
void lLog(Logger logger, enum lLogLevel LOG_LEVEL, lLogString MESSAGE) { int lLog(Logger* logger, enum lLogLevel LOG_LEVEL, lLogString* MESSAGE) {
char* LOG_LEVEL_STRING = LOG_LEVEL == 0 ? "INFO" : char* LOG_LEVEL_STRING = LOG_LEVEL == 0 ? "INFO" :
LOG_LEVEL == 1 ? "WARNING" : LOG_LEVEL == 1 ? "WARNING" :
LOG_LEVEL == 2 ? "ERROR" : LOG_LEVEL == 2 ? "ERROR" :
LOG_LEVEL == 3 ? "DEBUG" : LOG_LEVEL == 3 ? "DEBUG" :
"invalid_log_level"; "invalid_log_level";
printf("[%s]: %.*s\n", LOG_LEVEL_STRING, (int)MESSAGE.len, MESSAGE.buf);
printf("[%s]: %.*s\n", LOG_LEVEL_STRING, (int)MESSAGE->len, MESSAGE->buf);
return lLogString_array_append(&logger->history, MESSAGE);
} }

View File

@@ -2,6 +2,9 @@
#define LLog_H #define LLog_H
#include "time.h" #include "time.h"
#include <stdarg.h>
#define max_string_len 1024
typedef struct { typedef struct {
char *buf; char *buf;
@@ -29,20 +32,27 @@ typedef struct {
size_t capacity; size_t capacity;
lTimer* items; lTimer* items;
} timer_array; } timer_array;
int timer_array_append(timer_array* array, lTimer timer); int timer_array_append(timer_array* array, lTimer timer);
typedef struct {
size_t count;
size_t capacity;
lLogString** items;
} lLogString_array;
int lLogString_array_append(lLogString_array* array, lLogString* string);
typedef struct { typedef struct {
lLogString logfolder; lLogString logfolder;
timer_array timers; timer_array timers;
lLogString_array history;
} Logger; } Logger;
int create_timer(Logger* logger); int create_timer(Logger* logger);
void start_timer(Logger* logger, int timer_id); void start_timer(Logger* logger, int timer_id);
void stop_timer(Logger* logger, int timer_id); void stop_timer(Logger* logger, int timer_id);
lLogString to_lLogString(const char* string); lLogString* lLogString_new(const char* fmt, ...);
void lLog(Logger logger, enum lLogLevel LOG_LEVEL, lLogString MESSAGE); int lLog(Logger* logger, enum lLogLevel LOG_LEVEL, lLogString* MESSAGE);
#endif #endif

View File

@@ -1,20 +1,21 @@
#include "../include/LLog.h" #include "../include/LLog.h"
#include <stdio.h>
#include <unistd.h> #include <unistd.h>
int main(void) { int main(void) {
Logger logger = {0}; Logger logger = {0};
lLog(logger, lINFO, to_lLogString("Hello, INFO!")); int message_1_id = lLog(&logger, lINFO, lLogString_new("Hello, INFO!"));
lLog(logger, lWARNING, to_lLogString("Hello, WARNING!")); lLog(&logger, lINFO, logger.history.items[message_1_id]);
lLog(logger, lERROR, to_lLogString("Hello, ERROR!"));
lLog(logger, lDEBUG, to_lLogString("Hello, DEBUG!")); int message_2_id = lLog(&logger, lWARNING, lLogString_new("Hello, WARNING!"));
int message_3_id = lLog(&logger, lERROR, lLogString_new("Hello, ERROR!"));
int message_4_id = lLog(&logger, lDEBUG, lLogString_new("Hello, DEBUG!"));
int timer = create_timer(&logger); int timer = create_timer(&logger);
lTimespan* time_object = &logger.timers.items[timer].time; lTimespan* time_object = &logger.timers.items[timer].time;
start_timer(&logger, timer); start_timer(&logger, timer);
sleep(5); sleep(2);
stop_timer(&logger, timer); stop_timer(&logger, timer);
printf("\n%f seconds.\n", difftime(time_object->end, time_object->start)); lLog(&logger, lINFO, lLogString_new("%f seconds.", difftime(time_object->end, time_object->start)));
} }