]> ruderich.org/simon Gitweb - coloredstderr/coloredstderr.git/commitdiff
hookmacros.h: Be more careful to restore the errno.
authorSimon Ruderich <simon@ruderich.org>
Sat, 1 Jun 2013 20:47:23 +0000 (22:47 +0200)
committerSimon Ruderich <simon@ruderich.org>
Sat, 1 Jun 2013 20:47:23 +0000 (22:47 +0200)
check_handle_fd() or handle_fd_pre() might also modify it.

src/hookmacros.h

index 09e718a594f05216fb0034286ebb493ccdbd42cb..6f65d1e8e84ae86cd8974aea29fba3487201edd7 100644 (file)
@@ -26,6 +26,7 @@
 
 #define _HOOK_PRE(type, name) \
         int handle; \
+        int saved_errno = errno; \
         DLSYM_FUNCTION(real_ ## name, #name);
 #define _HOOK_PRE_FD(type, name, fd) \
         type result; \
         handle = check_handle_fd(fd); \
         if (handle) { \
             handle_fd_pre(fd, handle); \
-        }
+        } \
+        errno = saved_errno;
 #define _HOOK_PRE_FILE(type, name, file) \
         type result; \
         _HOOK_PRE(type, name) \
         handle = check_handle_fd(fileno(file)); \
         if (handle) { \
             handle_file_pre(file, handle); \
-        }
+        } \
+        errno = saved_errno;
 /* Save and restore the errno to make sure we return the errno of the original
  * function call. */
 #define _HOOK_POST_FD_(fd) \
         if (handle) { \
-            int saved_errno = errno; \
+            saved_errno = errno; \
             handle_fd_post(fd, handle); \
             errno = saved_errno; \
         }
@@ -56,7 +59,7 @@
         return result;
 #define _HOOK_POST_FILE(file) \
         if (handle) { \
-            int saved_errno = errno; \
+            saved_errno = errno; \
             handle_file_post(file, handle); \
             errno = saved_errno; \
         } \