// Copyright 2016 Joe Wilm, The Alacritty Project Contributors // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. // //! Compatibility layer for different font engines //! //! This module is developed as part of Alacritty; Alacritty does not include Windows support //! as a goal at this time, and neither does this module. //! //! CoreText is used on Mac OS. //! FreeType is used on everything that's not Mac OS. #![feature(integer_atomics)] #[cfg(not(target_os = "macos"))] extern crate fontconfig; #[cfg(not(target_os = "macos"))] extern crate freetype; #[cfg(target_os = "macos")] extern crate core_text; #[cfg(target_os = "macos")] extern crate core_foundation; #[cfg(target_os = "macos")] extern crate core_foundation_sys; #[cfg(target_os = "macos")] extern crate core_graphics; extern crate euclid; extern crate libc; use std::fmt; use std::sync::atomic::{AtomicU32, ATOMIC_U32_INIT, Ordering}; // If target isn't macos, reexport everything from ft #[cfg(not(target_os = "macos"))] mod ft; #[cfg(not(target_os = "macos"))] pub use ft::*; // If target is macos, reexport everything from darwin #[cfg(target_os = "macos")] mod darwin; #[cfg(target_os = "macos")] pub use darwin::*; #[derive(Debug, Clone, PartialEq, Eq, Hash)] pub struct FontDesc { name: String, style: String, } impl FontDesc { pub fn new(name: S, style: S) -> FontDesc where S: Into { FontDesc { name: name.into(), style: style.into() } } } /// Identifier for a Font for use in maps/etc #[derive(Debug, Clone, Copy, Hash, PartialEq, Eq)] pub struct FontKey { token: u32, } impl FontKey { /// Get next font key for given size /// /// The generated key will be globally unique pub fn next() -> FontKey { static TOKEN: AtomicU32 = ATOMIC_U32_INIT; FontKey { token: TOKEN.fetch_add(1, Ordering::SeqCst), } } } #[derive(Debug, Clone, Hash, PartialEq, Eq)] pub struct GlyphKey { pub c: char, pub font_key: FontKey, pub size: Size, } /// Font size stored as integer #[derive(Debug, Copy, Clone, Hash, PartialEq, Eq)] pub struct Size(i32); impl Size { /// Scale factor between font "Size" type and point size #[inline] pub fn factor() -> f32 { 2.0 } /// Create a new `Size` from a f32 size in points pub fn new(size: f32) -> Size { Size((size * Size::factor()) as i32) } /// Get the f32 size in points pub fn as_f32_pts(self) -> f32 { self.0 as f32 / Size::factor() } } pub struct RasterizedGlyph { pub c: char, pub width: i32, pub height: i32, pub top: i32, pub left: i32, pub buf: Vec, } struct BufDebugger<'a>(&'a [u8]); impl<'a> fmt::Debug for BufDebugger<'a> { fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result { f.debug_struct("GlyphBuffer") .field("len", &self.0.len()) .field("bytes", &self.0) .finish() } } impl fmt::Debug for RasterizedGlyph { fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result { f.debug_struct("RasterizedGlyph") .field("c", &self.c) .field("width", &self.width) .field("height", &self.height) .field("top", &self.top) .field("left", &self.left) .field("buf", &BufDebugger(&self.buf[..])) .finish() } } pub struct Metrics { pub average_advance: f64, pub line_height: f64, }