X-Git-Url: https://ruderich.org/simon/gitweb/?p=coloredstderr%2Fcoloredstderr.git;a=blobdiff_plain;f=src%2Fcoloredstderr.c;h=fd83b15bae63192597a914ff30f6525a7b1f7869;hp=064383ea545c90697fbc1f849ba301cc5799c494;hb=3676d3f21f0e1e2e59cd2fcafc64acccd3782ef9;hpb=3e894f0f32aa021b5c9033c3c71539c3965aa6de diff --git a/src/coloredstderr.c b/src/coloredstderr.c index 064383e..fd83b15 100644 --- a/src/coloredstderr.c +++ b/src/coloredstderr.c @@ -534,11 +534,12 @@ pid_t vfork(void) { * isn't allowed to perform any memory-modifications before the exec() * (except the pid_t result variable of vfork()). * - * As some programs don't adhere to the standard (e.g. the "child" closes - * or dups a descriptor before the exec()) and this breaks our tracking of - * file descriptors (e.g. it gets closed in the parent as well), we just - * fork() instead. This is in compliance with the POSIX standard and as - * most systems use copy-on-write anyway not a performance issue. */ + * As we have to store changes to the file descriptors in memory (e.g. the + * "child" closes or dups a descriptor before the exec()) and this + * modifies the parent as well due to the semantics of vfork() - thus + * breaking the requirements of vfork(), we just use fork instead(). This + * is in compliance with the POSIX standard and as most systems use + * copy-on-write anyway not a performance issue. */ return fork(); } #endif