1
  2
  3
  4
  5
  6
  7
  8
  9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
//! # tree2svg
//!
//! `tree2svg` Read a phylogentic trees in newick, phyloxml or recPhyloXML format and create a svg.

// Pour la doc et pour facilier l'usage par les utilisateurs du module:

mod arena;
pub use self::arena::Options;
pub use self::arena::Event;
pub use self::arena::Noeud;
pub use self::arena::ArenaTree;
pub use self::arena::check_for_obsolete;
pub use self::arena::newick2tree;
pub use self::arena::xml2tree;
pub use self::arena::real_length;
pub use self::arena::find_sptree;
pub use self::arena::find_rgtrees;
pub use self::arena::map_gene_trees;
pub use self::arena::map_species_trees;
pub use self::arena::bilan_mappings;
pub use self::arena::move_dupli_mappings;
pub use self::arena::center_gene_nodes;
pub use self::arena::set_species_width;
pub use self::arena::knuth_layout;
pub use self::arena::cladogramme;
pub use self::arena::check_contour_postorder;
pub use self::arena::check_vertical_contour_postorder;
pub use self::arena::push_right;
pub use self::arena::push_down;
pub use self::arena::node_xpos;
pub use self::arena::node_ypos;
pub use self::arena::get_contour_left;
pub use self::arena::get_contour_right;
pub use self::arena::shift_mod_xy;
pub use self::arena::set_middle_postorder;

mod drawing;
pub use self::drawing::draw_tree;
pub use self::drawing::draw_sptree_gntrees;
pub use self::drawing::get_carre;
pub use self::drawing::get_circle;
pub use self::drawing::get_cross;
pub use self::drawing::get_chemin_carre;
pub use self::drawing::get_chemin_sp;
pub use self::drawing::close_chemin_sp;


#[cfg(test)]
mod tests {
    use super::*;

    #[test]
    fn  check_val() {
        let mut tree: ArenaTree<String> = ArenaTree::default();
        let test = String::from("Test");
        let copy = test.clone();
        let index = tree.new_node(test);
        let mut node = &mut tree.arena[index];
        let val = node.get_val();
        assert_eq!(*val,copy);
    }

    #[test]
    fn  check_event() {
        let mut tree: ArenaTree<String> = ArenaTree::default();
        let test = String::from("Test");
        let copy = test.clone();
        let index = tree.new_node(test);
        let mut node = &mut tree.arena[index];
        node.set_event(Event::Undef);
        let event = node.get_event();
        assert_eq!(*event,Event::Undef);
    }
    #[test]
    fn  check_coords_noref() {
        let mut tree: ArenaTree<String> = ArenaTree::default();
        let test = String::from("Test");
        let copy = test.clone();
        let index = tree.new_node(test);
        let mut node = &mut tree.arena[index];
        node.set_x_noref(10.0);
        node.set_y_noref(20.0);
        let (x,y) = node.get_coords();
        assert_eq!((*x,*y),(10.0,20.0));
    }
    #[test]
    fn  check_coords() {
        let mut tree: ArenaTree<String> = ArenaTree::default();
        let test = String::from("Test");
        let copy = test.clone();
        let index = tree.new_node(test);
        let mut node = &mut tree.arena[index];
        node.set_x(&10.0);
        node.set_y(&20.0);
        let coords = node.get_coords();

        assert_eq!(coords,(&10.0,&20.0));
    }
    #[test]
    fn  check_x_noref() {
        let mut tree: ArenaTree<String> = ArenaTree::default();
        let test = String::from("Test");
        let copy = test.clone();
        let index = tree.new_node(test);
        let mut node = &mut tree.arena[index];
        node.set_x_noref(10.0);
        let x = node.get_x();
        assert_eq!(*x, 10.0);
    }
    #[test]
    fn  check_x() {
        let mut tree: ArenaTree<String> = ArenaTree::default();
        let test = String::from("Test");
        let copy = test.clone();
        let index = tree.new_node(test);
        let mut node = &mut tree.arena[index];
        node.set_x(&10.0);
        let x = node.get_x();
        assert_eq!(*x, 10.0);
    }




}