pub struct TextPropertyEntry {
pub text: String,
pub properties: HashMap<String, Value>,
pub style: Option<OverlayOptions>,
pub inline_overlays: Vec<InlineOverlay>,
pub segments: Vec<StyledSegment>,
pub pad_to_chars: Option<u32>,
pub truncate_to_chars: Option<u32>,
}Expand description
An entry with text and its properties
Fields§
§text: StringThe text content. When segments is non-empty text is
rebuilt from concatenating segment text during
normalize_widths and any value supplied here is replaced.
properties: HashMap<String, Value>Properties for this text
style: Option<OverlayOptions>Optional whole-entry styling
inline_overlays: Vec<InlineOverlay>Optional sub-range styling within this entry
segments: Vec<StyledSegment>Optional segment list. When non-empty the host concatenates
segment text into text and pushes one InlineOverlay
(in Char units) per styled segment plus the segment’s
nested overlays shifted by its position. Resolved before
truncate/pad/char-byte conversion in normalize_widths.
pad_to_chars: Option<u32>Pad text with spaces to this many display columns
(Unicode codepoints). No-op when text already has at
least this many codepoints. Applied before overlays are
resolved.
truncate_to_chars: Option<u32>Truncate text to at most this many display columns
(Unicode codepoints). When the budget is greater than
3 the truncated tail is replaced with ...; when it is
3 or less the text is cut at exactly the budget. Applied
before overlays are resolved.
Implementations§
Source§impl TextPropertyEntry
impl TextPropertyEntry
Sourcepub fn normalize_widths(&mut self)
pub fn normalize_widths(&mut self)
Resolve segments (if any) into text plus inline overlays,
then apply truncate_to_chars, then pad_to_chars, then
convert any unit: Char overlays to byte offsets against the
resulting text. Idempotent: an entry with no segments,
pad/truncate hints, or char-unit overlays is left untouched.
Truncation rounds the byte cut to a UTF-8 codepoint boundary. Char-offset overlays beyond the resulting codepoint count are clamped to that count.
Sourcepub fn with_property(self, key: impl Into<String>, value: Value) -> Self
pub fn with_property(self, key: impl Into<String>, value: Value) -> Self
Add a property
Sourcepub fn with_properties(self, props: HashMap<String, Value>) -> Self
pub fn with_properties(self, props: HashMap<String, Value>) -> Self
Set multiple properties
Sourcepub fn with_style(self, style: OverlayOptions) -> Self
pub fn with_style(self, style: OverlayOptions) -> Self
Set whole-entry styling
Sourcepub fn with_inline_overlay(
self,
start: usize,
end: usize,
style: OverlayOptions,
) -> Self
pub fn with_inline_overlay( self, start: usize, end: usize, style: OverlayOptions, ) -> Self
Add a sub-range inline overlay
Sourcepub fn with_segment(
self,
text: impl Into<String>,
style: Option<OverlayOptions>,
) -> Self
pub fn with_segment( self, text: impl Into<String>, style: Option<OverlayOptions>, ) -> Self
Push a styled segment. After normalize_widths runs, the
segment becomes part of text plus a Char-unit
InlineOverlay covering it (when style is set).
Trait Implementations§
Source§impl Clone for TextPropertyEntry
impl Clone for TextPropertyEntry
Source§fn clone(&self) -> TextPropertyEntry
fn clone(&self) -> TextPropertyEntry
1.0.0 (const: unstable) · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source. Read moreSource§impl Debug for TextPropertyEntry
impl Debug for TextPropertyEntry
Source§impl<'de> Deserialize<'de> for TextPropertyEntry
impl<'de> Deserialize<'de> for TextPropertyEntry
Source§fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
Source§impl Serialize for TextPropertyEntry
impl Serialize for TextPropertyEntry
Source§impl TS for TextPropertyEntry
impl TS for TextPropertyEntry
Source§type WithoutGenerics = TextPropertyEntry
type WithoutGenerics = TextPropertyEntry
WithoutGenerics should just be Self.
If the type does have generic parameters, then all generic parameters must be replaced with
a dummy type, e.g ts_rs::Dummy or (). The only requirement for these dummy types is that
EXPORT_TO must be None. Read moreSource§type OptionInnerType = TextPropertyEntry
type OptionInnerType = TextPropertyEntry
std::option::Option<T>, then this associated type is set to T.
All other implementations of TS should set this type to Self instead.Source§fn docs() -> Option<String>
fn docs() -> Option<String>
TS is derived, docs are
automatically read from your doc comments or #[doc = ".."] attributesSource§fn decl_concrete(cfg: &Config) -> String
fn decl_concrete(cfg: &Config) -> String
TS::decl().
If this type is not generic, then this function is equivalent to TS::decl().Source§fn decl(cfg: &Config) -> String
fn decl(cfg: &Config) -> String
type User = { user_id: number, ... }.
This function will panic if the type has no declaration. Read moreSource§fn inline(cfg: &Config) -> String
fn inline(cfg: &Config) -> String
{ user_id: number }.
This function will panic if the type cannot be inlined.Source§fn inline_flattened(cfg: &Config) -> String
fn inline_flattened(cfg: &Config) -> String
Source§fn visit_generics(v: &mut impl TypeVisitor)where
Self: 'static,
fn visit_generics(v: &mut impl TypeVisitor)where
Self: 'static,
Source§fn output_path() -> Option<PathBuf>
fn output_path() -> Option<PathBuf>
T should be exported, relative to the output directory.
The returned path does not include any base directory. Read moreSource§fn visit_dependencies(v: &mut impl TypeVisitor)where
Self: 'static,
fn visit_dependencies(v: &mut impl TypeVisitor)where
Self: 'static,
Source§fn dependencies(cfg: &Config) -> Vec<Dependency>where
Self: 'static,
fn dependencies(cfg: &Config) -> Vec<Dependency>where
Self: 'static,
Source§fn export(cfg: &Config) -> Result<(), ExportError>where
Self: 'static,
fn export(cfg: &Config) -> Result<(), ExportError>where
Self: 'static,
TS::export_all. Read moreSource§fn export_all(cfg: &Config) -> Result<(), ExportError>where
Self: 'static,
fn export_all(cfg: &Config) -> Result<(), ExportError>where
Self: 'static,
TS::export. Read more