I\'m trying to make a simple command that pauses for user input. I think it\'ll be useful in Bash scripts.
Here\'s my code:
#include
I'm not sure how to add a comment under a post so this isn't really an answer but a comment,
In linux Stdin is buffered so you need to flush it which is what pressing 'enter' does on your terminal. It seems you want to read from an unbuffered stream i.e you want to react to a keypress imediately (without the need to explicitly flush it).
You can create your own unbuffered stream using a file discriptor and then read from it using "getc", you may have to use termios to setup unbuffered input as others have suggested.
This is a simple method that worked for me on Windows 10:
#include <stdlib.h>
void pause(void);
int main(void)
{
printf("Testing pause.");
}
void pause(void)
{
system("pause");
}
From the GNU C Library Manual:
Function: char * fgets (char *s, int count, FILE *stream)
The fgets function reads characters from the stream stream up to and including a newline character and stores them in the string s, adding a null character to mark the end of the string. You must supply count characters worth of space in s, but the number of characters read is at most count − 1. The extra character space is used to hold the null character at the end of the string.
So, fgets(key,1,stdin);
reads 0 characters and returns. (read: immediately)
Use getchar
or getline
instead.
Edit: fgets also doesn't return once count
characters are available on the stream, it keeps waiting for a newline and then reads count
characters, so "any key" might not be the correct wording in this case then.
You can use this example to avoid line-buffering:
#include <stdio.h>
#include <termios.h>
#include <unistd.h>
int mygetch ( void )
{
int ch;
struct termios oldt, newt;
tcgetattr ( STDIN_FILENO, &oldt );
newt = oldt;
newt.c_lflag &= ~( ICANON | ECHO );
tcsetattr ( STDIN_FILENO, TCSANOW, &newt );
ch = getchar();
tcsetattr ( STDIN_FILENO, TCSANOW, &oldt );
return ch;
}
int main()
{
printf("Press any key to continue.\n");
mygetch();
printf("Bye.\n");
}