]> granicus.if.org Git - graphviz/log
graphviz
3 years agoMerge branch 'smattr/B88D27C7-7361-4A49-B653-D44870A5BACC' into 'main'
Matthew Fernandez [Sat, 6 Nov 2021 23:41:56 +0000 (23:41 +0000)]
Merge branch 'smattr/B88D27C7-7361-4A49-B653-D44870A5BACC' into 'main'

smyrna: more dead code removal

See merge request graphviz/graphviz!2260

3 years agosmyrna: remove unused 'ApplyTo'
Matthew Fernandez [Sun, 31 Oct 2021 16:48:49 +0000 (09:48 -0700)]
smyrna: remove unused 'ApplyTo'

3 years agoremove unused 'Edgecount'
Matthew Fernandez [Sat, 6 Nov 2021 22:34:24 +0000 (15:34 -0700)]
remove unused 'Edgecount'

3 years agosmyrna: remove unused 'Edges'
Matthew Fernandez [Sun, 31 Oct 2021 16:43:07 +0000 (09:43 -0700)]
smyrna: remove unused 'Edges'

3 years agosmyrna: remove unused 'Nodes'
Matthew Fernandez [Sun, 31 Oct 2021 16:42:14 +0000 (09:42 -0700)]
smyrna: remove unused 'Nodes'

3 years agosmyrna: remove unused 'customptr'
Matthew Fernandez [Sun, 31 Oct 2021 16:40:15 +0000 (09:40 -0700)]
smyrna: remove unused 'customptr'

3 years agosmyrna: remove unused 'picked_nodes'
Matthew Fernandez [Sun, 31 Oct 2021 16:39:25 +0000 (09:39 -0700)]
smyrna: remove unused 'picked_nodes'

3 years agosmyrna: remove unused 'picked_edges'
Matthew Fernandez [Sun, 31 Oct 2021 16:38:47 +0000 (09:38 -0700)]
smyrna: remove unused 'picked_edges'

3 years agosmyrna: remove unused 'maxnodedegree'
Matthew Fernandez [Sun, 31 Oct 2021 16:37:56 +0000 (09:37 -0700)]
smyrna: remove unused 'maxnodedegree'

3 years agosmyrna: remove unused 'avgedgelength'
Matthew Fernandez [Sun, 31 Oct 2021 16:36:49 +0000 (09:36 -0700)]
smyrna: remove unused 'avgedgelength'

3 years agosmyrna: remove unused 'init_zoom'
Matthew Fernandez [Sun, 31 Oct 2021 16:36:10 +0000 (09:36 -0700)]
smyrna: remove unused 'init_zoom'

3 years agosmyrna: remove unused 'xdotId'
Matthew Fernandez [Sun, 31 Oct 2021 16:35:12 +0000 (09:35 -0700)]
smyrna: remove unused 'xdotId'

3 years agoMerge branch 'smattr/fff5b118-1554-42de-9e8a-2fd20c431ad4' into 'main'
Matthew Fernandez [Sat, 6 Nov 2021 21:16:01 +0000 (21:16 +0000)]
Merge branch 'smattr/fff5b118-1554-42de-9e8a-2fd20c431ad4' into 'main'

rewrite strps.awk in Python and inline it

See merge request graphviz/graphviz!2254

3 years agorewrite strps.awk in Python and inline it
Matthew Fernandez [Sat, 30 Oct 2021 16:53:47 +0000 (09:53 -0700)]
rewrite strps.awk in Python and inline it

Related to #2118.

3 years agoremove unused 'doit' script
Matthew Fernandez [Sat, 6 Nov 2021 19:21:39 +0000 (12:21 -0700)]
remove unused 'doit' script

This script is not currently used for testing and will not be used in the
foreseeable future.

3 years agoMerge branch 'smattr/76B405EB-15C9-4CFD-92A7-84E228A6CEE8' into 'main'
Matthew Fernandez [Sat, 6 Nov 2021 18:49:08 +0000 (18:49 +0000)]
Merge branch 'smattr/76B405EB-15C9-4CFD-92A7-84E228A6CEE8' into 'main'

do not create packaging hierarchy directory for architecture

Closes #2149

See merge request graphviz/graphviz!2257

3 years agodo not create packaging hierarchy directory for architecture
Matthew Fernandez [Sat, 30 Oct 2021 19:39:40 +0000 (12:39 -0700)]
do not create packaging hierarchy directory for architecture

The packaging directories were created based on various dimensions of a matrix,
with architecture at the lowest level. On Linux and macOS, Graphviz is only
packaged for a single architecture (x86-64). On Windows, Graphviz is only
packaged for two architectures (x86 and x86-64). However, the architecture is
also present in the suffix of every packaged file. E.g.

  Graphviz-2.49.3-win32.exe
  Graphviz-2.49.3-win64.exe
  graphviz-nox-2.49.3-1.fc33.x86_64.rpm

So there is no ambiguity if we drop the architecture directory. This seems to be
a case of YAGNI¹ where the system was setup to accommodate multiple
architectures but this has not been needed. We remove it now to (1) reduce
complexity and (2) have less verbose release filenames.²

Closes #2149.

¹ https://en.wikipedia.org/wiki/You_aren%27t_gonna_need_it
² Example of a current verbose release filename,
  stable_windows_10_cmake_Release_Win32_graphviz-install-2.49.3-win32.exe

3 years agoMerge branch 'smattr/101bd97e-cdd6-447e-974e-e083cba467d8' into 'main'
Matthew Fernandez [Sat, 6 Nov 2021 17:32:43 +0000 (17:32 +0000)]
Merge branch 'smattr/101bd97e-cdd6-447e-974e-e083cba467d8' into 'main'

smyrna: replace duplicated 'xml_string' with 'xml_escape'

Closes #1868

See merge request graphviz/graphviz!2255

3 years agosmyrna: remove an open coded NULL
Matthew Fernandez [Sat, 30 Oct 2021 16:34:38 +0000 (09:34 -0700)]
smyrna: remove an open coded NULL

3 years agosmyrna: replace duplicated 'xml_string' with 'xml_escape'
Matthew Fernandez [Sat, 30 Oct 2021 16:33:03 +0000 (09:33 -0700)]
smyrna: replace duplicated 'xml_string' with 'xml_escape'

This completes the long journey of unifying four XML escaping routines into one.

Closes #1868.

3 years agosmyrna: replace duplicated libcommon functions with calls to their original
Matthew Fernandez [Sat, 30 Oct 2021 16:08:27 +0000 (09:08 -0700)]
smyrna: replace duplicated libcommon functions with calls to their original

There was no need for this duplication as Smyrna already used functionality from
the very place the originals of these functions lived.

3 years agosmyrna: also link against libpathplan
Matthew Fernandez [Sat, 30 Oct 2021 16:07:54 +0000 (09:07 -0700)]
smyrna: also link against libpathplan

An upcoming change will pull in a dependency on `freePath` that resides in
libpathplan.

3 years agosmyrna: also link against libgvc
Matthew Fernandez [Sat, 30 Oct 2021 15:57:46 +0000 (08:57 -0700)]
smyrna: also link against libgvc

Upcoming changes will add references to functions that are in libgvc. Note that
no changes are required to the MSBuild build system because it already links
Smyrna against libgvc.

3 years agosmyrna: add lib/pathplan to the include path
Matthew Fernandez [Sat, 30 Oct 2021 15:53:25 +0000 (08:53 -0700)]
smyrna: add lib/pathplan to the include path

Upcoming changes will transitively #include pathgeom.h.

3 years agosmyrna: add lib/gvc to the include path
Matthew Fernandez [Sat, 30 Oct 2021 15:45:38 +0000 (08:45 -0700)]
smyrna: add lib/gvc to the include path

Upcoming changes will use some lib/common headers that #include gvcext.h.

3 years agosmyrna: remove inaccurate comment
Matthew Fernandez [Sat, 30 Oct 2021 15:32:31 +0000 (08:32 -0700)]
smyrna: remove inaccurate comment

Smyrna *already* links against both libcommon and libcgraph.

3 years agoMerge branch 'smattr/f664153c-1704-49f7-a22f-72ed3c82bcc5' into 'main'
Matthew Fernandez [Sat, 6 Nov 2021 01:20:39 +0000 (01:20 +0000)]
Merge branch 'smattr/f664153c-1704-49f7-a22f-72ed3c82bcc5' into 'main'

-Wunused-parameter clean ups

See merge request graphviz/graphviz!2258

3 years agorender.h: remove commented out prototypes
Matthew Fernandez [Sun, 31 Oct 2021 03:35:10 +0000 (20:35 -0700)]
render.h: remove commented out prototypes

These functions were made static in a38c14955ecb7417487426f0f33dfd5f63ef1775.

3 years agoaddEdgeLabels: remove legacy comment
Matthew Fernandez [Sun, 31 Oct 2021 03:32:49 +0000 (20:32 -0700)]
addEdgeLabels: remove legacy comment

Fudge factors are used elsewhere in splines.c, but not within this function.

3 years agomakeMultiSpline: remove unused 'g' parameter
Matthew Fernandez [Sun, 31 Oct 2021 03:30:22 +0000 (20:30 -0700)]
makeMultiSpline: remove unused 'g' parameter

3 years agogenroute: remove unused 'g' parameter
Matthew Fernandez [Sun, 31 Oct 2021 03:26:43 +0000 (20:26 -0700)]
genroute: remove unused 'g' parameter

3 years agofinishEdge: remove unused 'g' parameter
Matthew Fernandez [Sun, 31 Oct 2021 03:23:09 +0000 (20:23 -0700)]
finishEdge: remove unused 'g' parameter

3 years agomakeSpline: remove unused 'g' parameter
Matthew Fernandez [Sun, 31 Oct 2021 03:19:24 +0000 (20:19 -0700)]
makeSpline: remove unused 'g' parameter

3 years agomakePolyline: remove unused 'g' parameter
Matthew Fernandez [Sun, 31 Oct 2021 03:15:45 +0000 (20:15 -0700)]
makePolyline: remove unused 'g' parameter

3 years agoattachOrthoEdges: remove unused 'g' parameter
Matthew Fernandez [Sun, 31 Oct 2021 03:12:03 +0000 (20:12 -0700)]
attachOrthoEdges: remove unused 'g' parameter

3 years agoaddEdgeLabels: remove unused 'g' parameter
Matthew Fernandez [Sun, 31 Oct 2021 03:07:47 +0000 (20:07 -0700)]
addEdgeLabels: remove unused 'g' parameter

3 years agomakeSelfArcs: remove unused 'P' parameter
Matthew Fernandez [Sun, 31 Oct 2021 03:02:11 +0000 (20:02 -0700)]
makeSelfArcs: remove unused 'P' parameter

3 years agomakeSelfEdge: remove unused 'P' parameter
Matthew Fernandez [Sun, 31 Oct 2021 02:58:25 +0000 (19:58 -0700)]
makeSelfEdge: remove unused 'P' parameter

3 years agoMerge branch 'smattr/C9AAEA67-8F95-48ED-8CC9-8AA2B3694602' into 'main'
Matthew Fernandez [Wed, 3 Nov 2021 02:28:08 +0000 (02:28 +0000)]
Merge branch 'smattr/C9AAEA67-8F95-48ED-8CC9-8AA2B3694602' into 'main'

gvconfig_libdir: fix const-correctness of char pointers in macOS code

See merge request graphviz/graphviz!2264

3 years agogvconfig_libdir: fix const-correctness of char pointers in macOS code
Matthew Fernandez [Wed, 3 Nov 2021 00:04:00 +0000 (17:04 -0700)]
gvconfig_libdir: fix const-correctness of char pointers in macOS code

Commit 284df35236e258a49b86fad6f0d062bf0c2fa840 changed the source pointer `tmp`
used here to be `const`. A side effect of this was introducing a warning
breaking the CMake build on macOS:

  lib/gvc/gvconfig.c:329:10: error: initializing 'char *' with an expression of
    type 'const char *' discards qualifiers
    [-Werror,-Wincompatible-pointer-types-discards-qualifiers]
                        char* s = tmp-1;
                              ^   ~~~~~

This commit was merged via !2231 whose source branch did not have permission to
use the macOS shared runners, so this issue was not caught in pre-merge CI.

3 years agoMerge branch 'dl_iterate_phdr' into 'main'
Matthew Fernandez [Tue, 2 Nov 2021 03:39:51 +0000 (03:39 +0000)]
Merge branch 'dl_iterate_phdr' into 'main'

Prefer dl_iterate_phdr(3) over /proc/self/maps on GNU/Linux

See merge request graphviz/graphviz!2231

3 years agoPrefer dl_iterate_phdr(3) over /proc/self/maps
Nehal J Wani [Sun, 17 Oct 2021 00:49:01 +0000 (20:49 -0400)]
Prefer dl_iterate_phdr(3) over /proc/self/maps

Instead of manually iterating over /proc/self/maps, shift to using the
GNU/Linux extension function: dl_iterate_phdr(), if available.

This also helps in getting around weird problems involving shiftfs + lxd
https://travis-ci.community/t/procfs-provides-paths-outside-of-container/9525

3 years agogvconfig: move declaration of 'tmp' var local to #if <platform> blocks
Nehal J Wani [Sun, 17 Oct 2021 12:25:46 +0000 (08:25 -0400)]
gvconfig: move declaration of 'tmp' var local to #if <platform> blocks

3 years agocommon: rename ET_<> macros to EDGETYPE_<>
Nehal J Wani [Sun, 17 Oct 2021 02:24:08 +0000 (22:24 -0400)]
common: rename ET_<> macros to EDGETYPE_<>

The ET_NONE macro conflicts with a macro by the same name in
/path/to/sysroot/usr/include/elf.h

3 years agoMerge branch 'dlls-win' into 'main'
Matthew Fernandez [Mon, 1 Nov 2021 15:47:20 +0000 (15:47 +0000)]
Merge branch 'dlls-win' into 'main'

Add option to skip installing dependency DLLs

See merge request graphviz/graphviz!2252

3 years agoplugin/pango: install pango/cairo DLLs only if install_win_dependency_dlls is ON
Nehal J Wani [Tue, 26 Oct 2021 20:31:02 +0000 (16:31 -0400)]
plugin/pango: install pango/cairo DLLs only if install_win_dependency_dlls is ON

3 years agoplugin/gd: install GD DLLs only if install_win_dependency_dlls is ON
Nehal J Wani [Tue, 26 Oct 2021 20:30:29 +0000 (16:30 -0400)]
plugin/gd: install GD DLLs only if install_win_dependency_dlls is ON

3 years agolibgvc: install expat DLLs only if install_win_dependency_dlls is ON
Nehal J Wani [Tue, 26 Oct 2021 20:29:31 +0000 (16:29 -0400)]
libgvc: install expat DLLs only if install_win_dependency_dlls is ON

3 years agotools: install expat/getopt DLLs only if install_win_dependency_dlls is ON
Nehal J Wani [Tue, 26 Oct 2021 20:27:28 +0000 (16:27 -0400)]
tools: install expat/getopt DLLs only if install_win_dependency_dlls is ON

3 years agoCMake: add option to skip installing dependency DLLs on Windows
Nehal J Wani [Tue, 26 Oct 2021 01:54:46 +0000 (21:54 -0400)]
CMake: add option to skip installing dependency DLLs on Windows

Helps packaging ecosystems like Conda which use dependencies from other
packages, and do not always vendor 3rd party libraries during packaging

3 years agoMerge branch 'libs-common-expat' into 'main'
Matthew Fernandez [Mon, 1 Nov 2021 01:37:33 +0000 (01:37 +0000)]
Merge branch 'libs-common-expat' into 'main'

Specify include directory of expat for lib/common

See merge request graphviz/graphviz!2251

3 years agocommon: CMake: specify include directory of expat
Nehal J Wani [Mon, 15 Feb 2021 20:19:14 +0000 (15:19 -0500)]
common: CMake: specify include directory of expat

A build system should not rely on the existence of 3rd party
library/header files in standard prefixes as one might want to compile
and link against a patched build or a custom install in some
non-standard location. This is also helpful for developers who rely on
package managers like Conda or Spack for their daily development.

If expat is a dep, we need to pass -I/path/containing/expat.h to the
compiler while compiling the source files of the target 'common_obj',
without which, one can face the following issue:

graphviz/lib/common/htmllex.c:28:10: fatal error: expat.h: No such file or directory
   28 | #include <expat.h>
      |          ^~~~~~~~~
compilation terminated.

3 years agoMerge branch 'smattr/677A5F24-BD20-44C7-99FA-FA21644D7F7F' into 'main'
Matthew Fernandez [Sun, 31 Oct 2021 18:01:35 +0000 (18:01 +0000)]
Merge branch 'smattr/677A5F24-BD20-44C7-99FA-FA21644D7F7F' into 'main'

remove Bashism from gvmap.sh

Closes #2151

See merge request graphviz/graphviz!2259

3 years agoadd changelog entry for prior commit
Matthew Fernandez [Sun, 31 Oct 2021 16:29:54 +0000 (09:29 -0700)]
add changelog entry for prior commit

Closes #2151.

3 years agoremove bashism from gvmap.sh
Laszlo Boszormenyi (GCS) [Sun, 31 Oct 2021 16:29:05 +0000 (09:29 -0700)]
remove bashism from gvmap.sh

3 years agoMerge branch 'smattr/62c1fda0-ad72-4ce8-85d2-726ad27635b1' into 'main'
Matthew Fernandez [Sun, 31 Oct 2021 02:24:25 +0000 (02:24 +0000)]
Merge branch 'smattr/62c1fda0-ad72-4ce8-85d2-726ad27635b1' into 'main'

clean up in debian/

See merge request graphviz/graphviz!2250

3 years agoremove leading debian/changelog entries related to unreleased versions
Matthew Fernandez [Sun, 24 Oct 2021 20:29:41 +0000 (13:29 -0700)]
remove leading debian/changelog entries related to unreleased versions

As far as I can tell, this style of specifying `(@VERSION@-1)` as the Debian
package version is intended to allow the CI work flow to install an unreleased
DEB file. This works but:

  1. The current list uses this identifier twice. Presumably commit
     57337e45d04ceecc3273f7f0d9e6a2440f8128cb made a mistake in introducing a
     new version instead of appending the changelog entry to the existing
     (pending) top entry. The result is that any attempt to use this changelog
     for actual packaging would be rejected due to two changelog sections for
     the same version.

  2. The Ubuntu Intrepid (8.10) package search functionality appears to have
     been lost to the sands of time, but all recent Graphviz Ubuntu and Debian
     packages have been produced by third-party volunteers external to Graphviz.
     The two leading entries gave the false impression that recent Graphviz
     Debian/Ubuntu packages are actually produced here. To avoid this going
     forwards we retarget this to Bionic (the lowest version of Ubuntu we
     support) and add an artificial entry indicating this is not meant to be
     released.

  3. There have been numerous changes in the era of these top two entries as
     well as more recently. It is not clear to me why these two changes were
     singled out for the changelog. Running the Debian packaging flow resulted
     in a changelog indicating these two items are the only changes between
     2.18-1ubuntu5 and 2.49.3.

Related to #251.

3 years agoupdate debian/control claimed dependencies
Matthew Fernandez [Sun, 24 Oct 2021 20:24:51 +0000 (13:24 -0700)]
update debian/control claimed dependencies

This is based on the current dependencies installed by
ci/ubuntu-21.10/Dockerfile. This is work towards #251.

3 years agoMerge branch 'smattr/0CB8CD6B-A813-4242-995C-1235E5FECCD9' into 'main'
Matthew Fernandez [Sat, 30 Oct 2021 20:25:27 +0000 (20:25 +0000)]
Merge branch 'smattr/0CB8CD6B-A813-4242-995C-1235E5FECCD9' into 'main'

some boolean → bool driven clean up

See merge request graphviz/graphviz!2249

3 years agoxlib_finalize: swap a boolean for a C99 bool for 'watching_file_p'
Matthew Fernandez [Sun, 24 Oct 2021 18:02:25 +0000 (11:02 -0700)]
xlib_finalize: swap a boolean for a C99 bool for 'watching_file_p'

3 years agoxlib_finalize: swap a boolean for a C99 bool for 'watching_stdin_p'
Matthew Fernandez [Sun, 24 Oct 2021 18:01:42 +0000 (11:01 -0700)]
xlib_finalize: swap a boolean for a C99 bool for 'watching_stdin_p'

3 years agoxlib plugin: remove unnecessary casts
Matthew Fernandez [Sun, 24 Oct 2021 18:00:45 +0000 (11:00 -0700)]
xlib plugin: remove unnecessary casts

These pointers implicitly coerce.

3 years agoxlib plugin: swap a boolean for a C99 bool for 'initialized'
Matthew Fernandez [Sun, 24 Oct 2021 17:55:29 +0000 (10:55 -0700)]
xlib plugin: swap a boolean for a C99 bool for 'initialized'

3 years agoxlib plugin: remove commented out code
Matthew Fernandez [Sun, 24 Oct 2021 17:55:01 +0000 (10:55 -0700)]
xlib plugin: remove commented out code

3 years agoJSON plugin: swap boolean state fields for C99 bools
Matthew Fernandez [Sun, 24 Oct 2021 17:53:44 +0000 (10:53 -0700)]
JSON plugin: swap boolean state fields for C99 bools

3 years agocgraph write: remove unused 'Attrs_not_written_flag' global
Matthew Fernandez [Sun, 24 Oct 2021 17:53:05 +0000 (10:53 -0700)]
cgraph write: remove unused 'Attrs_not_written_flag' global

3 years agoJSON plugin: remove unused 'Attrs_not_written_flag' state field
Matthew Fernandez [Sun, 24 Oct 2021 17:52:05 +0000 (10:52 -0700)]
JSON plugin: remove unused 'Attrs_not_written_flag' state field

3 years agogdgen_polyline: swap boolean for C99 bool
Matthew Fernandez [Sun, 24 Oct 2021 17:49:16 +0000 (10:49 -0700)]
gdgen_polyline: swap boolean for C99 bool

3 years agogdgen_ellipse: swap booleans for C99 bools
Matthew Fernandez [Sun, 24 Oct 2021 17:48:47 +0000 (10:48 -0700)]
gdgen_ellipse: swap booleans for C99 bools

3 years agogdgen_polygon: swap booleans for C99 bools
Matthew Fernandez [Sun, 24 Oct 2021 17:48:13 +0000 (10:48 -0700)]
gdgen_polygon: swap booleans for C99 bools

3 years agogdgen_bezier: swap booleans for C99 bools
Matthew Fernandez [Sun, 24 Oct 2021 17:47:33 +0000 (10:47 -0700)]
gdgen_bezier: swap booleans for C99 bools

3 years agoMerge branch 'smattr/FF18EC5E-E236-4FDB-ADB2-D128E9D654C7' into 'main'
Matthew Fernandez [Sat, 30 Oct 2021 18:51:23 +0000 (18:51 +0000)]
Merge branch 'smattr/FF18EC5E-E236-4FDB-ADB2-D128E9D654C7' into 'main'

lib/fdpgen: replace header guards with more modern #pragma once

See merge request graphviz/graphviz!2248

3 years agolib/fdpgen: replace header guards with more modern #pragma once
Matthew Fernandez [Sun, 24 Oct 2021 16:21:45 +0000 (09:21 -0700)]
lib/fdpgen: replace header guards with more modern #pragma once

3 years agoMerge branch 'smattr/1A3B7F32-8996-4CA8-8119-96D2D96B2DFD' into 'main'
Matthew Fernandez [Sat, 30 Oct 2021 17:26:39 +0000 (17:26 +0000)]
Merge branch 'smattr/1A3B7F32-8996-4CA8-8119-96D2D96B2DFD' into 'main'

remove Ubuntu 20.10 from CI testing

See merge request graphviz/graphviz!2253

3 years agoremove Ubuntu 20.10 from CI testing
Matthew Fernandez [Wed, 27 Oct 2021 00:32:39 +0000 (17:32 -0700)]
remove Ubuntu 20.10 from CI testing

Ubuntu 20.10 was EOLed on 2021-07-22.¹ Related to #2144.

¹ https://wiki.ubuntu.com/Releases

3 years agoMerge branch 'textlut' into 'main'
Matthew Fernandez [Sat, 30 Oct 2021 16:01:09 +0000 (16:01 +0000)]
Merge branch 'textlut' into 'main'

Improved fallback font metrics

See merge request graphviz/graphviz!2237

3 years agolib/common: add character width lookup tables for more fonts and variants
Ben Hansell [Mon, 18 Oct 2021 17:02:46 +0000 (17:02 +0000)]
lib/common: add character width lookup tables for more fonts and variants

This allows Graphviz to estimate the widths of text spans more accurately when built without a textlayout plugin. The textlayout plugins are platform-specific and can be difficult to build for obscure platforms (e.g. Graphviz Online), resulting in node labels not fitting within their nodes nicely.

lib/common: add new source file and header

lib/common: don't install new header

lib/common: redesign hard-coded font metrics

lib/common: remove unused variables

lib/common: format new source file with clang-format

lib/common: add more fonts

lib/common: add warning spam guards

lib/common: improve code style and comments

lib/common: improve code style and comments

lib/common: fix const compiler error

lib/common: reuse existing isalpha_no_locale function

lib/common: fix another const compilation error

lib/common: fix yet another const compilation error

update changelog

update changelog

3 years agolib/common: move isalpha_no_locale into utils.h
Ben Hansell [Mon, 25 Oct 2021 09:44:19 +0000 (09:44 +0000)]
lib/common: move isalpha_no_locale into utils.h

3 years agoMerge branch 'smattr/6c732dbe-b152-45fe-a3f8-78942750f452' into 'main'
Matthew Fernandez [Sat, 30 Oct 2021 06:22:07 +0000 (06:22 +0000)]
Merge branch 'smattr/6c732dbe-b152-45fe-a3f8-78942750f452' into 'main'

splines.c: some clean up

See merge request graphviz/graphviz!2245

3 years agosplines.c: abbreviate increment and decrement patterns
Matthew Fernandez [Sat, 23 Oct 2021 21:37:21 +0000 (14:37 -0700)]
splines.c: abbreviate increment and decrement patterns

3 years agosplines.c: rephrase explicit comparison against 'FALSE'
Matthew Fernandez [Sat, 23 Oct 2021 21:27:14 +0000 (14:27 -0700)]
splines.c: rephrase explicit comparison against 'FALSE'

3 years agosplines.c: reflow some text
Matthew Fernandez [Sat, 23 Oct 2021 21:27:03 +0000 (14:27 -0700)]
splines.c: reflow some text

3 years agosplines.c: remove unnecessary use of the comma operator
Matthew Fernandez [Sat, 23 Oct 2021 21:26:42 +0000 (14:26 -0700)]
splines.c: remove unnecessary use of the comma operator

3 years agosplines.c: remove some open coding of 'fmin', 'fmax'
Matthew Fernandez [Sat, 23 Oct 2021 21:26:12 +0000 (14:26 -0700)]
splines.c: remove some open coding of 'fmin', 'fmax'

3 years agosplines.c: strip trailing whitespace
Matthew Fernandez [Sat, 23 Oct 2021 21:19:52 +0000 (14:19 -0700)]
splines.c: strip trailing whitespace

3 years agosplines.c: remove unnecessary bracketing
Matthew Fernandez [Sat, 23 Oct 2021 21:02:49 +0000 (14:02 -0700)]
splines.c: remove unnecessary bracketing

3 years agobezier_clip: use a C99 bool for 'found'
Matthew Fernandez [Sat, 23 Oct 2021 20:50:27 +0000 (13:50 -0700)]
bezier_clip: use a C99 bool for 'found'

3 years agopolylineMidpoint: squash warnings about using 'mf' uninitialized
Matthew Fernandez [Sat, 23 Oct 2021 20:47:40 +0000 (13:47 -0700)]
polylineMidpoint: squash warnings about using 'mf' uninitialized

3 years agoMerge branch 'smattr/542e3839-b1e1-4258-b60c-2bb6ed50d161' into 'main'
Matthew Fernandez [Sat, 30 Oct 2021 03:35:25 +0000 (03:35 +0000)]
Merge branch 'smattr/542e3839-b1e1-4258-b60c-2bb6ed50d161' into 'main'

VML plugin: replace `html_string` with `xml_escape`

See merge request graphviz/graphviz!2247

3 years agoVML plugin: replace 'gvputs(… html_string(…))' with 'xml_escape' functionality
Matthew Fernandez [Sat, 23 Oct 2021 20:06:20 +0000 (13:06 -0700)]
VML plugin: replace 'gvputs(… html_string(…))' with 'xml_escape' functionality

This is further work towards unifying the XML escaping code (#1868). This change
has no functional impact but makes this processing slightly more efficient
(escaped text is emitted directly into the target file/stream instead of first
constructed in an intermediate buffer) and thread safe (a static buffer is no
longer used for escaping). The latter is not so significant as other factors
make it still unsafe to call into this plugin with multiple threads.

3 years agoadd a test for XML escaping
Matthew Fernandez [Sat, 23 Oct 2021 19:07:55 +0000 (12:07 -0700)]
add a test for XML escaping

This functionality was previously indirectly tested through some other graph
processing that uses escaping. However, this introduces some unit testing of
this function giving us an extra safe guard and an easier way to diagnose
problems with this functionality.

Related to #1868.

3 years agoxml_core: support a mode for escaping UTF-8 characters
Matthew Fernandez [Sat, 16 Oct 2021 05:24:34 +0000 (22:24 -0700)]
xml_core: support a mode for escaping UTF-8 characters

This is modeled after `html_string` in the VML plugin and intended to replace
that function in a future commit. It differs from `html_string` in the following
ways:

  * More limited unicode character detection. `html_string` has a very
    generalized notion of a valid character that extends to lengths beyond what
    UTF-8 allows. This new implementation in `xml_core` adheres more strictly to
    only valid UTF-8 character lengths.

  * Simpler character parsing. `html_string` is written in a style to (1) decode
    character byte length without branching and (2) use the outer loop to also
    loop over the UTF-8 character’s bytes. This new implementation in `xml_core`
    uses simpler, more obvious code for decoding the byte length and consumes
    more than one character of the input instead of reusing the outer loop. This
    code is not on a hot path and it is not necessary or helpful to
    micro-optimize the control flow.

  * Hex escapes instead of decimal escapes. `html_string` uses `&#[0-9]+;`
    escapes while this new implementation uses `&#x[0-9a-f]+;` escapes. For
    many characters, this results in a shorter sequence. A compiler that knows
    `snprintf` as a built-in (all recent GCC and Clang) should also be able to
    generate a hex escape without using any division operations.

Note that nothing yet uses this functionality; all existing calls that go
through this code have the `utf8` flag unset.

This code aborts on encountering an invalid UTF-8 character. This is not ideal,
but matches `html_string`’s error handling. Perhaps this can be improved in
future.

Related to #1868.

3 years agoxml_core: update input pointer to reflect how many characters were consumed
Matthew Fernandez [Sat, 16 Oct 2021 05:03:27 +0000 (22:03 -0700)]
xml_core: update input pointer to reflect how many characters were consumed

This has no immediate effect because the function only ever consumes a single
character. However, a future change will introduce more sophisticated escaping
that sometimes involves consuming more than one character from the input.

Related to #1868.

3 years agoMerge branch 'smattr/53697EE0-92BE-42AD-992E-0310A16FA68C' into 'main'
Matthew Fernandez [Sat, 30 Oct 2021 01:21:55 +0000 (01:21 +0000)]
Merge branch 'smattr/53697EE0-92BE-42AD-992E-0310A16FA68C' into 'main'

smyrna: more dead code removal

See merge request graphviz/graphviz!2244

3 years agosmyrna: remove unused 'anglexyz'
Matthew Fernandez [Sat, 23 Oct 2021 02:11:34 +0000 (19:11 -0700)]
smyrna: remove unused 'anglexyz'

3 years agosmyrna: remove unused 'anglexy'
Matthew Fernandez [Sat, 23 Oct 2021 02:11:16 +0000 (19:11 -0700)]
smyrna: remove unused 'anglexy'

3 years agosmyrna: remove unused 'anglez'
Matthew Fernandez [Sat, 23 Oct 2021 02:10:51 +0000 (19:10 -0700)]
smyrna: remove unused 'anglez'

3 years agosmyrna: remove unused 'angley'
Matthew Fernandez [Sat, 23 Oct 2021 02:10:28 +0000 (19:10 -0700)]
smyrna: remove unused 'angley'

3 years agosmyrna: remove unused 'anglex'
Matthew Fernandez [Sat, 23 Oct 2021 02:10:05 +0000 (19:10 -0700)]
smyrna: remove unused 'anglex'

3 years agosmyrna: remove unused 'camera_vectorz'
Matthew Fernandez [Sat, 23 Oct 2021 02:08:56 +0000 (19:08 -0700)]
smyrna: remove unused 'camera_vectorz'