Comments (4)
Nope, this is expected (and I unfortunately forgot to document it 😓). I intentionally skipped support for proto2 because Vitess doesn't use it and it makes memory pooling trickier. I take it your project is stuck in proto2 and not planning to upgrade to proto3? I'm still unsure of whether the additional complexity of supporting legacy proto2 is worth it, given the minimal use case.
from vtprotobuf.
The specific case is some legacy proto2 messages getting referenced in proto3 messages which causes compile errors as the vtproto helpers are not generated but are expected to exist in the proto3 helpers. This isn't a blocker, I just wanted to confirm since I didn't see it specifically documented.
from vtprotobuf.
As an additional entry point - our codebase does still have hundreds of proto2 files and the migration would be tricky and often risky.
This makes me interested if you're willing to accept patches to support generation (un)marshal/size methods for proto2?
I understand that pooling logic is tricky and we could skip it & ask people to migrate to proto3 for this additional feature.
from vtprotobuf.
@euroelessar: sure thing. It actually shouldn't be a massive change, some of the generators already have a proto3
param that toggles between proto2 and proto3 generated code. It's just a matter of finishing up all the corner cases. If you send a PR I'll review it.
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.