Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Also close stderr file descriptor #110

Closed
wants to merge 1 commit into from

Conversation

caioraposo
Copy link

This is similar to aa4633b but for stderr.

It can be reproduced with the following shell pipe line which does not terminate.

echo "text to copy" | wl-copy 2>&1 >/dev/null | cat

This fixes an issue I was having with a text editor.

This is similar to aa4633b but for stderr
@bugaevc
Copy link
Owner

bugaevc commented Feb 24, 2021

Hi, and thanks for taking interest in wl-clipboard!

Unfortunately, this case is less clear-cut than #100. An important point there was that wl-copy never writes to its stdout (as it produces no output), nor does it read from its stdin once it has read the whole stdin once (and copied it into a temp file). But it may and will use stderr for logging any errors, at any time, including after forking into background.

So redirecting stderr to /dev/null, as you suggest, is basically silencing any errors wl-copy may encounter. I believe it would also break WAYLAND_DEBUG logging. If silencing any errors/warnings from wl-copy is what you actually want, why don't you run it with stderr attached to /dev/null to begin with, e.g. wl-copy 2>/dev/null?

In case of an editor using wl-copy internally to implement copying, the proper fix would be for the editor to consider the text copied once the parent wl-copy exits, but keep watching for potential errors (and perhaps displaying them to the user) until the pipe is closed. Note that wl-clipboard is not the only clipboard program to use background-forking, e.g. xclip does the same, so the fix wouldn't specifically target wl-clipboard either.

@caioraposo
Copy link
Author

No problem, I clearly misunderstood the issue. I'll close this PR but thanks for your suggestions!

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

vis_pipe() doesn't correctly handle programs that fork to the background
2 participants