diff options
| author | Lars-Dominik Braun <PromyLOPh@gmail.com> | 2008-06-25 14:04:39 +0200 | 
|---|---|---|
| committer | Lars-Dominik Braun <PromyLOPh@gmail.com> | 2008-06-25 14:04:39 +0200 | 
| commit | af2ceec1e540bae28fdd3ec07158dcd137d3c9da (patch) | |
| tree | 4b8adcf4e01b378f28dd1ddb4adbf63229465d68 | |
| parent | 138480c6a7acb422e170e49e8027a69160745024 (diff) | |
| download | pianobar-af2ceec1e540bae28fdd3ec07158dcd137d3c9da.tar.gz pianobar-af2ceec1e540bae28fdd3ec07158dcd137d3c9da.tar.bz2 pianobar-af2ceec1e540bae28fdd3ec07158dcd137d3c9da.zip | |
client: Fix input hell, use readline
| -rw-r--r-- | src/main.c | 59 | 
1 files changed, 43 insertions, 16 deletions
| @@ -33,31 +33,63 @@ THE SOFTWARE.  #include <poll.h>  #include <readline/readline.h>  #include <time.h> +#include <ctype.h>  #include "terminal.h"  #include "settings.h"  #include "config.h"  #include "player.h" +/*	check whether complete string is numeric + *	@param the string + *	@return 1 = yes, 0 = not numeric + */ +char BarIsNumericStr (char *str) { +	while (*str != '\0') { +		if (isdigit (*str) == 0) { +			return 0; +		} +		str++; +	} +	return 1; +} + +/*	use readline to get integer value + *	@param prompt or NULL + *	@param returns integer + *	@return 1 = success, 0 = failure (not an integer, ...) + */ +char BarReadlineInt (char *prompt, int *retVal) { +	char *buf; +	char ret = 0; + +	if ((buf = readline (prompt)) != NULL && strlen (buf) > 0 && +			BarIsNumericStr (buf)) { +		*retVal = atoi (buf); +		ret = 1; +	} +	if (buf != NULL) { +		free (buf); +	} +	return ret; +} +  /*	let user pick one station   *	@param piano handle - *	@return pointer to selected station + *	@return pointer to selected station or NULL   */  PianoStation_t *BarUiSelectStation (PianoHandle_t *ph) {  	PianoStation_t *curStation = NULL; -	size_t i; +	int i = 0;  	printf ("which station do you want to listen to?\n"); -	i = 0;  	curStation = ph->stations;  	while (curStation != NULL) {  		printf ("%2i) %s\n", i, curStation->name);  		curStation = curStation->next;  		i++;  	} -	printf ("Press c to abort.\n"); - -	if (scanf ("%i", &i) < 1) { +	if (!BarReadlineInt (NULL, &i)) {  		return NULL;  	}  	curStation = ph->stations; @@ -74,17 +106,15 @@ PianoStation_t *BarUiSelectStation (PianoHandle_t *ph) {   */  PianoSong_t *BarUiSelectSong (PianoSong_t *startSong) {  	PianoSong_t *tmpSong = NULL; -	size_t i; +	int i = 0;  	tmpSong = startSong; -	i = 0;  	while (tmpSong != NULL) {  		printf ("%2u) %s - %s\n", i, tmpSong->artist, tmpSong->title);  		i++;  		tmpSong = tmpSong->next;  	} -	printf ("Press c to abort.\n"); -	if (scanf ("%i", &i) < 1) { +	if (!BarReadlineInt (NULL, &i)) {  		return NULL;  	}  	tmpSong = startSong; @@ -101,17 +131,15 @@ PianoSong_t *BarUiSelectSong (PianoSong_t *startSong) {   */  PianoArtist_t *BarUiSelectArtist (PianoArtist_t *startArtist) {  	PianoArtist_t *tmpArtist = NULL; -	size_t i; +	int i = 0;  	tmpArtist = startArtist; -	i = 0;  	while (tmpArtist != NULL) {  		printf ("%2u) %s\n", i, tmpArtist->name);  		i++;  		tmpArtist = tmpArtist->next;  	} -	printf ("Press c to abort.\n"); -	if (scanf ("%i", &i) < 1) { +	if (!BarReadlineInt (NULL, &i)) {  		return NULL;  	}  	tmpArtist = startArtist; @@ -251,12 +279,11 @@ int main (int argc, char **argv) {  	/* little hack, needed to signal: hey! we need a playlist, but don't  	 * free anything (there is nothing to be freed yet) */  	memset (&player, 0, sizeof (player)); -	player.finishedPlayback = 1;  	while (!doQuit) {  		/* check whether player finished playing and start playing new  		 * song */ -		if (player.finishedPlayback == 1) { +		if (player.finishedPlayback == 1 || curSong == NULL) {  			/* already played a song, clean up things */  			if (player.url != NULL) {  				scrobbleSong.length = BarSamplesToSeconds (player.samplerate, | 
