Skip to content

Commit

Permalink
Document builders in README
Browse files Browse the repository at this point in the history
  • Loading branch information
mzabaluev committed Mar 27, 2024
1 parent 1a55eb0 commit eab10f7
Showing 1 changed file with 49 additions and 0 deletions.
49 changes: 49 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -287,6 +287,55 @@ pub mod foo {

[^3]: Annotations have been elided for clarity. See below for a full example.

### Builders

[Builders] can be optionally generated for message types. A builder pattern API
allows constructing messages with code that does not need to be changed when
new fields are added to the message definition. For example,
if a matching builder name `Builder` is configured for this proto message:

```protobuf,ignore
message Person {
string name = 1;
repeated PhoneNumber phones = 2;
}
```

the following will be generated in addition to the message struct:

```rust,ignore
impl Person {
pub fn builder() -> person::Builder { ... }
}
pub mod person {
#[derive(Default)]
pub struct Builder {
// ...
}
impl Builder {
pub fn name(mut self, value: impl Into<String>) -> Self { ... }
pub fn phones(
mut self,
value: impl IntoIterator<Item = impl Into<PhoneNumber>>,
) -> Self {
...
}
pub fn build(self) -> super::Person { ... }
}
}
```

This can be combined with the `#[non_exhaustive]` attribute on the message struct
to ensure that field additions, which are backward-compatible accordingly to
the Protobuf semver convention, do not force semver breaks in a Rust crate that
provides the generated struct.

[Builders]: https://rust-lang.github.io/api-guidelines/type-safety.html#c-builder

### Services

`prost-build` allows a custom code-generator to be used for processing `service`
Expand Down

0 comments on commit eab10f7

Please sign in to comment.