mirror of
https://github.com/aler9/gortsplib
synced 2025-10-05 23:26:54 +08:00
base: return error from Write() methods
This commit is contained in:
@@ -35,10 +35,11 @@ func (b *body) read(header Header, rb *bufio.Reader) error {
|
||||
return nil
|
||||
}
|
||||
|
||||
func (b body) write(w io.Writer) {
|
||||
func (b body) write(w io.Writer) error {
|
||||
if len(b) == 0 {
|
||||
return
|
||||
return nil
|
||||
}
|
||||
|
||||
w.Write(b)
|
||||
_, err := w.Write(b)
|
||||
return err
|
||||
}
|
||||
|
@@ -98,7 +98,7 @@ func (h *Header) read(rb *bufio.Reader) error {
|
||||
return nil
|
||||
}
|
||||
|
||||
func (h Header) write(w io.Writer) {
|
||||
func (h Header) write(w io.Writer) error {
|
||||
// sort headers by key
|
||||
// in order to obtain deterministic results
|
||||
keys := make([]string, len(h))
|
||||
@@ -109,9 +109,13 @@ func (h Header) write(w io.Writer) {
|
||||
|
||||
for _, key := range keys {
|
||||
for _, val := range h[key] {
|
||||
w.Write([]byte(key + ": " + val + "\r\n"))
|
||||
_, err := w.Write([]byte(key + ": " + val + "\r\n"))
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
w.Write([]byte("\r\n"))
|
||||
_, err := w.Write([]byte("\r\n"))
|
||||
return err
|
||||
}
|
||||
|
@@ -106,11 +106,15 @@ func (f *InterleavedFrame) Read(maxPayloadSize int, br *bufio.Reader) error {
|
||||
}
|
||||
|
||||
// Write writes an InterleavedFrame into a buffered writer.
|
||||
func (f InterleavedFrame) Write(w io.Writer) {
|
||||
func (f InterleavedFrame) Write(w io.Writer) error {
|
||||
buf := []byte{0x24, byte(f.Channel), 0x00, 0x00}
|
||||
binary.BigEndian.PutUint16(buf[2:], uint16(len(f.Payload)))
|
||||
|
||||
w.Write(buf)
|
||||
_, err := w.Write(buf)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
w.Write(f.Payload)
|
||||
_, err = w.Write(f.Payload)
|
||||
return err
|
||||
}
|
||||
|
@@ -118,17 +118,23 @@ func (req *Request) ReadIgnoreFrames(maxPayloadSize int, rb *bufio.Reader) error
|
||||
}
|
||||
|
||||
// Write writes a request.
|
||||
func (req Request) Write(w io.Writer) {
|
||||
func (req Request) Write(w io.Writer) error {
|
||||
urStr := req.URL.CloneWithoutCredentials().String()
|
||||
w.Write([]byte(string(req.Method) + " " + urStr + " " + rtspProtocol10 + "\r\n"))
|
||||
_, err := w.Write([]byte(string(req.Method) + " " + urStr + " " + rtspProtocol10 + "\r\n"))
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
if len(req.Body) != 0 {
|
||||
req.Header["Content-Length"] = HeaderValue{strconv.FormatInt(int64(len(req.Body)), 10)}
|
||||
}
|
||||
|
||||
req.Header.write(w)
|
||||
err = req.Header.write(w)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
body(req.Body).write(w)
|
||||
return body(req.Body).write(w)
|
||||
}
|
||||
|
||||
// String implements fmt.Stringer.
|
||||
|
@@ -204,24 +204,30 @@ func (res *Response) ReadIgnoreFrames(maxPayloadSize int, rb *bufio.Reader) erro
|
||||
}
|
||||
|
||||
// Write writes a Response.
|
||||
func (res Response) Write(w io.Writer) {
|
||||
func (res Response) Write(w io.Writer) error {
|
||||
if res.StatusMessage == "" {
|
||||
if status, ok := statusMessages[res.StatusCode]; ok {
|
||||
res.StatusMessage = status
|
||||
}
|
||||
}
|
||||
|
||||
w.Write([]byte(rtspProtocol10 + " " +
|
||||
_, err := w.Write([]byte(rtspProtocol10 + " " +
|
||||
strconv.FormatInt(int64(res.StatusCode), 10) + " " +
|
||||
res.StatusMessage + "\r\n"))
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
if len(res.Body) != 0 {
|
||||
res.Header["Content-Length"] = HeaderValue{strconv.FormatInt(int64(len(res.Body)), 10)}
|
||||
}
|
||||
|
||||
res.Header.write(w)
|
||||
err = res.Header.write(w)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
body(res.Body).write(w)
|
||||
return body(res.Body).write(w)
|
||||
}
|
||||
|
||||
// String implements fmt.Stringer.
|
||||
|
Reference in New Issue
Block a user