summaryrefslogtreecommitdiff
path: root/Parser/intrcheck.c
diff options
context:
space:
mode:
authorGuido van Rossum <guido@python.org>1997-11-14 22:24:28 +0000
committerGuido van Rossum <guido@python.org>1997-11-14 22:24:28 +0000
commit359bcaa539d9bbb2b008b5fd0a76c758b489bed5 (patch)
treee6c5cb83090ef2a2cffcbb18f0ec5db28111a960 /Parser/intrcheck.c
parentc9fd600640229af8381f207b7d9224ba86db7206 (diff)
downloadcpython-git-359bcaa539d9bbb2b008b5fd0a76c758b489bed5.tar.gz
This fix (across 4 files in 3 directories) solves a subtle problem with
signal handlers in a fork()ed child process when Python is compiled with thread support. The bug was reported by Scott <scott@chronis.icgroup.com>. What happens is that after a fork(), the variables used by the signal module to determine whether this is the main thread or not are bogus, and it decides that no thread is the main thread, so no signals will be delivered. The solution is the addition of PyOS_AfterFork(), which fixes the signal module's variables. A dummy version of the function is present in the intrcheck.c source file which is linked when the signal module is not used.
Diffstat (limited to 'Parser/intrcheck.c')
-rw-r--r--Parser/intrcheck.c5
1 files changed, 5 insertions, 0 deletions
diff --git a/Parser/intrcheck.c b/Parser/intrcheck.c
index a2a31452bb..7fe6205f44 100644
--- a/Parser/intrcheck.c
+++ b/Parser/intrcheck.c
@@ -219,3 +219,8 @@ PyOS_InterruptOccurred()
}
#endif /* !OK */
+
+void
+PyOS_AfterFork()
+{
+}