Some refactoring
This commit is contained in:
parent
7c6aad7f3e
commit
1bf2591eda
39
main.go
39
main.go
@ -4,7 +4,6 @@ import (
|
|||||||
"bytes"
|
"bytes"
|
||||||
"flag"
|
"flag"
|
||||||
"fmt"
|
"fmt"
|
||||||
"io"
|
|
||||||
"log"
|
"log"
|
||||||
"math"
|
"math"
|
||||||
"math/rand"
|
"math/rand"
|
||||||
@ -138,24 +137,26 @@ func speakWeather() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func loadFile(filepath string) (name string, s beep.StreamSeekCloser, format beep.Format, err error) {
|
func loadFile(filepath string) (name string, s beep.StreamSeekCloser, format beep.Format, err error) {
|
||||||
for _, decoder := range []func(io.ReadCloser) (beep.StreamSeekCloser, beep.Format, error){flac.Decode, mp3.Decode, wav.Decode} {
|
var fd *os.File
|
||||||
var fd *os.File
|
|
||||||
|
|
||||||
name = path.Base(filepath)
|
name = path.Base(filepath)
|
||||||
|
|
||||||
fd, err = os.Open(filepath)
|
fd, err = os.Open(filepath)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
// Try decoding as FLAC
|
switch strings.ToLower(path.Ext(filepath)) {
|
||||||
s, format, err = decoder(fd)
|
case ".flac":
|
||||||
if err == nil {
|
s, format, err = flac.Decode(fd)
|
||||||
break
|
case ".mp3":
|
||||||
}
|
s, format, err = mp3.Decode(fd)
|
||||||
|
default:
|
||||||
|
s, format, err = wav.Decode(fd)
|
||||||
}
|
}
|
||||||
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
fd.Close()
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -177,7 +178,8 @@ func main() {
|
|||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
seed := time.Now().Unix() % 172800 * 64
|
seed := time.Now().Unix()
|
||||||
|
seed -= seed % 172800
|
||||||
|
|
||||||
log.Println("Starting reveil with seed:", seed)
|
log.Println("Starting reveil with seed:", seed)
|
||||||
|
|
||||||
@ -211,6 +213,7 @@ func main() {
|
|||||||
formats[i], formats[j] = formats[j], formats[i]
|
formats[i], formats[j] = formats[j], formats[i]
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
log.Println("Playlist in use:", strings.Join(paths, " ; "))
|
||||||
|
|
||||||
var launched time.Time
|
var launched time.Time
|
||||||
var volume *effects.Volume
|
var volume *effects.Volume
|
||||||
@ -218,7 +221,7 @@ func main() {
|
|||||||
dontUpdateVolume := false
|
dontUpdateVolume := false
|
||||||
hasClaironed := claironTime == nil || *claironTime == -1
|
hasClaironed := claironTime == nil || *claironTime == -1
|
||||||
hasSpokeWeather := weatherTime == nil || *weatherTime == -1
|
hasSpokeWeather := weatherTime == nil || *weatherTime == -1
|
||||||
reverseOrder := time.Now().Unix()%86400%2 == 0
|
reverseOrder := (time.Now().Unix()/86400)%2 == 0
|
||||||
playedItem := -1
|
playedItem := -1
|
||||||
|
|
||||||
// Create infinite stream
|
// Create infinite stream
|
||||||
@ -226,9 +229,11 @@ func main() {
|
|||||||
if !hasClaironed && time.Since(launched) >= *claironTime {
|
if !hasClaironed && time.Since(launched) >= *claironTime {
|
||||||
log.Println("clairon time!")
|
log.Println("clairon time!")
|
||||||
*claironTime += *claironTime / 2
|
*claironTime += *claironTime / 2
|
||||||
_, sample, format, err := loadFile("/home/nemunaire/www/audio/miracle-morning/clairon-reveil.mp3")
|
//_, sample, format, err := loadFile("/home/nemunaire/www/audio/miracle-morning/clairon-reveil.mp3")
|
||||||
|
//_, sample, format, err := loadFile("/home/nemunaire/www/audio/miracle-morning/coq.flac")
|
||||||
|
_, sample, format, err := loadFile("/home/nemunaire/www/audio/miracle-morning/NukeAnthem.flac")
|
||||||
if err == nil {
|
if err == nil {
|
||||||
volume.Volume = 1
|
volume.Volume = 0.1
|
||||||
dontUpdateVolume = true
|
dontUpdateVolume = true
|
||||||
if format.SampleRate != sampleRate {
|
if format.SampleRate != sampleRate {
|
||||||
return beep.Resample(3, format.SampleRate, sampleRate, sample)
|
return beep.Resample(3, format.SampleRate, sampleRate, sample)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user