X-Git-Url: https://ruderich.org/simon/gitweb/?p=coloredstderr%2Fcoloredstderr.git;a=blobdiff_plain;f=src%2Fhookmacros.h;h=35e64703ddcc1933891ea8645d155c6edea9282f;hp=f2a1fe89508d3b037b90e04e0e7a219985daf5b5;hb=9862b8c8f13fe3d5a6012a8d67562bdaef48b8af;hpb=c7f6f13de07d6010c5387a9db26e64310bbc657b diff --git a/src/hookmacros.h b/src/hookmacros.h index f2a1fe8..35e6470 100644 --- a/src/hookmacros.h +++ b/src/hookmacros.h @@ -22,24 +22,76 @@ /* Hook the function by creating a function with the same name. With * LD_PRELOAD our function will be preferred. The original function is stored - * in a static variable (real_*). */ + * in a static variable (real_*). Any function called in these macros must + * make sure to restore the errno if it changes it. + * + * "Pseudo code" for the following macros. is the name of the hooked + * function, is either a file descriptor or a FILE pointer. + * + * if (!real_) { + * real_ = dlsym_function(); + * if (!initialized) { + * init_from_environment(); + * } + * } + * if (tracked_fds_find()) { + * if (force_write_to_non_tty) { + * handle = 1; + * } else { + * handle = isatty(); + * } + * } else { + * handle = 0; + * } + * + * if (handle) { + * handle__pre(); + * } + * result = real_(); + * if (handle) { + * handle__post(); + * } + * return result; + */ #define _HOOK_PRE(type, name) \ int handle; \ - DLSYM_FUNCTION(real_ ## name, #name); + if (!(real_ ## name )) { \ + *(void **) (&(real_ ## name)) = dlsym_function(#name); \ + /* Initialize our data while we're at it. */ \ + if (!initialized) { \ + init_from_environment(); \ + } \ + } #define _HOOK_PRE_FD(type, name, fd) \ type result; \ _HOOK_PRE_FD_(type, name, fd) #define _HOOK_PRE_FD_(type, name, fd) \ _HOOK_PRE(type, name) \ - handle = check_handle_fd(fd); \ + if (tracked_fds_find(fd)) { \ + if (force_write_to_non_tty) { \ + handle = 1; \ + } else { \ + handle = isatty(fd); \ + } \ + } else { \ + handle = 0; \ + } \ if (handle) { \ handle_fd_pre(fd); \ } #define _HOOK_PRE_FILE(type, name, file) \ type result; \ _HOOK_PRE(type, name) \ - handle = check_handle_fd(fileno(file)); \ + if (tracked_fds_find(fileno(file))) { \ + if (force_write_to_non_tty) { \ + handle = 1; \ + } else { \ + handle = isatty(fileno(file)); \ + } \ + } else { \ + handle = 0; \ + } \ if (handle) { \ handle_file_pre(file); \ }