]> granicus.if.org Git - graphviz/log
graphviz
2 years agoremove redundant datetime computation in version script
Matthew Fernandez [Sat, 19 Nov 2022 17:39:00 +0000 (09:39 -0800)]
remove redundant datetime computation in version script

Instead of parsing the date Git gives us and then reformatting it into a new
form, we can just ask Git to give it to us in the format we want.

2 years agopush build system version computation into Python
Matthew Fernandez [Sat, 19 Nov 2022 17:31:19 +0000 (09:31 -0800)]
push build system version computation into Python

The Autotools build system was doing quite a bit of work to try and find a
`date` syntax that worked on the current platform and still failing (this logic
does not work on NetBSD). We can side step all of this by just doing date
manipulation in Python which we were calling anyway.

Gitlab: #2317

2 years agoremove 'GRAPHVIZ_VERSION_COMMIT' in the build system
Matthew Fernandez [Sat, 19 Nov 2022 17:13:13 +0000 (09:13 -0800)]
remove 'GRAPHVIZ_VERSION_COMMIT' in the build system

This is not used.

2 years agoMerge branch 'smattr/1fbc0bcb-4881-46b0-b5c2-1bcc4fd57266' into 'main'
Matthew Fernandez [Wed, 23 Nov 2022 17:44:10 +0000 (17:44 +0000)]
Merge branch 'smattr/1fbc0bcb-4881-46b0-b5c2-1bcc4fd57266' into 'main'

build sytem cleanup

See merge request graphviz/graphviz!2970

2 years agoAutotools: remove checking for the '_IO_read_end' member of 'FILE'
Matthew Fernandez [Thu, 8 Sep 2022 00:27:49 +0000 (17:27 -0700)]
Autotools: remove checking for the '_IO_read_end' member of 'FILE'

The last use of the result variable of this check, `HAVE_FILE_IO_READ_END`, was
removed in b2f287ca315dd5bf689d9ce2ca71dbfe63fb8a61.

2 years agoAutotools: remove checking for the '_next' member of 'FILE'
Matthew Fernandez [Thu, 8 Sep 2022 00:27:49 +0000 (17:27 -0700)]
Autotools: remove checking for the '_next' member of 'FILE'

The last use of the result variable of this check, `HAVE_FILE_NEXT`, was removed
in b2f287ca315dd5bf689d9ce2ca71dbfe63fb8a61.

2 years agoAutotools: remove checking for the '_r' member of 'FILE'
Matthew Fernandez [Thu, 8 Sep 2022 00:27:49 +0000 (17:27 -0700)]
Autotools: remove checking for the '_r' member of 'FILE'

The last use of the result variable of this check, `HAVE_FILE_R`, was removed
in b2f287ca315dd5bf689d9ce2ca71dbfe63fb8a61.

2 years agoAutotools: remove checking for the '_cnt' member of 'FILE'
Matthew Fernandez [Thu, 8 Sep 2022 00:27:49 +0000 (17:27 -0700)]
Autotools: remove checking for the '_cnt' member of 'FILE'

The last use of the result variable of this check, `HAVE_FILE_CNT`, was removed
in b2f287ca315dd5bf689d9ce2ca71dbfe63fb8a61.

2 years agoCMake: remove checking and fallback for 'ssize_t'
Matthew Fernandez [Thu, 8 Sep 2022 00:27:49 +0000 (17:27 -0700)]
CMake: remove checking and fallback for 'ssize_t'

It seems all contemporary supported platforms except Windows have `ssize_t`.
Furthermore, `int` is not a suitable fallback for a platform that does not have
`ssize_t`.

2 years agoMerge branch 'smattr/286d5d12-d610-4f58-b5c2-c9c36d4bfbf8' into 'main'
Matthew Fernandez [Wed, 23 Nov 2022 15:00:21 +0000 (15:00 +0000)]
Merge branch 'smattr/286d5d12-d610-4f58-b5c2-c9c36d4bfbf8' into 'main'

fdpgen: use cgraph wrappers for allocation

See merge request graphviz/graphviz!2971

2 years agofdpgen: squash -Wdebug warning when building without 'DEBUG' defined
Matthew Fernandez [Wed, 23 Nov 2022 04:38:39 +0000 (20:38 -0800)]
fdpgen: squash -Wdebug warning when building without 'DEBUG' defined

2 years agofdpgen: use 'size_t' types for object list counts
Matthew Fernandez [Wed, 23 Nov 2022 04:32:19 +0000 (20:32 -0800)]
fdpgen: use 'size_t' types for object list counts

Squashes some -Wsign-conversion warnings.

2 years agofdpgen objectList: use cgraph wrapper for allocation
Matthew Fernandez [Fri, 18 Nov 2022 01:14:41 +0000 (17:14 -0800)]
fdpgen objectList: use cgraph wrapper for allocation

The lib/cgraph/alloc.h wrappers are similar to the older lib/common/memory.h
wrappers except (1) they are header-only and (2) they live in a directory
(cgraph) that is at the root of the dependency tree. The long term plan is to
replace all use of lib/common/memory.h with lib/cgraph/alloc.h.

2 years agofdpgen makeClustObs: use cgraph wrappers for allocation
Matthew Fernandez [Fri, 18 Nov 2022 01:14:41 +0000 (17:14 -0800)]
fdpgen makeClustObs: use cgraph wrappers for allocation

The lib/cgraph/alloc.h wrappers are similar to the older lib/common/memory.h
wrappers except (1) they are header-only and (2) they live in a directory
(cgraph) that is at the root of the dependency tree. The long term plan is to
replace all use of lib/common/memory.h with lib/cgraph/alloc.h.

2 years agofdpgen addObj: use cgraph wrappers for allocation
Matthew Fernandez [Fri, 18 Nov 2022 01:14:41 +0000 (17:14 -0800)]
fdpgen addObj: use cgraph wrappers for allocation

The lib/cgraph/alloc.h wrappers are similar to the older lib/common/memory.h
wrappers except (1) they are header-only and (2) they live in a directory
(cgraph) that is at the root of the dependency tree. The long term plan is to
replace all use of lib/common/memory.h with lib/cgraph/alloc.h.

2 years agofdpgen compoundEdges: remove unused 'P' local
Matthew Fernandez [Wed, 23 Nov 2022 04:25:48 +0000 (20:25 -0800)]
fdpgen compoundEdges: remove unused 'P' local

2 years agofdpgen fdp_init_node_edge: use cgraph wrapper for allocation
Matthew Fernandez [Fri, 18 Nov 2022 01:14:41 +0000 (17:14 -0800)]
fdpgen fdp_init_node_edge: use cgraph wrapper for allocation

The lib/cgraph/alloc.h wrappers are similar to the older lib/common/memory.h
wrappers except (1) they are header-only and (2) they live in a directory
(cgraph) that is at the root of the dependency tree. The long term plan is to
replace all use of lib/common/memory.h with lib/cgraph/alloc.h.

2 years agofdpgen init_node: use cgraph wrapper for allocation
Matthew Fernandez [Fri, 18 Nov 2022 01:14:41 +0000 (17:14 -0800)]
fdpgen init_node: use cgraph wrapper for allocation

The lib/cgraph/alloc.h wrappers are similar to the older lib/common/memory.h
wrappers except (1) they are header-only and (2) they live in a directory
(cgraph) that is at the root of the dependency tree. The long term plan is to
replace all use of lib/common/memory.h with lib/cgraph/alloc.h.

2 years agofdpgen findCComp: use cgraph wrappers for allocation
Matthew Fernandez [Fri, 18 Nov 2022 01:14:41 +0000 (17:14 -0800)]
fdpgen findCComp: use cgraph wrappers for allocation

The lib/cgraph/alloc.h wrappers are similar to the older lib/common/memory.h
wrappers except (1) they are header-only and (2) they live in a directory
(cgraph) that is at the root of the dependency tree. The long term plan is to
replace all use of lib/common/memory.h with lib/cgraph/alloc.h.

2 years agofdpgen adjustGrid: use cgraph wrapper for allocation
Matthew Fernandez [Fri, 18 Nov 2022 01:14:41 +0000 (17:14 -0800)]
fdpgen adjustGrid: use cgraph wrapper for allocation

The lib/cgraph/alloc.h wrappers are similar to the older lib/common/memory.h
wrappers except (1) they are header-only and (2) they live in a directory
(cgraph) that is at the root of the dependency tree. The long term plan is to
replace all use of lib/common/memory.h with lib/cgraph/alloc.h.

2 years agofdpgen newBlock: use cgraph wrappers for allocation
Matthew Fernandez [Fri, 18 Nov 2022 01:14:41 +0000 (17:14 -0800)]
fdpgen newBlock: use cgraph wrappers for allocation

The lib/cgraph/alloc.h wrappers are similar to the older lib/common/memory.h
wrappers except (1) they are header-only and (2) they live in a directory
(cgraph) that is at the root of the dependency tree. The long term plan is to
replace all use of lib/common/memory.h with lib/cgraph/alloc.h.

2 years agofdpgen: allocate '_grid' as a global
Matthew Fernandez [Wed, 23 Nov 2022 03:53:35 +0000 (19:53 -0800)]
fdpgen: allocate '_grid' as a global

There is no need to heap-allocate this singleton.

2 years agofdpgen layout: use cgraph wrapper for allocation
Matthew Fernandez [Fri, 18 Nov 2022 01:14:41 +0000 (17:14 -0800)]
fdpgen layout: use cgraph wrapper for allocation

The lib/cgraph/alloc.h wrappers are similar to the older lib/common/memory.h
wrappers except (1) they are header-only and (2) they live in a directory
(cgraph) that is at the root of the dependency tree. The long term plan is to
replace all use of lib/common/memory.h with lib/cgraph/alloc.h.

2 years agofdpgen expandCluster: use cgraph wrapper for allocation
Matthew Fernandez [Fri, 18 Nov 2022 01:14:41 +0000 (17:14 -0800)]
fdpgen expandCluster: use cgraph wrapper for allocation

The lib/cgraph/alloc.h wrappers are similar to the older lib/common/memory.h
wrappers except (1) they are header-only and (2) they live in a directory
(cgraph) that is at the root of the dependency tree. The long term plan is to
replace all use of lib/common/memory.h with lib/cgraph/alloc.h.

2 years agofdpgen getEdgeList: use cgraph wrapper for allocation
Matthew Fernandez [Fri, 18 Nov 2022 01:14:41 +0000 (17:14 -0800)]
fdpgen getEdgeList: use cgraph wrapper for allocation

The lib/cgraph/alloc.h wrappers are similar to the older lib/common/memory.h
wrappers except (1) they are header-only and (2) they live in a directory
(cgraph) that is at the root of the dependency tree. The long term plan is to
replace all use of lib/common/memory.h with lib/cgraph/alloc.h.

2 years agofdpgen deriveGraph: use cgraph wrapper for allocation
Matthew Fernandez [Fri, 18 Nov 2022 01:14:41 +0000 (17:14 -0800)]
fdpgen deriveGraph: use cgraph wrapper for allocation

The lib/cgraph/alloc.h wrappers are similar to the older lib/common/memory.h
wrappers except (1) they are header-only and (2) they live in a directory
(cgraph) that is at the root of the dependency tree. The long term plan is to
replace all use of lib/common/memory.h with lib/cgraph/alloc.h.

2 years agofdpgen addEdge: use cgraph wrapper for allocation
Matthew Fernandez [Fri, 18 Nov 2022 01:14:41 +0000 (17:14 -0800)]
fdpgen addEdge: use cgraph wrapper for allocation

The lib/cgraph/alloc.h wrappers are similar to the older lib/common/memory.h
wrappers except (1) they are header-only and (2) they live in a directory
(cgraph) that is at the root of the dependency tree. The long term plan is to
replace all use of lib/common/memory.h with lib/cgraph/alloc.h.

2 years agofdpgen addCluster: use cgraph wrapper for allocation
Matthew Fernandez [Fri, 18 Nov 2022 01:14:41 +0000 (17:14 -0800)]
fdpgen addCluster: use cgraph wrapper for allocation

The lib/cgraph/alloc.h wrappers are similar to the older lib/common/memory.h
wrappers except (1) they are header-only and (2) they live in a directory
(cgraph) that is at the root of the dependency tree. The long term plan is to
replace all use of lib/common/memory.h with lib/cgraph/alloc.h.

2 years agofdpgen mkDeriveNode: use cgraph wrappers for allocation
Matthew Fernandez [Fri, 18 Nov 2022 01:14:41 +0000 (17:14 -0800)]
fdpgen mkDeriveNode: use cgraph wrappers for allocation

The lib/cgraph/alloc.h wrappers are similar to the older lib/common/memory.h
wrappers except (1) they are header-only and (2) they live in a directory
(cgraph) that is at the root of the dependency tree. The long term plan is to
replace all use of lib/common/memory.h with lib/cgraph/alloc.h.

2 years agofdpgen: remove 'SHOW_GRID' guarded code
Matthew Fernandez [Wed, 23 Nov 2022 02:53:36 +0000 (18:53 -0800)]
fdpgen: remove 'SHOW_GRID' guarded code

As far as I can tell, this code has never been compilable. It relies on `CellW`
and `CellH`, neither of which have ever been defined in Graphviz’ history.

2 years agoMerge branch 'smattr/6a68aa2c-f300-4e65-b38c-7dbd09efbb1b' into 'main'
Matthew Fernandez [Tue, 22 Nov 2022 16:51:43 +0000 (16:51 +0000)]
Merge branch 'smattr/6a68aa2c-f300-4e65-b38c-7dbd09efbb1b' into 'main'

drop special build system cases for ICC

Closes #2298

See merge request graphviz/graphviz!2968

2 years agoremove 'intptr_t' existence checks
Matthew Fernandez [Sun, 20 Nov 2022 19:29:55 +0000 (11:29 -0800)]
remove 'intptr_t' existence checks

The majority of Graphviz code was using the types `intptr_t` and `uintptr_t`
unconditionally. So it seems safe to assume that any compliant C99 environment
has both of these.

2 years agoremove setting of 'RC_IS_RC' variable in Autotools
Matthew Fernandez [Sun, 20 Nov 2022 19:19:27 +0000 (11:19 -0800)]
remove setting of 'RC_IS_RC' variable in Autotools

The last use of this was removed in 6faa34010f947510ec129af2d998614de8a513ed.

2 years agoremove unused 'RC_IS_WINDRES' variable in Autotools
Matthew Fernandez [Sun, 20 Nov 2022 19:18:26 +0000 (11:18 -0800)]
remove unused 'RC_IS_WINDRES' variable in Autotools

The last use of this was removed in 520da9cd8b8d23007f325e84fdbda733d7e6d57c.

2 years agodrop special build system cases for ICC
Matthew Fernandez [Sun, 20 Nov 2022 19:15:48 +0000 (11:15 -0800)]
drop special build system cases for ICC

The Intel C Compiler is now based on LLVM. We think this means it has a Clang
compatible front end, though we do not have access to it to check. If this is
accurate, it means the build system no longer needs any specialized ICC support.

Gitlab: closes #2298

2 years agoMerge branch 'gshklover_perf' into 'main'
Matthew Fernandez [Mon, 21 Nov 2022 01:15:32 +0000 (01:15 +0000)]
Merge branch 'gshklover_perf' into 'main'

Small performance improvement to simplex

See merge request graphviz/graphviz!2851

2 years agoSmall performance improvement to simplex
Gregory Shklover [Thu, 22 Sep 2022 07:27:48 +0000 (07:27 +0000)]
Small performance improvement to simplex

2 years agoMerge branch 'smattr/618319b7-f821-49c5-be38-5d715a6ee95d' into 'main'
Matthew Fernandez [Sat, 19 Nov 2022 22:49:51 +0000 (22:49 +0000)]
Merge branch 'smattr/618319b7-f821-49c5-be38-5d715a6ee95d' into 'main'

remove 'GRAPHVIZ_SOURCES' from the build system

See merge request graphviz/graphviz!2963

2 years agoremove 'GRAPHVIZ_SOURCES' from the build system
Matthew Fernandez [Sat, 19 Nov 2022 17:46:53 +0000 (09:46 -0800)]
remove 'GRAPHVIZ_SOURCES' from the build system

This URL is out of date and is only used in artifacts that have also bit rotted.

2 years agoMerge branch 'smattr/dd095df0-ddfa-490d-a073-4e0e81e759fe' into 'main'
Matthew Fernandez [Sat, 19 Nov 2022 06:15:39 +0000 (06:15 +0000)]
Merge branch 'smattr/dd095df0-ddfa-490d-a073-4e0e81e759fe' into 'main'

neatogen: migration to cgraph allocation wrappers, clean up

See merge request graphviz/graphviz!2960

2 years agoneatogen bbox: abbreviate some open coded 'fmax', 'fmin'
Matthew Fernandez [Fri, 18 Nov 2022 02:11:33 +0000 (18:11 -0800)]
neatogen bbox: abbreviate some open coded 'fmax', 'fmin'

2 years agoneatogen: remove some unnecessary parens
Matthew Fernandez [Fri, 18 Nov 2022 02:11:17 +0000 (18:11 -0800)]
neatogen: remove some unnecessary parens

2 years agoneatogen cmpItem: abbreviate and use early return style
Matthew Fernandez [Fri, 18 Nov 2022 02:01:46 +0000 (18:01 -0800)]
neatogen cmpItem: abbreviate and use early return style

2 years agoneatogen makeMultiSpline: use cgraph wrapper for allocation
Matthew Fernandez [Fri, 18 Nov 2022 01:14:41 +0000 (17:14 -0800)]
neatogen makeMultiSpline: use cgraph wrapper for allocation

The lib/cgraph/alloc.h wrappers are similar to the older lib/common/memory.h
wrappers except (1) they are header-only and (2) they live in a directory
(cgraph) that is at the root of the dependency tree. The long term plan is to
replace all use of lib/common/memory.h with lib/cgraph/alloc.h.

2 years agoneatogen triPath: use cgraph wrapper for allocation
Matthew Fernandez [Fri, 18 Nov 2022 01:14:41 +0000 (17:14 -0800)]
neatogen triPath: use cgraph wrapper for allocation

The lib/cgraph/alloc.h wrappers are similar to the older lib/common/memory.h
wrappers except (1) they are header-only and (2) they live in a directory
(cgraph) that is at the root of the dependency tree. The long term plan is to
replace all use of lib/common/memory.h with lib/cgraph/alloc.h.

2 years agoneatogen mkPoly: use cgraph wrapper for allocation
Matthew Fernandez [Fri, 18 Nov 2022 01:14:41 +0000 (17:14 -0800)]
neatogen mkPoly: use cgraph wrapper for allocation

The lib/cgraph/alloc.h wrappers are similar to the older lib/common/memory.h
wrappers except (1) they are header-only and (2) they live in a directory
(cgraph) that is at the root of the dependency tree. The long term plan is to
replace all use of lib/common/memory.h with lib/cgraph/alloc.h.

2 years agoneatogen genroute: use cgraph wrapper for allocation
Matthew Fernandez [Fri, 18 Nov 2022 01:14:41 +0000 (17:14 -0800)]
neatogen genroute: use cgraph wrapper for allocation

The lib/cgraph/alloc.h wrappers are similar to the older lib/common/memory.h
wrappers except (1) they are header-only and (2) they live in a directory
(cgraph) that is at the root of the dependency tree. The long term plan is to
replace all use of lib/common/memory.h with lib/cgraph/alloc.h.

2 years agoneatogen finishEdge: use cgraph wrapper for allocation
Matthew Fernandez [Fri, 18 Nov 2022 01:14:41 +0000 (17:14 -0800)]
neatogen finishEdge: use cgraph wrapper for allocation

The lib/cgraph/alloc.h wrappers are similar to the older lib/common/memory.h
wrappers except (1) they are header-only and (2) they live in a directory
(cgraph) that is at the root of the dependency tree. The long term plan is to
replace all use of lib/common/memory.h with lib/cgraph/alloc.h.

2 years agoneatogen mkRouter: use cgraph wrapper for allocation
Matthew Fernandez [Fri, 18 Nov 2022 01:14:41 +0000 (17:14 -0800)]
neatogen mkRouter: use cgraph wrapper for allocation

The lib/cgraph/alloc.h wrappers are similar to the older lib/common/memory.h
wrappers except (1) they are header-only and (2) they live in a directory
(cgraph) that is at the root of the dependency tree. The long term plan is to
replace all use of lib/common/memory.h with lib/cgraph/alloc.h.

2 years agoneatogen mkTriGraph: use cgraph wrapper for allocation
Matthew Fernandez [Fri, 18 Nov 2022 01:14:41 +0000 (17:14 -0800)]
neatogen mkTriGraph: use cgraph wrapper for allocation

The lib/cgraph/alloc.h wrappers are similar to the older lib/common/memory.h
wrappers except (1) they are header-only and (2) they live in a directory
(cgraph) that is at the root of the dependency tree. The long term plan is to
replace all use of lib/common/memory.h with lib/cgraph/alloc.h.

Note that in this change we can drop some explicit initialization because the
cgraph wrappers zero-initialize.

2 years agoneatogen: use a more appropriate type for counting edges
Matthew Fernandez [Fri, 18 Nov 2022 01:37:08 +0000 (17:37 -0800)]
neatogen: use a more appropriate type for counting edges

Squashes some -Wsign-conversion warnings.

2 years agoneatogen: remove upfront allocation of trigraph edges
Matthew Fernandez [Fri, 18 Nov 2022 01:27:12 +0000 (17:27 -0800)]
neatogen: remove upfront allocation of trigraph edges

Following on from fc465488e1e62fe5ef879b379a07ef272431f400, this removes
assumptions about how many total edges will be generated by this algorithm. New
edges are now allocated on demand when appending.

2 years agoneatogen mkTriIndices: use cgraph wrapper for allocation
Matthew Fernandez [Fri, 18 Nov 2022 01:14:41 +0000 (17:14 -0800)]
neatogen mkTriIndices: use cgraph wrapper for allocation

The lib/cgraph/alloc.h wrappers are similar to the older lib/common/memory.h
wrappers except (1) they are header-only and (2) they live in a directory
(cgraph) that is at the root of the dependency tree. The long term plan is to
replace all use of lib/common/memory.h with lib/cgraph/alloc.h.

2 years agoneatogen mkCtrlPts: use cgraph wrapper for allocation
Matthew Fernandez [Fri, 18 Nov 2022 01:14:41 +0000 (17:14 -0800)]
neatogen mkCtrlPts: use cgraph wrapper for allocation

The lib/cgraph/alloc.h wrappers are similar to the older lib/common/memory.h
wrappers except (1) they are header-only and (2) they live in a directory
(cgraph) that is at the root of the dependency tree. The long term plan is to
replace all use of lib/common/memory.h with lib/cgraph/alloc.h.

2 years agoneatogen addTri: use cgraph wrapper for allocation
Matthew Fernandez [Fri, 18 Nov 2022 01:14:41 +0000 (17:14 -0800)]
neatogen addTri: use cgraph wrapper for allocation

The lib/cgraph/alloc.h wrappers are similar to the older lib/common/memory.h
wrappers except (1) they are header-only and (2) they live in a directory
(cgraph) that is at the root of the dependency tree. The long term plan is to
replace all use of lib/common/memory.h with lib/cgraph/alloc.h.

2 years agoneatogen newIpair: use cgraph wrapper for allocation
Matthew Fernandez [Fri, 18 Nov 2022 01:14:02 +0000 (17:14 -0800)]
neatogen newIpair: use cgraph wrapper for allocation

The lib/cgraph/alloc.h wrappers are similar to the older lib/common/memory.h
wrappers except (1) they are header-only and (2) they live in a directory
(cgraph) that is at the root of the dependency tree. The long term plan is to
replace all use of lib/common/memory.h with lib/cgraph/alloc.h.

2 years agoneatogen newItem: use cgraph wrapper for allocation
Matthew Fernandez [Fri, 18 Nov 2022 01:12:52 +0000 (17:12 -0800)]
neatogen newItem: use cgraph wrapper for allocation

The lib/cgraph/alloc.h wrappers are similar to the older lib/common/memory.h
wrappers except (1) they are header-only and (2) they live in a directory
(cgraph) that is at the root of the dependency tree. The long term plan is to
replace all use of lib/common/memory.h with lib/cgraph/alloc.h.

2 years agoMerge branch 'smattr/gitlab-1838' into 'main'
Matthew Fernandez [Sat, 19 Nov 2022 03:57:43 +0000 (03:57 +0000)]
Merge branch 'smattr/gitlab-1838' into 'main'

CMake: fix: teach 'gvpack' how to find plugins at run time

Closes #1838

See merge request graphviz/graphviz!2947

2 years agoCMake: fix: teach 'gvpack' how to find plugins at run time
Matthew Fernandez [Sat, 12 Nov 2022 18:50:53 +0000 (10:50 -0800)]
CMake: fix: teach 'gvpack' how to find plugins at run time

Because `gvpack` links against the plugins as libraries rather than loading them
on demand, the dynamic linker needs to be able to locate the plugin libraries at
run time.

CC: Jaroslav Škarvada <jskarvad@redhat.com>
Gitlab: fixes #1838
Red Hat: fixes https://bugzilla.redhat.com/show_bug.cgi?id=1838679

2 years agoCMake: fix: stop disabling demand loading in tools
Matthew Fernandez [Fri, 11 Nov 2022 16:04:47 +0000 (08:04 -0800)]
CMake: fix: stop disabling demand loading in tools

The Autotools build system only disables demand loading in `gvpack` among the
tools, but the CMake build system was disabling it for all tools.

2 years agoMerge branch 'smattr/5af11577-90f4-461d-b097-b4931494e660' into 'main'
Matthew Fernandez [Sat, 19 Nov 2022 02:52:25 +0000 (02:52 +0000)]
Merge branch 'smattr/5af11577-90f4-461d-b097-b4931494e660' into 'main'

Start 7.0.3 development

See merge request graphviz/graphviz!2961

2 years agoStart 7.0.3 development
Matthew Fernandez [Sat, 19 Nov 2022 01:12:09 +0000 (17:12 -0800)]
Start 7.0.3 development

2 years agoMerge branch 'smattr/1361001b-6b80-47e2-b616-d78399cbb2ec' into 'main' 7.0.2
Matthew Fernandez [Sat, 19 Nov 2022 01:10:29 +0000 (01:10 +0000)]
Merge branch 'smattr/1361001b-6b80-47e2-b616-d78399cbb2ec' into 'main'

Stable Release 7.0.2

See merge request graphviz/graphviz!2959

2 years agoStable Release 7.0.2
Matthew Fernandez [Fri, 18 Nov 2022 01:03:45 +0000 (17:03 -0800)]
Stable Release 7.0.2

2 years agoMerge branch 'smattr/gitlab-265' into 'main'
Matthew Fernandez [Fri, 18 Nov 2022 01:01:39 +0000 (01:01 +0000)]
Merge branch 'smattr/gitlab-265' into 'main'

core plugin: stop emitting an empty 'alt' tag in cmap output

Closes #265

See merge request graphviz/graphviz!2958

2 years agocore plugin: stop emitting an empty 'alt' tag in cmap output
Matthew Fernandez [Thu, 17 Nov 2022 15:56:29 +0000 (07:56 -0800)]
core plugin: stop emitting an empty 'alt' tag in cmap output

This was working around a behavior on an old version of Microsoft Internet
Explorer that is no longer supported. Tooltips should show consistently on
modern browsers and the `alt` tag is once again available to be set dynamically
by Javascript or inherited.

Gitlab: closes #265
Reporte-by: ib
2 years agoMerge branch 'smattr/e1d8b50e-417f-46d2-9ae7-19dc5bceddf9' into 'main'
Matthew Fernandez [Thu, 17 Nov 2022 05:57:09 +0000 (05:57 +0000)]
Merge branch 'smattr/e1d8b50e-417f-46d2-9ae7-19dc5bceddf9' into 'main'

add 'gvedit' to the CMake build system

Closes #1836 and #1753

See merge request graphviz/graphviz!2953

2 years agoadd 'gvedit' to the CMake build system
Matthew Fernandez [Mon, 14 Nov 2022 03:37:35 +0000 (19:37 -0800)]
add 'gvedit' to the CMake build system

Note that we need to disable building GVEdit on Windows in CI because we do not
currently have Qt installed there.¹

Gitlab: closes #1753, closes #1836

¹ See https://gitlab.com/graphviz/graphviz/-/merge_requests/1569 for further
  discussion.

2 years agoCI: add Qt generated sources to files excluded from coverage analysis
Matthew Fernandez [Wed, 16 Nov 2022 04:20:34 +0000 (20:20 -0800)]
CI: add Qt generated sources to files excluded from coverage analysis

These will be generated by an upcoming commit adding GVEdit to the CMake build
system. The cryptic EWIEGA46WW directory in this path is a checksum generated by
`AUTOMOC`. But it is based on relative path and appears to be stable as long as
we do not rename any cmd/gvedit subdirectories.

Gitlab: #1836

2 years agoCI: modernize coverage script to use 'pathlib'
Matthew Fernandez [Wed, 16 Nov 2022 04:09:40 +0000 (20:09 -0800)]
CI: modernize coverage script to use 'pathlib'

2 years agoCI: abbreviate passing options to CMake in the windows build
Matthew Fernandez [Mon, 14 Nov 2022 05:05:08 +0000 (21:05 -0800)]
CI: abbreviate passing options to CMake in the windows build

2 years agogvedit: modernize 'QLabel::pixmap' calls
Matthew Fernandez [Mon, 14 Nov 2022 03:52:37 +0000 (19:52 -0800)]
gvedit: modernize 'QLabel::pixmap' calls

Qt 5.15 deprecated the version of this function that returns a pointer and
throws compiler warnings when calls to it are seen. This modernization is
necessary to avoid the upcoming integration of Gvedit into the CMake build
system failing in CI where `-Werror` is applied.

Unfortunately we need to do this conditionally while retaining the old code for,
e.g., CentOS 7 which has a version of Qt 5.15 that does not have the new API.

Gitlab: #1836

2 years agogvedit: locate attrs.txt based on the location of our own executable
Matthew Fernandez [Mon, 14 Nov 2022 03:18:11 +0000 (19:18 -0800)]
gvedit: locate attrs.txt based on the location of our own executable

This commit adapts 24bd92c1e5d49b354141cd06d88ca658991b9825 that taught Smyrna
how to find the share directory without a build time define to Gvedit. The
pattern is essentially the same, but we can take advantage of some nicer C++
mechanisms instead of C.

The motivation for this is to make integration of Gvedit into the CMake build
system easier. By doing location of the share directory in the code instead of
the build system, we can more easily ensure the same behavior between build
systems. A side effect of this is the `gvedit` binary becoming more relocatable.

Note that the Windows discovery mechanism differs from what it was before, but
it is now more in line with how discovery works on other platforms.

Gitlab: #1836

2 years agoMerge branch 'smattr/gitlab-42' into 'main'
Matthew Fernandez [Thu, 17 Nov 2022 04:52:41 +0000 (04:52 +0000)]
Merge branch 'smattr/gitlab-42' into 'main'

fix neato crash in trigraph code

Closes #42

See merge request graphviz/graphviz!2955

2 years agoneatogen: fix miscalculation of intermediate edge resources
Matthew Fernandez [Tue, 15 Nov 2022 04:36:15 +0000 (20:36 -0800)]
neatogen: fix miscalculation of intermediate edge resources

`genroute` was allocating an array for edge computation upfront. But what it was
not accounting for was that some of the functions it later calls _change_ the
`pn` value it used to determine how many array elements it should allocate.
Specifically, `Pshortestpath` can add new points to the polygon, thereby causing
the walk of the (now too short) array to write out of bounds.

Gitlab: fixes #42
Reported-by: mattjj
2 years agoneatogen: fix out of bounds write when exceeding estimated edges
Matthew Fernandez [Tue, 15 Nov 2022 04:16:48 +0000 (20:16 -0800)]
neatogen: fix out of bounds write when exceeding estimated edges

The `edgei` allocation in `mkTriGraph` was wrong. This code was written prior to
Git history, and it is not obvious how the calculation for how many edges to
allocate was arrived at. My educated guess is that the `+ 2` was intended to
account for the maximum number of final appended edges (the maximum trip count
of the trailing loop in this function), except that is 3 not 2. Bumping this to
3 indeed bypasses the ASan failure in #42.

Rather than just make that equally error prone adjustment, this commit stops
estimating the edge count upfront at all and instead allocates edges per-node
on-demand.

The prior code was allocating edges for all nodes as a contiguous array. Each
node would then be given an offset pointer into this array. Apart from the
problem described above, this meant all nodes apart from the last one could
overflow their edge count, silently corrupting their neighbor’s edges, in a way
undetectable by ASan. This refactoring gives each node distinct memory for its
edges. But this means we needed to introduce a node count (`nnodes`) to the
trigraph and free each of these separate allocations when destructing the
trigraph.

This also required passing in original edge counts to `resetGraph`. Previously
the code would detect an edge that needed to be removed by a node’s edges
running up against its neighbor’s. Obviously this was subject to the above
described bugs which could cause false negatives in this test, leading to even
further compounding data corruption.

Fixing this unfortunately only yields yet another ASan crash (below). This will
be addressed in an upcoming commit.

  WRITE of size 16 at 0x613000001860 thread T0
      #0 0x7f5b44579e80 in genroute lib/neatogen/multispline.c:869
      #1 0x7f5b4457f53d in makeMultiSpline lib/neatogen/multispline.c:1311
      #2 0x7f5b4452ac4d in _spline_edges lib/neatogen/neatosplines.c:632
      #3 0x7f5b4452b4c8 in splineEdges lib/neatogen/neatosplines.c:729
      #4 0x7f5b4452b5a6 in spline_edges1 lib/neatogen/neatosplines.c:742
      #5 0x7f5b4452b658 in spline_edges0 lib/neatogen/neatosplines.c:771
      #6 0x7f5b4451154d in init_nop lib/neatogen/neatoinit.c:597
      #7 0x7f5b44516ac9 in neato_layout lib/neatogen/neatoinit.c:1407
      #8 0x7f5b488a847f  (/tmp/tmp.jiRlFO5wtW/lib+0x8647f)
      #9 0x55ddbc8126dc in main graphviz/cmd/dot/dot.c:89
      #10 0x7f5b485e2d8f in __libc_start_call_main ../sysdeps/nptl/libc_start_call_main.h:58
      #11 0x7f5b485e2e3f in __libc_start_main_impl ../csu/libc-start.c:392
      #12 0x55ddbc812344 in _start (bin/dot+0x1344)

It should be clear from the above that the code here has a very error prone
structure. (1) Estimating how much memory is required upfront with non-trivial
calculations and (2) allocating a block of memory that is then partitioned out
to clients trusted not to run into each other, effectively creates a scenario
where bugs are undetectable by memory safety tools and easily compound one
another. In future the other allocations in this file should be rewritten to
avoid this structure too.

Gitlab: #42

2 years agoadd a test case for #42
Matthew Fernandez [Tue, 15 Nov 2022 03:32:37 +0000 (19:32 -0800)]
add a test case for #42

2 years agoMerge branch 'smattr/005583fa-dfb4-44c4-82b8-bc8e3b96a8ee' into 'main'
Matthew Fernandez [Thu, 17 Nov 2022 03:58:04 +0000 (03:58 +0000)]
Merge branch 'smattr/005583fa-dfb4-44c4-82b8-bc8e3b96a8ee' into 'main'

smyrna: fix macOS compilation errors

See merge request graphviz/graphviz!2951

2 years agosmyrna: fix 'readlink' compilation error on macOS
Matthew Fernandez [Sun, 13 Nov 2022 23:12:57 +0000 (15:12 -0800)]
smyrna: fix 'readlink' compilation error on macOS

The code added in 24bd92c1e5d49b354141cd06d88ca658991b9825 calls `readlink` in
multiple paths, including the macOS branch. This function needs the #include
<unistd.h> but we were only conditionally including it when not on Windows or
macOS, when we _do_ need it on macOS. Similar to the previous commit, it seems
this went unnoticed because the macOS CI jobs do not build Smyrna.

2 years agosmyrna: fix 'path' compilation error on macOS
Matthew Fernandez [Sun, 13 Nov 2022 23:05:49 +0000 (15:05 -0800)]
smyrna: fix 'path' compilation error on macOS

24bd92c1e5d49b354141cd06d88ca658991b9825 managed to commit code to Smyrna on
which the macOS branch of the logic does not compile. It seems this went
unnoticed because the macOS CI jobs do not build Smyrna.

2 years agouse input gradient angle rather than computed gradient angle when checking for 0
Matthew Fernandez [Sun, 13 Nov 2022 22:22:03 +0000 (14:22 -0800)]
use input gradient angle rather than computed gradient angle when checking for 0

When using radial gradients, a value of 0 is interpreted differently to other
values:¹

  a value of zero causes the colors to transform radially from the center; for
  non-zero values, the colors transform from a point near the object’s periphery
  as specified by the value.

The code affected in this commit is looking for this situation, but was
unnecessarily using the computed gradient angle. If the original is zero, the
computed angle will also be zero. So we can simplify this code for both human
readers and the compiler by using the original (integer) angle.

This squashes the warnings:

  gvrender_core_dot.c: In function ‘xdot_gradient_fillcolor’:
  gvrender_core_dot.c:644:19: warning: comparing floating-point with ‘==’ or
    ‘!=’ is unsafe [-Wfloat-equal]
    644 |         if (angle == 0) {
        |                   ^~
  gvrender_core_svg.c: In function ‘svg_rgradstyle’:
  gvrender_core_svg.c:602:15: warning: comparing floating-point with ‘==’ or
    ‘!=’ is unsafe [-Wfloat-equal]
    602 |     if (angle == 0.) {
        |               ^~
  gvrender_pango.c:322:19: warning: comparing floating-point with ‘==’ or ‘!=’
    is unsafe [-Wfloat-equal]
    322 |         if (angle == 0) {
        |                   ^~

Gitlab: related to #2313

¹ https://graphviz.org/docs/attrs/gradientangle/

2 years agoMerge branch 'smattr/681394c3-c5d5-4f79-ba6f-7039662791a1' into 'main'
Matthew Fernandez [Thu, 17 Nov 2022 02:48:41 +0000 (02:48 +0000)]
Merge branch 'smattr/681394c3-c5d5-4f79-ba6f-7039662791a1' into 'main'

tests: fix path from which to import 'gvtest'

See merge request graphviz/graphviz!2954

2 years agotests: fix legacy comments to rtest
Matthew Fernandez [Tue, 15 Nov 2022 01:20:32 +0000 (17:20 -0800)]
tests: fix legacy comments to rtest

These have been inaccurate since 0e19cdb9bff60fdeb1942f5dca677db9d8a24062.

2 years agotests: fix path from which to import 'gvtest'
Matthew Fernandez [Tue, 15 Nov 2022 01:19:02 +0000 (17:19 -0800)]
tests: fix path from which to import 'gvtest'

This has been wrong since 0e19cdb9bff60fdeb1942f5dca677db9d8a24062 removed the
rtest directory. And yet the tests in this file somehow still run correctly in
CI. I can only guess that insufficient test isolation under Pytest results in
some other test file putting the correct path in `sys.path` prior to this file
being processed.

2 years agoMerge commit '9985c8ace846fe13315a6686cb4d959a69c7d973' into smattr/b4ec63ae-dbf8...
Matthew Fernandez [Thu, 17 Nov 2022 01:56:26 +0000 (17:56 -0800)]
Merge commit '9985c8ace846fe13315a6686cb4d959a69c7d973' into smattr/b4ec63ae-dbf8-475e-ba57-e5dffdc7634e

2 years agoCONTRIBUTING: clarify that changelog entries should be appended
Matthew Fernandez [Thu, 17 Nov 2022 01:54:57 +0000 (17:54 -0800)]
CONTRIBUTING: clarify that changelog entries should be appended

2 years agoadd some more CHANGELOG detail to the SWIG 4.1.0 support
Matthew Fernandez [Thu, 17 Nov 2022 01:53:22 +0000 (17:53 -0800)]
add some more CHANGELOG detail to the SWIG 4.1.0 support

2 years agoFix php install for SWIG-4.0.1
Pierre Labastie [Tue, 15 Nov 2022 08:03:54 +0000 (09:03 +0100)]
Fix php install for SWIG-4.0.1

This version of SWIG does not generate gv.php anymore, so
installing it shouldn't be tried. The autotools framework is
already there, so just use a conditional in Makefile.am.

2 years agoMerge branch 'smattr/41de8cd1-5dc5-43d5-96cd-230258c7f141' into 'main'
Matthew Fernandez [Wed, 16 Nov 2022 17:19:13 +0000 (17:19 +0000)]
Merge branch 'smattr/41de8cd1-5dc5-43d5-96cd-230258c7f141' into 'main'

CI: ASan, UBSan tweaks

See merge request graphviz/graphviz!2957

2 years agoCI: show stack traces on UBSan errors
Matthew Fernandez [Wed, 16 Nov 2022 05:37:19 +0000 (21:37 -0800)]
CI: show stack traces on UBSan errors

2 years agoCI: also apply ASan, UBSan options to ld flags
Matthew Fernandez [Wed, 16 Nov 2022 05:29:14 +0000 (21:29 -0800)]
CI: also apply ASan, UBSan options to ld flags

The test job was doing this but the build job was not. Technically I think this
is unnecessary (I think CMake includes `CFLAGS` or `CXXFLAGS` when calling `ld`)
but it seems worth being consistent.

2 years agoCI: make UBSan errors in compiled test cases fail the test
Matthew Fernandez [Wed, 16 Nov 2022 05:26:51 +0000 (21:26 -0800)]
CI: make UBSan errors in compiled test cases fail the test

0d0c20797a0cf2937886945f3aecc4e8a9a55e8c adjusted this for the build job, but
not for the test job. It is useful to have this enabled for the test job as well
because some test cases involve compiling C code, for which we want full ASan
and UBSan enabled too.

Gitlab: #2200

2 years agoMerge branch 'defaultValue' into 'main'
Mark Hansen [Wed, 16 Nov 2022 07:42:39 +0000 (07:42 +0000)]
Merge branch 'defaultValue' into 'main'

Use a consistent name for defaultValue in utils.c

See merge request graphviz/graphviz!2952

2 years agoConstruct objects inline, brace else's
Mark Hansen [Wed, 16 Nov 2022 06:27:12 +0000 (17:27 +1100)]
Construct objects inline, brace else's

2 years agoutils.h is now clang-formatted
Mark Hansen [Tue, 15 Nov 2022 21:46:05 +0000 (08:46 +1100)]
utils.h is now clang-formatted

2 years agoInline variable declarations in utils.c
Mark Hansen [Mon, 14 Nov 2022 10:52:12 +0000 (21:52 +1100)]
Inline variable declarations in utils.c

And reformat some lines that were broken

2 years agoGive better names to mapBool arguments
Mark Hansen [Mon, 14 Nov 2022 10:50:40 +0000 (21:50 +1100)]
Give better names to mapBool arguments

2 years agoGive better argument name to edgeType
Mark Hansen [Mon, 14 Nov 2022 10:49:34 +0000 (21:49 +1100)]
Give better argument name to edgeType

2 years agoGive better names for setEdgeType arguments
Mark Hansen [Mon, 14 Nov 2022 10:49:06 +0000 (21:49 +1100)]
Give better names for setEdgeType arguments

2 years agoGive better argument names to safe_dcl
Mark Hansen [Mon, 14 Nov 2022 10:47:38 +0000 (21:47 +1100)]
Give better argument names to safe_dcl