diff options
| author | Lars-Dominik Braun <lars@6xq.net> | 2012-03-17 19:27:27 +0100 | 
|---|---|---|
| committer | Lars-Dominik Braun <lars@6xq.net> | 2012-03-17 19:27:27 +0100 | 
| commit | 7a02354513acad9e315b4f4f736b77a08de363a6 (patch) | |
| tree | 86042261e9c1bba2d773f4817a3c862ce12f09c9 /src | |
| parent | e6a87e15043767c0f1f00a62110e4bbb53de4ece (diff) | |
| download | pianobar-7a02354513acad9e315b4f4f736b77a08de363a6.tar.gz pianobar-7a02354513acad9e315b4f4f736b77a08de363a6.tar.bz2 pianobar-7a02354513acad9e315b4f4f736b77a08de363a6.zip | |
Auto-select last remaining item of filtered list
See #231.
Diffstat (limited to 'src')
| -rw-r--r-- | src/main.c | 3 | ||||
| -rw-r--r-- | src/settings.c | 3 | ||||
| -rw-r--r-- | src/settings.h | 3 | ||||
| -rw-r--r-- | src/ui.c | 41 | ||||
| -rw-r--r-- | src/ui.h | 4 | ||||
| -rw-r--r-- | src/ui_act.c | 9 | 
6 files changed, 42 insertions, 21 deletions
| @@ -137,7 +137,8 @@ static void BarMainGetInitialStation (BarApp_t *app) {  	}  	/* no autostart? ask the user */  	if (app->curStation == NULL) { -		app->curStation = BarUiSelectStation (app, app->ph.stations, "Select station: ", NULL); +		app->curStation = BarUiSelectStation (app, app->ph.stations, +				"Select station: ", NULL, app->settings.autoselect);  	}  	if (app->curStation != NULL) {  		BarUiPrintStation (&app->settings, app->curStation); diff --git a/src/settings.c b/src/settings.c index ee332cc..54edba9 100644 --- a/src/settings.c +++ b/src/settings.c @@ -120,6 +120,7 @@ void BarSettingsRead (BarSettings_t *settings) {  		settings->audioFormat = PIANO_AF_MP3;  		#endif  	#endif +	settings->autoselect = true;  	settings->history = 5;  	settings->volume = 0;  	settings->sortOrder = BAR_SORT_NAME_AZ; @@ -242,6 +243,8 @@ void BarSettingsRead (BarSettings_t *settings) {  		} else if (streq ("fifo", key)) {  			free (settings->fifo);  			settings->fifo = strdup (val); +		} else if (streq ("autoselect", key)) { +			settings->autoselect = atoi (val);  		} else if (streq ("tls_fingerprint", key)) {  			/* expects 40 byte hex-encoded sha1 */  			if (strlen (val) == 40) { diff --git a/src/settings.h b/src/settings.h index b975b23..4c4205e 100644 --- a/src/settings.h +++ b/src/settings.h @@ -24,6 +24,8 @@ THE SOFTWARE.  #ifndef _SETTINGS_H  #define _SETTINGS_H +#include <stdbool.h> +  #include <piano.h>  #include <waitress.h> @@ -78,6 +80,7 @@ typedef struct {  } BarMsgFormatStr_t;  typedef struct { +	bool autoselect;  	unsigned int history;  	int volume;  	BarStationSorting_t sortOrder; @@ -330,14 +330,17 @@ static PianoStation_t **BarSortedStations (PianoStation_t *unsortedStations,  /*	let user pick one station   *	@param app handle + *	@param stations that should be listed   *	@param prompt string   *	@param called if input was not a number + *	@param auto-select if only one station remains after filtering   *	@return pointer to selected station or NULL   */  PianoStation_t *BarUiSelectStation (BarApp_t *app, PianoStation_t *stations, -		const char *prompt, BarUiSelectStationCallback_t callback) { +		const char *prompt, BarUiSelectStationCallback_t callback, +		bool autoselect) {  	PianoStation_t **sortedStations = NULL, *retStation = NULL; -	size_t stationCount, i; +	size_t stationCount, i, lastDisplayed, displayCount;  	char buf[100];  	if (stations == NULL) { @@ -352,6 +355,7 @@ PianoStation_t *BarUiSelectStation (BarApp_t *app, PianoStation_t *stations,  			app->settings.sortOrder);  	do { +		displayCount = 0;  		for (i = 0; i < stationCount; i++) {  			const PianoStation_t *currStation = sortedStations[i];  			/* filter stations */ @@ -361,26 +365,33 @@ PianoStation_t *BarUiSelectStation (BarApp_t *app, PianoStation_t *stations,  						currStation->isQuickMix ? 'Q' : ' ',  						!currStation->isCreator ? 'S' : ' ',  						currStation->name); +				++displayCount; +				lastDisplayed = i;  			}  		}  		BarUiMsg (&app->settings, MSG_QUESTION, prompt); -		if (BarReadlineStr (buf, sizeof (buf), &app->input, -				BAR_RL_DEFAULT) == 0) { -			free (sortedStations); -			return NULL; -		} +		if (autoselect && displayCount == 1 && stationCount != 1) { +			/* auto-select last remaining station */ +			BarUiMsg (&app->settings, MSG_NONE, "%i\n", lastDisplayed); +			retStation = sortedStations[lastDisplayed]; +		} else { +			if (BarReadlineStr (buf, sizeof (buf), &app->input, +					BAR_RL_DEFAULT) == 0) { +				break; +			} -		if (isnumeric (buf)) { -			unsigned long selected = strtoul (buf, NULL, 0); -			if (selected < stationCount) { -				retStation = sortedStations[selected]; +			if (isnumeric (buf)) { +				unsigned long selected = strtoul (buf, NULL, 0); +				if (selected < stationCount) { +					retStation = sortedStations[selected]; +				}  			} -		} -		/* hand over buffer to external function if it was not a station number */ -		if (retStation == NULL && callback != NULL) { -			callback (app, buf); +			/* hand over buffer to external function if it was not a station number */ +			if (retStation == NULL && callback != NULL) { +				callback (app, buf); +			}  		}  	} while (retStation == NULL); @@ -24,6 +24,8 @@ THE SOFTWARE.  #ifndef _UI_H  #define _UI_H +#include <stdbool.h> +  #include <piano.h>  #include <waitress.h> @@ -37,7 +39,7 @@ typedef void (*BarUiSelectStationCallback_t) (BarApp_t *app, char *buf);  void BarUiMsg (const BarSettings_t *, const BarUiMsg_t, const char *, ...);  PianoStation_t *BarUiSelectStation (BarApp_t *, PianoStation_t *, const char *, -		BarUiSelectStationCallback_t); +		BarUiSelectStationCallback_t, bool);  PianoSong_t *BarUiSelectSong (const BarSettings_t *, PianoSong_t *,  		BarReadlineFds_t *);  PianoArtist_t *BarUiSelectArtist (BarApp_t *, PianoArtist_t *); diff --git a/src/ui_act.c b/src/ui_act.c index df6cb73..2cc559f 100644 --- a/src/ui_act.c +++ b/src/ui_act.c @@ -316,7 +316,7 @@ BarUiActCallback(BarUiActMoveSong) {  	reqData.step = 0;  	reqData.to = BarUiSelectStation (app, app->ph.stations, -			"Move song to station: ", NULL); +			"Move song to station: ", NULL, false);  	if (reqData.to != NULL) {  		/* find original station (just is case we're playing a quickmix  		 * station) */ @@ -379,7 +379,7 @@ BarUiActCallback(BarUiActRenameStation) {   */  BarUiActCallback(BarUiActSelectStation) {  	PianoStation_t *newStation = BarUiSelectStation (app, app->ph.stations, -			"Select station: ", NULL); +			"Select station: ", NULL, app->settings.autoselect);  	if (newStation != NULL) {  		app->curStation = newStation;  		BarUiPrintStation (&app->settings, app->curStation); @@ -475,7 +475,7 @@ BarUiActCallback(BarUiActSelectQuickMix) {  		PianoStation_t *toggleStation;  		while ((toggleStation = BarUiSelectStation (app, app->ph.stations,  				"Toggle quickmix for station: ", -				BarUiActQuickmixCallback)) != NULL) { +				BarUiActQuickmixCallback, false)) != NULL) {  			toggleStation->useQuickMix = !toggleStation->useQuickMix;  		}  		BarUiMsg (&app->settings, MSG_INFO, "Setting quickmix stations... "); @@ -660,7 +660,8 @@ BarUiActCallback(BarUiActManageStation) {  			}  		} else if (selectBuf[0] == 't') {  			PianoStation_t *station = BarUiSelectStation (app, -					reqData.info.stationSeeds, "Delete seed station: ", NULL); +					reqData.info.stationSeeds, "Delete seed station: ", NULL, +					false);  			if (station != NULL) {  				PianoRequestDataDeleteSeed_t subReqData; | 
