diff options
| -rw-r--r-- | contrib/config-example | 1 | ||||
| -rw-r--r-- | contrib/pianobar.1 | 16 | ||||
| -rw-r--r-- | src/main.c | 23 | ||||
| -rw-r--r-- | src/settings.c | 5 | ||||
| -rw-r--r-- | src/settings.h | 2 | ||||
| -rw-r--r-- | src/ui.c | 2 | ||||
| -rw-r--r-- | src/ui.h | 2 | 
7 files changed, 43 insertions, 8 deletions
| diff --git a/contrib/config-example b/contrib/config-example index d6186c4..5f5dc2d 100644 --- a/contrib/config-example +++ b/contrib/config-example @@ -60,6 +60,7 @@  #tired_icon =  [33mzZ[0m  #format_nowplaying_station = Station [35m%n[0m  #format_list_song = %i) %a - %t%r (%d)%@%s +#format_time = %e/%t  #rpc_host = internal-tuner.pandora.com  #partner_user = pandora one diff --git a/contrib/pianobar.1 b/contrib/pianobar.1 index 0cdf6c8..c5b82aa 100644 --- a/contrib/pianobar.1 +++ b/contrib/pianobar.1 @@ -329,6 +329,22 @@ Station name  Station id  .TP +.B format_time = %s%r/%t +Time format. + +.B %e +Elapsed time + +.B %r +Remaining time + +.B %s +Sign + +.B %t +Total time + +.TP  .B gain_mul = 1.0  Pandora sends a ReplayGain value with every song. This sets a multiplier so that the gain adjustment can be  reduced. 0.0 means no gain adjustment, 1.0 means full gain adjustment, values inbetween reduce the magnitude @@ -312,7 +312,7 @@ static void BarMainPlayerCleanup (BarApp_t *app, pthread_t *playerThread) {   */  static void BarMainPrintTime (BarApp_t *app) {  	unsigned int songRemaining; -	char sign; +	char sign[2] = {0, 0};  	player_t * const player = &app->player;  	pthread_mutex_lock (&player->lock); @@ -322,15 +322,26 @@ static void BarMainPrintTime (BarApp_t *app) {  	if (songPlayed <= songDuration) {  		songRemaining = songDuration - songPlayed; -		sign = '-'; +		sign[0] = '-';  	} else {  		/* longer than expected */  		songRemaining = songPlayed - songDuration; -		sign = '+'; +		sign[0] = '+';  	} -	BarUiMsg (&app->settings, MSG_TIME, "%c%02u:%02u/%02u:%02u\r", -			sign, songRemaining / 60, songRemaining % 60, -			songDuration / 60, songDuration % 60); + +	char outstr[512], totalFormatted[16], remainingFormatted[16], +			elapsedFormatted[16]; +	const char *vals[] = {totalFormatted, remainingFormatted, +			elapsedFormatted, sign}; +	snprintf (totalFormatted, sizeof (totalFormatted), "%02u:%02u", +			songDuration/60, songDuration%60); +	snprintf (remainingFormatted, sizeof (remainingFormatted), "%02u:%02u", +			songRemaining/60, songRemaining%60); +	snprintf (elapsedFormatted, sizeof (elapsedFormatted), "%02u:%02u", +			songPlayed/60, songPlayed%60); +	BarUiCustomFormat (outstr, sizeof (outstr), app->settings.timeFormat, +			"tres", vals); +	BarUiMsg (&app->settings, MSG_TIME, "%s\r", outstr);  }  /*	main loop diff --git a/src/settings.c b/src/settings.c index 7518177..5859b82 100644 --- a/src/settings.c +++ b/src/settings.c @@ -124,6 +124,7 @@ void BarSettingsDestroy (BarSettings_t *settings) {  	free (settings->npSongFormat);  	free (settings->npStationFormat);  	free (settings->listSongFormat); +	free (settings->timeFormat);  	free (settings->fifo);  	free (settings->audioPipe);  	free (settings->rpcHost); @@ -175,6 +176,7 @@ void BarSettingsRead (BarSettings_t *settings) {  	settings->npSongFormat = strdup ("\"%t\" by \"%a\" on \"%l\"%r%@%s");  	settings->npStationFormat = strdup ("Station \"%n\" (%i)");  	settings->listSongFormat = strdup ("%i) %a - %t%r"); +	settings->timeFormat = strdup ("%s%r/%t");  	settings->rpcHost = strdup (PIANO_RPC_HOST);  	settings->rpcTlsPort = strdup ("443");  	settings->partnerUser = strdup ("android"); @@ -389,6 +391,9 @@ void BarSettingsRead (BarSettings_t *settings) {  			} else if (streq ("format_list_song", key)) {  				free (settings->listSongFormat);  				settings->listSongFormat = strdup (val); +			} else if (streq ("format_time", key)) { +				free (settings->timeFormat); +				settings->timeFormat = strdup (val);  			} else if (streq ("fifo", key)) {  				free (settings->fifo);  				settings->fifo = BarSettingsExpandTilde (val, userhome); diff --git a/src/settings.h b/src/settings.h index 1a9b256..2e5a378 100644 --- a/src/settings.h +++ b/src/settings.h @@ -100,7 +100,7 @@ typedef struct {  	char *atIcon;  	char *npSongFormat;  	char *npStationFormat; -	char *listSongFormat; +	char *listSongFormat, *timeFormat;  	char *fifo;  	char *rpcHost, *rpcTlsPort, *partnerUser, *partnerPassword, *device, *inkey, *outkey, *caBundle;  	char *audioPipe; @@ -652,7 +652,7 @@ char *BarUiSelectMusicId (BarApp_t *app, PianoStation_t *station,   *	@param format characters   *	@param replacement for each given format character   */ -static void BarUiCustomFormat (char *dest, size_t destSize, const char *format, +void BarUiCustomFormat (char *dest, size_t destSize, const char *format,  		const char *formatChars, const char **formatVals) {  	bool haveFormatChar = false; @@ -53,4 +53,6 @@ void BarUiStartEventCmd (const BarSettings_t *, const char *,  bool BarUiPianoCall (BarApp_t * const, const PianoRequestType_t,  		void *, PianoReturn_t *, CURLcode *);  void BarUiHistoryPrepend (BarApp_t *app, PianoSong_t *song); +void BarUiCustomFormat (char *dest, size_t destSize, const char *format, +		const char *formatChars, const char **formatVals); | 
