Graphviz 13.0.0~dev.20250121.0651
|
abstract graph C library, Cgraph API More...
#include "cdt.h"
#include <inttypes.h>
#include <stdbool.h>
#include <stddef.h>
#include <stdint.h>
#include <stdio.h>
Go to the source code of this file.
Data Structures | |
struct | Agrec_s |
implementation of Agrec_t More... | |
struct | Agtag_s |
tag in Agobj_s for graphs, nodes, and edges. More... | |
struct | Agobj_s |
a generic header of Agraph_s, Agnode_s and Agedge_s More... | |
struct | Agsubnode_s |
This is the node struct allocated per graph (or subgraph). More... | |
struct | Agnode_s |
struct | Agedge_s |
struct | Agedgepair_s |
struct | Agdesc_s |
graph descriptor More... | |
struct | Agiddisc_s |
object ID allocator discipline More... | |
struct | Agiodisc_s |
IO services. More... | |
struct | Agdisc_s |
user's discipline More... | |
struct | Agdstate_s |
client state (closures) More... | |
struct | Agcbdisc_s |
client event callbacks, used in Agcbstack_s More... | |
struct | Agcbstack_s |
object event callbacks More... | |
struct | Agclos_s |
shared resources for Agraph_s More... | |
struct | Agraph_s |
graph or subgraph More... | |
struct | Agattr_s |
string attribute container More... | |
struct | Agsym_s |
string attribute descriptor symbol in Agattr_s.dict More... | |
struct | Agdatadict_s |
struct | graphviz_acyclic_options_t |
options for passing to graphviz_acyclic More... | |
struct | graphviz_tred_options_t |
options for passing to graphviz_tred More... | |
struct | graphviz_unflatten_options_t |
options for passing to graphviz_unflatten More... | |
Macros | |
#define | AGTAG(obj) (((Agobj_t *)(obj))->tag) |
#define | AGTYPE(obj) (AGTAG(obj).objtype) |
returns AGRAPH, AGNODE, or AGEDGE depending on the type of the object | |
#define | AGID(obj) (AGTAG(obj).id) |
returns the unique integer ID associated with the object | |
#define | AGSEQ(obj) (AGTAG(obj).seq) |
#define | AGATTRWF(obj) (AGTAG(obj).attrwf) |
#define | AGDATA(obj) (((Agobj_t *)(obj))->data) |
returns Agrec_t | |
#define | AGIN2OUT(inedge) ((inedge) - 1) |
Agedgepair_s.in -> Agedgepair_s.out. | |
#define | AGOUT2IN(outedge) ((outedge) + 1) |
Agedgepair_s.out -> Agedgepair_s.in/*#end#*/. | |
#define | AGOPP(e) ((AGTYPE(e) == AGINEDGE) ? AGIN2OUT(e) : AGOUT2IN(e)) |
#define | AGMKOUT(e) (AGTYPE(e) == AGOUTEDGE ? (e) : AGIN2OUT(e)) |
#define | AGMKIN(e) (AGTYPE(e) == AGINEDGE ? (e) : AGOUT2IN(e)) |
#define | AGTAIL(e) (AGMKIN(e)->node) |
#define | AGHEAD(e) (AGMKOUT(e)->node) |
#define | AGEQEDGE(e, f) (AGMKOUT(e) == AGMKOUT(f)) |
#define | agtail(e) AGTAIL(e) |
#define | aghead(e) AGHEAD(e) |
#define | agopp(e) AGOPP(e) |
opposite edge: flip Agedgepair_s.out ⇄ Agedgepair_s.in/*#end#*/ | |
#define | ageqedge(e, f) AGEQEDGE(e, f) |
edges are equal | |
#define | TAILPORT_ID "tailport" |
#define | HEADPORT_ID "headport" |
#define | AGSNMAIN(sn) ((sn) == (&((sn)->node->mainsub))) |
#define | EDGEOF(sn, rep) |
Typedefs | |
typedef uint64_t | IDTYPE |
unique per main graph ID | |
typedef struct Agtag_s | Agtag_t |
typedef struct Agobj_s | Agobj_t |
generic object header | |
typedef struct Agraph_s | Agraph_t |
graph, subgraph (or hyperedge) | |
typedef struct Agdesc_s | Agdesc_t |
graph descriptor | |
typedef struct Agdstate_s | Agdstate_t |
client state (closures) | |
typedef struct Agclos_s | Agclos_t |
common fields for graph/subgs | |
typedef struct Agnode_s | Agnode_t |
node (atom) | |
typedef struct Agsubnode_s | Agsubnode_t |
typedef struct Agedge_s | Agedge_t |
node pair | |
typedef struct Agedgepair_s | Agedgepair_t |
the edge object | |
typedef struct Agiddisc_s | Agiddisc_t |
object ID allocator | |
typedef struct Agiodisc_s | Agiodisc_t |
IO services. | |
typedef struct Agdisc_s | Agdisc_t |
union of client discipline methods | |
typedef struct Agcbdisc_s | Agcbdisc_t |
client event callbacks | |
typedef struct Agcbstack_s | Agcbstack_t |
enclosing state for Agcbdisc_t | |
typedef struct Agsym_s | Agsym_t |
string attribute descriptors | |
typedef struct Agattr_s | Agattr_t |
string attribute container | |
typedef struct Agdatadict_s | Agdatadict_t |
set of dictionaries per graph | |
typedef struct Agrec_s | Agrec_t |
generic header of Agattr_s, Agdatadict_s and user records | |
typedef void(* | agobjfn_t) (Agraph_t *g, Agobj_t *obj, void *arg) |
typedef void(* | agobjupdfn_t) (Agraph_t *g, Agobj_t *obj, void *arg, Agsym_t *sym) |
typedef int(* | agusererrf) (char *) |
Enumerations | |
enum | { AGRAPH , AGNODE , AGEDGE , AGOUTEDGE = AGEDGE , AGINEDGE } |
Object tags. Can't exceed 2 bits. See Agtag_s. More... | |
enum | agerrlevel_t { AGWARN , AGERR , AGMAX , AGPREV } |
Functions | |
void | agpushdisc (Agraph_t *g, Agcbdisc_t *disc, void *state) |
int | agpopdisc (Agraph_t *g, Agcbdisc_t *disc) |
Agraph_t * | agopen (char *name, Agdesc_t desc, Agdisc_t *disc) |
creates a new graph with the given name and kind | |
int | agclose (Agraph_t *g) |
deletes a graph, freeing its associated storage | |
Agraph_t * | agread (void *chan, Agdisc_t *disc) |
constructs a new graph | |
Agraph_t * | agmemread (const char *cp) |
reads a graph from the input string | |
Agraph_t * | agmemconcat (Agraph_t *g, const char *cp) |
void | agsetfile (const char *) |
sets the current file name for subsequent error reporting | |
Agraph_t * | agconcat (Agraph_t *g, void *chan, Agdisc_t *disc) |
merges the file contents with a pre-existing graph | |
int | agwrite (Agraph_t *g, void *chan) |
Return 0 on success, EOF on failure. | |
int | agisdirected (Agraph_t *g) |
int | agisundirected (Agraph_t *g) |
int | agisstrict (Agraph_t *g) |
int | agissimple (Agraph_t *g) |
Agnode_t * | agnode (Agraph_t *g, char *name, int createflag) |
Agnode_t * | agidnode (Agraph_t *g, IDTYPE id, int createflag) |
Agnode_t * | agsubnode (Agraph_t *g, Agnode_t *n, int createflag) |
Agnode_t * | agfstnode (Agraph_t *g) |
Agnode_t * | agnxtnode (Agraph_t *g, Agnode_t *n) |
Agnode_t * | aglstnode (Agraph_t *g) |
Agnode_t * | agprvnode (Agraph_t *g, Agnode_t *n) |
Agsubnode_t * | agsubrep (Agraph_t *g, Agnode_t *n) |
int | agnodebefore (Agnode_t *u, Agnode_t *v) |
int | agdelnode (Agraph_t *g, Agnode_t *arg_n) |
removes a node from a graph or subgraph. | |
int | agrelabel_node (Agnode_t *n, char *newname) |
Agedge_t * | agedge (Agraph_t *g, Agnode_t *t, Agnode_t *h, char *name, int createflag) |
Agedge_t * | agidedge (Agraph_t *g, Agnode_t *t, Agnode_t *h, IDTYPE id, int createflag) |
Agedge_t * | agsubedge (Agraph_t *g, Agedge_t *e, int createflag) |
Agedge_t * | agfstin (Agraph_t *g, Agnode_t *n) |
Agedge_t * | agnxtin (Agraph_t *g, Agedge_t *e) |
Agedge_t * | agfstout (Agraph_t *g, Agnode_t *n) |
Agedge_t * | agnxtout (Agraph_t *g, Agedge_t *e) |
Agedge_t * | agfstedge (Agraph_t *g, Agnode_t *n) |
Agedge_t * | agnxtedge (Agraph_t *g, Agedge_t *e, Agnode_t *n) |
int | agdeledge (Agraph_t *g, Agedge_t *arg_e) |
Agraph_t * | agraphof (void *obj) |
Agraph_t * | agroot (void *obj) |
int | agcontains (Agraph_t *, void *obj) |
returns non-zero if obj is a member of (sub)graph | |
char * | agnameof (void *) |
returns a string descriptor for the object. | |
int | agdelete (Agraph_t *g, void *obj) |
deletes object. Equivalent to agclose, agdelnode, and agdeledge for obj being a graph, node or edge, respectively. | |
int | agobjkind (void *obj) |
char * | agstrdup (Agraph_t *, const char *) |
returns a pointer to a reference-counted copy of the argument string, creating one if necessary | |
char * | agstrdup_html (Agraph_t *, const char *) |
int | aghtmlstr (const char *) |
char * | agstrbind (Agraph_t *g, const char *) |
int | agstrfree (Agraph_t *, const char *, bool is_html) |
char * | agstrcanon (char *, char *) |
char * | agcanonStr (char *str) |
Agsym_t * | agattr (Agraph_t *g, int kind, char *name, const char *value) |
creates or looks up attributes of a graph | |
Agsym_t * | agattr_html (Agraph_t *g, int kind, char *name, const char *value) |
agattr , but creates HTML-like values | |
Agsym_t * | agattrsym (void *obj, char *name) |
looks up a string attribute for a graph object given as an argument | |
Agsym_t * | agnxtattr (Agraph_t *g, int kind, Agsym_t *attr) |
permits traversing the list of attributes of a given type | |
int | agcopyattr (void *oldobj, void *newobj) |
copies all of the attributes from one object to another | |
void * | agbindrec (void *obj, const char *name, unsigned int recsize, int move_to_front) |
attaches a new record of the given size to the object | |
Agrec_t * | aggetrec (void *obj, const char *name, int move_to_front) |
find record in circular list and do optional move-to-front and lock | |
int | agdelrec (void *obj, const char *name) |
deletes a named record from one object | |
void | aginit (Agraph_t *g, int kind, const char *rec_name, int rec_size, int move_to_front) |
attach new records to objects of specified kind | |
void | agclean (Agraph_t *g, int kind, char *rec_name) |
calls agdelrec for all objects of the same class in an entire graph | |
char * | agget (void *obj, char *name) |
char * | agxget (void *obj, Agsym_t *sym) |
int | agset (void *obj, char *name, const char *value) |
int | agxset (void *obj, Agsym_t *sym, const char *value) |
int | agxset_html (void *obj, Agsym_t *sym, const char *value) |
int | agsafeset (void *obj, char *name, const char *value, const char *def) |
ensures the given attribute is declared before setting it locally on an object | |
Agraph_t * | agsubg (Agraph_t *g, char *name, int cflag) |
Agraph_t * | agidsubg (Agraph_t *g, IDTYPE id) |
constructor | |
Agraph_t * | agfstsubg (Agraph_t *g) |
Agraph_t * | agnxtsubg (Agraph_t *subg) |
Agraph_t * | agparent (Agraph_t *g) |
int | agdelsubg (Agraph_t *g, Agraph_t *sub) |
int | agnnodes (Agraph_t *g) |
int | agnedges (Agraph_t *g) |
int | agnsubg (Agraph_t *g) |
int | agdegree (Agraph_t *g, Agnode_t *n, int in, int out) |
int | agcountuniqedges (Agraph_t *g, Agnode_t *n, int in, int out) |
void | aginternalmapclearlocalnames (Agraph_t *g) |
agerrlevel_t | agseterr (agerrlevel_t) |
char * | aglasterr (void) |
int | agerr (agerrlevel_t level, const char *fmt,...) |
void | agerrorf (const char *fmt,...) |
void | agwarningf (const char *fmt,...) |
int | agerrors (void) |
int | agreseterrors (void) |
agusererrf | agseterrf (agusererrf) |
bool | graphviz_acyclic (Agraph_t *g, const graphviz_acyclic_options_t *opts, size_t *num_rev) |
void | graphviz_tred (Agraph_t *g, const graphviz_tred_options_t *opts) |
programmatic access to tred - transitive reduction | |
void | graphviz_unflatten (Agraph_t *g, const graphviz_unflatten_options_t *opts) |
size_t | graphviz_node_induce (Agraph_t *g, Agraph_t *edgeset) |
Variables | |
Agiddisc_t | AgIdDisc |
Agiodisc_t | AgIoDisc |
Agdisc_t | AgDefaultDisc |
Agdesc_t | Agdirected |
directed | |
Agdesc_t | Agstrictdirected |
strict directed. A strict graph cannot have multi-edges or self-arcs. | |
Agdesc_t | Agundirected |
undirected | |
Agdesc_t | Agstrictundirected |
strict undirected | |
Libcgraph supports graph programming by maintaining graphs in memory and reading and writing graph files. Graphs are composed of nodes, edges, and nested subgraphs. These graph objects may be attributed with string name-value pairs and programmer-defined records (see Attributes). All of Libcgraph’s global symbols have the prefix ag (case varying). In the following, if a function has a parameter int createflag
and the object does not exist, the function will create the specified object if createflag
is non-zero; otherwise, it will return NULL.
Definition in file cgraph.h.