mirror of
				https://github.com/SuperBFG7/ympd
				synced 2025-10-25 02:47:41 +00:00 
			
		
		
		
	Fix: creation of smartPlaylist mostPlayed
Feat: display versions on startup and in websocket welcome message
This commit is contained in:
		| @@ -925,7 +925,7 @@ int mympd_get_updatedb_state(char *buffer) { | ||||
|  | ||||
|     status = mpd_run_status(mpd.conn); | ||||
|     if (!status) | ||||
|         RETURN_ERROR_AND_RECOVER("replay_gain_status"); | ||||
|         RETURN_ERROR_AND_RECOVER("mpd_run_status"); | ||||
|     update_id = mpd_status_get_update_id(status); | ||||
|     #ifdef DEBUG | ||||
|     fprintf(stderr, "Update database ID: %d\n", update_id); | ||||
| @@ -1203,9 +1203,8 @@ void mympd_jukebox() { | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     if (nkeep < addSongs) { | ||||
|     if (nkeep < addSongs) | ||||
|         fprintf(stderr, "Warning: input didn't contain %d entries\n", addSongs); | ||||
|     } | ||||
|  | ||||
|     list_shuffle(&add_list); | ||||
|  | ||||
| @@ -1214,9 +1213,8 @@ void mympd_jukebox() { | ||||
|     while (current != NULL) { | ||||
|         if (mympd_state.jukeboxMode == 1) { | ||||
| 	    printf("Jukebox adding song: %s\n", current->data); | ||||
| 	    if (!mpd_run_add(mpd.conn, current->data)) { | ||||
| 	    if (!mpd_run_add(mpd.conn, current->data)) | ||||
|                 LOG_ERROR_AND_RECOVER("mpd_run_add"); | ||||
|             } | ||||
|             else | ||||
|                 nkeep++; | ||||
|         } | ||||
| @@ -1321,8 +1319,18 @@ int mympd_put_volume(char *buffer) { | ||||
| int mympd_put_welcome(char *buffer) { | ||||
|     int len; | ||||
|     struct json_out out = JSON_OUT_BUF(buffer, MAX_SIZE); | ||||
|     const unsigned *version = mpd_connection_get_server_version(mpd.conn); | ||||
|     char mpd_version[20]; | ||||
|     char libmpdclient_version[20]; | ||||
|  | ||||
|     len = json_printf(&out, "{type: welcome, data: {version: %Q}}", MYMPD_VERSION); | ||||
|     snprintf(mpd_version, 20, "%i.%i.%i", version[0], version[1], version[2]); | ||||
|     snprintf(libmpdclient_version, 20, "%i.%i.%i", LIBMPDCLIENT_MAJOR_VERSION, LIBMPDCLIENT_MINOR_VERSION, LIBMPDCLIENT_PATCH_VERSION); | ||||
|  | ||||
|     len = json_printf(&out, "{type: welcome, data: {mympdVersion: %Q, mpdVersion: %Q, libmpdclientVersion: %Q}}",  | ||||
|         MYMPD_VERSION, | ||||
|         mpd_version, | ||||
|         libmpdclient_version | ||||
|     ); | ||||
|      | ||||
|     CHECK_RETURN_LEN(); | ||||
|     return len; | ||||
| @@ -2556,7 +2564,7 @@ int mympd_smartpls_update(char *playlist, char *sticker, int maxentries) { | ||||
|             p_value = mpd_parse_sticker(pair->value, &j); | ||||
|             if (p_value != NULL) { | ||||
|                 value = strtol(p_value, &crap, 10); | ||||
|                 if (value > 1) | ||||
|                 if (value >= 1) | ||||
|                     list_push(&add_list, uri, value); | ||||
|                 if (value > value_max) | ||||
|                     value_max = value; | ||||
| @@ -2567,11 +2575,17 @@ int mympd_smartpls_update(char *playlist, char *sticker, int maxentries) { | ||||
|     mpd_response_finish(mpd.conn); | ||||
|     free(uri); | ||||
|  | ||||
|     #ifdef DEBUG | ||||
|     printf("add_list length: %d\n", add_list.length); | ||||
|     #endif | ||||
|  | ||||
|     mympd_smartpls_clear(playlist); | ||||
|       | ||||
|     if (value_max > 2) | ||||
|         value_max = value_max / 2; | ||||
|  | ||||
|     list_sort_by_value(&add_list, false); | ||||
|  | ||||
|     struct node *current = add_list.list; | ||||
|     while (current != NULL) { | ||||
|         if (current->value >= value_max) { | ||||
|   | ||||
| @@ -30,6 +30,7 @@ | ||||
| #include <pwd.h> | ||||
| #include <grp.h> | ||||
| #include <libgen.h> | ||||
| #include <mpd/client.h> | ||||
|  | ||||
| #include "../dist/src/mongoose/mongoose.h" | ||||
| #include "../dist/src/frozen/frozen.h" | ||||
| @@ -410,6 +411,8 @@ int main(int argc, char **argv) { | ||||
|     mpd.feat_library = false; | ||||
|      | ||||
|     if (argc == 2) { | ||||
|         printf("Starting myMPD %s\n", MYMPD_VERSION); | ||||
|         printf("libmpdclient %i.%i.%i\n", LIBMPDCLIENT_MAJOR_VERSION, LIBMPDCLIENT_MINOR_VERSION, LIBMPDCLIENT_PATCH_VERSION); | ||||
|         printf("Parsing config file: %s\n", argv[1]); | ||||
|         if (ini_parse(argv[1], inihandler, &config) < 0) { | ||||
|             printf("Can't load config file \"%s\"\n", argv[1]); | ||||
| @@ -428,8 +431,6 @@ int main(int argc, char **argv) { | ||||
|         return EXIT_FAILURE;     | ||||
|     } | ||||
|  | ||||
|     printf("Starting myMPD %s\n", MYMPD_VERSION); | ||||
|  | ||||
|     signal(SIGTERM, signal_handler); | ||||
|     signal(SIGINT, signal_handler); | ||||
|     setvbuf(stdout, NULL, _IOLBF, 0); | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 jcorporation
					jcorporation