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

ls: Fix quoting for dirnames with a colon : in recursive mode, and patch the quote-align GNU test #6559

Merged
merged 5 commits into from
Oct 15, 2024

Conversation

RenjiSann
Copy link
Contributor

Fixes #6554 and adds a test for it.

Copy link

GNU testsuite comparison:

Skipping an intermittent issue tests/tail/inotify-dir-recreate (passes in this run but fails in the 'main' branch)

@RenjiSann
Copy link
Contributor Author

@BenWiederhake @sylvestre @tertsdiepraam ping, if one of you has the time to take a look :)

@sylvestre
Copy link
Contributor

Sorry, i didn't look because your test fails a bunch of jobs:

--- TRY 3 STDERR:        coreutils::tests test_ls::test_ls_recursive_escape_dirname ---
thread 'test_ls::test_ls_recursive_escape_dirname' panicked at tests\common\util.rs:956:40:
called `Result::unwrap()` on an `Err` value: Os { code: 267, kind: NotADirectory, message: "The directory name is invalid." }
stack backtrace:
   0: std::panicking::begin_panic_handler
             at /rustc/129f3b9964af4d4a709d1383930ade12dfe7c081/library\std\src\panicking.rs:652
   1: core::panicking::panic_fmt
             at /rustc/129f3b9964af4d4a709d1383930ade12dfe7c081/library\core\src\panicking.rs:72
   2: core::result::unwrap_failed
             at /rustc/129f3b9964af4d4a709d1383930ade12dfe7c081/library\core\src\result.rs:1654
   3: enum2$<core::result::Result<tuple$<>,std::io::error::Error> >::unwrap
             at /rustc/129f3b9964af4d4a709d1383930ade12dfe7c081\library\core\src\result.rs:1077
   4: tests::common::util::AtPath::mkdir<ref$<str$> >
             at .\tests\common\util.rs:956
   5: tests::test_ls::test_ls_recursive_escape_dirname
             at .\tests\by-util\test_ls.rs:2204
   6: tests::test_ls::test_ls_recursive_escape_dirname::closure$0
             at .\tests\by-util\test_ls.rs:2201
   7: core::ops::function::FnOnce::call_once<tests::test_ls::test_ls_recursive_escape_dirname::closure_env$0,tuple$<> >
             at /rustc/129f3b9964af4d4a709d1383930ade12dfe7c081\library\core\src\ops\function.rs:250
   8: core::ops::function::FnOnce::call_once
             at /rustc/129f3b9964af4d4a709d1383930ade12dfe7c081/library\core\src\ops\function.rs:250
note: Some details are omitted, run with `RUST_BACKTRACE=full` for a verbose backtrace.

Copy link

GNU testsuite comparison:

Skip an intermittent issue tests/tail/inotify-dir-recreate (fails in this run but passes in the 'main' branch)

src/uu/ls/src/ls.rs Outdated Show resolved Hide resolved
@RenjiSann RenjiSann force-pushed the renji/fix-6554 branch 5 times, most recently from ff73f42 to a754178 Compare July 22, 2024 08:34
@RenjiSann
Copy link
Contributor Author

RenjiSann commented Jul 22, 2024

I have guessed that when using the shell quoting style, with show-control-chars display enabled, ls should quote the name if it does encounter a control character.

Commit 83c1447 handle this case.

EDIT: It seems that in shell mode, control characters induce simple quoting, no matter the status of show_control.

@RenjiSann RenjiSann force-pushed the renji/fix-6554 branch 3 times, most recently from 9c5b073 to c709722 Compare July 22, 2024 14:18
@RenjiSann
Copy link
Contributor Author

I have made a substantial change in the quoting_style file, regarding the quoting behavior of control characters in shell-* modes.

Even though I am pretty sure this change is sound for ls, it might have repercussions on other utils that use quoting_style

@RenjiSann
Copy link
Contributor Author

I realize this PR does duplicate the work in #6555.

Let's compare the changes and keep the best of both.

@RenjiSann RenjiSann changed the title ls: Fix quoting for dirnames with a colon : in recursive mode ls: Fix quoting for dirnames with a colon : in recursive mode, and patch the quote-align GNU test Jul 25, 2024
Copy link

GNU testsuite comparison:

Skip an intermittent issue tests/tail/inotify-dir-recreate (fails in this run but passes in the 'main' branch)
Congrats! The gnu test tests/ls/quote-align is no longer failing!
Congrats! The gnu test tests/rm/rm2 is no longer failing!

@RenjiSann
Copy link
Contributor Author

Style/Lint jobs are failing due to the clippy bump, but I will rebase the PR once #6592 has landed.

@RenjiSann RenjiSann force-pushed the renji/fix-6554 branch 3 times, most recently from 5d96927 to fc0f388 Compare July 25, 2024 22:48
Copy link

GNU testsuite comparison:

Skip an intermittent issue tests/tail/inotify-dir-recreate (fails in this run but passes in the 'main' branch)
Congrats! The gnu test tests/ls/quote-align is no longer failing!
Congrats! The gnu test tests/rm/rm2 is no longer failing!

@RenjiSann
Copy link
Contributor Author

I keep finding edge cases : \a is a control character, yet it shall not be escaped in shell mode. I need to rework my solution.

So far:

$ LC_ALL=C /usr/bin/ls --quoting=shell test
 xx?bell   xx?backspace  'xx?tab'  'xx?linefeed'   xx?vtab   xx?formfeed  'xx?carriage'  'xx space'

$ LC_ALL=C ./target/debug/ls --quoting=shell test
'xx?bell'  'xx?backspace'  'xx?tab'  'xx?linefeed'  'xx?vtab'  'xx?formfeed'  'xx?carriage'  'xx space'

I don't see a specific pattern, so I guess we will have to do it by hand.

@RenjiSann
Copy link
Contributor Author

Also, I think you inverted for ^ : with --quoting-style=shell, a caret should be escaped, and we currently don't

Copy link

GNU testsuite comparison:

Congrats! The gnu test tests/ls/quote-align is no longer failing!

Copy link

GNU testsuite comparison:

Skip an intermittent issue tests/tail/inotify-dir-recreate (fails in this run but passes in the 'main' branch)
Congrats! The gnu test tests/ls/quote-align is no longer failing!

Copy link

GNU testsuite comparison:

Congrats! The gnu test tests/ls/quote-align is no longer failing!

@RenjiSann RenjiSann force-pushed the renji/fix-6554 branch 2 times, most recently from 014fbc0 to 66b0f12 Compare September 18, 2024 14:24
Copy link

GNU testsuite comparison:

Congrats! The gnu test tests/ls/quote-align is no longer failing!
Skipping an intermittent issue tests/rm/rm1 (passes in this run but fails in the 'main' branch)
Congrats! The gnu test tests/timeout/timeout is no longer failing!

@BenWiederhake
Copy link
Collaborator

Current set of problems with this PR:

  • git conflict, cannot merge as-is
  • = should be quoted in --quoting-style=shell
  • = should be quoted in --quoting-style=shell-escape
  • Non-unicode filenames are lost, everything is replaced by \xEF\xBF\xBD ("replacement character"). If you wish we can define this as out-of-scope for this PR.
  • Filenames with high bit set (including valid unicode) in c, escape, shell-escape, and shell-escape-always. This is known issue ls: printing of 8-bit filenames is incorrect in most cases in LC_ALL=C #6639, and therefore out-of-scope.

Copy link

GNU testsuite comparison:

Congrats! The gnu test tests/ls/quote-align is no longer failing!

@RenjiSann
Copy link
Contributor Author

Current set of problems with this PR:

* `=` should be quoted in `--quoting-style=shell`

* `=` should be quoted in `--quoting-style=shell-escape`

* Non-unicode filenames are lost, everything is replaced by `\xEF\xBF\xBD` ("replacement character"). If you wish we can define this as out-of-scope for this PR.

* Filenames with high bit set (including valid unicode) in `c`, `escape`, `shell-escape`, and `shell-escape-always`. This is known issue [ls: printing of 8-bit filenames is incorrect in most cases in `LC_ALL=C` #6639](https://github.com/uutils/coreutils/issues/6639), and therefore out-of-scope.

Thanks for the review.

The conflict and the behavior for = are fixed.

Regarding the two other points, we can leave them for future PRs, I think it's out of the scope of this PR.

Copy link

GNU testsuite comparison:

GNU test failed: tests/timeout/timeout. tests/timeout/timeout is passing on 'main'. Maybe you have to rebase?
Congrats! The gnu test tests/ls/quote-align is no longer failing!

@sylvestre sylvestre merged commit 6935a0d into uutils:main Oct 15, 2024
65 of 67 checks passed
@sylvestre
Copy link
Contributor

thanks :)

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.

ls: gnu test case quote-align compatibility
4 participants