-
-
Notifications
You must be signed in to change notification settings - Fork 2k
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
Issues with -f or --file switch and a file with a backslash character (\) #832
Comments
Am I misinterpreting the usage of the -f/--file parameter? Am I supposed to be using the file as my search query? facepalm EDIT: Yup. The Slashes example is still an issue though. |
The
The patterns in the file have to follow the same regex syntax rules as a pattern supplied on the command line. In Rust's regex engine, the So, instead of Alternatively, you might be able to use the |
I appreciate the feedback, this clears up my misunderstanding. I think you can probably close this issue as I was not using the switch correctly.
- Paul Hey
From Outlook<https://aka.ms/qtex0l> iOS
…________________________________
From: dana <[email protected]>
Sent: Thursday, February 22, 2018 6:23:05 PM
To: BurntSushi/ripgrep
Cc: Paul Hey; Author
Subject: Re: [BurntSushi/ripgrep] Issues with -f or --file switch and a file with a backslash character (\) (#832)
The -f file contains a list of patterns that rg should search for (instead of using a pattern supplied directly on the command line). For example, these are basically equivalent searches:
# Pattern supplied on command line
% rg 'foo.*bar' file1 file2 file3
# Pattern supplied via file with `-f`
% cat patterns
foo.*bar
% rg -f patterns file1 file2 file3
The patterns in the file have to follow the same regex syntax rules as a pattern supplied on the command line. In Rust's regex engine, the \ character can be used either to make characters that are normally special not special (for example, \* matches a literal * character) or the other way around (for example, \d matches a digit). Since \ itself is therefore a special character, you need to escape it to make it match a literal \ in your file.
So, instead of \fixme (or whatever), make your pattern \\fixme.
Alternatively, you might be able to use the -F option to make rg treat patterns as literal strings (see rg --help).
—
You are receiving this because you authored the thread.
Reply to this email directly, view it on GitHub<#832 (comment)>, or mute the thread<https://github.com/notifications/unsubscribe-auth/AOfyKqfsXiL21-gDOINxZpDMQ-BxiVHiks5tXiEIgaJpZM4SQQGu>.
|
@leftcoastbeard Thanks for the bug report! Could you please help us understand how we can improve ripgrep's documentation such that it would have prevented this confusion? |
I think the simplest way would be to update the Usage options from:
```
USAGE:
rg [OPTIONS] PATTERN [PATH ...]
rg [OPTIONS] [-e PATTERN ...] [-f FILE ...] [PATH ...]
rg [OPTIONS] --files [PATH ...]
rg [OPTIONS] --type-list
```
To something like:
```
USAGE:
rg [OPTIONS] PATTERN [PATH ...]
rg [OPTIONS] [-e PATTERN ...] [-f PATTERNFILE ...] [PATH ...]
rg [OPTIONS] --files [PATH ...]
rg [OPTIONS] --type-list
```
The full help has it explained clearly, more or less. I just needed to RTM.
Thanks,
…-Paul Hey
From: Andrew Gallant [mailto:[email protected]]
Sent: February 23, 2018 03:50
To: BurntSushi/ripgrep <[email protected]>
Cc: Paul Hey <[email protected]>; Mention <[email protected]>
Subject: Re: [BurntSushi/ripgrep] Issues with -f or --file switch and a file with a backslash character (\) (#832)
@leftcoastbeard<https://github.com/leftcoastbeard> Thanks for the bug report! Could you please help us understand how we can improve ripgrep's documentation such that it would have prevented this confusion?
—
You are receiving this because you were mentioned.
Reply to this email directly, view it on GitHub<#832 (comment)>, or mute the thread<https://github.com/notifications/unsubscribe-auth/AOfyKhi0lXu-sl2tZuOKF8mvfWHpigZVks5tXqX3gaJpZM4SQQGu>.
|
@leftcoastbeard Done! Thanks. |
What version of ripgrep are you using?
ripgrep 0.8.1
-SIMD -AVX
What operating system are you using ripgrep on?
Windows 10 x64, 1709
Describe your question, feature request, or bug.
If this is a bug, what are the steps to reproduce the behavior?
Using file.txt as this:
This produces:
If I run without the -f switch I get:
Another weird error: test.txt
Running:
Should have done this:
If this is a bug, what is the actual behavior?
Debug for first:
Debug for second:
Gist Here
The --debug stopped working after this dumped (couldn't replicate the debug output again).
Show the command you ran and the actual output. Include the
--debug
flag inyour invocation of ripgrep.
The text was updated successfully, but these errors were encountered: