mirror of
https://github.com/jech/galene.git
synced 2024-11-22 16:45:58 +01:00
Split out sending loop into a separate function.
This commit is contained in:
parent
9bd093e78c
commit
a813cc9ce4
1 changed files with 54 additions and 53 deletions
107
client.go
107
client.go
|
@ -286,10 +286,9 @@ func addUpConn(c *client, id string) (*upConnection, error) {
|
||||||
c.mu.Unlock()
|
c.mu.Unlock()
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
list := packetlist.New(32)
|
|
||||||
track := &upTrack{
|
track := &upTrack{
|
||||||
track: remote,
|
track: remote,
|
||||||
list: list,
|
list: packetlist.New(32),
|
||||||
maxBitrate: ^uint64(0),
|
maxBitrate: ^uint64(0),
|
||||||
}
|
}
|
||||||
u.tracks = append(u.tracks, track)
|
u.tracks = append(u.tracks, track)
|
||||||
|
@ -304,62 +303,64 @@ func addUpConn(c *client, id string) (*upConnection, error) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
go func() {
|
go upLoop(conn, track)
|
||||||
buf := make([]byte, packetlist.BufSize)
|
|
||||||
var packet rtp.Packet
|
|
||||||
var local []*downTrack
|
|
||||||
var localTime time.Time
|
|
||||||
window := packetwindow.New()
|
|
||||||
for {
|
|
||||||
now := time.Now()
|
|
||||||
if now.Sub(localTime) > time.Second/2 {
|
|
||||||
local = track.getLocal()
|
|
||||||
localTime = now
|
|
||||||
}
|
|
||||||
|
|
||||||
i, err := remote.Read(buf)
|
|
||||||
if err != nil {
|
|
||||||
if err != io.EOF {
|
|
||||||
log.Printf("%v", err)
|
|
||||||
}
|
|
||||||
break
|
|
||||||
}
|
|
||||||
|
|
||||||
err = packet.Unmarshal(buf[:i])
|
|
||||||
if err != nil {
|
|
||||||
log.Printf("%v", err)
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
|
|
||||||
window.Set(packet.SequenceNumber)
|
|
||||||
if packet.SequenceNumber-window.First() > 24 {
|
|
||||||
first, bitmap := window.Get17()
|
|
||||||
if bitmap != ^uint16(0) {
|
|
||||||
err := conn.sendNACK(track, first, ^bitmap)
|
|
||||||
if err != nil {
|
|
||||||
log.Printf("%v", err)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
list.Store(packet.SequenceNumber, buf[:i])
|
|
||||||
|
|
||||||
for _, l := range local {
|
|
||||||
if l.muted() {
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
err := l.track.WriteRTP(&packet)
|
|
||||||
if err != nil && err != io.ErrClosedPipe {
|
|
||||||
log.Printf("%v", err)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}()
|
|
||||||
})
|
})
|
||||||
|
|
||||||
return conn, nil
|
return conn, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func upLoop(conn *upConnection, track *upTrack) {
|
||||||
|
buf := make([]byte, packetlist.BufSize)
|
||||||
|
var packet rtp.Packet
|
||||||
|
var local []*downTrack
|
||||||
|
var localTime time.Time
|
||||||
|
window := packetwindow.New()
|
||||||
|
for {
|
||||||
|
now := time.Now()
|
||||||
|
if now.Sub(localTime) > time.Second/2 {
|
||||||
|
local = track.getLocal()
|
||||||
|
localTime = now
|
||||||
|
}
|
||||||
|
|
||||||
|
i, err := track.track.Read(buf)
|
||||||
|
if err != nil {
|
||||||
|
if err != io.EOF {
|
||||||
|
log.Printf("%v", err)
|
||||||
|
}
|
||||||
|
break
|
||||||
|
}
|
||||||
|
|
||||||
|
err = packet.Unmarshal(buf[:i])
|
||||||
|
if err != nil {
|
||||||
|
log.Printf("%v", err)
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
|
||||||
|
window.Set(packet.SequenceNumber)
|
||||||
|
if packet.SequenceNumber-window.First() > 24 {
|
||||||
|
first, bitmap := window.Get17()
|
||||||
|
if bitmap != ^uint16(0) {
|
||||||
|
err := conn.sendNACK(track, first, ^bitmap)
|
||||||
|
if err != nil {
|
||||||
|
log.Printf("%v", err)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
track.list.Store(packet.SequenceNumber, buf[:i])
|
||||||
|
|
||||||
|
for _, l := range local {
|
||||||
|
if l.muted() {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
err := l.track.WriteRTP(&packet)
|
||||||
|
if err != nil && err != io.ErrClosedPipe {
|
||||||
|
log.Printf("%v", err)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
func delUpConn(c *client, id string) {
|
func delUpConn(c *client, id string) {
|
||||||
c.mu.Lock()
|
c.mu.Lock()
|
||||||
defer c.mu.Unlock()
|
defer c.mu.Unlock()
|
||||||
|
|
Loading…
Reference in a new issue