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

Fix external command name parsing with backslashes, and add tests #13027

Merged
merged 1 commit into from
Jun 3, 2024

Conversation

devyn
Copy link
Contributor

@devyn devyn commented Jun 1, 2024

Description

Fixes #13016 and adds tests for many variations of external call parsing.

I just realized @kubouch took a crack at this too (#13022) so really whichever is better, but I think the
tests are a good addition.

@kubouch
Copy link
Contributor

kubouch commented Jun 1, 2024

That's fine, I just quickly tested one thing, let's go with your version.

@kubouch kubouch merged commit b50903c into nushell:main Jun 3, 2024
13 checks passed
@fdncred
Copy link
Collaborator

fdncred commented Jun 3, 2024

@devyn @kubouch This just hangs now. I'm not convinced #13016 is fixed yet.

 let b = c:\Users\username\.cargo\bin\bat.exe

This kind of works

let b = 'c:\Users\username\.cargo\bin\bat.exe'

but then I can't do

$b readme.md

I have to do. Not sure this is good or bad?

^$b readme.md

@kubouch
Copy link
Contributor

kubouch commented Jun 3, 2024

@fdncred

let b = c:\Users\username\.cargo\bin\bat.exe

tries to run c:\Users\username\.cargo\bin\bat.exe and store the result to b. So, I think it makes sense that it hangs. alias b = c:\Users\username\.cargo\bin\bat.exe should be working, though.

The caret is required for running an external from a string, that seems to work as intended.

@fdncred
Copy link
Collaborator

fdncred commented Jun 3, 2024

I don't understand what you're saying because you used 2 identical examples and said one should work and the other shouldn't. LOL.

I'm not sure #13016 is fixed unless we say it has to be in quotes.

@kubouch
Copy link
Contributor

kubouch commented Jun 3, 2024

Look at the first word: let vs. alias.

@fdncred
Copy link
Collaborator

fdncred commented Jun 3, 2024

ROTFL! I'm so stupid. You're right. In this situation let = bad, alias = good. I feel better now.

@hustcer hustcer added this to the v0.95.0 milestone Jun 4, 2024
devyn added a commit that referenced this pull request Jun 20, 2024
…he parser (#13089)

# Description

We've had a lot of different issues and PRs related to arg handling with
externals since the rewrite of `run-external` in #12921:

- #12950
- #12955
- #13000
- #13001
- #13021
- #13027
- #13028
- #13073

Many of these are caused by the argument handling of external calls and
`run-external` being very special and involving the parser handing
quoted strings over to `run-external` so that it knows whether to expand
tildes and globs and so on. This is really unusual and also makes it
harder to use `run-external`, and also harder to understand it (and
probably is part of the reason why it was rewritten in the first place).

This PR moves a lot more of that work over to the parser, so that by the
time `run-external` gets it, it's dealing with much more normal Nushell
values. In particular:

- Unquoted strings are handled as globs with no expand
- The unescaped-but-quoted handling of strings was removed, and the
parser constructs normal looking strings instead, removing internal
quotes so that `run-external` doesn't have to do it
- Bare word interpolation is now supported and expansion is done in this
case
- Expressions typed as `Glob` containing `Expr::StringInterpolation` now
produce `Value::Glob` instead, with the quoted status from the expr
passed through so we know if it was a bare word
- Bare word interpolation for values typed as `glob` now possible, but
not implemented
- Because expansion is now triggered by `Value::Glob(_, false)` instead
of looking at the expr, externals now support glob types

# User-Facing Changes

- Bare word interpolation works for external command options, and
otherwise embedded in other strings:
  ```nushell
  ^echo --foo=(2 + 2) # prints --foo=4
  ^echo -foo=$"(2 + 2)" # prints -foo=4
  ^echo foo="(2 + 2)" # prints (no interpolation!) foo=(2 + 2)
  ^echo foo,(2 + 2),bar # prints foo,4,bar
  ```

- Bare word interpolation expands for external command head/args:
  ```nushell
  let name = "exa"
  ~/.cargo/bin/($name) # this works, and expands the tilde
  ^$"~/.cargo/bin/($name)" # this doesn't expand the tilde
  ^echo ~/($name)/* # this glob is expanded
  ^echo $"~/($name)/*" # this isn't expanded
  ```

- Ndots are now supported for the head of an external command
(`^.../foo` works)

- Glob values are now supported for head/args of an external command,
and expanded appropriately:
  ```nushell
  ^("~/.cargo/bin/exa" | into glob) # the tilde is expanded
  ^echo ("*.txt" | into glob) # this glob is expanded
  ```

- `run-external` now works more like any other command, without
expecting a special call convention
  for its args:
  ```nushell
  run-external echo "'foo'"
  # before PR: 'foo'
  # after PR:  foo
  run-external echo "*.txt"
  # before PR: (glob is expanded)
  # after PR:  *.txt
  ```

# Tests + Formatting
Lots of tests added and cleaned up. Some tests that weren't active on
Windows changed to use `nu --testbin cococo` so that they can work.
Added a test for Linux only to make sure tilde expansion of commands
works, because changing `HOME` there causes `~` to reliably change.

- 🟢 `toolkit fmt`
- 🟢 `toolkit clippy`
- 🟢 `toolkit test`
- 🟢 `toolkit test stdlib`

# After Submitting
- [ ] release notes: make sure to mention the new syntaxes that are
supported
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.

nushell 0.94.1 breaks Windows path handling
4 participants