summaryrefslogtreecommitdiff
path: root/src/gtkext/graph/node-int.h
blob: dca4af5aa3f6d29924e357e357749c02c8f49412 (plain)
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

/* OpenIDA - Outil d'analyse de fichiers binaires
 * node-int.h - prototypes pour la gestion élémentaire des blocs sous forme de noeuds
 *
 * Copyright (C) 2013 Cyrille Bagard
 *
 *  This file is part of OpenIDA.
 *
 *  OpenIDA is free software; you can redistribute it and/or modify
 *  it under the terms of the GNU General Public License as published by
 *  the Free Software Foundation; either version 3 of the License, or
 *  (at your option) any later version.
 *
 *  OpenIDA is distributed in the hope that it will be useful,
 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 *  GNU General Public License for more details.
 *
 *  You should have received a copy of the GNU General Public License
 *  along with Foobar.  If not, see <http://www.gnu.org/licenses/>.
 */


#ifndef _GTKEXT_GRAPH_NODE_INT_H
#define _GTKEXT_GRAPH_NODE_INT_H


#include "node.h"



/* Fournit le rang du noeud dans le graphique. */
typedef unsigned int (* get_node_rank_fc) (const GGraphNode *);

/* Réinitialise la position d'un noeud d'encapsulation. */
typedef void (* node_set_pos_fc) (GGraphNode *, gint *, gint *);

/* Réinitialise la position d'un noeud d'encapsulation. */
typedef void (* node_reset_pos_fc) (GGraphNode *);

/* Altère la position du noeud d'encapsulation. */
typedef void (* node_set_pos_fc) (GGraphNode *, gint *, gint *);

/* Fournit la position du noeud d'encapsulation. */
typedef void (* node_get_pos_fc) (const GGraphNode *, gint *, gint *);

/* Indique l'espace requis pour un noeud d'encapsulation. */
typedef GtkAllocation (* node_get_alloc_fc) (const GGraphNode *);

/* Parcourt tous les noeuds graphiques dans un ordre donné. */
typedef bool (* visit_flow_nodes_fc) (GGraphNode *, graph_node_visitor_cb, void *);

/* Recherche le noeud contenant un autre noeud. */
typedef GGraphNode * (* find_container_fc) (GGraphNode *, GGraphNode *);


/* Intermédiaire entre le noeud dot et la bribe de code (instance) */
struct _GGraphNode
{
    GObject parent;                         /* A laisser en premier        */

    get_node_rank_fc get_rank;              /* Premier rang d'appartenance */
    node_reset_pos_fc reset_pos;            /* Réinitialise l'emplacement  */
    node_set_pos_fc set_pos;                /* Définit l'emplacement       */
    node_get_pos_fc get_pos;                /* Fournit l'emplacement       */
    node_get_alloc_fc get_alloc;            /* Fournit l'espace nécessaire */
    visit_flow_nodes_fc visit;              /* Visite des noeuds d'exécut° */
    find_container_fc contain;              /* Retrouve un conteneur       */

    GtkWidget *view;                        /* Morceau de code représenté  */
    char name[NODE_NAME_LEN];               /* Adresse sous forme humaine  */

    GtkAllocation alloc;                    /* Emplacement du bloc rattaché*/
    gint pending_x;                         /* Décallage à appliquer #1    */
    gint pending_y;                         /* Décallage à appliquer #2    */

};


/* Intermédiaire entre le noeud dot et la bribe de code (classe) */
struct _GGraphNodeClass
{
    GObjectClass parent;                    /* A laisser en premier        */

    double dpi_x;                           /* Résolution en abscisse      */
    double dpi_y;                           /* Résolution en ordonnée      */

};



#endif  /* _GTKEXT_GRAPH_NODE_INT_H */