Files
obitools4/pkg/obiiter/speed.go

82 lines
1.4 KiB
Go
Raw Normal View History

package obiiter
2022-02-18 22:53:09 +01:00
import (
2023-02-16 13:32:27 +01:00
"fmt"
"os"
"time"
"github.com/schollz/progressbar/v3"
)
2023-01-22 22:04:17 +01:00
func (iterator IBioSequence) Speed(message ...string) IBioSequence {
2023-02-16 13:32:27 +01:00
// If the STDERR is redicted and doesn't end up to a terminal
// No progress bar is printed.
o, _ := os.Stderr.Stat()
if (o.Mode() & os.ModeCharDevice) != os.ModeCharDevice {
return iterator
}
2023-01-22 22:04:17 +01:00
newIter := MakeIBioSequence()
newIter.Add(1)
go func() {
newIter.WaitAndClose()
}()
2022-02-24 12:14:52 +01:00
pbopt := make([]progressbar.Option, 0, 5)
pbopt = append(pbopt,
progressbar.OptionSetWriter(os.Stderr),
progressbar.OptionSetWidth(15),
progressbar.OptionShowCount(),
progressbar.OptionShowIts(),
2022-02-24 12:14:52 +01:00
)
if len(message) > 0 {
pbopt = append(pbopt,
progressbar.OptionSetDescription(message[0]),
)
} else {
pbopt = append(pbopt,
progressbar.OptionSetDescription("[Sequence Processing]"),
)
}
bar := progressbar.NewOptions(-1, pbopt...)
go func() {
c := 0
start := time.Now()
for iterator.Next() {
batch := iterator.Get()
c += batch.Len()
newIter.Push(batch)
elapsed := time.Since(start)
if elapsed > (time.Millisecond * 100) {
bar.Add(c)
c = 0
start = time.Now()
}
}
2023-02-16 13:32:27 +01:00
fmt.Fprintln(os.Stderr)
newIter.Done()
}()
if iterator.IsPaired() {
newIter.MarkAsPaired()
}
2022-02-18 22:53:09 +01:00
return newIter
}
2022-10-27 11:18:44 +02:00
func SpeedPipe(message ...string) Pipeable {
2023-01-22 22:04:17 +01:00
f := func(iterator IBioSequence) IBioSequence {
2022-10-27 11:18:44 +02:00
return iterator.Speed(message...)
}
return f
2022-02-24 12:14:52 +01:00
}