Blame
Date:
Thu Mar 10 16:30:37 2022 UTC
Message:
don't try to match the prev/next song; been broken since tx in load was added originally i tried to match the previous or next song in the playing queue after a load command if the current song was not matched. The idea is ok-ish, but the implementation was broken and become a no-op after some recent refactoring in that area.
001
2022-02-16
op
/*
002
2022-02-16
op
* Copyright (c) 2022 Omar Polo <op@openbsd.org>
003
2022-02-16
op
*
004
2022-02-16
op
* Permission to use, copy, modify, and distribute this software for any
005
2022-02-16
op
* purpose with or without fee is hereby granted, provided that the above
006
2022-02-16
op
* copyright notice and this permission notice appear in all copies.
007
2022-02-16
op
*
008
2022-02-16
op
* THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
009
2022-02-16
op
* WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
010
2022-02-16
op
* MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
011
2022-02-16
op
* ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
012
2022-02-16
op
* WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
013
2022-02-16
op
* ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
014
2022-02-16
op
* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
015
2022-02-16
op
*/
016
2022-02-16
op
017
2022-02-17
op
#include <sys/types.h>
018
2022-02-17
op
019
2022-02-17
op
#include <regex.h>
020
2022-02-16
op
#include <stdlib.h>
021
2022-02-19
op
#include <string.h>
022
2022-02-16
op
#include <syslog.h>
023
2022-02-16
op
024
2022-02-16
op
#include "log.h"
025
2022-02-16
op
#include "xmalloc.h"
026
2022-02-16
op
#include "playlist.h"
027
2022-02-16
op
028
2022-02-16
op
#define MAX(a, b) ((a) > (b) ? (a) : (b))
029
2022-02-16
op
030
2022-02-19
op
struct playlist playlist;
031
2022-02-19
op
enum play_state play_state;
032
2022-02-19
op
int repeat_one;
033
2022-02-19
op
int repeat_all = 1;
034
2022-02-19
op
ssize_t play_off = -1;
035
2022-02-19
op
const char *current_song;
036
2022-02-16
op
037
2022-02-19
op
static void
038
2022-02-19
op
setsong(ssize_t i)
039
2022-02-19
op
{
040
2022-02-19
op
free((char *)current_song);
041
2022-02-19
op
if (i == -1)
042
2022-02-19
op
current_song = NULL;
043
2022-02-19
op
else
044
2022-02-19
op
current_song = xstrdup(playlist.songs[i]);
045
2022-02-19
op
}
046
2022-02-19
op
047
2022-02-16
op
void
048
2022-03-02
op
playlist_swap(struct playlist *p, ssize_t off)
049
2022-02-17
op
{
050
2022-02-19
op
ssize_t i = -1;
051
2022-02-19
op
052
2022-03-02
op
if (off > p->len)
053
2022-03-02
op
off = -1;
054
2022-03-02
op
055
2022-03-02
op
if (current_song != NULL && off < 0) {
056
2022-03-10
op
/* try to match the currently played song */
057
2022-02-19
op
for (i = 0; i < p->len; ++i) {
058
2022-02-19
op
if (!strcmp(current_song, p->songs[i]))
059
2022-02-19
op
break;
060
2022-02-19
op
}
061
2022-02-19
op
if (i == p->len)
062
2022-02-19
op
i = -1;
063
2022-02-19
op
}
064
2022-02-19
op
065
2022-02-17
op
playlist_truncate();
066
2022-02-17
op
067
2022-02-19
op
if (i != -1)
068
2022-02-19
op
play_off = i;
069
2022-03-02
op
else if (off >= 0)
070
2022-03-02
op
play_off = off;
071
2022-02-19
op
072
2022-02-17
op
playlist.len = p->len;
073
2022-02-17
op
playlist.cap = p->cap;
074
2022-02-17
op
playlist.songs = p->songs;
075
2022-03-02
op
076
2022-03-02
op
if (play_state == STATE_STOPPED)
077
2022-03-02
op
setsong(play_off);
078
2022-02-17
op
}
079
2022-02-17
op
080
2022-02-17
op
void
081
2022-02-17
op
playlist_push(struct playlist *playlist, const char *path)
082
2022-02-16
op
{
083
2022-02-16
op
size_t newcap;
084
2022-02-16
op
085
2022-02-17
op
if (playlist->len == playlist->cap) {
086
2022-02-17
op
newcap = MAX(16, playlist->cap * 1.5);
087
2022-02-17
op
playlist->songs = xrecallocarray(playlist->songs,
088
2022-02-17
op
playlist->cap, newcap, sizeof(*playlist->songs));
089
2022-02-17
op
playlist->cap = newcap;
090
2022-02-16
op
}
091
2022-02-16
op
092
2022-02-17
op
playlist->songs[playlist->len++] = xstrdup(path);
093
2022-02-16
op
}
094
2022-02-16
op
095
2022-02-17
op
void
096
2022-02-17
op
playlist_enqueue(const char *path)
097
2022-02-17
op
{
098
2022-02-17
op
playlist_push(&playlist, path);
099
2022-02-17
op
}
100
2022-02-17
op
101
2022-02-16
op
const char *
102
2022-02-16
op
playlist_advance(void)
103
2022-02-16
op
{
104
2022-02-16
op
if (playlist.len == 0) {
105
2022-02-16
op
play_state = STATE_STOPPED;
106
2022-02-16
op
return NULL;
107
2022-02-16
op
}
108
2022-02-16
op
109
2022-02-16
op
play_off++;
110
2022-02-16
op
if (play_off == playlist.len) {
111
2022-02-16
op
if (repeat_all)
112
2022-02-16
op
play_off = 0;
113
2022-02-16
op
else {
114
2022-02-16
op
play_state = STATE_STOPPED;
115
2022-02-16
op
play_off = -1;
116
2022-02-19
op
setsong(play_off);
117
2022-02-16
op
return NULL;
118
2022-02-16
op
}
119
2022-02-16
op
}
120
2022-02-16
op
121
2022-02-19
op
setsong(play_off);
122
2022-02-16
op
play_state = STATE_PLAYING;
123
2022-02-16
op
return playlist.songs[play_off];
124
2022-02-16
op
}
125
2022-02-16
op
126
2022-02-17
op
const char *
127
2022-02-17
op
playlist_previous(void)
128
2022-02-17
op
{
129
2022-02-17
op
if (playlist.len == 0) {
130
2022-02-17
op
play_state = STATE_STOPPED;
131
2022-02-17
op
return NULL;
132
2022-02-17
op
}
133
2022-02-17
op
134
2022-02-17
op
play_off--;
135
2022-02-17
op
if (play_off < 0) {
136
2022-02-17
op
if (repeat_all)
137
2022-02-17
op
play_off = playlist.len - 1;
138
2022-02-17
op
else {
139
2022-02-17
op
play_state = STATE_STOPPED;
140
2022-02-17
op
play_off = -1;
141
2022-02-19
op
setsong(play_off);
142
2022-02-17
op
return NULL;
143
2022-02-17
op
}
144
2022-02-17
op
}
145
2022-02-17
op
146
2022-02-19
op
setsong(play_off);
147
2022-02-17
op
play_state = STATE_PLAYING;
148
2022-02-17
op
return playlist.songs[play_off];
149
2022-02-17
op
}
150
2022-02-17
op
151
2022-02-16
op
void
152
2022-02-16
op
playlist_reset(void)
153
2022-02-16
op
{
154
2022-02-16
op
play_off = -1;
155
2022-02-16
op
}
156
2022-02-16
op
157
2022-02-16
op
void
158
2022-02-17
op
playlist_free(struct playlist *playlist)
159
2022-02-16
op
{
160
2022-02-16
op
size_t i;
161
2022-02-16
op
162
2022-02-17
op
for (i = 0; i < playlist->len; ++i)
163
2022-02-17
op
free(playlist->songs[i]);
164
2022-02-17
op
free(playlist->songs);
165
2022-02-17
op
playlist->songs = NULL;
166
2022-02-16
op
167
2022-02-17
op
playlist->len = 0;
168
2022-02-17
op
playlist->cap = 0;
169
2022-02-17
op
}
170
2022-02-17
op
171
2022-02-17
op
void
172
2022-02-17
op
playlist_truncate(void)
173
2022-02-17
op
{
174
2022-02-17
op
playlist_free(&playlist);
175
2022-02-16
op
play_off = -1;
176
2022-02-16
op
}
177
2022-02-16
op
178
2022-02-16
op
void
179
2022-02-16
op
playlist_dropcurrent(void)
180
2022-02-16
op
{
181
2022-02-16
op
size_t i;
182
2022-02-16
op
183
2022-02-16
op
if (play_off == -1 || playlist.len == 0)
184
2022-02-16
op
return;
185
2022-02-16
op
186
2022-02-16
op
free(playlist.songs[play_off]);
187
2022-02-22
op
setsong(-1);
188
2022-02-16
op
189
2022-02-16
op
playlist.len--;
190
2022-02-16
op
for (i = play_off; i < playlist.len; ++i)
191
2022-02-16
op
playlist.songs[i] = playlist.songs[i+1];
192
2022-02-22
op
play_off--;
193
2022-02-16
op
194
2022-02-16
op
playlist.songs[playlist.len] = NULL;
195
2022-02-16
op
}
196
2022-02-17
op
197
2022-02-17
op
const char *
198
2022-02-17
op
playlist_jump(const char *arg)
199
2022-02-17
op
{
200
2022-02-17
op
size_t i;
201
2022-02-17
op
regex_t re;
202
2022-02-17
op
203
2022-02-17
op
if (regcomp(&re, arg, REG_ICASE | REG_NOSUB) != 0)
204
2022-02-17
op
return NULL;
205
2022-02-17
op
206
2022-02-17
op
for (i = 0; i < playlist.len; ++i) {
207
2022-02-17
op
if (regexec(&re, playlist.songs[i], 0, NULL, 0) == 0)
208
2022-02-17
op
break;
209
2022-02-17
op
}
210
2022-02-17
op
regfree(&re);
211
2022-02-17
op
212
2022-02-17
op
if (i == playlist.len)
213
2022-02-17
op
return NULL;
214
2022-02-17
op
215
2022-02-17
op
play_state = STATE_PLAYING;
216
2022-02-17
op
play_off = i;
217
2022-02-19
op
setsong(play_off);
218
2022-02-17
op
return playlist.songs[i];
219
2022-02-17
op
}
Omar Polo