this post was submitted on 02 Oct 2023
1418 points (96.8% liked)
Programmer Humor
19660 readers
358 users here now
Welcome to Programmer Humor!
This is a place where you can post jokes, memes, humor, etc. related to programming!
For sharing awful code theres also Programming Horror.
Rules
- Keep content in english
- No advertisements
- Posts must be related to programming or programmer topics
founded 1 year ago
MODERATORS
you are viewing a single comment's thread
view the rest of the comments
view the rest of the comments
You could also say that
down
should not complete todownload
since those are completely different strings and you shouldn't expect one to get you the other.Sorry,
down
is a substring ofdownload
I don't get your point either?Substring is not string.
If they were interchangeable, then "D" & "d" should be too.
down
matchesdown*
because*
also includes empty string. Alsodownload
matchesdown*
D
matchesD*
butd
is not matchingD*
becauseD
is a different character thand
.but why do we have to match specifically against
substr*
? it's not a law of nature, we could also match against the regex(?i)substr(?-i).*
not saying that one option is necessarily better, but I don't see a good reason for which any one of these options would be terrible
Because usability. If you have the files
down
down1
down2
downxyz
anddownload
and the user only knows that it was "something with down" it's best to show the user everything matching "down*" and let the user decide what's the correct one.Also I'm not sure but wouldn't your expression show everything if only one character would be entered?
And again I don't see this solving anything if the entered string actually contains other characters then what's in the file (
D
!=d
)Yes one could argue that some form of advanced algorithm or even AI could be used to identify such use case like download and Download but this is programming Humor, not linguisic Humor.
would it not be usable to have completion be case insensitive? I seem to be able to use that... if I only remember "something with down", I could just as easily forget the capitalization of "down". maybe I have
downloads
andDown
? why not show everything matching case insensitively and let the user decide what's the correct one?I didn't really understand what you thought the regex did incorrectly, but I think the regex works fine, at least for most implementations, anyways what I meant is just a case insensitive version of the regular substring completion, which shouldn't be too difficult to make.
The only thing it solves is the frustration of having to look for a file/directory twice because you didn't remember it's capitalization. again, those are different characters just like a
do
anddownloads
are different strings, but it can be easier for users if they can just press tab and let the computer fill the part of the name the don't remember (or don't want to type).you don't need an advanced algorithm or and AI, there are many easy ways to make completion case insensitive (like that regex for example). Issues involving names are inherently somewhat linguistic, but either way interactive shells are meant to be (at least somewhat) usable to humans, and as seen by the post, some people would prefer completion to be case insensitive.