git-annex/doc/bugs/fsck_output.mdwn

37 lines
1.2 KiB
Text
Raw Normal View History

2011-03-18 17:54:32 +00:00
When you check several files and the fsck fails, you get confusing output:
<pre>
2011-03-18 20:47:20 +00:00
O fsck test1 (checksum...)
E Only 1 of 2 trustworthy copies of test1 exist.
E Back it up with git-annex copy.
O
O failed
O fsck test2 (checksum...)
E Only 1 of 2 trustworthy copies of test2 exist.
E Back it up with git-annex copy.
O
O failed
2011-03-18 17:54:32 +00:00
</pre>
The newline is in the wrong place and confuses the user. It should be printed _after_ "failed".
2011-03-18 20:47:20 +00:00
> This is a consequence of part of the output being printed to stderr, and
> part to stdout. I've marked the lines above with E and O.
>
> Normally a "failed" is preceeded by a message output to stdout desribing
> the problem; such a message will not be "\n" terminated, so a newline
> is always displayed before "failed". In this case, since the message
> is sent to stderr, it is newline terminated.
>
> Fixing this properly would involve storing state, or rethinking
> when git-annex displays newlines (and I rather like its behavior
2011-03-18 21:05:03 +00:00
> otherwise).
>
> A related problem occurs if an error message is unexpetedly printed.
> Dummying up an example:
>
> O get test1 (from foo...) E git-annex: failed to run ssh
2011-03-18 21:05:03 +00:00
> failed
>
> --[[Joey]]