use glib::translate::*;
use std::{ffi::c_char, ptr};
#[cfg(feature = "v1_44")]
use crate::ShapeFlags;
pub use crate::auto::functions::*;
use crate::{Analysis, AttrIterator, AttrList, Context, Direction, GlyphString, Item, ffi};
#[doc(alias = "pango_reorder_items")]
pub fn reorder_items(logical_items: &glib::List<Item>) -> glib::List<Item> {
unsafe {
FromGlibPtrContainer::from_glib_full(ffi::pango_reorder_items(
logical_items.as_ptr() as *mut _
))
}
}
#[doc(alias = "pango_shape_full")]
pub fn shape_full(
item_text: &str,
paragraph_text: Option<&str>,
analysis: &Analysis,
glyphs: &mut GlyphString,
) {
let item_length = item_text.len() as i32;
let paragraph_length = paragraph_text.map(|t| t.len() as i32).unwrap_or_default();
let paragraph_ptr = paragraph_text.map_or(ptr::null(), |t| t.as_ptr() as *const c_char);
unsafe {
ffi::pango_shape_full(
item_text.as_ptr() as *const c_char,
item_length,
paragraph_ptr,
paragraph_length,
analysis.to_glib_none().0,
glyphs.to_glib_none_mut().0,
);
}
}
#[doc(alias = "pango_shape")]
pub fn shape(item_text: &str, analysis: &Analysis, glyphs: &mut GlyphString) {
let item_length = item_text.len() as i32;
unsafe {
ffi::pango_shape(
item_text.as_ptr() as *const c_char,
item_length,
analysis.to_glib_none().0,
glyphs.to_glib_none_mut().0,
);
}
}
#[cfg(feature = "v1_44")]
#[cfg_attr(docsrs, doc(cfg(feature = "v1_44")))]
#[doc(alias = "pango_shape_with_flags")]
pub fn shape_with_flags(
item_text: &str,
paragraph_text: Option<&str>,
analysis: &Analysis,
glyphs: &mut GlyphString,
flags: ShapeFlags,
) {
let item_length = item_text.len() as i32;
let paragraph_length = paragraph_text.map(|t| t.len() as i32).unwrap_or_default();
let paragraph_ptr = paragraph_text.map_or(ptr::null(), |t| t.as_ptr() as *const c_char);
unsafe {
ffi::pango_shape_with_flags(
item_text.as_ptr() as *const c_char,
item_length,
paragraph_ptr,
paragraph_length,
analysis.to_glib_none().0,
glyphs.to_glib_none_mut().0,
flags.into_glib(),
);
}
}
#[doc(alias = "pango_extents_to_pixels")]
pub fn extents_to_pixels(
mut inclusive: Option<&mut crate::Rectangle>,
mut nearest: Option<&mut crate::Rectangle>,
) {
unsafe {
ffi::pango_extents_to_pixels(inclusive.to_glib_none_mut().0, nearest.to_glib_none_mut().0);
}
}
#[doc(alias = "pango_itemize")]
pub fn itemize(
context: &Context,
text: &str,
start_index: i32,
length: i32,
attrs: &AttrList,
cached_iter: Option<&AttrIterator>,
) -> Vec<Item> {
let total_length = text.len() as i32;
assert!(
start_index >= 0 && start_index < total_length,
"start_index is out of range"
);
assert!(
length >= 0 && start_index.checked_add(length).unwrap() <= total_length,
"start_index + length is out of range"
);
unsafe {
FromGlibPtrContainer::from_glib_full(ffi::pango_itemize(
context.to_glib_none().0,
text.to_glib_none().0,
start_index,
length,
attrs.to_glib_none().0,
mut_override(cached_iter.to_glib_none().0),
))
}
}
#[doc(alias = "pango_itemize_with_base_dir")]
pub fn itemize_with_base_dir(
context: &Context,
base_dir: Direction,
text: &str,
start_index: i32,
length: i32,
attrs: &AttrList,
cached_iter: Option<&AttrIterator>,
) -> Vec<Item> {
let total_length = text.len() as i32;
assert!(
start_index >= 0 && start_index < total_length,
"start_index is out of range"
);
assert!(
length >= 0 && start_index.checked_add(length).unwrap() <= total_length,
"start_index + length is out of range"
);
unsafe {
FromGlibPtrContainer::from_glib_full(ffi::pango_itemize_with_base_dir(
context.to_glib_none().0,
base_dir.into_glib(),
text.to_glib_none().0,
start_index,
length,
attrs.to_glib_none().0,
mut_override(cached_iter.to_glib_none().0),
))
}
}