4 * Copyright (C) 2013 Simon Ruderich
6 * This program is free software: you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License as published by
8 * the Free Software Foundation, either version 3 of the License, or
9 * (at your option) any later version.
11 * This program is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
16 * You should have received a copy of the GNU General Public License
17 * along with this program. If not, see <http://www.gnu.org/licenses/>.
23 static void debug_write(int fd, int first_call, char const *format, va_list ap) {
26 int written = vsnprintf(buffer, sizeof(buffer), format, ap);
28 if ((size_t)written >= sizeof(buffer)) {
29 written = sizeof(buffer) - 1;
32 /* Make sure these functions are loaded. */
33 DLSYM_FUNCTION(real_write, "write");
34 DLSYM_FUNCTION(real_close, "close");
38 real_write(fd, &nl, 1);
40 real_write(fd, buffer, (size_t)written);
45 static void debug(char const *format, ...) {
48 int saved_errno = errno;
50 /* If the file doesn't exist, do nothing. Prevents writing log files in
51 * unexpected places. The user must create the file manually. */
52 int fd = open(DEBUG_FILE, O_WRONLY | O_APPEND);
58 static int call_count = 0;
62 debug_write(fd, call_count == 1, format, ap);
69 static void warning(char const *format, ...) {
72 int saved_errno = errno;
74 char const *home = getenv("HOME");
80 char path[strlen(home) + 1 + strlen(WARNING_FILE) + 1];
83 strcat(path, WARNING_FILE);
85 /* Create the warning file if it doesn't exist yet. */
86 int fd = open(path, O_WRONLY | O_APPEND | O_CREAT, S_IRUSR | S_IWUSR);
92 static int call_count = 0;
96 debug_write(fd, call_count == 1, format, ap);