mirror of
https://github.com/SuperBFG7/ympd
synced 2025-01-27 17:34:55 +00:00
Feat: myMPDsmart-newestSongs #38
This commit is contained in:
parent
4540e853ff
commit
f5ff28a40a
@ -37,4 +37,16 @@ stickers = true
|
|||||||
taglist = Artist,Album,AlbumArtist,Title,Track,Genre,Date,Composer,Performer
|
taglist = Artist,Album,AlbumArtist,Title,Track,Genre,Date,Composer,Performer
|
||||||
|
|
||||||
#Enable smart playlists
|
#Enable smart playlists
|
||||||
smartplaylists = true
|
smartpls = true
|
||||||
|
|
||||||
|
#Newest songs = newest song minus one week
|
||||||
|
smartpls_newest = 604800
|
||||||
|
|
||||||
|
#Add max songs to myMPDsmart-newestSongs
|
||||||
|
smartpls_maxnewest = 200
|
||||||
|
|
||||||
|
#Add max songs to myMPDsmart-bestRated
|
||||||
|
smartpls_maxlike = 200
|
||||||
|
|
||||||
|
#Add max songs to myMPDsmart-mostPlayed
|
||||||
|
smartpls_maxplaycount = 200
|
||||||
|
129
src/mpd_client.c
129
src/mpd_client.c
@ -636,9 +636,9 @@ void mympd_mpd_features() {
|
|||||||
printf("MPD don't support stickers, disabling myMPD feature\n");
|
printf("MPD don't support stickers, disabling myMPD feature\n");
|
||||||
config.stickers = false;
|
config.stickers = false;
|
||||||
}
|
}
|
||||||
if (config.stickers == false && config.smartplaylists == true) {
|
if (config.stickers == false && config.smartpls == true) {
|
||||||
printf("Stickers are disabled, disabling smartplaylists\n");
|
printf("Stickers are disabled, disabling smartplaylists\n");
|
||||||
config.smartplaylists = false;
|
config.smartpls = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
printf("MPD supported tags: ");
|
printf("MPD supported tags: ");
|
||||||
@ -1883,12 +1883,38 @@ void mympd_disconnect() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
int mympd_smartpls_update_all() {
|
int mympd_smartpls_update_all() {
|
||||||
if (!config.smartplaylists)
|
if (!config.smartpls)
|
||||||
return 0;
|
return 0;
|
||||||
if (mympd_smartpls_update("like", "myMPDsmart-bestRated") != 0)
|
if (mympd_smartpls_update("like", "myMPDsmart-bestRated") != 0)
|
||||||
return 1;
|
return 1;
|
||||||
if (mympd_smartpls_update("playCount", "myMPDsmart-mostPlayed") != 0)
|
if (mympd_smartpls_update("playCount", "myMPDsmart-mostPlayed") != 0)
|
||||||
return 1;
|
return 1;
|
||||||
|
if (mympd_smartpls_update_newest("myMPDsmart-newestSongs") != 0)
|
||||||
|
return 1;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int mympd_smartpls_clear(char *playlist) {
|
||||||
|
struct mpd_playlist *pl;
|
||||||
|
const char *plpath;
|
||||||
|
bool exists = false;
|
||||||
|
if (!mpd_send_list_playlists(mpd.conn)) {
|
||||||
|
LOG_ERROR_AND_RECOVER("mpd_send_list_playlists");
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
while((pl = mpd_recv_playlist(mpd.conn)) != NULL) {
|
||||||
|
plpath = mpd_playlist_get_path(pl);
|
||||||
|
if (strcmp(playlist, plpath) == 0)
|
||||||
|
exists = true;
|
||||||
|
mpd_playlist_free(pl);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (exists) {
|
||||||
|
if (!mpd_run_rm(mpd.conn, playlist)) {
|
||||||
|
LOG_ERROR_AND_RECOVER("mpd_run_rm");
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1902,10 +1928,7 @@ int mympd_smartpls_update(char *sticker, char *playlist) {
|
|||||||
long value_max = 0;
|
long value_max = 0;
|
||||||
size_t len = 0;
|
size_t len = 0;
|
||||||
ssize_t read;
|
ssize_t read;
|
||||||
unsigned i = 0;
|
long i = 0;
|
||||||
struct mpd_playlist *pl;
|
|
||||||
const char *plpath;
|
|
||||||
bool exists = false;
|
|
||||||
|
|
||||||
FILE *fp = fopen("/var/lib/mympd/tmp/playlist.tmp", "w");
|
FILE *fp = fopen("/var/lib/mympd/tmp/playlist.tmp", "w");
|
||||||
if (fp == NULL) {
|
if (fp == NULL) {
|
||||||
@ -1913,7 +1936,7 @@ int mympd_smartpls_update(char *sticker, char *playlist) {
|
|||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
if (!mpd_send_sticker_find(mpd.conn, "song", "", sticker)) {
|
if (!mpd_send_sticker_find(mpd.conn, "song", "", sticker)) {
|
||||||
LOG_ERROR_AND_RECOVER("mpd_run_rm");
|
LOG_ERROR_AND_RECOVER("mpd_send_sticker_find");
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
while ((pair = mpd_recv_pair(mpd.conn)) != NULL) {
|
while ((pair = mpd_recv_pair(mpd.conn)) != NULL) {
|
||||||
@ -1934,22 +1957,7 @@ int mympd_smartpls_update(char *sticker, char *playlist) {
|
|||||||
mpd_response_finish(mpd.conn);
|
mpd_response_finish(mpd.conn);
|
||||||
fclose(fp);
|
fclose(fp);
|
||||||
|
|
||||||
if (!mpd_send_list_playlists(mpd.conn)) {
|
mympd_smartpls_clear(playlist);
|
||||||
LOG_ERROR_AND_RECOVER("mpd_run_rm");
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
while((pl = mpd_recv_playlist(mpd.conn)) != NULL) {
|
|
||||||
plpath = mpd_playlist_get_path(pl);
|
|
||||||
if (strcmp(playlist, plpath) == 0)
|
|
||||||
exists = true;
|
|
||||||
mpd_playlist_free(pl);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (exists)
|
|
||||||
if (!mpd_run_rm(mpd.conn, playlist)) {
|
|
||||||
LOG_ERROR_AND_RECOVER("mpd_run_rm");
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (value_max > 2)
|
if (value_max > 2)
|
||||||
value_max = value_max / 2;
|
value_max = value_max / 2;
|
||||||
@ -1966,6 +1974,75 @@ int mympd_smartpls_update(char *sticker, char *playlist) {
|
|||||||
if (value <= value_max)
|
if (value <= value_max)
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
if (!mpd_run_playlist_add(mpd.conn, playlist, name)) {
|
||||||
|
LOG_ERROR_AND_RECOVER("mpd_run_playlist_add");
|
||||||
|
fclose(fp);
|
||||||
|
free(uri);
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
i++;
|
||||||
|
if (strcmp(sticker, "playCount") == 0) {
|
||||||
|
if (i >= config.smartpls_maxplaycount)
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
else if (strcmp(sticker, "like") == 0) {
|
||||||
|
if (i >= config.smartpls_maxlike)
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
fclose(fp);
|
||||||
|
free(uri);
|
||||||
|
unlink("/var/lib/mympd/tmp/playlist.tmp");
|
||||||
|
printf("Updated %s with %ld songs, minValue: %ld\n", playlist, i, value_max);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int mympd_smartpls_update_newest(char *playlist) {
|
||||||
|
struct mpd_song *song;
|
||||||
|
char *uri;
|
||||||
|
char *p_value;
|
||||||
|
char *name;
|
||||||
|
char *crap;
|
||||||
|
time_t value;
|
||||||
|
time_t value_max = 0;
|
||||||
|
size_t len = 0;
|
||||||
|
ssize_t read;
|
||||||
|
long i = 0;
|
||||||
|
|
||||||
|
FILE *fp = fopen("/var/lib/mympd/tmp/playlist.tmp", "w");
|
||||||
|
if (fp == NULL) {
|
||||||
|
printf("Error opening /var/lib/mympd/tmp/playlist.tmp");
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
if (!mpd_send_list_all_meta(mpd.conn, "/")) {
|
||||||
|
LOG_ERROR_AND_RECOVER("mpd_send_list_all_meta");
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
while ((song = mpd_recv_song(mpd.conn)) != NULL) {
|
||||||
|
value = mpd_song_get_last_modified(song);
|
||||||
|
if (value > value_max)
|
||||||
|
value_max = value;
|
||||||
|
fprintf(fp, "%s::%ld\n", mpd_song_get_uri(song), value);
|
||||||
|
mpd_song_free(song);
|
||||||
|
}
|
||||||
|
mpd_response_finish(mpd.conn);
|
||||||
|
fclose(fp);
|
||||||
|
|
||||||
|
mympd_smartpls_clear(playlist);
|
||||||
|
|
||||||
|
value_max -= config.smartpls_newest; //one week
|
||||||
|
|
||||||
|
fp = fopen("/var/lib/mympd/tmp/playlist.tmp", "r");
|
||||||
|
if (fp == NULL) {
|
||||||
|
printf("Error opening /var/lib/mympd/tmp/playlist.tmp");
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
while ((read = getline(&uri, &len, fp)) != -1) {
|
||||||
|
name = strtok(uri, "::");
|
||||||
|
p_value = strtok(NULL, "::");
|
||||||
|
value = strtol(p_value, &crap, 10);
|
||||||
|
if (value >= value_max)
|
||||||
|
continue;
|
||||||
if (!mpd_run_playlist_add(mpd.conn, playlist, name)) {
|
if (!mpd_run_playlist_add(mpd.conn, playlist, name)) {
|
||||||
LOG_ERROR_AND_RECOVER("mpd_run_rm");
|
LOG_ERROR_AND_RECOVER("mpd_run_rm");
|
||||||
fclose(fp);
|
fclose(fp);
|
||||||
@ -1973,10 +2050,12 @@ int mympd_smartpls_update(char *sticker, char *playlist) {
|
|||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
i++;
|
i++;
|
||||||
|
if (i >= config.smartpls_maxnewest)
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
fclose(fp);
|
fclose(fp);
|
||||||
free(uri);
|
free(uri);
|
||||||
unlink("/var/lib/mympd/tmp/playlist.tmp");
|
unlink("/var/lib/mympd/tmp/playlist.tmp");
|
||||||
printf("Updated %s with %u songs, minValue: %ld\n", playlist, i, value_max);
|
printf("Updated %s with %ld songs, minValue: %ld\n", playlist, i, value_max);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -162,7 +162,11 @@ typedef struct {
|
|||||||
bool stickers;
|
bool stickers;
|
||||||
bool mixramp;
|
bool mixramp;
|
||||||
const char* taglist;
|
const char* taglist;
|
||||||
bool smartplaylists;
|
bool smartpls;
|
||||||
|
long smartpls_newest;
|
||||||
|
long smartpls_maxnewest;
|
||||||
|
long smartpls_maxlike;
|
||||||
|
long smartpls_maxplaycount;
|
||||||
} t_config;
|
} t_config;
|
||||||
|
|
||||||
t_config config;
|
t_config config;
|
||||||
@ -199,7 +203,9 @@ void mympd_last_played_song_id(int song_id);
|
|||||||
void mympd_get_sticker(const char *uri, t_sticker *sticker);
|
void mympd_get_sticker(const char *uri, t_sticker *sticker);
|
||||||
void mympd_jukebox();
|
void mympd_jukebox();
|
||||||
int mympd_smartpls_update_all();
|
int mympd_smartpls_update_all();
|
||||||
|
int mympd_smartpls_clear(char *playlist);
|
||||||
int mympd_smartpls_update(char *sticker, char *playlist);
|
int mympd_smartpls_update(char *sticker, char *playlist);
|
||||||
|
int mympd_smartpls_update_newest(char *playlist);
|
||||||
int mympd_get_updatedb_state(char *buffer);
|
int mympd_get_updatedb_state(char *buffer);
|
||||||
int mympd_put_state(char *buffer, int *current_song_id, int *next_song_id, int *last_song_id, unsigned *queue_version, unsigned *queue_length);
|
int mympd_put_state(char *buffer, int *current_song_id, int *next_song_id, int *last_song_id, unsigned *queue_version, unsigned *queue_length);
|
||||||
int mympd_put_outputs(char *buffer);
|
int mympd_put_outputs(char *buffer);
|
||||||
|
18
src/mympd.c
18
src/mympd.c
@ -162,11 +162,19 @@ static int inihandler(void* user, const char* section, const char* name, const c
|
|||||||
p_config->stickers = true;
|
p_config->stickers = true;
|
||||||
else
|
else
|
||||||
p_config->stickers = false;
|
p_config->stickers = false;
|
||||||
else if (MATCH("smartplaylists"))
|
else if (MATCH("smartpls"))
|
||||||
if (strcmp(value, "true") == 0)
|
if (strcmp(value, "true") == 0)
|
||||||
p_config->smartplaylists = true;
|
p_config->smartpls = true;
|
||||||
else
|
else
|
||||||
p_config->smartplaylists = false;
|
p_config->smartpls = false;
|
||||||
|
else if (MATCH("smartpls_newest"))
|
||||||
|
p_config->smartpls_newest = strtol(value, &crap, 10);
|
||||||
|
else if (MATCH("smartpls_maxnewest"))
|
||||||
|
p_config->smartpls_maxnewest = strtol(value, &crap, 10);
|
||||||
|
else if (MATCH("smartpls_maxlike"))
|
||||||
|
p_config->smartpls_maxlike = strtol(value, &crap, 10);
|
||||||
|
else if (MATCH("smartpls_maxplaycount"))
|
||||||
|
p_config->smartpls_maxplaycount = strtol(value, &crap, 10);
|
||||||
else if (MATCH("mixramp"))
|
else if (MATCH("mixramp"))
|
||||||
if (strcmp(value, "true") == 0)
|
if (strcmp(value, "true") == 0)
|
||||||
p_config->mixramp = true;
|
p_config->mixramp = true;
|
||||||
@ -203,7 +211,9 @@ int main(int argc, char **argv) {
|
|||||||
config.stickers = true;
|
config.stickers = true;
|
||||||
config.mixramp = true;
|
config.mixramp = true;
|
||||||
config.taglist = "Artist,Album,AlbumArtist,Title,Track,Genre,Date,Composer,Performer";
|
config.taglist = "Artist,Album,AlbumArtist,Title,Track,Genre,Date,Composer,Performer";
|
||||||
config.smartplaylists = true;
|
config.smartpls = true;
|
||||||
|
config.smartpls_newest = 604800;
|
||||||
|
config.smartpls_maxnewest = 200;
|
||||||
|
|
||||||
mpd.timeout = 3000;
|
mpd.timeout = 3000;
|
||||||
mpd.last_update_sticker_song_id = -1;
|
mpd.last_update_sticker_song_id = -1;
|
||||||
|
Loading…
Reference in New Issue
Block a user