summaryrefslogtreecommitdiff
path: root/font/src/ft/fc/pattern.rs
diff options
context:
space:
mode:
authorKirill Chibisov <contact@kchibisov.com>2020-05-14 04:25:11 +0300
committerGitHub <noreply@github.com>2020-05-14 04:25:11 +0300
commit7ae701d57b10c07dda1a83a6d6b252c0af8785cb (patch)
tree9af22a6a09024de24b7ce23f61cade7e76533c2a /font/src/ft/fc/pattern.rs
parentb656fba35ed12b776e8204115a6c6de76eda0a3b (diff)
downloadalacritty-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.rs28
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)
}