]> granicus.if.org Git - graphviz/commitdiff
remove cgraph macro aliases
authorMatthew Fernandez <matthew.fernandez@gmail.com>
Sun, 26 Dec 2021 03:56:19 +0000 (19:56 -0800)
committerMatthew Fernandez <matthew.fernandez@gmail.com>
Tue, 4 Jan 2022 02:05:43 +0000 (18:05 -0800)
The functions removed in this commit were intended to be aliases for the
same-named macros declared in cgraph.h. The claimed purpose is debugger
introspection.

It is unclear to me what value these have in a modern development environment.
Some modern debuggers can understand macro definitions. Those that cannot are
_impeded_ by these aliases. A developer debugging looks at the alias definition
and thinks they understand the code, but they do not. The code that is executing
on their system is _not_ the code these functions compile to. To state something
stronger: it is unclear to me how these definitions were ever helpful. They
appear to (accidentally) obscure what is actually occurring in the machine at
runtime.

Note that these functions also bloated the cgraph .so/.a size by including
functions that were never called.

lib/cgraph/edge.c

index 0b1e195b6575ada891cc0becb31148c76222db1d..f42dda6a128bc3bb874c023d6ed4fb97ea653fb4 100644 (file)
@@ -469,37 +469,3 @@ Dtdisc_t Ag_subedge_id_disc = {
     agdictobjmem,
     NIL(Dtevent_f)
 };
-
-/* expose macros as functions for ease of debugging
-and to expose them to foreign languages without C preprocessor. */
-#ifdef ageqedge
-#undef ageqedge
-#endif
-CGRAPH_API int ageqedge(Agedge_t * e, Agedge_t * f)
-{
-    return AGEQEDGE(e, f);
-}
-
-#ifdef agtail
-#undef agtail
-#endif
-CGRAPH_API Agnode_t *agtail(Agedge_t * e)
-{
-    return AGTAIL(e);
-}
-
-#ifdef aghead
-#undef aghead
-#endif
-CGRAPH_API Agnode_t *aghead(Agedge_t * e)
-{
-    return AGHEAD(e);
-}
-
-#ifdef agopp
-#undef agopp
-#endif
-CGRAPH_API Agedge_t *agopp(Agedge_t * e)
-{
-    return AGOPP(e);
-}