this post was submitted on 25 Apr 2026
17 points (84.0% liked)

Ask Lemmy

39277 readers
2069 users here now

A Fediverse community for open-ended, thought provoking questions


Rules: (interactive)


1) Be nice and; have funDoxxing, trolling, sealioning, racism, toxicity and dog-whistling are not welcomed in AskLemmy. Remember what your mother said: if you can't say something nice, don't say anything at all. In addition, the site-wide Lemmy.world terms of service also apply here. Please familiarize yourself with them


2) All posts must end with a '?'This is sort of like Jeopardy. Please phrase all post titles in the form of a proper question ending with ?


3) No spamPlease do not flood the community with nonsense. Actual suspected spammers will be banned on site. No astroturfing.


4) NSFW is okay, within reasonJust remember to tag posts with either a content warning or a [NSFW] tag. Overtly sexual posts are not allowed, please direct them to either !asklemmyafterdark@lemmy.world or !asklemmynsfw@lemmynsfw.com. NSFW comments should be restricted to posts tagged [NSFW].


5) This is not a support community.
It is not a place for 'how do I?', type questions. If you have any questions regarding the site itself or would like to report a community, please direct them to Lemmy.world Support or email info@lemmy.world. For other questions check our partnered communities list, or use the search function.


6) No US Politics.
Please don't post about current US Politics. If you need to do this, try !politicaldiscussion@lemmy.world or !askusa@discuss.online


Reminder: The terms of service apply here too.

Partnered Communities:

Tech Support

No Stupid Questions

You Should Know

Reddit

Jokes

Ask Ouija


Logo design credit goes to: tubbadu


founded 2 years ago
MODERATORS
 

Edit: After prompting the user to choose between "login (1)" and "create an account (2)", I am trying to have the program check that:

  • the input is an integer
  • that the input, in case of an integer, is only valid if one (1) or two (2)
  • (optionally) that the data size of the user input is not greater than the integer number one (1) or two (2), as a security measure, to hinder overflow exploits

If I allocate [] or [1] to intCheck the program goes into an endless loop from the very start. No user input required. If, however, I allocate [2] or more, the program works as intended, as long as the total size of bytes of the user input is less than the number of bytes previously allocated. If, however, the user input results in a byte size greater than what was preallocated, the program repeats the else condition of the while loop - here, printf - that number of times. Is this an overflow of choice or what?

//Bank of Haruhi  
 
//TODO  
// - Create user account: require user first name, last name, user name, password, age (deny if < 20 yrs)  
// - Prompt login (deny if != password && username)  
// - Display menu ("About the Bank of Haru", "Account Settings", "Check your balance", "Deposit", "Withdraw", "Close account", "Logout")  
 
#include <stdio.h>  
#include <string.h>  
#include <stdbool.h>  
 
int main(void) {  
 
//Base 
char intCheck[3] = ""; //Will "if (sscanf(char,%d,&int) == true)" check for ANY "char" or a predetermined amount of "char"?  
 
//Registration and login  
char firstName[] = "";  
char lastName[] = "";  
char password[] = "";  
int age = 0;  
 
//Menues and selections  
int choice = 0;  
int arithmeticChoice = 0;  
 
//Balance, deposit and withdrawal  
float balance = 0.0;  
float deposit = 0.0;  
float withdraw = 0.0;  
 
printf("Welcome to the Bank of Haruhi! Please login (1) or create an account (2): ");  
 
while (fgets(intCheck, sizeof(intCheck),stdin)) {  
intCheck[strlen(intCheck) - 1] = '\0';  
if (sscanf(intCheck, "%d", &choice) == true && sizeof(intCheck) == 4 && choice == 1 || choice == 2) break; //I'm keeping "sizeof(intCheck)" in order to excercise byte size input validation, but I could just remove it and let "if choice == 1 || 2" restrict the valid input.  
else printf("Please enter ""1"" to login or ""2"" to create a new account: ");  
}  
 
return 0;  
 
}  

The program is, of course, not nearly complete. I just stopped doing anything else, as soon as I stumbled upon this phenomenon.

you are viewing a single comment's thread
view the rest of the comments