mirror of
https://github.com/mudler/luet.git
synced 2025-09-06 09:41:05 +00:00
Update vendor github.com/cavaliercoder/grab
This commit is contained in:
58
vendor/github.com/cavaliercoder/grab/transfer.go
generated
vendored
58
vendor/github.com/cavaliercoder/grab/transfer.go
generated
vendored
@@ -4,30 +4,42 @@ import (
|
||||
"context"
|
||||
"io"
|
||||
"sync/atomic"
|
||||
"time"
|
||||
|
||||
"github.com/cavaliercoder/grab/bps"
|
||||
)
|
||||
|
||||
type transfer struct {
|
||||
n int64 // must be 64bit aligned on 386
|
||||
ctx context.Context
|
||||
lim RateLimiter
|
||||
w io.Writer
|
||||
r io.Reader
|
||||
b []byte
|
||||
n int64 // must be 64bit aligned on 386
|
||||
ctx context.Context
|
||||
gauge bps.Gauge
|
||||
lim RateLimiter
|
||||
w io.Writer
|
||||
r io.Reader
|
||||
b []byte
|
||||
}
|
||||
|
||||
func newTransfer(ctx context.Context, lim RateLimiter, dst io.Writer, src io.Reader, buf []byte) *transfer {
|
||||
return &transfer{
|
||||
ctx: ctx,
|
||||
lim: lim,
|
||||
w: dst,
|
||||
r: src,
|
||||
b: buf,
|
||||
ctx: ctx,
|
||||
gauge: bps.NewSMA(6), // five second moving average sampling every second
|
||||
lim: lim,
|
||||
w: dst,
|
||||
r: src,
|
||||
b: buf,
|
||||
}
|
||||
}
|
||||
|
||||
// copy behaves similarly to io.CopyBuffer except that it checks for cancelation
|
||||
// of the given context.Context and reports progress in a thread-safe manner.
|
||||
// of the given context.Context, reports progress in a thread-safe manner and
|
||||
// tracks the transfer rate.
|
||||
func (c *transfer) copy() (written int64, err error) {
|
||||
// maintain a bps gauge in another goroutine
|
||||
ctx, cancel := context.WithCancel(c.ctx)
|
||||
defer cancel()
|
||||
go bps.Watch(ctx, c.gauge, c.N, time.Second)
|
||||
|
||||
// start the transfer
|
||||
if c.b == nil {
|
||||
c.b = make([]byte, 32*1024)
|
||||
}
|
||||
@@ -39,12 +51,6 @@ func (c *transfer) copy() (written int64, err error) {
|
||||
default:
|
||||
// keep working
|
||||
}
|
||||
if c.lim != nil {
|
||||
err = c.lim.WaitN(c.ctx, len(c.b))
|
||||
if err != nil {
|
||||
return
|
||||
}
|
||||
}
|
||||
nr, er := c.r.Read(c.b)
|
||||
if nr > 0 {
|
||||
nw, ew := c.w.Write(c.b[0:nr])
|
||||
@@ -60,6 +66,13 @@ func (c *transfer) copy() (written int64, err error) {
|
||||
err = io.ErrShortWrite
|
||||
break
|
||||
}
|
||||
// wait for rate limiter
|
||||
if c.lim != nil {
|
||||
err = c.lim.WaitN(c.ctx, nr)
|
||||
if err != nil {
|
||||
return
|
||||
}
|
||||
}
|
||||
}
|
||||
if er != nil {
|
||||
if er != io.EOF {
|
||||
@@ -79,3 +92,12 @@ func (c *transfer) N() (n int64) {
|
||||
n = atomic.LoadInt64(&c.n)
|
||||
return
|
||||
}
|
||||
|
||||
// BPS returns the current bytes per second transfer rate using a simple moving
|
||||
// average.
|
||||
func (c *transfer) BPS() (bps float64) {
|
||||
if c == nil || c.gauge == nil {
|
||||
return 0
|
||||
}
|
||||
return c.gauge.BPS()
|
||||
}
|
||||
|
Reference in New Issue
Block a user