diff --git a/libjava/ChangeLog b/libjava/ChangeLog index f92645a65694f07f1df788fddd601937c7d7473c..9201d268ffeeaad3ac36f45d38a234d110d3d033 100644 --- a/libjava/ChangeLog +++ b/libjava/ChangeLog @@ -1,3 +1,10 @@ +2001-02-13 Tom Tromey <tromey@redhat.com> + + Fix for PR libgcj/1351: + * posix.cc (_Jv_select): Throw InterruptedIOException if thread is + interrupted. + Include Thread.h and InterruptedIOException.h. + 2001-02-13 Bryce McKinlay <bryce@albatross.co.nz> * java/io/BlockDataException.java: Removed. diff --git a/libjava/posix.cc b/libjava/posix.cc index d470a644da3c9d92c31a606f65a3c9baf59d4863..1f5b037f704b0b07d53cab9e24834e498b826b87 100644 --- a/libjava/posix.cc +++ b/libjava/posix.cc @@ -1,6 +1,6 @@ // posix.cc -- Helper functions for POSIX-flavored OSs. -/* Copyright (C) 2000 Free Software Foundation +/* Copyright (C) 2000, 2001 Free Software Foundation This file is part of libgcj. @@ -14,6 +14,10 @@ details. */ #include <errno.h> +#include <jvm.h> +#include <java/lang/Thread.h> +#include <java/io/InterruptedIOException.h> + #if defined (ECOS) extern "C" unsigned long long _clock (void); #endif @@ -76,6 +80,10 @@ _Jv_select (int n, fd_set *readfds, fd_set *writefds, if (r != -1 || errno != EINTR) return r; + // Here we know we got EINTR. + if (java::lang::Thread::interrupted ()) + throw new java::io::InterruptedIOException (JvNewStringLatin1 ("select interrupted")); + struct timeval after; if (timeout) {