From 90c5e00f5e589507c9255d067797da0b48734291 Mon Sep 17 00:00:00 2001 From: Knut Wannheden Date: Thu, 24 Oct 2024 09:29:26 +0200 Subject: [PATCH] Fix socket timeout handling in `PythonParser` --- .../org/openrewrite/python/PythonParser.java | 19 ++++++------------- 1 file changed, 6 insertions(+), 13 deletions(-) diff --git a/rewrite-python/src/main/java/org/openrewrite/python/PythonParser.java b/rewrite-python/src/main/java/org/openrewrite/python/PythonParser.java index 07c621a8..6a72c133 100644 --- a/rewrite-python/src/main/java/org/openrewrite/python/PythonParser.java +++ b/rewrite-python/src/main/java/org/openrewrite/python/PythonParser.java @@ -103,20 +103,13 @@ public Stream parseInputs(Iterable inputs, @Nullable Path rel generator.writeString("parse-python-file"); generator.writeString(input.getPath().toString()); } - }, parser -> { - int oldTimeout = socket.getSoTimeout(); - try { - if (parseTimeoutMs > 0) { - // make sure we don't block forever - socket.setSoTimeout(parseTimeoutMs); - } - Tree tree = new ReceiverContext(remotingContext.newReceiver(parser), remotingContext).receiveTree(null); - return (SourceFile) tree; - } catch (Exception e) { - return ParseError.build(this, input, relativeTo, ctx, e); - } finally { - socket.setSoTimeout(oldTimeout); + // make sure we don't block forever when reading + if (parseTimeoutMs > 0) { + socket.setSoTimeout(parseTimeoutMs); } + }, parser -> { + Tree tree = new ReceiverContext(remotingContext.newReceiver(parser), remotingContext).receiveTree(null); + return (SourceFile) tree; }, socket))) .withSourcePath(path) .withFileAttributes(FileAttributes.fromPath(input.getPath()))