this post was submitted on 13 Sep 2023
13 points (65.1% liked)
Asklemmy
43810 readers
1229 users here now
A loosely moderated place to ask open-ended questions
If your post meets the following criteria, it's welcome here!
- Open-ended question
- Not offensive: at this point, we do not have the bandwidth to moderate overtly political discussions. Assume best intent and be excellent to each other.
- Not regarding using or support for Lemmy: context, see the list of support communities and tools for finding communities below
- Not ad nauseam inducing: please make sure it is a question that would be new to most members
- An actual topic of discussion
Looking for support?
Looking for a community?
- Lemmyverse: community search
- sub.rehab: maps old subreddits to fediverse options, marks official as such
- !lemmy411@lemmy.ca: a community for finding communities
~Icon~ ~by~ ~@Double_A@discuss.tchncs.de~
founded 5 years ago
MODERATORS
you are viewing a single comment's thread
view the rest of the comments
view the rest of the comments
Text input by a user is almost always a string, because the user presses 0 or more keys on their keyboard before hitting enter.
Without validation, we have no way to know that the user typed - did they type “1” or “True”, or did they embrace chaos and type in “Batman”? Unless we check, we can’t be sure.
We can assume, but then we have to accept that our program will have what we call “undefined behaviour” if our assumption is incorrect - which is definitely not good. In the best case scenario, your code harmlessly crashes. In the worst case scenario, your code is being used by the Pentagon for some reason and just started global thermonuclear war, which ideally should be avoided.
There are ways around this. For example, we could listen for individual keystrokes and only accept the inputs if they meet our criteria - if the user presses the 1 key, that’s true, if they press 0, that’s false, any other key is ignored, for example.
But the best thing to do, in my humble opinion, is to accept a string input and then check what the user entered. In most cases, “True” or “False” aren’t usually what we want, unless you’re writing some sort of true or false guessing game or something. Most cases where we want a Boolean input from a user, it’s a yes/no kind of thing. “Would you like to continue?” or “Shall we start global thermonuclear war? y/N”
So you’re better off just embracing the string, and using that to determine behaviour, rather than a Boolean directly. For example, something along the lines of :
As others mentioned in the thread, it may be wise to convert the input to lowercase - just in case the user enters Y or y. Personally I wouldn’t go so far as to take the first letter as the answer, in case the user enters “you must be joking!” for example :-)