diff options
author | Kirill Chibisov <contact@kchibisov.com> | 2020-05-14 04:25:11 +0300 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-05-14 04:25:11 +0300 |
commit | 7ae701d57b10c07dda1a83a6d6b252c0af8785cb (patch) | |
tree | 9af22a6a09024de24b7ce23f61cade7e76533c2a /font/src/ft/fc/pattern.rs | |
parent | b656fba35ed12b776e8204115a6c6de76eda0a3b (diff) | |
download | alacritty-7ae701d57b10c07dda1a83a6d6b252c0af8785cb.tar.gz alacritty-7ae701d57b10c07dda1a83a6d6b252c0af8785cb.zip |
Add support for Fontconfig embolden and matrix options
Fixes #1754.
Diffstat (limited to 'font/src/ft/fc/pattern.rs')
-rw-r--r-- | font/src/ft/fc/pattern.rs | 28 |
1 files changed, 26 insertions, 2 deletions
diff --git a/font/src/ft/fc/pattern.rs b/font/src/ft/fc/pattern.rs index f40cc9c9..da459b6d 100644 --- a/font/src/ft/fc/pattern.rs +++ b/font/src/ft/fc/pattern.rs @@ -21,10 +21,14 @@ use std::str; use foreign_types::{foreign_type, ForeignType, ForeignTypeRef}; use libc::{c_char, c_double, c_int}; +use super::ffi::FcMatrix; use super::ffi::FcResultMatch; use super::ffi::{FcBool, FcFontRenderPrepare, FcPatternGetBool, FcPatternGetDouble}; use super::ffi::{FcChar8, FcConfigSubstitute, FcDefaultSubstitute, FcPattern, FcPatternHash}; -use super::ffi::{FcPatternAddCharSet, FcPatternDestroy, FcPatternDuplicate, FcPatternGetCharSet}; +use super::ffi::{ + FcPatternAddCharSet, FcPatternDestroy, FcPatternDuplicate, FcPatternGetCharSet, + FcPatternGetMatrix, +}; use super::ffi::{FcPatternAddDouble, FcPatternAddString, FcPatternCreate, FcPatternGetString}; use super::ffi::{FcPatternAddInteger, FcPatternGetInteger, FcPatternPrint}; @@ -572,9 +576,10 @@ impl PatternRef { } } + /// Get charset from the pattern. pub fn get_charset(&self) -> Option<&CharSetRef> { unsafe { - let mut charset: *mut _ = ptr::null_mut(); + let mut charset = ptr::null_mut(); let result = FcPatternGetCharSet( self.as_ptr(), @@ -591,6 +596,25 @@ impl PatternRef { } } + /// Get matrix from the pattern. + pub fn get_matrix(&self) -> Option<FcMatrix> { + unsafe { + let mut matrix = ptr::null_mut(); + let result = FcPatternGetMatrix( + self.as_ptr(), + b"matrix\0".as_ptr() as *mut c_char, + 0, + &mut matrix, + ); + + if result == FcResultMatch { + Some(*matrix) + } else { + None + } + } + } + pub fn file(&self, index: usize) -> Option<PathBuf> { unsafe { self.get_string(b"file\0").nth(index) }.map(From::from) } |