commit 663c0c69f76c0fc86ea06a56efc0719bc3d7c4ab Author: David Fifield david@bamsoftware.com Date: Thu Feb 21 10:49:50 2019 -0700
Make the native extension work with GOARCH=386. --- webextension/native/endian_386.go | 8 ++++++++ webextension/native/main.go | 10 ++++++++-- 2 files changed, 16 insertions(+), 2 deletions(-)
diff --git a/webextension/native/endian_386.go b/webextension/native/endian_386.go new file mode 100644 index 0000000..6a1e44e --- /dev/null +++ b/webextension/native/endian_386.go @@ -0,0 +1,8 @@ +// The WebExtension browser–app protocol uses native-endian length prefixes :/ +// https://developer.mozilla.org/en-US/docs/Mozilla/Add-ons/WebExtensions/Nativ... + +package main + +import "encoding/binary" + +var NativeEndian = binary.LittleEndian diff --git a/webextension/native/main.go b/webextension/native/main.go index 5d071b3..9424715 100644 --- a/webextension/native/main.go +++ b/webextension/native/main.go @@ -138,8 +138,11 @@ func writeResponseSpec(w io.Writer, spec *responseSpec) error { panic(err) }
+ // len returns int, which is specified to be either 32 or 64 bits, so it + // will never be truncated when converting to uint64. + // https://golang.org/ref/spec#Numeric_types length := len(encodedSpec) - if length > math.MaxUint32 { + if uint64(length) > math.MaxUint32 { return fmt.Errorf("response spec is too long to represent: %d", length) } err = binary.Write(w, binary.BigEndian, uint32(length)) @@ -177,8 +180,11 @@ func recvWebExtensionMessage(r io.Reader) ([]byte, error) { // Send a WebExtension message. // https://developer.mozilla.org/en-US/docs/Mozilla/Add-ons/WebExtensions/Nativ... func sendWebExtensionMessage(w io.Writer, message []byte) error { + // len returns int, which is specified to be either 32 or 64 bits, so it + // will never be truncated when converting to uint64. + // https://golang.org/ref/spec#Numeric_types length := len(message) - if length > math.MaxUint32 { + if uint64(length) > math.MaxUint32 { return fmt.Errorf("WebExtension message is too long to represent: %d", length) } err := binary.Write(w, NativeEndian, uint32(length))