Graphviz
13.0.0~dev.20250121.0651
Loading...
Searching...
No Matches
structures.h
Go to the documentation of this file.
1
/*************************************************************************
2
* Copyright (c) 2011 AT&T Intellectual Property
3
* All rights reserved. This program and the accompanying materials
4
* are made available under the terms of the Eclipse Public License v1.0
5
* which accompanies this distribution, and is available at
6
* https://www.eclipse.org/legal/epl-v10.html
7
*
8
* Contributors: Details at https://graphviz.org
9
*************************************************************************/
10
11
#pragma once
12
13
#include "
types.h
"
14
#include "
cgraph.h
"
15
#include <
ortho/rawgraph.h
>
16
#include <stdbool.h>
17
#include <stddef.h>
18
#include <
util/list.h
>
19
20
typedef
struct
{
21
double
p1
, p2;
22
}
paird
;
23
24
typedef
struct
{
25
int
a
,b;
26
}
pair
;
27
28
typedef
struct
{
29
pair
t1
, t2;
30
}
pair2
;
31
32
typedef
enum
{
B_NODE
,
B_UP
,
B_LEFT
,
B_DOWN
,
B_RIGHT
}
bend
;
33
34
/* Example : segment connecting maze point (3,2)
35
* and (3,8) has isVert = 1, common coordinate = 3, p1 = 2, p2 = 8
36
*/
37
typedef
struct
segment
{
38
bool
isVert
;
39
double
comm_coord
;
/* the common coordinate */
40
paird
p
;
/* end points */
41
bend
l1
,
l2
;
42
size_t
ind_no
;
43
int
track_no
;
/* track number assigned in the channel */
44
struct
segment
*
prev
;
45
struct
segment
*
next
;
46
}
segment
;
47
48
typedef
struct
{
49
size_t
n
;
50
segment
*
segs
;
51
}
route
;
52
53
DEFINE_LIST
(seg_list,
segment
*)
54
55
typedef struct {
56
Dtlink_t
link
;
57
paird
p
;
/* extrema of channel */
58
seg_list_t
seg_list
;
59
rawgraph
*
G
;
60
struct
cell
*
cp
;
61
}
channel
;
62
63
#define N_DAD(n) (n)->n_dad
cgraph.h
abstract graph C library, Cgraph API
list.h
DEFINE_LIST
#define DEFINE_LIST(name, type)
Definition
list.h:21
rawgraph.h
cell
result of partitioning available space, part of maze
Definition
grid.h:33
channel
Definition
structures.h:55
channel::cp
struct cell * cp
Definition
structures.h:60
channel::seg_list
seg_list_t seg_list
segment pointers
Definition
structures.h:58
channel::link
Dtlink_t link
Definition
structures.h:56
channel::p
paird p
Definition
structures.h:57
channel::G
rawgraph * G
Definition
structures.h:59
dtlink_s_
Definition
cdt.h:51
pair2
Definition
structures.h:28
pair2::t1
pair t1
Definition
structures.h:29
pair
Definition
graph_generator.c:445
pair::a
int a
Definition
structures.h:25
paird
Definition
structures.h:20
paird::p1
double p1
Definition
structures.h:21
rawgraph
Definition
rawgraph.h:25
route
Definition
structures.h:48
route::segs
segment * segs
Definition
structures.h:50
route::n
size_t n
Definition
structures.h:49
segment
Definition
structures.h:37
segment::p
paird p
Definition
structures.h:40
segment::comm_coord
double comm_coord
Definition
structures.h:39
segment::ind_no
size_t ind_no
index number of this segment in its channel
Definition
structures.h:42
segment::next
struct segment * next
Definition
structures.h:45
segment::l2
bend l2
Definition
structures.h:41
segment::l1
bend l1
Definition
structures.h:41
segment::isVert
bool isVert
Definition
structures.h:38
segment::track_no
int track_no
Definition
structures.h:43
segment::prev
struct segment * prev
Definition
structures.h:44
bend
bend
Definition
structures.h:32
B_LEFT
@ B_LEFT
Definition
structures.h:32
B_RIGHT
@ B_RIGHT
Definition
structures.h:32
B_DOWN
@ B_DOWN
Definition
structures.h:32
B_UP
@ B_UP
Definition
structures.h:32
B_NODE
@ B_NODE
Definition
structures.h:32
types.h
graphs, nodes and edges info: Agraphinfo_t, Agnodeinfo_t and Agedgeinfo_t
lib
ortho
structures.h
Generated by
1.9.8