pub struct HelloWorldProvider;
Expand description

A data provider returning Hello World strings in different languages.

Mostly useful for testing.

Examples

use icu_locid::locale;
use icu_provider::hello_world::*;
use icu_provider::prelude::*;

let german_hello_world: DataPayload<HelloWorldV1Marker> =
    HelloWorldProvider
        .load(DataRequest {
            locale: &locale!("de").into(),
            metadata: Default::default(),
        })
        .expect("Loading should succeed")
        .take_payload()
        .expect("Data should be present");

assert_eq!("Hallo Welt", german_hello_world.get().message);

Load the reverse string using an auxiliary key:

use icu_provider::hello_world::*;
use icu_provider::prelude::*;

let reverse_hello_world: DataPayload<HelloWorldV1Marker> =
    HelloWorldProvider
        .load(DataRequest {
            locale: &"en-x-reverse".parse().unwrap(),
            metadata: Default::default(),
        })
        .expect("Loading should succeed")
        .take_payload()
        .expect("Data should be present");

assert_eq!("Olleh Dlrow", reverse_hello_world.get().message);

Implementations§

source§

impl HelloWorldProvider

source

const DATA: &'static [(&'static str, &'static str)] = _

Trait Implementations§

source§

impl DataProvider<HelloWorldV1Marker> for HelloWorldProvider

source§

fn load( &self, req: DataRequest<'_> ) -> Result<DataResponse<HelloWorldV1Marker>, DataError>

Query the provider for data, returning the result. Read more
source§

impl Debug for HelloWorldProvider

source§

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

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

impl Default for HelloWorldProvider

source§

fn default() -> HelloWorldProvider

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

impl DynamicDataProvider<AnyMarker> for HelloWorldProvider

source§

fn load_data( &self, key: DataKey, req: DataRequest<'_> ) -> Result<DataResponse<AnyMarker>, DataError>

Query the provider for data, returning the result. Read more
source§

impl PartialEq<HelloWorldProvider> for HelloWorldProvider

source§

fn eq(&self, other: &HelloWorldProvider) -> bool

This method tests for self and other values to be equal, and is used by ==.
1.0.0 · source§

fn ne(&self, other: &Rhs) -> bool

This method tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
source§

impl StructuralPartialEq for HelloWorldProvider

Auto Trait Implementations§

Blanket Implementations§

source§

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

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<P> AsDynamicDataProviderAnyMarkerWrap for Pwhere P: DynamicDataProvider<AnyMarker> + ?Sized,

source§

fn as_any_provider(&self) -> DynamicDataProviderAnyMarkerWrap<'_, P>

Returns an object implementing AnyProvider when called on DynamicDataProvider<AnyMarker>
source§

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

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for Twhere 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 Twhere 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, U> TryFrom<U> for Twhere 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 Twhere 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.
source§

impl<T> ErasedDestructor for Twhere T: 'static,

source§

impl<T> MaybeSendSync for T