manifest::v2

Struct FontFamilyAliasSet

Source
pub struct FontFamilyAliasSet { /* private fields */ }
Expand description

Represents a set of font family aliases, and optionally, typeface properties that should be applied when treating those aliases as the canonical family.

For example, the font family "Roboto" might have one alias set of the form:

{
  "names": [ "Roboto Condensed" ],
  "width": "condensed"
}

This means that when a client requests the family "Roboto Condensed", the font server will treat that as a request for "Roboto" with Width::Condensed.

The font family "Noto Sans CJK" might have aliases of the form:

[
  {
    "names": [ "Noto Sans CJK KR", "Noto Sans KR" ],
    "languages": [ "ko" ]
  },
  {
    "names": [ "Noto Sans CJK JP", "Noto Sans JP" ],
    "languages: [ "ja" ]
  }
]

When a client requests "Noto Sans CJK JP" or "Noto Sans JP", the font server will look under "Noto Sans CJK" for typefaces that support Japanese ("ja").

Create using FontFamilyAliasSet::new if the aliases will map to typeface property overrides, or FontFamilyAliasSet::without_overrides to create a plain set of aliases.

When loaded by the font server, a FontFamilyAliasSet is expanded over all the names, creating an alias entry for every name, with identical style and languages values.

Implementations§

Source§

impl FontFamilyAliasSet

Source

pub fn new( names: impl IntoIterator<Item = impl AsRef<str>>, style: impl Into<StyleOptions>, languages: impl IntoIterator<Item = impl AsRef<str>>, ) -> Result<Self, Error>

Create a new FontFamilyAliasSet with one or more names, and with optional style and language overrides.

  • names: A list of one more alias names
  • style: Optionally, style overrides that are automatically applied to the typeface request when one of the names is requested.
  • languages: Optionally, a list of language codes that is automatically applied to the typeface request when one of the names is requested. Do not sort the language codes. They are given in priority order, just as in TypefaceQuery.languages.

Examples:

use manifest::v2::FontFamilyAliasSet;
use manifest::serde_ext::StyleOptions;

// Alias set for "Noto Sans CJK" for Traditional Chinese. Both `"Noto Sans CJK TC"` and
// `"Noto Sans TC"` will serve as aliases that apply the languages `["zh-Hant", "zh-Bopo"]`
// when requested.
FontFamilyAliasSet::new(
    vec!["Noto Sans CJK TC", "Noto Sans TC"],
    StyleOptions::default(),
    vec!["zh-Hant", "zh-Bopo"]);

// Alias set for "Roboto Condensed". `"Roboto Condensed"` will serve as an alias that
// applies the style options `width: condensed` when requested.
FontFamilyAliasSet::new(
    vec!["Roboto Condensed"],
    StyleOptions {
        width: Some(fidl_fuchsia_fonts::Width::Condensed),
        ..Default::default()
    },
    vec![]);
Source

pub fn without_overrides( names: impl IntoIterator<Item = impl AsRef<str>>, ) -> Result<Self, Error>

Create a new FontFamilyAliasSet with one or more names, with no typeface property overrides.

Source

pub fn names(&self) -> impl Iterator<Item = &String>

Gets the alias names in this set.

Source

pub fn style_overrides(&self) -> &StyleOptions

Gets the style property overrides for this set of aliases (may be empty).

Source

pub fn language_overrides(&self) -> impl Iterator<Item = &String>

Gets the language code overrides for this set of aliases (may be empty).

Source

pub fn has_overrides(&self) -> bool

Whether the alias set has any property overrides. If false, it’s just a name alias.

Source

pub fn has_style_overrides(&self) -> bool

Whether the alias set has style overrides.

Source

pub fn has_language_overrides(&self) -> bool

Whether the alias set has language overrides.

Trait Implementations§

Source§

impl Clone for FontFamilyAliasSet

Source§

fn clone(&self) -> FontFamilyAliasSet

Returns a copy of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for FontFamilyAliasSet

Source§

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

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

impl<'de> Deserialize<'de> for FontFamilyAliasSet

Source§

fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>
where __D: Deserializer<'de>,

Deserialize this value from the given Serde deserializer. Read more
Source§

impl Hash for FontFamilyAliasSet

Source§

fn hash<__H: Hasher>(&self, state: &mut __H)

Feeds this value into the given Hasher. Read more
1.3.0 · Source§

fn hash_slice<H>(data: &[Self], state: &mut H)
where H: Hasher, Self: Sized,

Feeds a slice of this type into the given Hasher. Read more
Source§

impl PartialEq for FontFamilyAliasSet

Source§

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

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

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

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl Serialize for FontFamilyAliasSet

Source§

fn serialize<__S>(&self, __serializer: __S) -> Result<__S::Ok, __S::Error>
where __S: Serializer,

Serialize this value into the given Serde serializer. Read more
Source§

impl Eq for FontFamilyAliasSet

Source§

impl StructuralPartialEq for FontFamilyAliasSet

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> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dst: *mut T)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. Read more
§

impl<T, D> Encode<Ambiguous1, D> for T
where D: ResourceDialect,

§

unsafe fn encode( self, _encoder: &mut Encoder<'_, D>, _offset: usize, _depth: Depth, ) -> Result<(), Error>

Encodes the object into the encoder’s buffers. Any handles stored in the object are swapped for Handle::INVALID. Read more
§

impl<T, D> Encode<Ambiguous2, D> for T
where D: ResourceDialect,

§

unsafe fn encode( self, _encoder: &mut Encoder<'_, D>, _offset: usize, _depth: Depth, ) -> Result<(), Error>

Encodes the object into the encoder’s buffers. Any handles stored in the object are swapped for Handle::INVALID. 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.

§

impl<T> Pointable for T

§

const ALIGN: usize = _

The alignment of pointer.
§

type Init = T

The type for initializers.
§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

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

Source§

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>,

Source§

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.
§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

§

fn vzip(self) -> V

Source§

impl<T> DeserializeOwned for T
where T: for<'de> Deserialize<'de>,