use Buildable;
use TreeDragDest;
use TreeDragSource;
use TreeIter;
use TreeModel;
use TreeSortable;
use ffi;
use glib::object::IsA;
use glib::translate::*;
use std::fmt;
glib_wrapper! {
pub struct TreeStore(Object<ffi::GtkTreeStore, ffi::GtkTreeStoreClass, TreeStoreClass>) @implements Buildable, TreeDragDest, TreeDragSource, TreeModel, TreeSortable;
match fn {
get_type => || ffi::gtk_tree_store_get_type(),
}
}
impl TreeStore {
}
pub const NONE_TREE_STORE: Option<&TreeStore> = None;
pub trait TreeStoreExt: 'static {
fn append<'a, P: Into<Option<&'a TreeIter>>>(&self, parent: P) -> TreeIter;
fn clear(&self);
fn insert<'a, P: Into<Option<&'a TreeIter>>>(&self, parent: P, position: i32) -> TreeIter;
fn insert_after<'a, 'b, P: Into<Option<&'a TreeIter>>, Q: Into<Option<&'b TreeIter>>>(&self, parent: P, sibling: Q) -> TreeIter;
fn insert_before<'a, 'b, P: Into<Option<&'a TreeIter>>, Q: Into<Option<&'b TreeIter>>>(&self, parent: P, sibling: Q) -> TreeIter;
fn is_ancestor(&self, iter: &TreeIter, descendant: &TreeIter) -> bool;
fn iter_depth(&self, iter: &TreeIter) -> i32;
fn iter_is_valid(&self, iter: &TreeIter) -> bool;
fn move_after<'a, P: Into<Option<&'a TreeIter>>>(&self, iter: &TreeIter, position: P);
fn move_before<'a, P: Into<Option<&'a TreeIter>>>(&self, iter: &TreeIter, position: P);
fn prepend<'a, P: Into<Option<&'a TreeIter>>>(&self, parent: P) -> TreeIter;
fn remove(&self, iter: &TreeIter) -> bool;
fn swap(&self, a: &TreeIter, b: &TreeIter);
}
impl<O: IsA<TreeStore>> TreeStoreExt for O {
fn append<'a, P: Into<Option<&'a TreeIter>>>(&self, parent: P) -> TreeIter {
let parent = parent.into();
unsafe {
let mut iter = TreeIter::uninitialized();
ffi::gtk_tree_store_append(self.as_ref().to_glib_none().0, iter.to_glib_none_mut().0, mut_override(parent.to_glib_none().0));
iter
}
}
fn clear(&self) {
unsafe {
ffi::gtk_tree_store_clear(self.as_ref().to_glib_none().0);
}
}
fn insert<'a, P: Into<Option<&'a TreeIter>>>(&self, parent: P, position: i32) -> TreeIter {
let parent = parent.into();
unsafe {
let mut iter = TreeIter::uninitialized();
ffi::gtk_tree_store_insert(self.as_ref().to_glib_none().0, iter.to_glib_none_mut().0, mut_override(parent.to_glib_none().0), position);
iter
}
}
fn insert_after<'a, 'b, P: Into<Option<&'a TreeIter>>, Q: Into<Option<&'b TreeIter>>>(&self, parent: P, sibling: Q) -> TreeIter {
let parent = parent.into();
let sibling = sibling.into();
unsafe {
let mut iter = TreeIter::uninitialized();
ffi::gtk_tree_store_insert_after(self.as_ref().to_glib_none().0, iter.to_glib_none_mut().0, mut_override(parent.to_glib_none().0), mut_override(sibling.to_glib_none().0));
iter
}
}
fn insert_before<'a, 'b, P: Into<Option<&'a TreeIter>>, Q: Into<Option<&'b TreeIter>>>(&self, parent: P, sibling: Q) -> TreeIter {
let parent = parent.into();
let sibling = sibling.into();
unsafe {
let mut iter = TreeIter::uninitialized();
ffi::gtk_tree_store_insert_before(self.as_ref().to_glib_none().0, iter.to_glib_none_mut().0, mut_override(parent.to_glib_none().0), mut_override(sibling.to_glib_none().0));
iter
}
}
fn is_ancestor(&self, iter: &TreeIter, descendant: &TreeIter) -> bool {
unsafe {
from_glib(ffi::gtk_tree_store_is_ancestor(self.as_ref().to_glib_none().0, mut_override(iter.to_glib_none().0), mut_override(descendant.to_glib_none().0)))
}
}
fn iter_depth(&self, iter: &TreeIter) -> i32 {
unsafe {
ffi::gtk_tree_store_iter_depth(self.as_ref().to_glib_none().0, mut_override(iter.to_glib_none().0))
}
}
fn iter_is_valid(&self, iter: &TreeIter) -> bool {
unsafe {
from_glib(ffi::gtk_tree_store_iter_is_valid(self.as_ref().to_glib_none().0, mut_override(iter.to_glib_none().0)))
}
}
fn move_after<'a, P: Into<Option<&'a TreeIter>>>(&self, iter: &TreeIter, position: P) {
let position = position.into();
unsafe {
ffi::gtk_tree_store_move_after(self.as_ref().to_glib_none().0, mut_override(iter.to_glib_none().0), mut_override(position.to_glib_none().0));
}
}
fn move_before<'a, P: Into<Option<&'a TreeIter>>>(&self, iter: &TreeIter, position: P) {
let position = position.into();
unsafe {
ffi::gtk_tree_store_move_before(self.as_ref().to_glib_none().0, mut_override(iter.to_glib_none().0), mut_override(position.to_glib_none().0));
}
}
fn prepend<'a, P: Into<Option<&'a TreeIter>>>(&self, parent: P) -> TreeIter {
let parent = parent.into();
unsafe {
let mut iter = TreeIter::uninitialized();
ffi::gtk_tree_store_prepend(self.as_ref().to_glib_none().0, iter.to_glib_none_mut().0, mut_override(parent.to_glib_none().0));
iter
}
}
fn remove(&self, iter: &TreeIter) -> bool {
unsafe {
from_glib(ffi::gtk_tree_store_remove(self.as_ref().to_glib_none().0, mut_override(iter.to_glib_none().0)))
}
}
fn swap(&self, a: &TreeIter, b: &TreeIter) {
unsafe {
ffi::gtk_tree_store_swap(self.as_ref().to_glib_none().0, mut_override(a.to_glib_none().0), mut_override(b.to_glib_none().0));
}
}
}
impl fmt::Display for TreeStore {
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
write!(f, "TreeStore")
}
}