Code separation.
This commit is contained in:
parent
7c71092ac3
commit
0e61fa549d
3 changed files with 70 additions and 70 deletions
23
restful.liq
Normal file
23
restful.liq
Normal file
|
@ -0,0 +1,23 @@
|
|||
def get_http_data(headers, url) =
|
||||
if string.contains(prefix='https', url) then
|
||||
let (status, _, data) = https.get(headers=headers, url)
|
||||
let (_, status_code, _) = status
|
||||
(status_code, data)
|
||||
else
|
||||
let (status, _, data) = http.get(headers=headers, url)
|
||||
let (_, status_code, _) = status
|
||||
(status_code, data)
|
||||
end
|
||||
end
|
||||
|
||||
def post_http_data(headers, postdata, url) =
|
||||
if string.contains(prefix='https', url) then
|
||||
let (status, _, data) = https.post(headers=headers, data=postdata, url)
|
||||
let (_, status_code, _) = status
|
||||
(status_code, data)
|
||||
else
|
||||
let (status, _, data) = http.post(headers=headers, data=postdata, url)
|
||||
let (_, status_code, _) = status
|
||||
(status_code, data)
|
||||
end
|
||||
end
|
74
spradio.liq
74
spradio.liq
|
@ -1,4 +1,6 @@
|
|||
%include "secrets.liq"
|
||||
%include "tweaks.liq"
|
||||
%include "restful.liq"
|
||||
|
||||
set("init.daemon", true)
|
||||
set("init.daemon.change_user", true)
|
||||
|
@ -20,76 +22,6 @@ set("scheduler.non_blocking_queues", 3)
|
|||
|
||||
set("audio.converter.samplerate.libsamplerate.quality", "best")
|
||||
|
||||
security = single(id="default", fallback_audio)
|
||||
|
||||
# Tweaked custom crossfade to deal with jingles..
|
||||
def smart_cross(~start_next=5.,~fade_in=3.,~fade_out=3.,
|
||||
~default=(fun (a,b) -> sequence([a, b])),
|
||||
~high=-15., ~medium=-32., ~margin=4.,
|
||||
~width=2.,~conservative=false,s)
|
||||
fade.out = fade.out(type="sin", duration=fade_out)
|
||||
fade.in = fade.in(type="sin", duration=fade_in)
|
||||
add = fun (a,b) -> add(normalize=false, [b, a])
|
||||
log = log(label="smart_cross")
|
||||
|
||||
def transition(a,b,ma,mb,sa,sb)
|
||||
list.iter(fun(x)-> log(level=4, "Before: #{x}"), ma)
|
||||
list.iter(fun(x)-> log(level=4, "After : #{x}"), mb)
|
||||
|
||||
if ma["type"] == "J" or mb["type"] == "J" then
|
||||
log("Old or new file is a jingle: sequenced transition.")
|
||||
sequence([sa, sb])
|
||||
elsif
|
||||
# Do not fade if it's already very low.
|
||||
b >= a + margin and a <= medium and b <= high
|
||||
then
|
||||
log("new >= old + margin, old <= medium and new <= high.")
|
||||
log("Do not fade if it's already very low.")
|
||||
log("Transition: crossed, no fade.")
|
||||
add(sa, sb)
|
||||
|
||||
# What to do with a loud end and a quiet beginning ?
|
||||
# A good idea is to use a jingle to separate the two tracks,
|
||||
# but that's another story.
|
||||
else
|
||||
# Otherwise, A and B are just too loud to overlap nicely,
|
||||
# or the difference between them is too large and overlapping would
|
||||
# completely mask one of them.
|
||||
# log("No transition: using default.")
|
||||
# default(sa, sb)
|
||||
log("Transition: crossed, fade-in, fade-out.")
|
||||
add(fade.out(sa), fade.in(sb))
|
||||
end
|
||||
end
|
||||
|
||||
cross(width=width, duration=start_next,
|
||||
conservative=conservative, transition,s)
|
||||
end
|
||||
|
||||
def get_http_data(headers, url) =
|
||||
if string.contains(prefix='https', url) then
|
||||
let (status, _, data) = https.get(headers=headers, url)
|
||||
let (_, status_code, _) = status
|
||||
(status_code, data)
|
||||
else
|
||||
let (status, _, data) = http.get(headers=headers, url)
|
||||
let (_, status_code, _) = status
|
||||
(status_code, data)
|
||||
end
|
||||
end
|
||||
|
||||
def post_http_data(headers, postdata, url) =
|
||||
if string.contains(prefix='https', url) then
|
||||
let (status, _, data) = https.post(headers=headers, data=postdata, url)
|
||||
let (_, status_code, _) = status
|
||||
(status_code, data)
|
||||
else
|
||||
let (status, _, data) = http.post(headers=headers, data=postdata, url)
|
||||
let (_, status_code, _) = status
|
||||
(status_code, data)
|
||||
end
|
||||
end
|
||||
|
||||
def next_song() =
|
||||
log = log(label="next_song")
|
||||
|
||||
|
@ -141,6 +73,8 @@ def just_played(m) =
|
|||
end
|
||||
end
|
||||
|
||||
security = single(id="default", fallback_audio)
|
||||
|
||||
radio = request.dynamic(id="main", default_duration=120., length=60., next_song)
|
||||
radio = map_metadata(update=false, change_meta, radio)
|
||||
radio = on_metadata(id="main", just_played, radio)
|
||||
|
|
43
tweaks.liq
Normal file
43
tweaks.liq
Normal file
|
@ -0,0 +1,43 @@
|
|||
# Tweaked custom crossfade to deal with jingles..
|
||||
def smart_cross(~start_next=5.,~fade_in=3.,~fade_out=3.,
|
||||
~default=(fun (a,b) -> sequence([a, b])),
|
||||
~high=-15., ~medium=-32., ~margin=4.,
|
||||
~width=2.,~conservative=false,s)
|
||||
fade.out = fade.out(type="sin", duration=fade_out)
|
||||
fade.in = fade.in(type="sin", duration=fade_in)
|
||||
add = fun (a,b) -> add(normalize=false, [b, a])
|
||||
log = log(label="smart_cross")
|
||||
|
||||
def transition(a,b,ma,mb,sa,sb)
|
||||
list.iter(fun(x)-> log(level=4, "Before: #{x}"), ma)
|
||||
list.iter(fun(x)-> log(level=4, "After : #{x}"), mb)
|
||||
|
||||
if ma["type"] == "J" or mb["type"] == "J" then
|
||||
log("Old or new file is a jingle: sequenced transition.")
|
||||
sequence([sa, sb])
|
||||
elsif
|
||||
# Do not fade if it's already very low.
|
||||
b >= a + margin and a <= medium and b <= high
|
||||
then
|
||||
log("new >= old + margin, old <= medium and new <= high.")
|
||||
log("Do not fade if it's already very low.")
|
||||
log("Transition: crossed, no fade.")
|
||||
add(sa, sb)
|
||||
|
||||
# What to do with a loud end and a quiet beginning ?
|
||||
# A good idea is to use a jingle to separate the two tracks,
|
||||
# but that's another story.
|
||||
else
|
||||
# Otherwise, A and B are just too loud to overlap nicely,
|
||||
# or the difference between them is too large and overlapping would
|
||||
# completely mask one of them.
|
||||
# log("No transition: using default.")
|
||||
# default(sa, sb)
|
||||
log("Transition: crossed, fade-in, fade-out.")
|
||||
add(fade.out(sa), fade.in(sb))
|
||||
end
|
||||
end
|
||||
|
||||
cross(width=width, duration=start_next,
|
||||
conservative=conservative, transition,s)
|
||||
end
|
Loading…
Reference in a new issue