mirror of
https://github.com/refraction-networking/utls.git
synced 2025-04-03 20:17:36 +03:00
all: use bytes.Cut, strings.Cut
Many uses of Index/IndexByte/IndexRune/Split/SplitN can be written more clearly using the new Cut functions. Do that. Also rewrite to other functions if that's clearer. For #46336. Change-Id: I68d024716ace41a57a8bf74455c62279bde0f448 Reviewed-on: https://go-review.googlesource.com/c/go/+/351711 Trust: Russ Cox <rsc@golang.org> Run-TryBot: Russ Cox <rsc@golang.org> TryBot-Result: Go Bot <gobot@golang.org> Reviewed-by: Ian Lance Taylor <iant@golang.org>
This commit is contained in:
parent
3ada52a07f
commit
b5419a1985
2 changed files with 11 additions and 12 deletions
|
@ -97,18 +97,18 @@ func (o *opensslOutputSink) Write(data []byte) (n int, err error) {
|
|||
o.all = append(o.all, data...)
|
||||
|
||||
for {
|
||||
i := bytes.IndexByte(o.line, '\n')
|
||||
if i < 0 {
|
||||
line, next, ok := bytes.Cut(o.line, []byte("\n"))
|
||||
if !ok {
|
||||
break
|
||||
}
|
||||
|
||||
if bytes.Equal([]byte(opensslEndOfHandshake), o.line[:i]) {
|
||||
if bytes.Equal([]byte(opensslEndOfHandshake), line) {
|
||||
o.handshakeComplete <- struct{}{}
|
||||
}
|
||||
if bytes.Equal([]byte(opensslReadKeyUpdate), o.line[:i]) {
|
||||
if bytes.Equal([]byte(opensslReadKeyUpdate), line) {
|
||||
o.readKeyUpdate <- struct{}{}
|
||||
}
|
||||
o.line = o.line[i+1:]
|
||||
o.line = next
|
||||
}
|
||||
|
||||
return len(data), nil
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue