Skip to content

Commit a125197

Browse files
committed
feat: make DynamicMessage public
1 parent a542121 commit a125197

File tree

2 files changed

+14
-3
lines changed

2 files changed

+14
-3
lines changed

protobuf/src/reflect/dynamic/mod.rs

Lines changed: 13 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -1,3 +1,9 @@
1+
//! This module contains dynamic reflection.
2+
//!
3+
//! It is used for dynamically getting fields' values.
4+
5+
#![doc(hidden)]
6+
17
use std::any::Any;
28
use std::any::TypeId;
39
use std::fmt;
@@ -95,8 +101,11 @@ impl DynamicFieldValue {
95101
}
96102
}
97103

104+
/// Structure used for dynamic reflection.
105+
///
106+
/// It is mostly used for dynamically getting fields' values.
98107
#[derive(Debug, Clone)]
99-
pub(crate) struct DynamicMessage {
108+
pub struct DynamicMessage {
100109
descriptor: MessageDescriptor,
101110
/// Fields by index in the description.
102111
/// This field is lazy-init: it is empty when created.
@@ -127,7 +136,8 @@ impl DynamicMessage {
127136
}
128137
}
129138

130-
pub(crate) fn get_reflect<'a>(&'a self, field: &FieldDescriptor) -> ReflectFieldRef<'a> {
139+
/// Get a field reference for a field descriptor.
140+
pub fn get_reflect<'a>(&'a self, field: &FieldDescriptor) -> ReflectFieldRef<'a> {
131141
let (descriptor, index) = field.regular();
132142
assert_eq!(self.descriptor, descriptor);
133143
if self.fields.is_empty() {
@@ -137,6 +147,7 @@ impl DynamicMessage {
137147
}
138148
}
139149

150+
/// Clear a field.
140151
pub fn clear_field(&mut self, field: &FieldDescriptor) {
141152
let (descriptor, index) = field.regular();
142153
assert_eq!(self.descriptor, descriptor);

protobuf/src/reflect/mod.rs

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -14,7 +14,7 @@
1414
//! Some minor adjustements are made to make code more idiomatic to rust.
1515
1616
mod acc;
17-
mod dynamic;
17+
pub mod dynamic;
1818
mod enums;
1919
pub(crate) mod error;
2020
mod field;

0 commit comments

Comments
 (0)