aboutsummaryrefslogtreecommitdiffstats
path: root/components/gfx/platform/macos
diff options
context:
space:
mode:
authorLinus Färnstrand <faern@faern.net>2018-01-29 10:11:45 +0100
committerLinus Färnstrand <faern@faern.net>2018-01-29 10:21:44 +0100
commitc23534ce498241fd02b3bfb5a796578a70d69028 (patch)
tree2087375328b3c54206d4e43574084003c2183fb5 /components/gfx/platform/macos
parentfc7e88611e5f21ee568c548688a639097cfdc3eb (diff)
downloadservo-c23534ce498241fd02b3bfb5a796578a70d69028.tar.gz
servo-c23534ce498241fd02b3bfb5a796578a70d69028.zip
Use new CFArray iterator features
Diffstat (limited to 'components/gfx/platform/macos')
-rw-r--r--components/gfx/platform/macos/font_list.rs18
1 files changed, 4 insertions, 14 deletions
diff --git a/components/gfx/platform/macos/font_list.rs b/components/gfx/platform/macos/font_list.rs
index ed3858a8466..d72111f9c1e 100644
--- a/components/gfx/platform/macos/font_list.rs
+++ b/components/gfx/platform/macos/font_list.rs
@@ -2,20 +2,13 @@
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
-use core_foundation::base::TCFType;
-use core_foundation::string::{CFString, CFStringRef};
use core_text;
-use core_text::font_descriptor::{CTFontDescriptor, CTFontDescriptorRef};
use std::borrow::ToOwned;
-use std::mem;
pub fn for_each_available_family<F>(mut callback: F) where F: FnMut(String) {
let family_names = core_text::font_collection::get_family_names();
- for strref in family_names.iter() {
- let family_name_ref: CFStringRef = unsafe { mem::transmute(strref) };
- let family_name_cf: CFString = unsafe { TCFType::wrap_under_get_rule(family_name_ref) };
- let family_name = family_name_cf.to_string();
- callback(family_name);
+ for family_name in family_names.iter() {
+ callback(family_name.to_string());
}
}
@@ -25,11 +18,8 @@ pub fn for_each_variation<F>(family_name: &str, mut callback: F) where F: FnMut(
let family_collection = core_text::font_collection::create_for_family(family_name);
if let Some(family_collection) = family_collection {
let family_descriptors = family_collection.get_descriptors();
- for descref in family_descriptors.iter() {
- let descref: CTFontDescriptorRef = unsafe { mem::transmute(descref) };
- let desc: CTFontDescriptor = unsafe { TCFType::wrap_under_get_rule(descref) };
- let postscript_name = desc.font_name();
- callback(postscript_name);
+ for family_descriptor in family_descriptors.iter() {
+ callback(family_descriptor.font_name());
}
}
}