Struct fea_rs::compile::Compiler

source ·
pub struct Compiler<'a> { /* private fields */ }
Expand description

A builder-style entry point for the compiler.

This is intended as the principal public API for this crate.

let glyph_map = make_glyph_map();
let my_font_bytes = Compiler::new("path/to/features.fea", &glyph_map)
    .verbose(true)
    .compile_binary().unwrap();

Implementations§

source§

impl<'a> Compiler<'a>

source

pub fn new(root_path: impl Into<OsString>, glyph_map: &'a GlyphMap) -> Self

Configure a new compilation run with a root source and a glyph map.

In the general case, root_path will be a path to a feature file on disk; however you may compile from memory by passing a custom SourceResolver to the with_resolver method, in which case root_path can be any identifier that your resolver will resolve.

source

pub fn with_resolver(self, resolver: impl SourceResolver + 'static) -> Self

Provide a custom SourceResolver, for mapping paths to their contents.

source

pub fn with_variable_info(self, var_info: &'a dyn VariationInfo) -> Self

Provide VariationInfo, necessary when compiling features for a variable font.

source

pub fn verbose(self, verbose: bool) -> Self

👎Deprecated since 0.14.1: use print_warnings method instead

Specify verbosity.

When verbose is true, we will print all warnings.

source

pub fn print_warnings(self, warnings: bool) -> Self

Indicate whether or not warnings should be printed (default is true)

source

pub fn max_error_messages(self, max_n_errors: usize) -> Self

Specify a maximum number of messages to print when errors occur.

Default is some arbitrary ‘reasonable’ number (currently 100.) To suppress errors, pass 0. To print all errors, pass a number as large as the number of errors you intend to write.

source

pub fn with_project_root(self, project_root: impl Into<PathBuf>) -> Self

Specify an explicit project root.

This is useful in cases where import resolution is based on an explicit base directory, such as when dealing with certain source formats.

source

pub fn with_opts(self, opts: Opts) -> Self

Specify additional compiler options.

source

pub fn compile(self) -> Result<Compilation, CompilerError>

Parse, validate and compile this source.

This returns a Compilation object that contains all of the features and lookups generated during compilation. If you would like to go directly to a binary font, you can use compile_binary instead.

source

pub fn compile_binary(self) -> Result<Vec<u8>, CompilerError>

Compile to a binary font.

Auto Trait Implementations§

§

impl<'a> !RefUnwindSafe for Compiler<'a>

§

impl<'a> !Send for Compiler<'a>

§

impl<'a> !Sync for Compiler<'a>

§

impl<'a> Unpin for Compiler<'a>

§

impl<'a> !UnwindSafe for Compiler<'a>

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<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<U, T> ToOwnedObj<U> for Twhere U: FromObjRef<T>,

source§

fn to_owned_obj(&self, data: FontData<'_>) -> U

Convert this type into T, using the provided data to resolve any offsets.
source§

impl<U, T> ToOwnedTable<U> for Twhere U: FromTableRef<T>,

source§

fn to_owned_table(&self) -> U

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.