]> granicus.if.org Git - graphviz/log
graphviz
3 years agoMerge branch 'smattr/E64BA158-2E02-488E-9F5A-2ADC94C357C6' into 'master'
Matthew Fernandez [Sun, 24 Jan 2021 02:17:42 +0000 (02:17 +0000)]
Merge branch 'smattr/E64BA158-2E02-488E-9F5A-2ADC94C357C6' into 'master'

fix: suppress re-running CI on tagged commits

Closes #1901

See merge request graphviz/graphviz!1703

3 years agofix: suppress re-running CI on tagged commits
Matthew Fernandez [Sun, 17 Jan 2021 02:33:33 +0000 (18:33 -0800)]
fix: suppress re-running CI on tagged commits

Several tasks in the CI setup were allowed to run on tagged commits. This meant
that pushing a new tag would result in re-running CI on the tagged commit. This
was already confusing, but was compounded by these unrestricted tasks depending
on non-tag-only tasks. The result was that CI would stall and fail because
dependencies could not be satisfied.

To fix this we simply disallow all CI on a tag. This means that a tagged commit
that is not on any branch will not be tested. However, no one should be pushing
such a commit to the Graphviz repository. All tagged commits that are on a
branch will be tested via their SHA. This is not expected to cause any problems
as the Graphviz build system never checks the Git tag or whether a commit is
tagged at all.

Fixes #1901.

3 years agoMerge branch 'smattr/480984E2-F863-4F4B-8813-9EFB371B8CCC' into 'master'
Matthew Fernandez [Sun, 24 Jan 2021 01:13:20 +0000 (01:13 +0000)]
Merge branch 'smattr/480984E2-F863-4F4B-8813-9EFB371B8CCC' into 'master'

document how to build Graphviz for developers

See merge request graphviz/graphviz!1700

3 years agodocument how to build Graphviz for developers
Matthew Fernandez [Thu, 7 Jan 2021 03:36:12 +0000 (19:36 -0800)]
document how to build Graphviz for developers

3 years agoMerge !1699
Matthew Fernandez [Sun, 24 Jan 2021 00:38:48 +0000 (16:38 -0800)]
Merge !1699

3 years agoadd changelog item about prior commits
Matthew Fernandez [Sat, 23 Jan 2021 23:51:45 +0000 (15:51 -0800)]
add changelog item about prior commits

3 years agoFix memory leak in make_map_internal
Alex Henrie [Sat, 9 Jan 2021 09:02:07 +0000 (02:02 -0700)]
Fix memory leak in make_map_internal

3 years agoFix memory leak in gv_get_ps_fontlist
Alex Henrie [Thu, 7 Jan 2021 03:35:57 +0000 (20:35 -0700)]
Fix memory leak in gv_get_ps_fontlist

3 years agoFix memory leaks in Multilevel_(MQ|Modularity)_Clustering_establish
Alex Henrie [Thu, 7 Jan 2021 03:35:57 +0000 (20:35 -0700)]
Fix memory leaks in Multilevel_(MQ|Modularity)_Clustering_establish

3 years agoMerge branch 'smattr/529f1002-e2fa-4706-ba00-2b3ad0811c15' into 'master'
Matthew Fernandez [Sat, 23 Jan 2021 23:46:53 +0000 (23:46 +0000)]
Merge branch 'smattr/529f1002-e2fa-4706-ba00-2b3ad0811c15' into 'master'

unify and correct RectArea implementations

Closes #1906

See merge request graphviz/graphviz!1697

3 years agofix: unify and correct RectArea implementations
Matthew Fernandez [Sat, 12 Dec 2020 16:45:19 +0000 (08:45 -0800)]
fix: unify and correct RectArea implementations

Two implementations of RectArea were provided that implemented the overflow
check based on whether there was a larger type than unsigned int available. It
is unnecessary to maintain multiple implementations of this as the overflow
check can be written in a width-independent way.

Moreover the `LLONG_MAX > UINT_MAX` alternative was incorrect. E.g. on x86-64
where this alternative is used, if `r->boundary[i + NUMDIMS] - r->boundary[i]`
is `UINT_MAX` and the accumulated value in `a_test` is `(long long)UINT_MAX`,
the multiplication (which is done on operands promoted to long long) overflows
causing undefined behavior. In practice, you would likely get a negative value,
that then erroneously passes the overflow check.

Related to #1898. Fixes #1906.

3 years agofix: remove Circo test of root.gv from rtest.py-tested graphs
Matthew Fernandez [Mon, 28 Dec 2020 03:13:58 +0000 (19:13 -0800)]
fix: remove Circo test of root.gv from rtest.py-tested graphs

This graph generates an overflow when computing the area of rectangles required
to layout it out. It should be rejected but it currently incorrectly is not.
Related to #1906.

3 years agoMerge branch 'smattr/AB3ED35D-6FC9-4811-92FB-9C0FB6F5E9E4' into 'master'
Matthew Fernandez [Sat, 23 Jan 2021 23:14:25 +0000 (23:14 +0000)]
Merge branch 'smattr/AB3ED35D-6FC9-4811-92FB-9C0FB6F5E9E4' into 'master'

Autotools build system support for Guile 2.2

See merge request graphviz/graphviz!1696

3 years agosupport Guile 2.2 in the Autotools build system
Matthew Fernandez [Sun, 27 Dec 2020 22:19:27 +0000 (14:19 -0800)]
support Guile 2.2 in the Autotools build system

The build system detection of Guile was relying on a binary named guile-config.
As of Guile 2.2, coexisting versions of Guile are supported and so the
guile-config binary is suffixed with its version. The result of this mismatch
was that the build system would fail to detect Guile 2.2 on platforms that did
not provide a guile-config redirection shim.

Guile 3.0 has already been out for awhile, but this commit does not add support
for it. The devel packages for it do not seem yet available on any major Linux
distro. We should extend this support to 3.0 when it becomes more widely
available if Graphviz' use of Guile is compatible. Related to #1885.

3 years agofix: lookup Guile version by guile-config, not guile
Matthew Fernandez [Sun, 27 Dec 2020 22:50:32 +0000 (14:50 -0800)]
fix: lookup Guile version by guile-config, not guile

The Autotools build system was using the binary "guile" to detect what version
of Guile to build and link against. However, this is the Guile runtime system,
not the Guile developer dependencies. The effect of this was that the build
system could detect e.g. Guile 2.0 when guile20-devel was not installed. Related
to #1885.

3 years agoremove legacy Python 2 comments in Dockerfiles
Matthew Fernandez [Sun, 27 Dec 2020 21:18:27 +0000 (13:18 -0800)]
remove legacy Python 2 comments in Dockerfiles

These look to have been copied from Dockerfiles for other OSes that install
python2-devel or its equivalent. However, these ones do not so this comment does
not belong here.

3 years agoMerge cherry-picked commits from !1695
Matthew Fernandez [Sat, 23 Jan 2021 22:40:25 +0000 (14:40 -0800)]
Merge cherry-picked commits from !1695

3 years agoignore (or for one internal function remove) unused params
Ed J [Sat, 26 Dec 2020 19:12:36 +0000 (19:12 +0000)]
ignore (or for one internal function remove) unused params

3 years agofix a comment typo
Ed J [Sat, 26 Dec 2020 19:10:16 +0000 (19:10 +0000)]
fix a comment typo

3 years agoignore more generated files
Ed J [Fri, 25 Dec 2020 14:58:53 +0000 (14:58 +0000)]
ignore more generated files

3 years agoMerge branch 'smattr/D2B1FED2-41ED-4F48-81E6-B421639BB5EE' into 'master'
Matthew Fernandez [Sat, 23 Jan 2021 21:55:17 +0000 (21:55 +0000)]
Merge branch 'smattr/D2B1FED2-41ED-4F48-81E6-B421639BB5EE' into 'master'

some clean up of the HTML lexer

Closes #1913

See merge request graphviz/graphviz!1694

3 years agoremove some unnecessary bracketing in the HTML lexer
Matthew Fernandez [Sat, 26 Dec 2020 01:20:13 +0000 (17:20 -0800)]
remove some unnecessary bracketing in the HTML lexer

3 years agoremove micro-optimizations in HTML lexer
Matthew Fernandez [Sat, 26 Dec 2020 01:16:16 +0000 (17:16 -0800)]
remove micro-optimizations in HTML lexer

This code was attempting to avoid an expensive call to strcasecmp when the first
byte already indicates a mismatch. Modern compilers can perform this
optimization themselves, including inlining strcasecmp and unrolling and
vectorizing its loop. Manually comparing the first byte actually impedes the
compiler because it's harder for it to see your intent. Related to #1913.

3 years agofix incorrect parsing of ALIGN attribute in a <BR> HTML tag
Matthew Fernandez [Sat, 26 Dec 2020 21:26:00 +0000 (13:26 -0800)]
fix incorrect parsing of ALIGN attribute in a <BR> HTML tag

The logical operators here were incorrect. Rather than flipping them to the
correct operators, we undo this micro-optimization and write this code in a more
obvious manner. Fixes #1913.

3 years agotest case for #1913
Matthew Fernandez [Sat, 26 Dec 2020 21:20:59 +0000 (13:20 -0800)]
test case for #1913

3 years agoremove a Vim modeline
Matthew Fernandez [Sat, 26 Dec 2020 01:12:34 +0000 (17:12 -0800)]
remove a Vim modeline

This is only relevant for Vim users that have modeline support enabled and adds
clutter to the file.

3 years agouse libc limit constants instead of defining our own
Matthew Fernandez [Sat, 26 Dec 2020 01:11:12 +0000 (17:11 -0800)]
use libc limit constants instead of defining our own

These are available in the C standard library even prior to C89. This change has
no effect on functionality, as the replaced constants have identical values.

3 years agoremove a legacy RCS tag
Matthew Fernandez [Sat, 26 Dec 2020 01:09:20 +0000 (17:09 -0800)]
remove a legacy RCS tag

Related to #1798.

3 years agoMerge branch 'smattr/E2228C5B-49AF-464B-9869-7F2D29F459D9' into 'master'
Matthew Fernandez [Sat, 23 Jan 2021 21:21:50 +0000 (21:21 +0000)]
Merge branch 'smattr/E2228C5B-49AF-464B-9869-7F2D29F459D9' into 'master'

remove the use of NIL and friends

See merge request graphviz/graphviz!1692

3 years agoremove the use of NIL and friends
Matthew Fernandez [Fri, 18 Dec 2020 01:53:07 +0000 (17:53 -0800)]
remove the use of NIL and friends

NULL is more concise and more widely understood than the Graphviz-specific macro
NIL. We leave the definitions of NIL in case others are using these through the
public API.

3 years agoMerge branch 'smattr/3fd88959-c0fa-43fa-b8d0-1a39ff9cfac4' into 'master'
Matthew Fernandez [Sat, 23 Jan 2021 20:26:52 +0000 (20:26 +0000)]
Merge branch 'smattr/3fd88959-c0fa-43fa-b8d0-1a39ff9cfac4' into 'master'

some clean up in lib/gvpr/compile.c

See merge request graphviz/graphviz!1685

3 years agoremove some unnecessary bracketing
Matthew Fernandez [Wed, 25 Nov 2020 01:21:53 +0000 (17:21 -0800)]
remove some unnecessary bracketing

3 years agoremove some unnecessary casts
Matthew Fernandez [Wed, 25 Nov 2020 01:21:03 +0000 (17:21 -0800)]
remove some unnecessary casts

These coercions happen implicitly.

3 years agoremove a Vim modeline comment
Matthew Fernandez [Wed, 25 Nov 2020 01:19:59 +0000 (17:19 -0800)]
remove a Vim modeline comment

3 years agoturn ISEDGE macro into a function
Matthew Fernandez [Wed, 25 Nov 2020 01:07:33 +0000 (17:07 -0800)]
turn ISEDGE macro into a function

There's no need for this to be a macro or play bitwise tricks.

3 years agofix a comment typo
Matthew Fernandez [Wed, 25 Nov 2020 01:07:16 +0000 (17:07 -0800)]
fix a comment typo

3 years agoremove a RCS marker
Matthew Fernandez [Wed, 25 Nov 2020 01:06:31 +0000 (17:06 -0800)]
remove a RCS marker

Related to #1798.

3 years agoMerge branch 'smattr/36c9e35e-ec5c-4cf3-add5-51e394840fb2' into 'master'
Matthew Fernandez [Sat, 23 Jan 2021 19:55:07 +0000 (19:55 +0000)]
Merge branch 'smattr/36c9e35e-ec5c-4cf3-add5-51e394840fb2' into 'master'

minor cleanups

See merge request graphviz/graphviz!1683

3 years agoremove an dead store
Matthew Fernandez [Sun, 22 Nov 2020 06:02:54 +0000 (22:02 -0800)]
remove an dead store

This variable, `el`, is immediately reassigned in the following loop.

3 years agoremove some use of the NIL macro
Matthew Fernandez [Sun, 22 Nov 2020 06:01:33 +0000 (22:01 -0800)]
remove some use of the NIL macro

3 years agoremove an unnecessary intermediate buffer
Matthew Fernandez [Sun, 22 Nov 2020 05:57:26 +0000 (21:57 -0800)]
remove an unnecessary intermediate buffer

3 years agoremove commented out code
Matthew Fernandez [Sun, 22 Nov 2020 05:56:54 +0000 (21:56 -0800)]
remove commented out code

3 years agoremove unused macros
Matthew Fernandez [Sun, 22 Nov 2020 05:56:32 +0000 (21:56 -0800)]
remove unused macros

3 years agoremove micro-optimization in streq()
Matthew Fernandez [Sun, 22 Nov 2020 05:55:38 +0000 (21:55 -0800)]
remove micro-optimization in streq()

Modern compilers can already do tricks like this as they know strcmp() through
__builtin_strcmp().

3 years agoremove some unnecessary bracketing
Matthew Fernandez [Sun, 22 Nov 2020 05:51:02 +0000 (21:51 -0800)]
remove some unnecessary bracketing

3 years agoremove some unnecessary casts
Matthew Fernandez [Sun, 22 Nov 2020 05:33:45 +0000 (21:33 -0800)]
remove some unnecessary casts

These pointers implicitly coerce.

3 years agoMerge branch 'smattr/62f363ec-36df-4415-9029-91da24a61289' into 'master'
Matthew Fernandez [Sat, 23 Jan 2021 19:23:32 +0000 (19:23 +0000)]
Merge branch 'smattr/62f363ec-36df-4415-9029-91da24a61289' into 'master'

stop disabling assertions in libcgraph when DEBUG is undefined

See merge request graphviz/graphviz!1682

3 years agostop disabling assertions in libcgraph when DEBUG is undefined
Matthew Fernandez [Sat, 21 Nov 2020 23:22:29 +0000 (15:22 -0800)]
stop disabling assertions in libcgraph when DEBUG is undefined

This is counterintuitive to developers and moreover assertions are already
controllable via NDEBUG.

3 years agoMerge branch 'smattr/3e8082b9-bc17-4b27-968e-caa712091d2b' into 'master'
Matthew Fernandez [Sat, 23 Jan 2021 18:51:16 +0000 (18:51 +0000)]
Merge branch 'smattr/3e8082b9-bc17-4b27-968e-caa712091d2b' into 'master'

more VPSC clean up

See merge request graphviz/graphviz!1677

3 years agoVPSC: uniformly treat objects as structs that need to be exposed to C
Matthew Fernandez [Sat, 21 Nov 2020 16:42:21 +0000 (08:42 -0800)]
VPSC: uniformly treat objects as structs that need to be exposed to C

The keywords "class" and "struct" are synonyms in C++, except for changing the
default visibility of declarations within the object. By using struct for
anything that needs to be declared in the C API, we can avoid some #ifdef mess
in this header.

3 years agoremove a manual allocation
Matthew Fernandez [Sat, 21 Nov 2020 02:04:10 +0000 (18:04 -0800)]
remove a manual allocation

3 years agoremove some useless code
Matthew Fernandez [Sat, 21 Nov 2020 02:03:48 +0000 (18:03 -0800)]
remove some useless code

3 years agouse empty() to check size() against 0 in VPSC
Matthew Fernandez [Sat, 21 Nov 2020 01:20:28 +0000 (17:20 -0800)]
use empty() to check size() against 0 in VPSC

This is significantly faster for large vectors.

3 years agoremove unnecessary extern C
Matthew Fernandez [Sat, 21 Nov 2020 01:13:34 +0000 (17:13 -0800)]
remove unnecessary extern C

This file #includes csolve_VPSC.h, so the compiler has already seen prototypes
for these functions marked extern C.

3 years agoremove some unused using declarations
Matthew Fernandez [Sat, 21 Nov 2020 01:13:22 +0000 (17:13 -0800)]
remove some unused using declarations

3 years agoremove unnecessary explicit void in VPSC
Matthew Fernandez [Sat, 21 Nov 2020 01:12:50 +0000 (17:12 -0800)]
remove unnecessary explicit void in VPSC

Unlike in C, prototypes with no parameter list are not ambiguous in C++.

3 years agoremove Vim modeline comments in VPSC
Matthew Fernandez [Sat, 21 Nov 2020 01:11:54 +0000 (17:11 -0800)]
remove Vim modeline comments in VPSC

These have no effect for any developer not using Vim or with modeline disabled.
A better way to achieve this now is clang-format.

3 years agouse #pragma once guards in VPSC
Matthew Fernandez [Sat, 21 Nov 2020 01:09:52 +0000 (17:09 -0800)]
use #pragma once guards in VPSC

These are supported by all recent compilers and are less error prone than old
style header guards.

3 years agoupdate Adaptagrams URLs
Matthew Fernandez [Sat, 21 Nov 2020 01:08:24 +0000 (17:08 -0800)]
update Adaptagrams URLs

It is debatable whether this is useful as the upstream project seems to be dead.

3 years agoremove VPSC RCS markers
Matthew Fernandez [Sat, 21 Nov 2020 01:05:36 +0000 (17:05 -0800)]
remove VPSC RCS markers

These RCS version control markers no longer serve a purpose, now that Graphviz
is hosted in Git. Related to #1798.

3 years agoMerge branch 'smattr/A7F35B6D-9CED-4C89-B438-AE0CC4ECD4FA' into 'master'
Matthew Fernandez [Sat, 23 Jan 2021 18:18:53 +0000 (18:18 +0000)]
Merge branch 'smattr/A7F35B6D-9CED-4C89-B438-AE0CC4ECD4FA' into 'master'

remove some extraneous lib/vpsc code

See merge request graphviz/graphviz!1675

3 years agoremove an unnecessary destructor
Matthew Fernandez [Mon, 16 Nov 2020 00:32:27 +0000 (16:32 -0800)]
remove an unnecessary destructor

These vector members of the class are automatically cleared when an object of
this type is destructed.

3 years agoremove unused BadIterator exception
Matthew Fernandez [Mon, 16 Nov 2020 00:21:50 +0000 (16:21 -0800)]
remove unused BadIterator exception

3 years agoremove unused Overflow exception
Matthew Fernandez [Mon, 16 Nov 2020 00:20:58 +0000 (16:20 -0800)]
remove unused Overflow exception

If there is a need of this in future, std::out_of_range is more appropriate.

3 years agoremove unused OutOfMemory exception
Matthew Fernandez [Mon, 16 Nov 2020 00:19:39 +0000 (16:19 -0800)]
remove unused OutOfMemory exception

If there is a need of something like this in future, std::bad_alloc is more
appropriate.

3 years agoremove undefined class
Matthew Fernandez [Mon, 16 Nov 2020 00:18:43 +0000 (16:18 -0800)]
remove undefined class

Thankfully it seems no one ever implemented this declared class which sounds,
well, stupid.

3 years agoMerge branch 'smattr/c8469035-634e-4199-bca6-86971c094ed8' into 'master'
Matthew Fernandez [Sat, 23 Jan 2021 05:06:59 +0000 (05:06 +0000)]
Merge branch 'smattr/c8469035-634e-4199-bca6-86971c094ed8' into 'master'

remove another setjmp/longjmp use

See merge request graphviz/graphviz!1671

3 years agoabbreviate some comparisons against boolean literals
Matthew Fernandez [Sat, 14 Nov 2020 20:45:29 +0000 (12:45 -0800)]
abbreviate some comparisons against boolean literals

3 years agoremove unnecessary open coding of NULL
Matthew Fernandez [Sat, 14 Nov 2020 20:37:21 +0000 (12:37 -0800)]
remove unnecessary open coding of NULL

3 years agoremove some unnecessary bracketing
Matthew Fernandez [Sat, 14 Nov 2020 20:36:42 +0000 (12:36 -0800)]
remove some unnecessary bracketing

3 years agoremove an unnecessary prototype
Matthew Fernandez [Sat, 14 Nov 2020 20:30:42 +0000 (12:30 -0800)]
remove an unnecessary prototype

3 years agoremove unused INCIDENT macro
Matthew Fernandez [Sat, 14 Nov 2020 20:28:58 +0000 (12:28 -0800)]
remove unused INCIDENT macro

3 years agoremove a now-unused jump buffer
Matthew Fernandez [Sat, 14 Nov 2020 20:25:45 +0000 (12:25 -0800)]
remove a now-unused jump buffer

Related to #1801.

3 years agoremove use of longjmp() in update()
Matthew Fernandez [Sat, 14 Nov 2020 20:21:28 +0000 (12:21 -0800)]
remove use of longjmp() in update()

Like the change to add_tree_edge(), this also fixes some resource leakage that
occurred in this error path. Now the tree list in rank2 is correctly cleaned up
on error. Related to #1801.

3 years agoanticipate a non-zero return value from update()
Matthew Fernandez [Sat, 14 Nov 2020 20:18:07 +0000 (12:18 -0800)]
anticipate a non-zero return value from update()

Related to #1801.

3 years agoadd a return value to update()
Matthew Fernandez [Sat, 14 Nov 2020 20:10:57 +0000 (12:10 -0800)]
add a return value to update()

Related to #1801.

3 years agoremove use of longjmp() in add_tree_edge()
Matthew Fernandez [Sat, 14 Nov 2020 20:04:38 +0000 (12:04 -0800)]
remove use of longjmp() in add_tree_edge()

This also fixes some resource leaks that occurred in this path. The longjmp()
would jump over some intermediate allocations that had been made, whereas we now
return back through the callers, cleaning up resources as we go. Related to
#1801.

3 years agoanticipate add_tree_edge() returning non-zero
Matthew Fernandez [Sat, 14 Nov 2020 20:00:49 +0000 (12:00 -0800)]
anticipate add_tree_edge() returning non-zero

Related to #1801.

3 years agoadd a return value to add_tree_edge()
Matthew Fernandez [Sat, 14 Nov 2020 19:55:15 +0000 (11:55 -0800)]
add a return value to add_tree_edge()

Related to #1801.

3 years agoanticipate merge_trees() returning NULL to indicate failure
Matthew Fernandez [Sat, 14 Nov 2020 19:54:40 +0000 (11:54 -0800)]
anticipate merge_trees() returning NULL to indicate failure

Related to #1801.

3 years agoanticipate tight_subtree_search() returning a negative value as error
Matthew Fernandez [Sat, 14 Nov 2020 19:49:12 +0000 (11:49 -0800)]
anticipate tight_subtree_search() returning a negative value as error

Related to #1801.

3 years agoanticipate find_tight_subtree() returning NULL
Matthew Fernandez [Sat, 14 Nov 2020 19:44:21 +0000 (11:44 -0800)]
anticipate find_tight_subtree() returning NULL

Related to #1801.

3 years agoanticipate return codes from feasible_tree other than 0 and 1
Matthew Fernandez [Sat, 14 Nov 2020 19:36:10 +0000 (11:36 -0800)]
anticipate return codes from feasible_tree other than 0 and 1

Related to #1801.

3 years agoinclude advice to disable assertions in a profiling build
Matthew Fernandez [Sat, 14 Nov 2020 19:07:37 +0000 (11:07 -0800)]
include advice to disable assertions in a profiling build

Something I overlooked in bfd08ce02f62e2c7700f71e36afa5c771062e842.

3 years agoMerge branch 'smattr/4b9b767b-5a9a-44d6-9ea4-a434951fa7bf' into 'master'
Matthew Fernandez [Sat, 23 Jan 2021 04:34:36 +0000 (04:34 +0000)]
Merge branch 'smattr/4b9b767b-5a9a-44d6-9ea4-a434951fa7bf' into 'master'

fix: drop Qt4 qmake support

Closes #1862

See merge request graphviz/graphviz!1670

3 years agofix: drop Qt4 qmake support
Matthew Fernandez [Sat, 14 Nov 2020 02:19:37 +0000 (18:19 -0800)]
fix: drop Qt4 qmake support

It looks to me as if cdc5efaf40d94b1020b650d654f94ebf0a856c62 attempted to
consolidate Qt5 support but actually erroneously re-enabled Qt4 qmake support.
This re-enabled qmake doesn't work because it produces a Makefile designed to
work with Qt4, while the CFLAGS and LDFLAGS set by PKG_CHECK_MODULES are all
based on Qt5 library names.

The outcome of this is that building on a Linux machine with libqt5 and
libqt4-dev installed but *not* libqt5-dev (a legal configuration) causes
Graphviz compilation to fail when processing GVEdit #includes it cannot find.

The fix here is to simply remove support for Qt4's qmake because Qt4 is
deprecated [0] and force the build system to find Qt5's qmake. Closes #1862.

  [0]: https://www.qt.io/blog/2014/11/27/qt-4-8-x-support-to-be-extended-for-another-year

3 years agoMerge branch 'smattr/D4AF680D-21E8-413F-9F38-CF85B7818E6D' into 'master'
Matthew Fernandez [Sat, 23 Jan 2021 03:48:18 +0000 (03:48 +0000)]
Merge branch 'smattr/D4AF680D-21E8-413F-9F38-CF85B7818E6D' into 'master'

remove some unused files

See merge request graphviz/graphviz!1668

3 years agoremove unused typegraph script
Matthew Fernandez [Fri, 13 Nov 2020 01:10:58 +0000 (17:10 -0800)]
remove unused typegraph script

3 years agoremove unused Makeargs
Matthew Fernandez [Fri, 13 Nov 2020 01:07:36 +0000 (17:07 -0800)]
remove unused Makeargs

3 years agoMerge branch 'remve-unused-Agglomerative_Ink_Bundling_aggressive_establish' into...
Matthew Fernandez [Sat, 23 Jan 2021 03:04:24 +0000 (03:04 +0000)]
Merge branch 'remve-unused-Agglomerative_Ink_Bundling_aggressive_establish' into 'master'

Remove unused Agglomerative_Ink_Bundling_aggressive_establish

See merge request graphviz/graphviz!1667

3 years agoMerge branch 'smattr/C3CD4BF2-D5D6-4E62-A4BC-96C3E6271116' into 'master'
Matthew Fernandez [Sat, 23 Jan 2021 03:01:26 +0000 (03:01 +0000)]
Merge branch 'smattr/C3CD4BF2-D5D6-4E62-A4BC-96C3E6271116' into 'master'

remove Tito metadata

See merge request graphviz/graphviz!1666

3 years agoremove Tito metadata
Matthew Fernandez [Wed, 11 Nov 2020 15:44:41 +0000 (07:44 -0800)]
remove Tito metadata

Tito is a tool for managing RPM-based projects [0]. As far as I am aware,
we no longer use this.

  [0]: https://github.com/rpm-software-management/tito

3 years agoMerge branch 'smattr/2d31215e-d6d1-4ac9-9f12-03a74e2d3351' into 'master'
Matthew Fernandez [Sat, 23 Jan 2021 02:29:00 +0000 (02:29 +0000)]
Merge branch 'smattr/2d31215e-d6d1-4ac9-9f12-03a74e2d3351' into 'master'

fix memory leak when making labels

See merge request graphviz/graphviz!1665

3 years agoremove unnecessary casts of make_label() argument
Matthew Fernandez [Tue, 10 Nov 2020 04:19:45 +0000 (20:19 -0800)]
remove unnecessary casts of make_label() argument

These pointers implicitly coerce to void*.

3 years agofix memory leak in label construction
Matthew Fernandez [Tue, 10 Nov 2020 04:15:00 +0000 (20:15 -0800)]
fix memory leak in label construction

make_label() internally strdups its input, so this extra allocation was simply
being lost. This was observable using an ASan-instrumented build and the command
`dot -Tsvg -o /dev/null ./rtest/share/alf.gv`:

  Direct leak of 121 byte(s) in 12 object(s) allocated from:
    #0 0x7fd2541bf810 in strdup (/lib/x86_64-linux-gnu/libasan.so.5+0x3a810)
    #1 0x7fd25404a955 in parse_reclbl /tmp/tmp.bXYbsH93VJ/graphviz/lib/common/shapes.c:3314
    #2 0x7fd25404a5eb in parse_reclbl /tmp/tmp.bXYbsH93VJ/graphviz/lib/common/shapes.c:3292
    #3 0x7fd25404ca5f in record_init /tmp/tmp.bXYbsH93VJ/graphviz/lib/common/shapes.c:3556
    #4 0x7fd25405966a in common_init_node /tmp/tmp.bXYbsH93VJ/graphviz/lib/common/utils.c:658
    #5 0x7fd24fc78a01 in dot_init_node /tmp/tmp.bXYbsH93VJ/graphviz/lib/dotgen/dotinit.c:40
    #6 0x7fd24fc79522 in dot_init_node_edge /tmp/tmp.bXYbsH93VJ/graphviz/lib/dotgen/dotinit.c:81
    #7 0x7fd24fc7ad61 in dotLayout /tmp/tmp.bXYbsH93VJ/graphviz/lib/dotgen/dotinit.c:295
    #8 0x7fd24fc7c4b9 in doDot /tmp/tmp.bXYbsH93VJ/graphviz/lib/dotgen/dotinit.c:450
    #9 0x7fd24fc7ca94 in dot_layout /tmp/tmp.bXYbsH93VJ/graphviz/lib/dotgen/dotinit.c:496
    #10 0x7fd253f7673d in gvLayoutJobs /tmp/tmp.bXYbsH93VJ/graphviz/lib/gvc/gvlayout.c:85
    #11 0x55a9961b3960 in main /tmp/tmp.bXYbsH93VJ/graphviz/cmd/dot/dot.c:132
    #12 0x7fd253d2309a in __libc_start_main ../csu/libc-start.c:308

  Direct leak of 118 byte(s) in 19 object(s) allocated from:
    #0 0x7fd2541bf810 in strdup (/lib/x86_64-linux-gnu/libasan.so.5+0x3a810)
    #1 0x7fd25404a955 in parse_reclbl /tmp/tmp.bXYbsH93VJ/graphviz/lib/common/shapes.c:3314
    #2 0x7fd25404ca5f in record_init /tmp/tmp.bXYbsH93VJ/graphviz/lib/common/shapes.c:3556
    #3 0x7fd25405966a in common_init_node /tmp/tmp.bXYbsH93VJ/graphviz/lib/common/utils.c:658
    #4 0x7fd24fc78a01 in dot_init_node /tmp/tmp.bXYbsH93VJ/graphviz/lib/dotgen/dotinit.c:40
    #5 0x7fd24fc79522 in dot_init_node_edge /tmp/tmp.bXYbsH93VJ/graphviz/lib/dotgen/dotinit.c:81
    #6 0x7fd24fc7ad61 in dotLayout /tmp/tmp.bXYbsH93VJ/graphviz/lib/dotgen/dotinit.c:295
    #7 0x7fd24fc7c4b9 in doDot /tmp/tmp.bXYbsH93VJ/graphviz/lib/dotgen/dotinit.c:450
    #8 0x7fd24fc7ca94 in dot_layout /tmp/tmp.bXYbsH93VJ/graphviz/lib/dotgen/dotinit.c:496
    #9 0x7fd253f7673d in gvLayoutJobs /tmp/tmp.bXYbsH93VJ/graphviz/lib/gvc/gvlayout.c:85
    #10 0x55a9961b3960 in main /tmp/tmp.bXYbsH93VJ/graphviz/cmd/dot/dot.c:132
    #11 0x7fd253d2309a in __libc_start_main ../csu/libc-start.c:308

3 years agoMerge branch 'smattr/47A158E5-FA26-4B4C-8E27-A9024E198823' into 'master'
Matthew Fernandez [Sat, 23 Jan 2021 01:57:25 +0000 (01:57 +0000)]
Merge branch 'smattr/47A158E5-FA26-4B4C-8E27-A9024E198823' into 'master'

remove CentOS 6 from CI

Closes #1915

See merge request graphviz/graphviz!1704

3 years agoremove CentOS 6 from CI
Matthew Fernandez [Sat, 2 Jan 2021 02:43:21 +0000 (18:43 -0800)]
remove CentOS 6 from CI

CentOS 6 was EOLed in December 2020. Closes #1915.

3 years agoMerge branch 'dotguide-fix' into 'master'
Matthew Fernandez [Sat, 23 Jan 2021 01:08:12 +0000 (01:08 +0000)]
Merge branch 'dotguide-fix' into 'master'

fix minor dotguide.pdf mistake

See merge request graphviz/graphviz!1701

3 years agoMerge branch 'development-release-2.46.1-dev' into 'master'
Matthew Fernandez [Tue, 19 Jan 2021 01:44:55 +0000 (01:44 +0000)]
Merge branch 'development-release-2.46.1-dev' into 'master'

Development release 2.46.1~dev

See merge request graphviz/graphviz!1673

3 years agoStart 2.46.1~dev development series
Magnus Jacobsson [Sun, 15 Nov 2020 11:49:19 +0000 (12:49 +0100)]
Start 2.46.1~dev development series