pub struct GvdbHashTableBuilder<'a> { /* private fields */ }
Expand description

Create hash tables for use in GVDB files

§Example

use glib::prelude::*;
use gvdb::write::{GvdbFileWriter, GvdbHashTableBuilder};

let file_writer = GvdbFileWriter::new();
let mut table_builder = GvdbHashTableBuilder::new();
table_builder
    .insert_string("string", "test string")
    .unwrap();
let gvdb_data = file_writer.write_to_vec_with_table(table_builder).unwrap();

Implementations§

source§

impl<'a> GvdbHashTableBuilder<'a>

source

pub fn new() -> Self

Create a new empty GvdbHashTableBuilder with the default path separator /

let mut table_builder = GvdbHashTableBuilder::new();
source

pub fn with_path_separator(sep: Option<&str>) -> Self

Create a new empty GvdbHashTableBuilder a different path separator than / or none at all

let mut table_builder = GvdbHashTableBuilder::with_path_separator(Some(":"));
source

pub fn insert_value( &mut self, key: &(impl ToString + ?Sized), value: Value<'a> ) -> GvdbBuilderResult<()>

Insert Value item for key

use zvariant::Value;
let mut table_builder = gvdb::write::GvdbHashTableBuilder::new();
let variant = Value::new(123u32);
table_builder.insert_value("variant_123", variant);
source

pub fn insert<T>( &mut self, key: &(impl ToString + ?Sized), value: T ) -> GvdbBuilderResult<()>
where T: Into<Value<'a>> + ?Sized,

Insert item for key where item needs to be Into<zvariant::Value>

use zvariant::Value;
let mut table_builder = gvdb::write::GvdbHashTableBuilder::new();
let value = 123u32;
table_builder.insert("variant_123", value);
source

pub fn insert_gvariant( &mut self, key: &(impl ToString + ?Sized), variant: Variant ) -> GvdbBuilderResult<()>

Insert GVariant item for key

let mut table_builder = gvdb::write::GvdbHashTableBuilder::new();
let variant = 123u32.to_variant();
table_builder.insert_gvariant("variant_123", variant);
source

pub fn insert_string( &mut self, key: &(impl ToString + ?Sized), string: &(impl ToString + ?Sized) ) -> GvdbBuilderResult<()>

Convenience method to create a string type GVariant for value and insert it at key

table_builder.insert_string("string_key", "string_data");
source

pub fn insert_bytes( &mut self, key: &(impl ToString + ?Sized), bytes: &'a [u8] ) -> GvdbBuilderResult<()>

Convenience method to create a byte type GVariant for value and insert it at key

table_builder.insert_bytes("bytes", &[1, 2, 3, 4, 5]);
source

pub fn insert_table( &mut self, key: &(impl ToString + ?Sized), table_builder: GvdbHashTableBuilder<'a> ) -> GvdbBuilderResult<()>

Insert an entire hash table at key.

let mut table_builder = GvdbHashTableBuilder::new();
let mut table_builder_2 = GvdbHashTableBuilder::new();
table_builder_2
    .insert_value("int", Value::new(42u32))
    .unwrap();

table_builder
    .insert_table("table", table_builder_2)
    .unwrap();
source

pub fn len(&self) -> usize

The number of items contained in the hash table builder

source

pub fn is_empty(&self) -> bool

Whether the hash table builder contains no items

Trait Implementations§

source§

impl<'a> Debug for GvdbHashTableBuilder<'a>

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl<'a> Default for GvdbHashTableBuilder<'a>

source§

fn default() -> Self

Returns the “default value” for a type. Read more

Auto Trait Implementations§

Blanket Implementations§

source§

impl<T> Any for T
where T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for T
where T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for T
where U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<T> NoneValue for T
where T: Default,

§

type NoneType = T

source§

fn null_value() -> T

The none-equivalent value.
source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.