Some refactoring

This commit is contained in:
nemunaire 2021-10-30 12:25:52 +02:00
parent 7c6aad7f3e
commit 1bf2591eda

39
main.go
View File

@ -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)