ConnClient: speedup play in case of udp connections

This commit is contained in:
aler9
2020-08-15 22:12:59 +02:00
parent 7f40a9331b
commit 6975ef8a96

View File

@@ -485,6 +485,19 @@ func (c *ConnClient) Play(u *url.URL) (*Response, error) {
return nil, fmt.Errorf("Play() can be called only after SetupUDP() or SetupTCP()") return nil, fmt.Errorf("Play() can be called only after SetupUDP() or SetupTCP()")
} }
res, err := func() (*Response, error) {
if *c.streamProtocol == StreamProtocolUdp {
res, err := c.Do(&Request{
Method: PLAY,
Url: u,
})
if err != nil {
return nil, err
}
return res, nil
} else {
_, err := c.Do(&Request{ _, err := c.Do(&Request{
Method: PLAY, Method: PLAY,
Url: u, Url: u,
@@ -494,7 +507,6 @@ func (c *ConnClient) Play(u *url.URL) (*Response, error) {
return nil, err return nil, err
} }
res, err := func() (*Response, error) {
frame := &InterleavedFrame{ frame := &InterleavedFrame{
Content: make([]byte, 0, clientTcpReadBufferSize), Content: make([]byte, 0, clientTcpReadBufferSize),
} }
@@ -509,18 +521,19 @@ func (c *ConnClient) Play(u *url.URL) (*Response, error) {
} }
if res, ok := recv.(*Response); ok { if res, ok := recv.(*Response); ok {
if res.StatusCode != StatusOK {
return nil, fmt.Errorf("bad status code: %d (%s)", res.StatusCode, res.StatusMessage)
}
return res, nil return res, nil
} }
} }
}
}() }()
if err != nil { if err != nil {
return nil, err return nil, err
} }
if res.StatusCode != StatusOK {
return nil, fmt.Errorf("bad status code: %d (%s)", res.StatusCode, res.StatusMessage)
}
c.receiverReportTerminate = make(chan struct{}) c.receiverReportTerminate = make(chan struct{})
c.receiverReportDone = make(chan struct{}) c.receiverReportDone = make(chan struct{})