Comments (6)
@vmg / @jasonlong Could you please check the above issue.
from vtprotobuf.
Can confirm that I am seeing this as well.
from vtprotobuf.
To confirm, is this from encoding a message like, OptionalByte{Value: nil}
or OptionalByte{Value: []byte{}}
?
I would suspect these encode differently since optional fields are ignored from the proto encoding when the value doesn't exist.
I can check into this later, but that's what stands out to me without any other investigation.
from vtprotobuf.
Ah, ok, so I see the difference and can confirm slightly different behavior.
package main
import (
"vtprotobuftest/test"
"fmt"
"google.golang.org/protobuf/proto"
)
func main() {
a := test.OptionalByte{
Value: nil,
}
b := test.OptionalByte{
Value: []byte{},
}
fmt.Println("proto.Marshal:")
fmt.Printf("%#v\n", must(proto.Marshal(&a)))
fmt.Printf("%#v\n", must(proto.Marshal(&b)))
fmt.Println()
fmt.Println("vtproto:")
fmt.Printf("%#v\n", must((&a).MarshalVT()))
fmt.Printf("%#v\n", must((&b).MarshalVT()))
}
func must[T any](v T, err error) T {
if err != nil {
panic(err)
}
return v
}
Is my test script, just using the proto from the OP.
Output is:
proto.Marshal:
[]byte{}
[]byte{0xa, 0x0}
vtproto:
[]byte{}
[]byte{}
So it's the empty byte array case, not a nil byte array. Lemme see if I can dig in and see where we differ.
from vtprotobuf.
So this also seems to be explicitly for when optional
is used, when it's just bytes value = 1;
, it does marshal to no bytes. So I'm guessing the standard encoder need to explicitly say "this is missing" vs "there are no bytes".
from vtprotobuf.
Yeah exactly. That's the purpose of optional
.
from vtprotobuf.
Related Issues (20)
- Uncompilable code generated for repeated groups
- Duplicated code generated for GRPC client/server HOT 1
- Panic after WKT commit: assignment to entry in nil map HOT 2
- Extensions are not encoded
- docs/feature: Nested ReturnToVTPool() HOT 4
- bug: oneof field that includes bytes field yields invalid ResetVT method
- Supporting Embedded and Nullable features from gogo proto HOT 2
- bug: Broken ResetVT generation for optional message HOT 1
- bug: grpc client methods does not use qualified idents
- feature: poolable messages paths with wildcard HOT 2
- unmarshal_unsafe feature produced code does not compile: "Cannot use intStringLen (type int) as the type IntegerType" HOT 1
- Run vtproto multiple times on different files of the same package HOT 3
- bug: IsMap not checked on message field's ReturnToVTpool
- bug: UnmarshalUnsafe panics when map values are empty strings HOT 2
- Request for New Release that Includes Well-Known Type Support HOT 4
- gRPC codec has different semantic on Unmarshal than the default one HOT 1
- v0.6.0 is creating issues in ubuntu20 HOT 2
- Offering assistance and discussing upkeep / releases for vtprotobuf HOT 8
- wrong pool unmarshal slize HOT 3
- Add optional unsafe operations HOT 2
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from vtprotobuf.