]> granicus.if.org Git - graphviz/log
graphviz
3 years agolib/gvpr: use GVDLL instead of _WIN32 to control gprDisc init in compile.c
Magnus Jacobsson [Sun, 2 Jan 2022 15:02:47 +0000 (16:02 +0100)]
lib/gvpr: use GVDLL instead of _WIN32 to control gprDisc init in compile.c

Without this change, an upcoming commit that changes cgraph.h to use
GVDLL instead of _WIN32 to control storage-class attributes would
cause this error:

compile.c:85:29: error: initializer element is not constant
   85 | static Agdisc_t gprDisc = { &AgMemDisc, &AgIdDisc, &gprIoDisc };
      |                             ^
compile.c:85:29: note: (near initialization for ‘gprDisc.mem’)

Towards https://gitlab.com/graphviz/graphviz/-/issues/2173.

3 years agodot: MSBuild: define GVDLL to ensure correct storage-class attributes
Magnus Jacobsson [Sat, 1 Jan 2022 17:01:01 +0000 (18:01 +0100)]
dot: MSBuild: define GVDLL to ensure correct storage-class attributes

An upcoming commit will change the storage-class attributes to be
controlled by the GVDLL symbol in cgraph.h.

Without this change, errors like this would occur:

dot.obj : error LNK2001: unresolved external symbol _Agdirected

Towards https://gitlab.com/graphviz/graphviz/-/issues/2173.

3 years agosccmap: MSBuild: define GVDLL to ensure correct storage-class attributes
Magnus Jacobsson [Sat, 1 Jan 2022 17:01:01 +0000 (18:01 +0100)]
sccmap: MSBuild: define GVDLL to ensure correct storage-class attributes

An upcoming commit will change the storage-class attributes to be
controlled by the GVDLL symbol in cgraph.h.

Without this change, errors like this would occur:

sccmap.obj : error LNK2001: unresolved external symbol _Agdirected

Towards https://gitlab.com/graphviz/graphviz/-/issues/2173.

3 years agobcomps: MSBuild: define GVDLL to ensure correct storage-class attributes
Magnus Jacobsson [Sat, 1 Jan 2022 17:01:01 +0000 (18:01 +0100)]
bcomps: MSBuild: define GVDLL to ensure correct storage-class attributes

An upcoming commit will change the storage-class attributes to be
controlled by the GVDLL symbol in cgraph.h.

Without this change, errors like this would occur:

bcomps.obj : error LNK2001: unresolved external symbol _Agstrictundirected

Towards https://gitlab.com/graphviz/graphviz/-/issues/2173.

3 years agomm2gv: MSBuild: define GVDLL to ensure correct storage-class attributes
Magnus Jacobsson [Sat, 1 Jan 2022 17:01:01 +0000 (18:01 +0100)]
mm2gv: MSBuild: define GVDLL to ensure correct storage-class attributes

An upcoming commit will change the storage-class attributes to be
controlled by the GVDLL symbol in cgraph.h.

Without this change, errors like this would occur:

mm2gv.obj : error LNK2001: unresolved external symbol _Agdirected

Towards https://gitlab.com/graphviz/graphviz/-/issues/2173.

3 years agoccomps: MSBuild: define GVDLL to ensure correct storage-class attributes
Magnus Jacobsson [Sat, 1 Jan 2022 17:01:01 +0000 (18:01 +0100)]
ccomps: MSBuild: define GVDLL to ensure correct storage-class attributes

An upcoming commit will change the storage-class attributes to be
controlled by the GVDLL symbol in cgraph.h.

Without this change, errors like this would occur:

ccomps.obj : error LNK2001: unresolved external symbol _Agstrictundirected

Towards https://gitlab.com/graphviz/graphviz/-/issues/2173.

3 years agodotgen: MSBuild: define GVDLL to ensure correct storage-class attributes
Magnus Jacobsson [Sat, 1 Jan 2022 17:01:01 +0000 (18:01 +0100)]
dotgen: MSBuild: define GVDLL to ensure correct storage-class attributes

An upcoming commit will change the storage-class attributes to be
controlled by the GVDLL symbol in cgraph.h.

Without this change, errors like this would occur:

dotgen.lib(mincross.obj) : error LNK2001: unresolved external symbol _Agstrictdirected

Towards https://gitlab.com/graphviz/graphviz/-/issues/2173.

3 years agoStart 3.0 development series
Magnus Jacobsson [Fri, 7 Jan 2022 11:48:49 +0000 (12:48 +0100)]
Start 3.0 development series

An upcoming commit will introduce a breaking change.

3 years agoMerge branch 'smattr/18156802-8e89-4532-9958-fdc6fb4c0f13' into 'main'
Matthew Fernandez [Sat, 8 Jan 2022 17:12:02 +0000 (17:12 +0000)]
Merge branch 'smattr/18156802-8e89-4532-9958-fdc6fb4c0f13' into 'main'

convert lib/mingle/ink.c to C++

See merge request graphviz/graphviz!2381

3 years agolib/mingle: remove an unused sparse include
Matthew Fernandez [Fri, 7 Jan 2022 03:40:08 +0000 (19:40 -0800)]
lib/mingle: remove an unused sparse include

3 years agolib/mingle: replace some 'MIN' usage with 'std::min'
Matthew Fernandez [Fri, 7 Jan 2022 03:38:52 +0000 (19:38 -0800)]
lib/mingle: replace some 'MIN' usage with 'std::min'

3 years agolib/mingle ink: pass point lists around as vectors instead of C arrays
Matthew Fernandez [Fri, 7 Jan 2022 03:27:50 +0000 (19:27 -0800)]
lib/mingle ink: pass point lists around as vectors instead of C arrays

3 years agolib/mingle ink: avoid manual memory management of 'targets'
Matthew Fernandez [Thu, 6 Jan 2022 06:16:40 +0000 (22:16 -0800)]
lib/mingle ink: avoid manual memory management of 'targets'

3 years agolib/mingle: scope use of an array to a local temp
Matthew Fernandez [Thu, 6 Jan 2022 06:13:16 +0000 (22:13 -0800)]
lib/mingle: scope use of an array to a local temp

Similar to the preceding changes for `sources`, it is not clear to me why this
code was using the `targets` array when the output values are irrelevant.

3 years agolib/mingle ink: avoid manual memory management of 'sources'
Matthew Fernandez [Thu, 6 Jan 2022 06:08:38 +0000 (22:08 -0800)]
lib/mingle ink: avoid manual memory management of 'sources'

3 years agolib/mingle: scope use of an array to a local temp
Matthew Fernandez [Thu, 6 Jan 2022 06:00:51 +0000 (22:00 -0800)]
lib/mingle: scope use of an array to a local temp

It is not clear to me why this loop was using the `sources` array. AFAICT the
values written to this array are (1) not used by subsequent loop iterations (no
loop-carried dependency) and (2) not used after the loop before being
overwritten by other values.

This change cuts the dependency. A future commit will refactor the allocation in
this area to avoid allocating a possibly-unused array upfront.

3 years agolib/mingle: rephrase some open coded hypotenuse calculations
Matthew Fernandez [Thu, 6 Jan 2022 05:50:53 +0000 (21:50 -0800)]
lib/mingle: rephrase some open coded hypotenuse calculations

Surprisingly every `sqrt` call in this file except one is a hypotenuse
calculation that can be done more accurately. Maybe `hypot` was not widely
available when this code was written.

3 years agolib/mingle: replace some 'MAX' usage with 'std::max'
Matthew Fernandez [Thu, 6 Jan 2022 05:43:39 +0000 (21:43 -0800)]
lib/mingle: replace some 'MAX' usage with 'std::max'

This is straightforward find-and-replace. No attempt was made to investigate if
the surrounding algorithm could/should be rephrased.

Gitlab: #2154

3 years agolib/mingle: [nfc] change C includes to their C++ equivalents
Matthew Fernandez [Thu, 6 Jan 2022 05:38:03 +0000 (21:38 -0800)]
lib/mingle: [nfc] change C includes to their C++ equivalents

3 years agolib/mingle: move ink.c into C++
Matthew Fernandez [Thu, 6 Jan 2022 04:32:31 +0000 (20:32 -0800)]
lib/mingle: move ink.c into C++

lib/mingle already has a C++ source, requiring it to link against the C++
standard library. There is no advantage to keeping some of its sources in C.

This does nothing fancy, just rename the existing file. All contained code looks
compatible across C and C++. Future commits will refactor this to more modern
C++ style.

Gitlab: #2154

3 years agolib/mingle: [nfc] pre-emptively squash -fpermissive warning
Matthew Fernandez [Thu, 6 Jan 2022 04:48:07 +0000 (20:48 -0800)]
lib/mingle: [nfc] pre-emptively squash -fpermissive warning

When moving this code to C++ in an upcoming commit, this would otherwise
trigger:

  lib/mingle/ink.cpp:46:22: error: uninitialized const 'Origin' [-fpermissive]
   static const point_t Origin;
                        ^
  In file included from lib/mingle/ink.cpp:17:0:
  lib/mingle/ink.h:19:16: note: 'const struct point_t' has no user-provided
    default constructor
   typedef struct {
                  ^
  lib/mingle/ink.h:20:10: note: and the implicitly-defined constructor does not
    initialize 'double point_t::x'
     double x, y;
          ^

This noisy initialization can probably be undone after mingle and libmingle are
moved to entirely C++.

Gitlab: #2154

3 years agolib/mingle: [nfc] remove an unused include
Matthew Fernandez [Thu, 6 Jan 2022 04:25:12 +0000 (20:25 -0800)]
lib/mingle: [nfc] remove an unused include

3 years agoMerge branch 'fix-parallel-visual-studio-builds' into 'main'
Magnus Jacobsson [Thu, 6 Jan 2022 10:56:24 +0000 (10:56 +0000)]
Merge branch 'fix-parallel-visual-studio-builds' into 'main'

Fix parallel Visual Studio builds

See merge request graphviz/graphviz!2377

3 years agoadd a changelog entry for Visual Studio fix
Magnus Jacobsson [Thu, 6 Jan 2022 09:53:30 +0000 (10:53 +0100)]
add a changelog entry for Visual Studio fix

https://gitlab.com/graphviz/graphviz/-/issues/2175.

3 years agotwopigen: MSBuild: add project reference to version
Magnus Jacobsson [Sun, 2 Jan 2022 21:43:26 +0000 (22:43 +0100)]
twopigen: MSBuild: add project reference to version

Closes https://gitlab.com/graphviz/graphviz/-/issues/2175.

3 years agocircogen: MSBuild: add project reference to version
Magnus Jacobsson [Sun, 2 Jan 2022 20:56:32 +0000 (21:56 +0100)]
circogen: MSBuild: add project reference to version

Towards https://gitlab.com/graphviz/graphviz/-/issues/2175.

3 years agoortho: MSBuild: add project reference to version
Magnus Jacobsson [Sun, 2 Jan 2022 20:44:53 +0000 (21:44 +0100)]
ortho: MSBuild: add project reference to version

Towards https://gitlab.com/graphviz/graphviz/-/issues/2175.

3 years agofdpgen: MSBuild: add project reference to version
Magnus Jacobsson [Sun, 2 Jan 2022 20:44:29 +0000 (21:44 +0100)]
fdpgen: MSBuild: add project reference to version

Towards https://gitlab.com/graphviz/graphviz/-/issues/2175.

3 years agopatchwork: MSBuild: add project reference to version
Magnus Jacobsson [Sun, 2 Jan 2022 20:27:42 +0000 (21:27 +0100)]
patchwork: MSBuild: add project reference to version

Towards https://gitlab.com/graphviz/graphviz/-/issues/2175.

3 years agogv2gml: MSBuild: add project reference to gvc
Magnus Jacobsson [Sun, 2 Jan 2022 20:26:03 +0000 (21:26 +0100)]
gv2gml: MSBuild: add project reference to gvc

Towards https://gitlab.com/graphviz/graphviz/-/issues/2175.

3 years agoMerge branch 'smattr/a679a524-8d3d-45b7-8da2-729372854b24' into 'main'
Matthew Fernandez [Thu, 6 Jan 2022 02:04:39 +0000 (02:04 +0000)]
Merge branch 'smattr/a679a524-8d3d-45b7-8da2-729372854b24' into 'main'

remove reused buffer in spline routing

See merge request graphviz/graphviz!2359

3 years agoremove reused buffer in spline routing
Matthew Fernandez [Fri, 24 Dec 2021 18:11:06 +0000 (10:11 -0800)]
remove reused buffer in spline routing

Code in routespl.c used a long-lived buffer, `ps`, that it resized to deal with
various operations. This made the code thread-unsafe, and note that there are
also various work arounds in routespl.c to deal with re-entrancy which is
complicated by this design.

This commit rephrases `simpleSplineRoute` and `_routesplines` to dynamically
allocate a fresh buffer for each operation. The ergonomics cost of this is that
callers of `simpleSplineRoute`, `routesplines`, and `routepolylines` now need to
eventually free the returned pointer. This is unfortunately fairly noisy to deal
with in C and would have been cleaner in C++.

In future, this direction should probably be taken further to allow
`routesplinesinit` and `routesplinesterm` to be removed. This design that relies
on static globals is incompatible with multi-threading, so if Graphviz ever
wants to support multi-threading, this will need to be removed.

Note that this commit introduce two new warnings (for the `calloc` calls with
`int` values). The cost seems worth it and hopefully these warnings can be
removed in future.

This change has a performance impact. For smaller graphs, this likely slightly
degrades performance due to repeated small allocations that previously would not
have been required. For larger graphs, this perhaps improves performance as the
allocator no longer (spuriously) believes it needs to retain the contents of
`ps` across calls.

3 years agoMerge branch 'smattr/3e7bbb62-f0eb-49c3-8fc3-e02f3948ea62' into 'main'
Matthew Fernandez [Wed, 5 Jan 2022 16:59:32 +0000 (16:59 +0000)]
Merge branch 'smattr/3e7bbb62-f0eb-49c3-8fc3-e02f3948ea62' into 'main'

more boolean → bool modernization

See merge request graphviz/graphviz!2369

3 years agopoly_gencode: remove claim that 'filled' is a boolean
Matthew Fernandez [Mon, 27 Dec 2021 03:22:50 +0000 (19:22 -0800)]
poly_gencode: remove claim that 'filled' is a boolean

This variable is not treated as a boolean within this function. Declaring it as
a boolean appears to have been a mistake and only worked out coincidentally as
all set values fit within the `boolean` type.

3 years agohandle_keypress: return a C99 bool instead of a boolean
Matthew Fernandez [Mon, 27 Dec 2021 03:14:43 +0000 (19:14 -0800)]
handle_keypress: return a C99 bool instead of a boolean

3 years agogetdoubles2ptf: return a C99 bool instead of boolean
Matthew Fernandez [Mon, 27 Dec 2021 03:11:07 +0000 (19:11 -0800)]
getdoubles2ptf: return a C99 bool instead of boolean

3 years agoglitz_finalize: use a C99 bool for 'watching_p' instead of a boolean
Matthew Fernandez [Mon, 27 Dec 2021 03:08:46 +0000 (19:08 -0800)]
glitz_finalize: use a C99 bool for 'watching_p' instead of a boolean

3 years agogdgen_begin_page: use a C99 bool for 'truecolor_p' instead of a boolean
Matthew Fernandez [Mon, 27 Dec 2021 03:07:38 +0000 (19:07 -0800)]
gdgen_begin_page: use a C99 bool for 'truecolor_p' instead of a boolean

3 years agopccomps: use a C99 bool for 'pin' instead of a boolean
Matthew Fernandez [Mon, 27 Dec 2021 03:06:08 +0000 (19:06 -0800)]
pccomps: use a C99 bool for 'pin' instead of a boolean

3 years agostress_majorization_cola: use a C99 for 'converged' instead of a boolean
Matthew Fernandez [Mon, 27 Dec 2021 03:04:12 +0000 (19:04 -0800)]
stress_majorization_cola: use a C99 for 'converged' instead of a boolean

3 years agogvplugin_list: use a C99 bool for 'new' instead of boolean
Matthew Fernandez [Mon, 27 Dec 2021 03:02:29 +0000 (19:02 -0800)]
gvplugin_list: use a C99 bool for 'new' instead of boolean

3 years agouse C99 bools for 'isVert' members instead of booleans
Matthew Fernandez [Mon, 27 Dec 2021 02:57:49 +0000 (18:57 -0800)]
use C99 bools for 'isVert' members instead of booleans

3 years agogenerateNonoverlapConstraints: take a C99 bool instead of boolean
Matthew Fernandez [Mon, 27 Dec 2021 02:52:23 +0000 (18:52 -0800)]
generateNonoverlapConstraints: take a C99 bool instead of boolean

Note that this required propagating this change through to `genXConstraints` as
well.

3 years agospline_edges0: take a C99 bool instead of a boolean
Matthew Fernandez [Mon, 27 Dec 2021 02:42:24 +0000 (18:42 -0800)]
spline_edges0: take a C99 bool instead of a boolean

3 years agomakeSpline: take a C99 bool instead of a boolean
Matthew Fernandez [Mon, 27 Dec 2021 02:39:45 +0000 (18:39 -0800)]
makeSpline: take a C99 bool instead of a boolean

3 years agoMerge branch 'unify-storage-class-declarations-in-cdt' into 'main'
Magnus Jacobsson [Wed, 5 Jan 2022 08:19:58 +0000 (08:19 +0000)]
Merge branch 'unify-storage-class-declarations-in-cdt' into 'main'

Unify storage-class declarations in cdt.h with Graphviz standard

See merge request graphviz/graphviz!2378

3 years agocdt: [nfc] align storage-class declarations to Graphviz standard in cdt.h
Magnus Jacobsson [Sat, 1 Jan 2022 15:45:42 +0000 (16:45 +0100)]
cdt: [nfc] align storage-class declarations to Graphviz standard in cdt.h

3 years agocdt: use GVDLL instead of _WIN32 to control storage-class attributes in cdt.h
Magnus Jacobsson [Sat, 1 Jan 2022 15:44:04 +0000 (16:44 +0100)]
cdt: use GVDLL instead of _WIN32 to control storage-class attributes in cdt.h

Towards https://gitlab.com/graphviz/graphviz/-/issues/2173.

3 years agocdt: [nfc] remove whitespace in preprocessor directives in cdt.h
Magnus Jacobsson [Sat, 1 Jan 2022 15:42:27 +0000 (16:42 +0100)]
cdt: [nfc] remove whitespace in preprocessor directives in cdt.h

3 years agocdt: MSBuild: define GVDLL to ensure correct storage-class attributes
Magnus Jacobsson [Sat, 1 Jan 2022 16:37:22 +0000 (17:37 +0100)]
cdt: MSBuild: define GVDLL to ensure correct storage-class attributes

An upcoming commit will change the storage-class attributes to be
controlled by the GVDLL symbol in cdt.h.

Without this change, the following error would occur:

LINK : fatal error LNK1104: cannot open file 'C:\GitLab-Runner\builds\magjac\graphviz\Debug\Graphviz\bin\cdt.lib' [C:\GitLab-Runner\builds\magjac\graphviz\lib\pathplan\Pathplan.vcxproj]

Towards https://gitlab.com/graphviz/graphviz/-/issues/2173.

3 years agogvpack: MSBuild: define GVDLL to ensure correct storage-class attributes
Magnus Jacobsson [Sat, 1 Jan 2022 17:01:01 +0000 (18:01 +0100)]
gvpack: MSBuild: define GVDLL to ensure correct storage-class attributes

An upcoming commit will change the storage-class attributes to be
controlled by the GVDLL symbol in cdt.h.

Without this change, errors like this would occur:

gvpack.obj : error LNK2001: unresolved external symbol _Dtoset

Towards https://gitlab.com/graphviz/graphviz/-/issues/2173.

3 years agographml2gv: MSBuild: define GVDLL to ensure correct storage-class attributes
Magnus Jacobsson [Sat, 1 Jan 2022 17:01:01 +0000 (18:01 +0100)]
graphml2gv: MSBuild: define GVDLL to ensure correct storage-class attributes

An upcoming commit will change the storage-class attributes to be
controlled by the GVDLL symbol in cdt.h.

Without this change, errors like this would occur:

graphml2gv.obj : error LNK2001: unresolved external symbol _Dtoset

Towards https://gitlab.com/graphviz/graphviz/-/issues/2173.

3 years agogxl2gv: MSBuild: define GVDLL to ensure correct storage-class attributes
Magnus Jacobsson [Sat, 1 Jan 2022 17:01:01 +0000 (18:01 +0100)]
gxl2gv: MSBuild: define GVDLL to ensure correct storage-class attributes

An upcoming commit will change the storage-class attributes to be
controlled by the GVDLL symbol in cdt.h.

Without this change, errors like this would occur:

gxl2gv.obj : error LNK2001: unresolved external symbol _Dtoset

Towards https://gitlab.com/graphviz/graphviz/-/issues/2173.

3 years agodijkstra: MSBuild: define GVDLL to ensure correct storage-class attributes
Magnus Jacobsson [Sat, 1 Jan 2022 17:01:01 +0000 (18:01 +0100)]
dijkstra: MSBuild: define GVDLL to ensure correct storage-class attributes

An upcoming commit will change the storage-class attributes to be
controlled by the GVDLL symbol in cdt.h.

Without this change, errors like this would occur:

dijkstra.obj : error LNK2001: unresolved external symbol _Dtoset

Towards https://gitlab.com/graphviz/graphviz/-/issues/2173.

3 years agogml2gv: MSBuild: define GVDLL to ensure correct storage-class attributes
Magnus Jacobsson [Sat, 1 Jan 2022 17:01:01 +0000 (18:01 +0100)]
gml2gv: MSBuild: define GVDLL to ensure correct storage-class attributes

An upcoming commit will change the storage-class attributes to be
controlled by the GVDLL symbol in cdt.h.

Without this change, errors like this would occur:

gv2gxl.obj : error LNK2001: unresolved external symbol _Dtoset

Towards https://gitlab.com/graphviz/graphviz/-/issues/2173.

3 years agoplugin/core: MSBuild: define GVDLL to ensure correct storage-class attributes
Magnus Jacobsson [Sat, 1 Jan 2022 17:01:01 +0000 (18:01 +0100)]
plugin/core: MSBuild: define GVDLL to ensure correct storage-class attributes

An upcoming commit will change the storage-class attributes to be
controlled by the GVDLL symbol in cdt.h.

Without this change, errors like this would occur:

gvrender_core_json.obj : error LNK2001: unresolved external symbol _Dtoset

Towards https://gitlab.com/graphviz/graphviz/-/issues/2173.

3 years agofdpgen: MSBuild: define GVDLL to ensure correct storage-class attributes
Magnus Jacobsson [Sat, 1 Jan 2022 17:01:01 +0000 (18:01 +0100)]
fdpgen: MSBuild: define GVDLL to ensure correct storage-class attributes

An upcoming commit will change the storage-class attributes to be
controlled by the GVDLL symbol in cdt.h.

Without this change, errors like this would occur:

fdpgen.lib(grid.obj) : error LNK2001: unresolved external symbol _Dtoset

Towards https://gitlab.com/graphviz/graphviz/-/issues/2173.

3 years agocircogen: MSBuild: define GVDLL to ensure correct storage-class attributes
Magnus Jacobsson [Sat, 1 Jan 2022 17:01:01 +0000 (18:01 +0100)]
circogen: MSBuild: define GVDLL to ensure correct storage-class attributes

An upcoming commit will change the storage-class attributes to be
controlled by the GVDLL symbol in cdt.h.

Without this change, errors like this would occur:

circogen.lib(edgelist.obj) : error LNK2001: unresolved external symbol _Dtoset

Towards https://gitlab.com/graphviz/graphviz/-/issues/2173.

3 years agoneatogen: MSBuild: define GVDLL to ensure correct storage-class attributes
Magnus Jacobsson [Sat, 1 Jan 2022 17:01:01 +0000 (18:01 +0100)]
neatogen: MSBuild: define GVDLL to ensure correct storage-class attributes

An upcoming commit will change the storage-class attributes to be
controlled by the GVDLL symbol in cdt.h.

Without this change, errors like this would occur:

neatogen.lib(neatosplines.obj) : error LNK2001: unresolved external symbol _Dtoset

Towards https://gitlab.com/graphviz/graphviz/-/issues/2173.

3 years agoexpr: MSBuild: define GVDLL to ensure correct storage-class attributes
Magnus Jacobsson [Sat, 1 Jan 2022 17:01:01 +0000 (18:01 +0100)]
expr: MSBuild: define GVDLL to ensure correct storage-class attributes

An upcoming commit will change the storage-class attributes to be
controlled by the GVDLL symbol in cdt.h.

Without this change, errors like this would occur:

expr.lib(y.tab.obj) : error LNK2001: unresolved external symbol _Dtset

Towards https://gitlab.com/graphviz/graphviz/-/issues/2173.

3 years agocgraph: MSBuild: define GVDLL to ensure correct storage-class attributes
Magnus Jacobsson [Sat, 1 Jan 2022 17:01:01 +0000 (18:01 +0100)]
cgraph: MSBuild: define GVDLL to ensure correct storage-class attributes

An upcoming commit will change the storage-class attributes to be
controlled by the GVDLL symbol in cdt.h.

Without this change, errors like this would occur:

refstr.obj : error LNK2001: unresolved external symbol _Dttree [C:\GitLab-Runner\builds\magjac\graphviz\lib\cgraph\cgraph.vcxproj]

Towards https://gitlab.com/graphviz/graphviz/-/issues/2173.

3 years agoMerge branch 'post-remove-gvc-def-file-cleanup' into 'main'
Magnus Jacobsson [Wed, 5 Jan 2022 06:29:25 +0000 (06:29 +0000)]
Merge branch 'post-remove-gvc-def-file-cleanup' into 'main'

Some cleanup of duplicate declarations

See merge request graphviz/graphviz!2379

3 years agoplugin/gd: remove duplicate definition of Bezier in gvrender_gd_vrml.c
Magnus Jacobsson [Sun, 1 Aug 2021 20:57:20 +0000 (22:57 +0200)]
plugin/gd: remove duplicate definition of Bezier in gvrender_gd_vrml.c

Removes this warning:

C:\Users\magja\graphviz\plugin\gd\gvrender_gd_vrml.c(41,86): warning C4273: 'Bezier': inconsistent dll linkage [C:\Users\magja\graphviz\plugin\gd\gvplugin_gd.vcxproj]

3 years agoplugin/gd: remove duplicate declaration of shapeOf in plugin/gd/gvrender_gd_vrml.c
Magnus Jacobsson [Sun, 1 Aug 2021 20:54:53 +0000 (22:54 +0200)]
plugin/gd: remove duplicate declaration of shapeOf in plugin/gd/gvrender_gd_vrml.c

3 years agosparse: replace local declaration of colorxlate with including common/colorprocs...
Magnus Jacobsson [Tue, 27 Jul 2021 09:48:19 +0000 (11:48 +0200)]
sparse: replace local declaration of colorxlate with including common/colorprocs.h in colorutil.h

3 years agosparse: MSBuild: add windows include dir to find config.h
Magnus Jacobsson [Sun, 12 Dec 2021 11:27:44 +0000 (12:27 +0100)]
sparse: MSBuild: add windows include dir to find config.h

An upcoming commit which will include config.h in colorprocs.h would
otherwise cause this error:

C:\Users\magja\graphviz\lib\common\colorprocs.h(13,10): fatal error C1083: Cannot open include file: 'config.h': No such file or directory [C:\Users\magja\graphviz\lib\sparse\gvsparse.vcxproj]

3 years agodot: unconditionally include globals.h in dot.c instead of duplicating declarations...
Magnus Jacobsson [Mon, 26 Jul 2021 13:28:04 +0000 (15:28 +0200)]
dot: unconditionally include globals.h in dot.c instead of duplicating declarations for WIN32_DLL

3 years agoMerge branch 'remove-gvc-def-file' into 'main'
Magnus Jacobsson [Tue, 4 Jan 2022 17:51:05 +0000 (17:51 +0000)]
Merge branch 'remove-gvc-def-file' into 'main'

Remove the last symbols from gvc.def and remove the gvc.def file

Closes #2058

See merge request graphviz/graphviz!2376

3 years agogvc: remove now empty and obsolete gvc.def file
Magnus Jacobsson [Mon, 26 Jul 2021 11:19:38 +0000 (13:19 +0200)]
gvc: remove now empty and obsolete gvc.def file

Closes https://gitlab.com/graphviz/graphviz/-/issues/2058.

3 years agogvc: autotools: remove now obsolete use of gvc.def
Magnus Jacobsson [Mon, 26 Jul 2021 11:19:38 +0000 (13:19 +0200)]
gvc: autotools: remove now obsolete use of gvc.def

Towards https://gitlab.com/graphviz/graphviz/-/issues/2058.

3 years agogvc: CMake: remove now obsolete use of gvc.def
Magnus Jacobsson [Mon, 26 Jul 2021 11:19:38 +0000 (13:19 +0200)]
gvc: CMake: remove now obsolete use of gvc.def

Towards https://gitlab.com/graphviz/graphviz/-/issues/2058.

3 years agogvc: MSBuild: remove now obsolete use of gvc.def in project file
Magnus Jacobsson [Mon, 26 Jul 2021 11:19:38 +0000 (13:19 +0200)]
gvc: MSBuild: remove now obsolete use of gvc.def in project file

Towards https://gitlab.com/graphviz/graphviz/-/issues/2058.

3 years agogvc: remove now obsolete exporting of render.h symbol rank2 from gvc.def
Magnus Jacobsson [Wed, 15 Dec 2021 06:34:06 +0000 (07:34 +0100)]
gvc: remove now obsolete exporting of render.h symbol rank2 from gvc.def

Towards https://gitlab.com/graphviz/graphviz/-/issues/2058.

3 years agocommon: add missing declaration of rank2 to render.h
Magnus Jacobsson [Sun, 1 Aug 2021 11:25:17 +0000 (13:25 +0200)]
common: add missing declaration of rank2 to render.h

Also remove duplicated declaration of rank2 in rank.c in dotgen.

Towards https://gitlab.com/graphviz/graphviz/-/issues/2058.

3 years agogvc: remove now obsolete exporting of render.h symbols from gvc.def
Magnus Jacobsson [Wed, 15 Dec 2021 21:00:19 +0000 (22:00 +0100)]
gvc: remove now obsolete exporting of render.h symbols from gvc.def

Towards https://gitlab.com/graphviz/graphviz/-/issues/2058.

3 years agocommon: correct storage class attributes in render.h
Magnus Jacobsson [Sat, 11 Dec 2021 06:21:22 +0000 (07:21 +0100)]
common: correct storage class attributes in render.h

Towards https://gitlab.com/graphviz/graphviz/-/issues/2058.

3 years agogvc: remove now obsolete exporting of gvcproc.h symbol gvrender_ptf from gvc.def
Magnus Jacobsson [Wed, 15 Dec 2021 20:47:02 +0000 (21:47 +0100)]
gvc: remove now obsolete exporting of gvcproc.h symbol gvrender_ptf from gvc.def

Towards https://gitlab.com/graphviz/graphviz/-/issues/2058.

3 years agogvc: add storage-class attribute declaration of gvrender_ptf to gvcproc.h
Magnus Jacobsson [Wed, 28 Jul 2021 08:31:46 +0000 (10:31 +0200)]
gvc: add storage-class attribute declaration of gvrender_ptf to gvcproc.h

This will allow removing this symbol from gvc.def in an upcoming commit.

Note that no other symbols from gvcproc.h were exported from gvc.def,
hence the attributes are applied only to gvrender_ptf.

Towards https://gitlab.com/graphviz/graphviz/-/issues/2058.

3 years agoplugin/gd: replace local declaration of gvrender_ptf with including gvcproc.h in...
Magnus Jacobsson [Wed, 28 Jul 2021 08:31:46 +0000 (10:31 +0200)]
plugin/gd: replace local declaration of gvrender_ptf with including gvcproc.h in gvrender_gd_vrml.c

Towards https://gitlab.com/graphviz/graphviz/-/issues/2058.

3 years agoMerge branch 'smattr/659D906E-26CA-46C5-9E8A-CEC2CDBDE034' into 'main'
Matthew Fernandez [Tue, 4 Jan 2022 16:53:58 +0000 (16:53 +0000)]
Merge branch 'smattr/659D906E-26CA-46C5-9E8A-CEC2CDBDE034' into 'main'

convert mingle to C++

See merge request graphviz/graphviz!2362

3 years agomingle: use safer C++ casts
Matthew Fernandez [Sat, 25 Dec 2021 20:39:30 +0000 (12:39 -0800)]
mingle: use safer C++ casts

3 years agomingle: remove unnecessary include
Matthew Fernandez [Sat, 25 Dec 2021 20:36:15 +0000 (12:36 -0800)]
mingle: remove unnecessary include

3 years agomingle: use C++ 'nullptr' instead of C 'NULL'
Matthew Fernandez [Sat, 25 Dec 2021 20:35:50 +0000 (12:35 -0800)]
mingle: use C++ 'nullptr' instead of C 'NULL'

3 years agomingle: strip trailing space
Matthew Fernandez [Sat, 25 Dec 2021 20:35:08 +0000 (12:35 -0800)]
mingle: strip trailing space

3 years agomingle: replace C stdio with C++ iostream
Matthew Fernandez [Sat, 25 Dec 2021 20:32:36 +0000 (12:32 -0800)]
mingle: replace C stdio with C++ iostream

3 years agomingle bundle: avoid some manual memory management
Matthew Fernandez [Sat, 25 Dec 2021 20:17:42 +0000 (12:17 -0800)]
mingle bundle: avoid some manual memory management

Note that this appears to actually fix a memory leak as `xx` was never freed
previously.

3 years agomingle genBundleColors: avoid some manual memory management
Matthew Fernandez [Sat, 25 Dec 2021 20:10:38 +0000 (12:10 -0800)]
mingle genBundleColors: avoid some manual memory management

3 years agomingle: replace an 'agxbuf' with a 'std::ostringstream'
Matthew Fernandez [Sat, 25 Dec 2021 20:01:29 +0000 (12:01 -0800)]
mingle: replace an 'agxbuf' with a 'std::ostringstream'

Related to #2154.

3 years agoremove reference to non-existent cmd/mingle/ReadMe.txt
Matthew Fernandez [Sat, 25 Dec 2021 19:12:12 +0000 (11:12 -0800)]
remove reference to non-existent cmd/mingle/ReadMe.txt

3 years agoconvert Mingle to C++
Matthew Fernandez [Sat, 25 Dec 2021 19:05:47 +0000 (11:05 -0800)]
convert Mingle to C++

cmd/mingle depends on lib/mingle, which in turn depends on libANN, a C++
library. Thus the `mingle` binary needs to link against the C++ standard
library. There is no advantage to Mingle being implemented in C, and some nice
advantages to it being implemented in C++ instead.

This commit does a basic rename, as AFAICT nothing in minglemain.c has varying
semantics between C and C++. Future commits will use C++ features to simplify
the code.

Related to #2154.

3 years agomingle: cast results of 'malloc'
Matthew Fernandez [Sat, 25 Dec 2021 19:33:51 +0000 (11:33 -0800)]
mingle: cast results of 'malloc'

This has no effect at present. However, when moving this code to C++ in an
upcoming commit, it would trigger -fpermissive problems. This change
pre-emptively prevents this issue.

3 years agomingle: cast 'name' parameter values in 'agattr' calls
Matthew Fernandez [Sat, 25 Dec 2021 19:31:51 +0000 (11:31 -0800)]
mingle: cast 'name' parameter values in 'agattr' calls

This has no effect at present. However, when moving this code to C++ in an
upcoming commit, it would trigger -Wwrite-strings warnings. This change
pre-emptively prevents these warnings.

3 years agomingle: convert usage text to a const char array
Matthew Fernandez [Sat, 25 Dec 2021 19:26:32 +0000 (11:26 -0800)]
mingle: convert usage text to a const char array

This makes the intent of the code slightly clearer, but also pre-emptively
avoids an upcoming -Wwrite-strings warning when converting this code to C++.

Related to #2154.

3 years agolib/mingle: add guards, making headers safe to include from C++
Matthew Fernandez [Sat, 25 Dec 2021 19:11:27 +0000 (11:11 -0800)]
lib/mingle: add guards, making headers safe to include from C++

An upcoming change will convert cmd/mingle/minglemain.c to C++, which
includes some of these headers.

Related to #2154.

3 years agolib/sparse/color_palette.h: disambiguate an include
Matthew Fernandez [Sat, 25 Dec 2021 19:10:41 +0000 (11:10 -0800)]
lib/sparse/color_palette.h: disambiguate an include

3 years agolib/sparse: add guards, making headers safe to include from C++
Matthew Fernandez [Sat, 25 Dec 2021 19:09:15 +0000 (11:09 -0800)]
lib/sparse: add guards, making headers safe to include from C++

An upcoming change will convert cmd/mingle/minglemain.c to C++, which
transitively includes some of these headers.

Related to #2154.

3 years agoMerge branch 'smattr/f2181a81-197c-481f-af2f-df55298be60e' into 'main'
Matthew Fernandez [Tue, 4 Jan 2022 03:01:56 +0000 (03:01 +0000)]
Merge branch 'smattr/f2181a81-197c-481f-af2f-df55298be60e' into 'main'

remove cgraph macro aliases

See merge request graphviz/graphviz!2366

3 years agoremove cgraph macro aliases
Matthew Fernandez [Sun, 26 Dec 2021 03:56:19 +0000 (19:56 -0800)]
remove cgraph macro aliases

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.

3 years agoremove problematic 'agmkin', 'agmkout'
Matthew Fernandez [Sun, 26 Dec 2021 03:46:31 +0000 (19:46 -0800)]
remove problematic 'agmkin', 'agmkout'

These functions were introduced in c9b7b0719776e022d760195fae2727b84be82eda to
match `AGMKOUT` and `AGMKIN` (#1212). But there are no exposed prototypes for
these. So the only way to call them is to externally prototype them with a
best-guess type signature and hope Graphviz never changes. This commit removes
them to reduce portability problems.

3 years agoMerge branch 'smattr/59EAC8A6-959D-4CE7-86FD-A4205260BFC3' into 'main'
Matthew Fernandez [Tue, 4 Jan 2022 01:59:27 +0000 (01:59 +0000)]
Merge branch 'smattr/59EAC8A6-959D-4CE7-86FD-A4205260BFC3' into 'main'

enable Mingle on CentOS

See merge request graphviz/graphviz!2335