This is part of the Semicolon&Sons Code Diary - consisting of lessons learned on the job. You're in the unix category.
Last Updated: 2025-01-18
I wanted to parse the output of a subprocess (i.e. I was looking for the content "listening")
I had the following code:
pipe_read, pipe_write = IO.pipe
pid = Process.spawn(
start_vim_server,
in: pipe_read,
out: pipe_write
)
# pipe_read.gets never had any content
until (line = pipe_read.gets) =~ /listening/i
puts "waiting #{line}"
sleep 0.1
end
When I ran it, I noticed the output "listening" appearing on the terminal, but pipe_read
had 0 lines, therefore my loop never even ran.
The fix was to pay attention to STDERR
as well:
pipe_read, pipe_write = IO.pipe
pid = Process.spawn(
start_vim_server,
in: pipe_read,
err: pipe_write,
out: pipe_write
)