Skip to content

Commit

Permalink
fix: vcsim: output signed byte in ByteSlice.MarshalXML
Browse files Browse the repository at this point in the history
Fixes #3615

Signed-off-by: Doug MacEachern <dougm@broadcom.com>
  • Loading branch information
dougm committed Nov 19, 2024
1 parent a0a0072 commit 29de346
Show file tree
Hide file tree
Showing 2 changed files with 32 additions and 1 deletion.
3 changes: 2 additions & 1 deletion vim25/types/byte_slice.go
Original file line number Diff line number Diff line change
Expand Up @@ -36,7 +36,8 @@ func (b ByteSlice) MarshalXML(e *xml.Encoder, field xml.StartElement) error {
Name: field.Name,
}
for i := range b {
if err := e.EncodeElement(b[i], start); err != nil {
// Using int8() here to output a signed byte (issue #3615)
if err := e.EncodeElement(int8(b[i]), start); err != nil {
return err
}
}
Expand Down
30 changes: 30 additions & 0 deletions vim25/types/byte_slice_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -43,3 +43,33 @@ func TestByteSlice(t *testing.T) {
t.Errorf("out=%#v", out.Byte)
}
}

func TestSignedByteSlice(t *testing.T) {
// int8: <byte>4</byte><byte>-80</byte><byte>-79</byte><byte>-78</byte>
// uint8: <byte>4</byte><byte>176</byte><byte>177</byte><byte>178</byte>
in := &ArrayOfByte{
Byte: []uint8{0x4, 0xb0, 0xb1, 0xb2},
}

res, err := xml.Marshal(in)
if err != nil {
t.Fatal(err)
}

var out struct {
Byte []int8 `xml:"byte,omitempty" json:"_value"`
}

// ByteSlice.MarshalXML must output signed byte, otherwise this fails with:
// strconv.ParseInt: parsing "176": value out of range
if err := xml.Unmarshal(res, &out); err != nil {
t.Logf("%s", string(res))
t.Fatal(err)
}

for i := range in.Byte {
if in.Byte[i] != byte(out.Byte[i]) {
t.Errorf("out=%x", out.Byte[i])
}
}
}

0 comments on commit 29de346

Please sign in to comment.