+ CloseHandle(log_file);
+ log_file = INVALID_HANDLE_VALUE;
+}
+
+void syslog(int priority, const char *message, ... /* argument */)
+{
+ va_list v;
+ int len;
+ char *output;
+ DWORD bytes_written;
+
+ if (log_file == INVALID_HANDLE_VALUE) {
+ log_file = CreateFileA("syslog.txt", GENERIC_WRITE, FILE_SHARE_READ | FILE_SHARE_WRITE, NULL, OPEN_ALWAYS, 0, NULL);
+ }
+
+ if (log_file == INVALID_HANDLE_VALUE) {
+ log_err("syslog: failed to open log file\n");
+ return;
+ }
+
+ va_start(v, message);
+ len = _vscprintf(message, v);
+ output = malloc(len + sizeof(char));
+ vsprintf_s(output, len + sizeof(char), message, v);
+ WriteFile(log_file, output, len, &bytes_written, NULL);
+ va_end(v);
+ free(output);