]> granicus.if.org Git - graphviz/log
graphviz
2 years agoMerge branch 'smattr/03db530d-2fe9-47e3-b566-bda45c2928ce' into 'main'
Matthew Fernandez [Sat, 6 Aug 2022 19:13:43 +0000 (19:13 +0000)]
Merge branch 'smattr/03db530d-2fe9-47e3-b566-bda45c2928ce' into 'main'

expr: replace 'exdump' SFIO buffer with an 'agxbuf'

See merge request graphviz/graphviz!2781

2 years agoexpr: remove unused parameters from 'Exdisc_t.matchf'
Matthew Fernandez [Fri, 5 Aug 2022 04:43:03 +0000 (21:43 -0700)]
expr: remove unused parameters from 'Exdisc_t.matchf'

I guess when I committed 260f650085eb25b5b68c81a5960232d025fb6942 it was not
obvious to me that this is entirely part of private internal interfaces and the
callback signature involved is not exposed publicly.

2 years agoexpr: remove unused parameters from 'Exdisc_t.setf'
Matthew Fernandez [Fri, 5 Aug 2022 04:35:28 +0000 (21:35 -0700)]
expr: remove unused parameters from 'Exdisc_t.setf'

I guess when I committed 5b4de3922a2f169c2e773ffe85651898aedd9351 it was not
obvious to me that this is entirely part of private internal interfaces and the
callback signature involved is not exposed publicly.

2 years agoexpr: remove dereferencing and parens around calling 'Exdisc_t.keyf'
Matthew Fernandez [Fri, 5 Aug 2022 04:29:21 +0000 (21:29 -0700)]
expr: remove dereferencing and parens around calling 'Exdisc_t.keyf'

The compiler does not need to be explicitly told how to call through a function
pointer.

2 years agoexpr: remove unused parameters from 'Exdisc_t.keyf'
Matthew Fernandez [Fri, 5 Aug 2022 04:28:01 +0000 (21:28 -0700)]
expr: remove unused parameters from 'Exdisc_t.keyf'

I guess when I committed 2e9753d9c9886f5bc013212420528e9a18bc592b it was not
obvious to me that this is entirely part of private internal interfaces and the
callback signature involved is not exposed publicly.

2 years agoexpr: remove dereferencing and parens around calling 'Exdisc_t.stringof'
Matthew Fernandez [Fri, 5 Aug 2022 04:23:19 +0000 (21:23 -0700)]
expr: remove dereferencing and parens around calling 'Exdisc_t.stringof'

The compiler does not need to be explicitly told how to call through a function
pointer.

2 years agoexpr: remove dereferencing and parens around calling 'Exdisc_t.typename'
Matthew Fernandez [Fri, 5 Aug 2022 04:21:45 +0000 (21:21 -0700)]
expr: remove dereferencing and parens around calling 'Exdisc_t.typename'

The compiler does not need to be explicitly told how to call through a function
pointer.

2 years agoexpr: remove unused 'pg' parameter from 'Exdisc_t.typename'
Matthew Fernandez [Fri, 5 Aug 2022 04:20:54 +0000 (21:20 -0700)]
expr: remove unused 'pg' parameter from 'Exdisc_t.typename'

2 years agoexpr: remove dereferencing and parens around calling 'Exdisc_t.binaryf'
Matthew Fernandez [Fri, 5 Aug 2022 04:16:27 +0000 (21:16 -0700)]
expr: remove dereferencing and parens around calling 'Exdisc_t.binaryf'

The compiler does not need to be explicitly told how to call through a function
pointer.

2 years agoexpr: remove unused parameters from 'Exdisc_t.binaryf'
Matthew Fernandez [Fri, 5 Aug 2022 04:15:09 +0000 (21:15 -0700)]
expr: remove unused parameters from 'Exdisc_t.binaryf'

I guess when I committed b0ec7b2eb448a2cb68ffb3751e9e054aecc60c24 it was not
obvious to me that this is entirely part of private internal interfaces and the
callback signature involved is not exposed publicly.

2 years agoexpr: remove dereferencing and parens around calling 'Exdisc_t.convertf'
Matthew Fernandez [Fri, 5 Aug 2022 04:10:26 +0000 (21:10 -0700)]
expr: remove dereferencing and parens around calling 'Exdisc_t.convertf'

The compiler does not need to be explicitly told how to call through a function
pointer.

2 years agoexpr: remove unused parameters from 'Exdisc_t.convertf'
Matthew Fernandez [Fri, 5 Aug 2022 04:07:55 +0000 (21:07 -0700)]
expr: remove unused parameters from 'Exdisc_t.convertf'

I guess when I committed 17479ab6569d40a4778870f712226aa7916f3ca3 it was not
obvious to me that this is entirely part of private internal interfaces and the
callback signature involved is not exposed publicly.

2 years agoexpr: remove dereferencing and parens around calling 'Exdisc_t.reff'
Matthew Fernandez [Fri, 5 Aug 2022 03:56:27 +0000 (20:56 -0700)]
expr: remove dereferencing and parens around calling 'Exdisc_t.reff'

The compiler does not need to be explicitly told how to call through a function
pointer.

2 years agoexpr: remove further unused parameters from 'Exdisc_t.reff'
Matthew Fernandez [Fri, 5 Aug 2022 03:49:08 +0000 (20:49 -0700)]
expr: remove further unused parameters from 'Exdisc_t.reff'

I guess when I committed ef3ed2a98a46d0641d936c62fde78e719cef98f8 it was not
obvious to me that this is entirely part of private internal interfaces and the
callback signature involved is not exposed publicly.

2 years agoexpr: remove now unused 'disc' parameter from 'Exdisc_t.reff'
Matthew Fernandez [Fri, 5 Aug 2022 03:46:42 +0000 (20:46 -0700)]
expr: remove now unused 'disc' parameter from 'Exdisc_t.reff'

2 years agoexpr: replace 'exdump' SFIO buffer with an 'agxbuf'
Matthew Fernandez [Fri, 5 Aug 2022 03:36:32 +0000 (20:36 -0700)]
expr: replace 'exdump' SFIO buffer with an 'agxbuf'

Unfortunately there is no easy way to stage this. We need to do it all at once,
updating every use of `deparse` and all `exdump`’s internals.

This change improves locality – it is more obvious to both users and the
compiler that the contents of this temporary buffer does not need to be retained
beyond calls to `exerror`. This is a small step towards deprecating SFIO.

Gitlab: #1873

2 years agoexpr: inline private state into 'Excc_t'
Matthew Fernandez [Fri, 5 Aug 2022 02:13:43 +0000 (19:13 -0700)]
expr: inline private state into 'Excc_t'

Now that `Excc_t` is encapsulated in excc.c and no longer considered an
extensible struct, we can stop playing macro tricks to give it extra fields and
just express these more naturally.

2 years agoexpr: move 'Excc_t', 'Exccdisc_t' into excc.c
Matthew Fernandez [Fri, 5 Aug 2022 02:09:43 +0000 (19:09 -0700)]
expr: move 'Excc_t', 'Exccdisc_t' into excc.c

Following the previous commit, these are no longer referenced anywhere else.

2 years agoexpr: make 'exccopen', 'exccclose' static
Matthew Fernandez [Fri, 5 Aug 2022 01:59:13 +0000 (18:59 -0700)]
expr: make 'exccopen', 'exccclose' static

These are not used outside of their containing file, and making them private
will enable some more impactful clean up.

2 years agoexpr gen: remove dereferencing and parens on function pointer
Matthew Fernandez [Fri, 5 Aug 2022 01:48:41 +0000 (18:48 -0700)]
expr gen: remove dereferencing and parens on function pointer

The compiler knows how to call through a function pointer without needing to be
explicitly told.

2 years agoexpr exccopen: only pass SFIO stream to callback
Matthew Fernandez [Fri, 5 Aug 2022 01:41:06 +0000 (18:41 -0700)]
expr exccopen: only pass SFIO stream to callback

This function invokes `dtwalk` passing the callback `global` to be called with
a state parameter it supplies. It was supplying `cc`, but the callback only uses
a single member of this struct. So we can simplify this code by just passing the
stream the callback writes to, `cc->ccdisc-text`, or equivalently `disc->text`.

2 years agoMerge branch 'smattr/173D0FC2-B18B-4FFB-B2E6-6272F7273A5C' into 'main'
Matthew Fernandez [Sat, 6 Aug 2022 05:45:15 +0000 (05:45 +0000)]
Merge branch 'smattr/173D0FC2-B18B-4FFB-B2E6-6272F7273A5C' into 'main'

fix unchecked allocation failures, remove 'N_NEW' definitions

See merge request graphviz/graphviz!2777

2 years agoccomps: remove 'N_NEW' that was only used in one place
Matthew Fernandez [Sun, 31 Jul 2022 16:30:26 +0000 (09:30 -0700)]
ccomps: remove 'N_NEW' that was only used in one place

This brings us one step closer to having a single `N_NEW` macro in the tree and
not having to constantly wonder which of the `N_NEW` definitions is in scope at
any point where you see it called.

2 years agoPango plugin: remove unused 'NEW'
Matthew Fernandez [Sun, 31 Jul 2022 16:28:47 +0000 (09:28 -0700)]
Pango plugin: remove unused 'NEW'

2 years agoPango plugin gv_get_ps_fontlist: postpone 'family_name' allocation
Matthew Fernandez [Sun, 31 Jul 2022 16:26:41 +0000 (09:26 -0700)]
Pango plugin gv_get_ps_fontlist: postpone 'family_name' allocation

Rather than allocating this upfront and then potentially needing to free it
later, we can use a string view to postpone the allocation to when we know it is
actually needed. This works because the lifetime of the backing memory extends
until the call to `g_free(families)`. This also fixes the lack of allocation
failure checks; instead of `strdup` we now call `strview_str` that gracefully
exits on allocation failure.

2 years agoPango plugin get_font_mapping: fix unchecked allocation
Matthew Fernandez [Sun, 31 Jul 2022 16:17:49 +0000 (09:17 -0700)]
Pango plugin get_font_mapping: fix unchecked allocation

2 years agoPango plugin gv_get_ps_fontlist: fix unchecked allocation
Matthew Fernandez [Sun, 31 Jul 2022 16:17:16 +0000 (09:17 -0700)]
Pango plugin gv_get_ps_fontlist: fix unchecked allocation

2 years agocommon genEllipticPath: fix unchecked allocation
Matthew Fernandez [Sun, 31 Jul 2022 16:16:12 +0000 (09:16 -0700)]
common genEllipticPath: fix unchecked allocation

2 years agocommon moveTo: fix unchecked allocation
Matthew Fernandez [Sun, 31 Jul 2022 16:15:42 +0000 (09:15 -0700)]
common moveTo: fix unchecked allocation

2 years agogml2gv nameOf: fix unchecked allocation
Matthew Fernandez [Sun, 31 Jul 2022 16:14:14 +0000 (09:14 -0700)]
gml2gv nameOf: fix unchecked allocation

2 years agogvgen makeTreeGen: fix unchecked allocation
Matthew Fernandez [Sun, 31 Jul 2022 16:07:38 +0000 (09:07 -0700)]
gvgen makeTreeGen: fix unchecked allocation

2 years agogvgen getCnt: fix unchecked allocation
Matthew Fernandez [Sun, 31 Jul 2022 16:06:12 +0000 (09:06 -0700)]
gvgen getCnt: fix unchecked allocation

2 years agogvgen mkTree: fix unchecked allocations
Matthew Fernandez [Sun, 31 Jul 2022 16:05:37 +0000 (09:05 -0700)]
gvgen mkTree: fix unchecked allocations

2 years agogvgen makeTetrix: fix unchecked allocations
Matthew Fernandez [Sun, 31 Jul 2022 16:05:06 +0000 (09:05 -0700)]
gvgen makeTetrix: fix unchecked allocations

2 years agogvgen makeSierpinski: fix unchecked allocations
Matthew Fernandez [Sun, 31 Jul 2022 16:04:11 +0000 (09:04 -0700)]
gvgen makeSierpinski: fix unchecked allocations

2 years agoMerge branch 'smattr/dcb7bc23-5914-43ae-94d5-0003feef06b0' into 'main'
Matthew Fernandez [Sat, 6 Aug 2022 00:58:56 +0000 (00:58 +0000)]
Merge branch 'smattr/dcb7bc23-5914-43ae-94d5-0003feef06b0' into 'main'

gvpr: more compiler warning squashing

See merge request graphviz/graphviz!2778

2 years agogvpr endString: squash a -Wconversion waning
Matthew Fernandez [Wed, 3 Aug 2022 01:37:21 +0000 (18:37 -0700)]
gvpr endString: squash a -Wconversion waning

`c` is known to be '\\' here.

2 years agogvpr parseID: simplify loop
Matthew Fernandez [Wed, 3 Aug 2022 01:34:31 +0000 (18:34 -0700)]
gvpr parseID: simplify loop

2 years agogvpr readc: cast to squash -Wconversion warnings
Matthew Fernandez [Wed, 3 Aug 2022 01:30:41 +0000 (18:30 -0700)]
gvpr readc: cast to squash -Wconversion warnings

These variables are known to be '\n' here.

2 years agogvpr: represent binding count as a size_t
Matthew Fernandez [Wed, 3 Aug 2022 01:29:15 +0000 (18:29 -0700)]
gvpr: represent binding count as a size_t

Squashes 3 -Wsign-conversion warnings.

2 years agogvpr tvtypeToStr: take a long long instead of int
Matthew Fernandez [Wed, 3 Aug 2022 01:16:18 +0000 (18:16 -0700)]
gvpr tvtypeToStr:  take a long long instead of int

This function is always called with long long values, so lets match it with its
callers. Squashes 2 -Wconversion warnings.

2 years agogvpr binary: remove unnecessary parens
Matthew Fernandez [Wed, 3 Aug 2022 01:06:11 +0000 (18:06 -0700)]
gvpr binary: remove unnecessary parens

2 years agogvpr binary: use local types that corresponds to the values being stored
Matthew Fernandez [Wed, 3 Aug 2022 01:04:11 +0000 (18:04 -0700)]
gvpr binary: use local types that corresponds to the values being stored

Squashes 2 -Wconversion warnings.

2 years agogvpr validTVT: remove unnecessary parens
Matthew Fernandez [Wed, 3 Aug 2022 01:06:50 +0000 (18:06 -0700)]
gvpr validTVT: remove unnecessary parens

2 years agogvpr validTVT: return a more appropriate type
Matthew Fernandez [Wed, 3 Aug 2022 01:01:57 +0000 (18:01 -0700)]
gvpr validTVT: return a more appropriate type

2 years agogvpr validTVT: take a long long instead of int
Matthew Fernandez [Wed, 3 Aug 2022 00:58:10 +0000 (17:58 -0700)]
gvpr validTVT: take a long long instead of int

This function is always called with long long values, so lets match it with its
callers. Squashes 2 -Wconversion warnings.

2 years agogvpr setval: use a local type that corresponds to the value being stored in it
Matthew Fernandez [Wed, 3 Aug 2022 00:55:49 +0000 (17:55 -0700)]
gvpr setval: use a local type that corresponds to the value being stored in it

Squashes a -Wconversion warning. This has no effect on functionality because the
`validTVT` call is confirming the value is within the expected range.

2 years agoMerge branch 'smattr/91ab2290-e3c6-4966-93b8-b1d10a129711' into 'main'
Matthew Fernandez [Fri, 5 Aug 2022 15:37:31 +0000 (15:37 +0000)]
Merge branch 'smattr/91ab2290-e3c6-4966-93b8-b1d10a129711' into 'main'

pathplan clean up and warning squashing

See merge request graphviz/graphviz!2776

2 years agoneatogen printvis: remove unnecessary casts
Matthew Fernandez [Sat, 30 Jul 2022 21:47:05 +0000 (14:47 -0700)]
neatogen printvis: remove unnecessary casts

The type of the fields of `pts` can vary between `float` and `double` depending
compile time options, which is what this code was attempting to deal with. But
`float` and `double` are treated identically with respect to `printf`, so there
is no need to cast.

2 years agopathplan compVis: remove always-0 parameter
Matthew Fernandez [Sat, 30 Jul 2022 21:45:43 +0000 (14:45 -0700)]
pathplan compVis: remove always-0 parameter

2 years agopathplan Pobspath: squash a -Wconversion warning
Matthew Fernandez [Sat, 30 Jul 2022 16:56:42 +0000 (09:56 -0700)]
pathplan Pobspath: squash a -Wconversion warning

Here again the proper solution would be to make the struct’s field also a
`size_t` but once again it is part of the public API that we would like to avoid
breaking.

2 years agopathplan Pobspath: replace an unchecked array 'malloc' with 'gv_calloc'
Matthew Fernandez [Sat, 30 Jul 2022 16:50:18 +0000 (09:50 -0700)]
pathplan Pobspath: replace an unchecked array 'malloc' with 'gv_calloc'

This function has no way of reporting failure to the caller. So this turns an
allocation failure from a messy crash into a more graceful exit.

2 years agopathplan Pobsopen: call 'calloc' instead of 'malloc' when allocating arrays
Matthew Fernandez [Sat, 30 Jul 2022 16:47:54 +0000 (09:47 -0700)]
pathplan Pobsopen: call 'calloc' instead of 'malloc' when allocating arrays

This is the generally preferred way of doing this that avoids various pitfalls,
such as integer overflow during multiplication.

2 years agopathplan Pobsopen: use a 'size_t' when calling 'malloc'
Matthew Fernandez [Sat, 30 Jul 2022 16:45:16 +0000 (09:45 -0700)]
pathplan Pobsopen: use a 'size_t' when calling 'malloc'

Squashes a -Wsign-conversion warning and makes explicit a previously implicit
assumption.

2 years agopathplan Pobsopen: use a 'size_t' when counting objects
Matthew Fernandez [Sat, 30 Jul 2022 16:38:15 +0000 (09:38 -0700)]
pathplan Pobsopen: use a 'size_t' when counting objects

This squashes 3 -Wsign-conversion warnings and is generally closer to what we
would like to do here. The “proper” fix is for fields like `vconfig_t.N` to
become `size_t` instead of `int`. But unfortunately they are part of the public
API, and it seems undesirable to break API for this.

Note that an assumption previously implicit in this function, that all inputs
had a non-negative polygon count, is now an explicit assertion.

2 years agopathplan Pobsopen: fix unchecked allocation failures
Matthew Fernandez [Sat, 30 Jul 2022 16:29:47 +0000 (09:29 -0700)]
pathplan Pobsopen: fix unchecked allocation failures

The first `malloc` of `rv` was checked for failure but the subsequent ones were
assumed to succeed.

2 years agopathplan: remove 'mymalloc' wrapper
Matthew Fernandez [Sat, 30 Jul 2022 16:21:45 +0000 (09:21 -0700)]
pathplan: remove 'mymalloc' wrapper

The calling code does not rely on the semantics of `malloc` returning `NULL`
when called with a 0 size. It unconditionally frees these arrays in `Pobsclose`
so allocations returning a non-`NULL` pointer for 0-sized allocations (which
Glibc typically does) is fine. Maintaining a wrapper that enforces this is
unnecessary.

2 years agoMerge branch 'smattr/b76f3f9f-2903-4d65-bbfd-8ce53a769f47' into 'main'
Matthew Fernandez [Thu, 4 Aug 2022 02:07:58 +0000 (02:07 +0000)]
Merge branch 'smattr/b76f3f9f-2903-4d65-bbfd-8ce53a769f47' into 'main'

warning squashing and removing unused 'flag' parameters

See merge request graphviz/graphviz!2775

2 years agosfdpgen SparseStressMajorizationSmoother_new: remove 'scale_initial_coord' param
Matthew Fernandez [Sat, 30 Jul 2022 01:17:00 +0000 (18:17 -0700)]
sfdpgen SparseStressMajorizationSmoother_new: remove 'scale_initial_coord' param

This is always set to true.

2 years agosfdpgen SparseStressMajorizationSmoother_new: remove inverse distance weighting
Matthew Fernandez [Sat, 30 Jul 2022 01:11:26 +0000 (18:11 -0700)]
sfdpgen SparseStressMajorizationSmoother_new: remove inverse distance weighting

This scheme is unused.

2 years agogvmap makeMap: remove now unused 'flag' local
Matthew Fernandez [Sat, 30 Jul 2022 01:06:19 +0000 (18:06 -0700)]
gvmap makeMap: remove now unused 'flag' local

2 years agogvmap make_map_from_rectangle_groups: remove now unused 'flag' parameter
Matthew Fernandez [Sat, 30 Jul 2022 01:01:06 +0000 (18:01 -0700)]
gvmap make_map_from_rectangle_groups: remove now unused 'flag' parameter

2 years agogvmap make_map_internal: remove 'flag' parameter
Matthew Fernandez [Sat, 30 Jul 2022 00:56:38 +0000 (17:56 -0700)]
gvmap make_map_internal: remove 'flag' parameter

This is always set to 0 and conveys no information to the caller.

2 years agosparse QuadTree_get_nearest: remove 'flag' parameter
Matthew Fernandez [Sat, 30 Jul 2022 00:52:12 +0000 (17:52 -0700)]
sparse QuadTree_get_nearest: remove 'flag' parameter

This is always set to 0 and conveys no information to the caller.

2 years agosparse QuadTree_get_nearest_internal: remove 'flag' parameter
Matthew Fernandez [Sat, 30 Jul 2022 00:42:04 +0000 (17:42 -0700)]
sparse QuadTree_get_nearest_internal: remove 'flag' parameter

This is always set to 0 and conveys no information to the caller.

2 years agosfdpgen: remove unnecessary casts of 'Operator.data' pointers
Matthew Fernandez [Sat, 30 Jul 2022 00:39:34 +0000 (17:39 -0700)]
sfdpgen: remove unnecessary casts of 'Operator.data' pointers

2 years agosfdpgen SparseMatrix_solve: remove 'flag' parameter
Matthew Fernandez [Sat, 30 Jul 2022 00:35:04 +0000 (17:35 -0700)]
sfdpgen SparseMatrix_solve: remove 'flag' parameter

This is always set to 0 and conveys no information to the caller.

2 years agosfdpgen SparseMatrix_solve: remove unused Jacobi matrix solving
Matthew Fernandez [Sat, 30 Jul 2022 00:30:23 +0000 (17:30 -0700)]
sfdpgen SparseMatrix_solve: remove unused Jacobi matrix solving

This also removes the `method` parameter to this function, which was only ever
set to a single value. This squashes 8 compiler warnings and drops a lot of dead
code.

2 years agoneatogen constrained_majorization_vpsc: s/fabs/fabsf when dealing with floats
Matthew Fernandez [Sat, 30 Jul 2022 00:07:17 +0000 (17:07 -0700)]
neatogen constrained_majorization_vpsc: s/fabs/fabsf when dealing with floats

This squashes a -Wfloat-conversion warning.

2 years agoneatogen stress_majorization_cola: remove unused 'nedges_graph' parameter
Matthew Fernandez [Sat, 30 Jul 2022 00:05:50 +0000 (17:05 -0700)]
neatogen stress_majorization_cola: remove unused 'nedges_graph' parameter

2 years agoneatogen tweakEnd: remove unused 'pl' parameter
Matthew Fernandez [Sat, 30 Jul 2022 00:24:05 +0000 (17:24 -0700)]
neatogen tweakEnd: remove unused 'pl' parameter

2 years agoneatogen addTriEdge: remove unused 'd' parameter
Matthew Fernandez [Sat, 30 Jul 2022 00:24:05 +0000 (17:24 -0700)]
neatogen addTriEdge: remove unused 'd' parameter

This function was ignoring the parameter and calculating the edge distance
itself internally.

2 years agoMerge branch 'point-test-doc' into 'main'
Matthew Fernandez [Wed, 3 Aug 2022 02:57:42 +0000 (02:57 +0000)]
Merge branch 'point-test-doc' into 'main'

pointset: doxygen comments

See merge request graphviz/graphviz!2700

2 years agopointset: doxygen comments
Costa Shulyupin [Wed, 3 Aug 2022 02:57:41 +0000 (02:57 +0000)]
pointset: doxygen comments

2 years agoMerge branch 'partition-doc' into 'main'
Matthew Fernandez [Wed, 3 Aug 2022 01:22:37 +0000 (01:22 +0000)]
Merge branch 'partition-doc' into 'main'

partition.h: add doxygen comments

See merge request graphviz/graphviz!2707

2 years agopartition.h: add doxygen comments
Costa Shulyupin [Sat, 28 May 2022 04:11:52 +0000 (07:11 +0300)]
partition.h: add doxygen comments

2 years agopartition.h: add names of arguments
Costa Shulyupin [Sat, 28 May 2022 04:13:06 +0000 (07:13 +0300)]
partition.h: add names of arguments

and remove by the way redundant `extern`

2 years agoMerge branch 'smattr/312b41d1-07fa-4afd-911f-b761fdd0d6db' into 'main'
Matthew Fernandez [Tue, 2 Aug 2022 05:31:31 +0000 (05:31 +0000)]
Merge branch 'smattr/312b41d1-07fa-4afd-911f-b761fdd0d6db' into 'main'

gvpr warning squashing

See merge request graphviz/graphviz!2774

2 years agogvpr canontoken: use char instead of unsigned char, introduce casts
Matthew Fernandez [Thu, 28 Jul 2022 02:21:45 +0000 (19:21 -0700)]
gvpr canontoken: use char instead of unsigned char, introduce casts

It is not clear to me why this code was using unsigned char when it can do the
same thing with less typing and fewer compiler warnings using char. This also
introduces casts to squash warnings from some of the more pedantic compiler
implementations. See 6c29170f9f29466374fbc6e8e62a1b6916c6bc59 for details.

2 years agogvpr canontoken: remove commented out code
Matthew Fernandez [Thu, 28 Jul 2022 02:17:37 +0000 (19:17 -0700)]
gvpr canontoken: remove commented out code

2 years agogvpr readLine: squash -Wconversion warnings
Matthew Fernandez [Thu, 28 Jul 2022 02:13:15 +0000 (19:13 -0700)]
gvpr readLine: squash -Wconversion warnings

`c` is guaranteed to fit in a char here.

2 years agogvpr freadFile: squash a -Wsign-compare warning
Matthew Fernandez [Thu, 28 Jul 2022 02:11:31 +0000 (19:11 -0700)]
gvpr freadFile: squash a -Wsign-compare warning

2 years agogvpr fwriteFile: squash a -Wsign-compare warning
Matthew Fernandez [Thu, 28 Jul 2022 02:11:01 +0000 (19:11 -0700)]
gvpr fwriteFile: squash a -Wsign-compare warning

2 years agogvpr cloneO: squash a -Wswitch-default warning
Matthew Fernandez [Thu, 28 Jul 2022 02:08:38 +0000 (19:08 -0700)]
gvpr cloneO: squash a -Wswitch-default warning

This switch is exhaustive.

2 years agogvpr copy: squash a -Wswitch-default warning
Matthew Fernandez [Thu, 28 Jul 2022 02:07:24 +0000 (19:07 -0700)]
gvpr copy: squash a -Wswitch-default warning

This switch is exhaustive.

2 years agogvpr rindexOf: return a long instead of int
Matthew Fernandez [Thu, 28 Jul 2022 02:05:51 +0000 (19:05 -0700)]
gvpr rindexOf: return a long instead of int

The only use of this function stores the return value in a long, so lets just
return a long, squashing two compiler warnings.

2 years agogvpr cmppair: squash -Wunused-parameter warnings
Matthew Fernandez [Thu, 28 Jul 2022 01:58:25 +0000 (18:58 -0700)]
gvpr cmppair: squash -Wunused-parameter warnings

This function is used as a callback, so cannot easily have these unused
parameters removed.

2 years agoMerge branch 'smattr/a2930eb8-ba18-4789-bf34-93446083513e' into 'main'
Matthew Fernandez [Sat, 30 Jul 2022 00:56:20 +0000 (00:56 +0000)]
Merge branch 'smattr/a2930eb8-ba18-4789-bf34-93446083513e' into 'main'

lib/ast warning squashing and simplification

See merge request graphviz/graphviz!2773

2 years agoast onematch: simplify string comparisons by using string views
Matthew Fernandez [Sun, 24 Jul 2022 18:06:48 +0000 (11:06 -0700)]
ast onematch: simplify string comparisons by using string views

2 years agoast onematch: fuse comparison against 'xdigi' and 't'
Matthew Fernandez [Sun, 24 Jul 2022 17:49:39 +0000 (10:49 -0700)]
ast onematch: fuse comparison against 'xdigi' and 't'

Freed of the limitations of hash function in the previous commit, we can express
this as a single comparison.

2 years agoast onematch: rephrase hash-based switch into string comparisons
Matthew Fernandez [Sun, 24 Jul 2022 17:44:09 +0000 (10:44 -0700)]
ast onematch: rephrase hash-based switch into string comparisons

This code was using a hand rolled hash function to implement a series of string
comparisons as a jump table. I guess at some point this must have been a
necessary optimization due to limitations of the day’s compilers/machines. In a
modern environment, this is a deoptimization, impeding the compiler’s ability to
understand your intent. Modern compilers know the string comparison functions as
built-ins and can use SIMD¹/SWAR² tricks to emit a short string comparison as a
single instruction. They are also capable of transforming an if-then-else ladder
into a switch if their heuristics predict it will be worthwhile.

¹ https://en.wikipedia.org/wiki/Single_instruction,_multiple_data
² https://en.wikipedia.org/wiki/SWAR

2 years agoast gobble: squash -Wswitch-default warning
Matthew Fernandez [Sun, 24 Jul 2022 17:18:40 +0000 (10:18 -0700)]
ast gobble: squash -Wswitch-default warning

2 years agoast strmatch: squash -Wundef warnings
Matthew Fernandez [Sun, 24 Jul 2022 17:17:53 +0000 (10:17 -0700)]
ast strmatch: squash -Wundef warnings

2 years agoast stresc: squash -Wswitch-default warning
Matthew Fernandez [Sun, 24 Jul 2022 17:07:01 +0000 (10:07 -0700)]
ast stresc: squash -Wswitch-default warning

2 years agoast stresc: remove return value
Matthew Fernandez [Sun, 24 Jul 2022 17:05:08 +0000 (10:05 -0700)]
ast stresc: remove return value

The computation of the return value for this function was relying on string
lengths that fitted in an `int`, something that is generally but not always
true. The compiler complained about this with -Wconversion. The only caller of
this function does not use the return value, so lets just remove it.

2 years agoast: prototype 'pathcanon' in library header instead of inline near its use
Matthew Fernandez [Sun, 24 Jul 2022 16:59:13 +0000 (09:59 -0700)]
ast: prototype 'pathcanon' in library header instead of inline near its use

This squashes a -Wmissing-prototypes, is better style, and is generally inline
with the rest of lib/ast.

2 years agoast fmtbuf: squash -Wsign-compare warning
Matthew Fernandez [Sun, 24 Jul 2022 16:55:56 +0000 (09:55 -0700)]
ast fmtbuf: squash -Wsign-compare warning

This is computing the number of bytes remaining in `buf`; the number of bytes
between a pointer to the current offset and the end of `buf`. Thus it is always
non-negative.

2 years agoast chrtoi: squash -Wswitch-default warning
Matthew Fernandez [Sun, 24 Jul 2022 16:54:52 +0000 (09:54 -0700)]
ast chrtoi: squash -Wswitch-default warning

2 years agoast chrtoi: remove unnecessary cast
Matthew Fernandez [Sun, 24 Jul 2022 16:51:29 +0000 (09:51 -0700)]
ast chrtoi: remove unnecessary cast

2 years agoast chrtoi: squash -Wsign-compare warning
Matthew Fernandez [Sun, 24 Jul 2022 16:50:50 +0000 (09:50 -0700)]
ast chrtoi: squash -Wsign-compare warning