]> granicus.if.org Git - graphviz/log
graphviz
3 years agoremove unused (and shadowed) MAX_GRPS
Matthew Fernandez [Thu, 20 May 2021 00:17:02 +0000 (17:17 -0700)]
remove unused (and shadowed) MAX_GRPS

3 years agoremove unused string_split
Matthew Fernandez [Thu, 20 May 2021 00:07:11 +0000 (17:07 -0700)]
remove unused string_split

Apart from being unused, this function has multiple issues:

  1. Comment typo “separater.”
  2. Comment discusses a path returning 1 that does not exist.
  3. Useless return value.
  4. The last store to len in the last loop is dead. This variable is unused
     after this point because the containing loop is exited and it is unused in
     the remainder of the function.
  5. The two mallocs in the last loop over-allocate by one byte. The len
     variable tracking the length of strings being constructed here was
     incremented *past* the '\0' terminator in the previous line. Thus the
     length of the string including '\0' is len, not len + 1.
  6. The allocations in the loop are essentially doing an open-coded strdup (or
     even more efficiently, strndup).
  7. Both the large static buffer swork and the optional larger allocation into
     swork1 are unnecessary. Tracking offset and length in s would allow using
     the original memory as a source to any strndup/strncpy.
  8. The ss allocation reserves one entry too many. The number of tokens is
     ntokens, not ntokens + 1, and this array is not zeroed on allocation so the
     last entry merely contains garbage.

3 years agoremove unused maxlen and MAX_GPRS
Matthew Fernandez [Thu, 20 May 2021 00:05:40 +0000 (17:05 -0700)]
remove unused maxlen and MAX_GPRS

These look to have been copy-pasted from cmd/gvmap/gvmap.c despite not being
used in this file.

3 years agoremove an unused enum
Matthew Fernandez [Thu, 20 May 2021 00:05:06 +0000 (17:05 -0700)]
remove an unused enum

3 years agoMerge branch 'smattr/c6c4b95c-0778-48a4-8cb3-bc41691a30f8' into 'main'
Matthew Fernandez [Fri, 28 May 2021 04:54:34 +0000 (04:54 +0000)]
Merge branch 'smattr/c6c4b95c-0778-48a4-8cb3-bc41691a30f8' into 'main'

clean up in lib/sparse and some minor warning squashing

See merge request graphviz/graphviz!1971

3 years agoremove unused SparseMatrix_import_binary_fp
Matthew Fernandez [Sat, 22 May 2021 01:17:08 +0000 (18:17 -0700)]
remove unused SparseMatrix_import_binary_fp

3 years agoremove unused SparseMatrix_import_binary
Matthew Fernandez [Sat, 22 May 2021 01:16:38 +0000 (18:16 -0700)]
remove unused SparseMatrix_import_binary

3 years agoremove unused SparseMatrix_export_binary_fp
Matthew Fernandez [Sat, 22 May 2021 01:15:45 +0000 (18:15 -0700)]
remove unused SparseMatrix_export_binary_fp

3 years agoremove unused SparseMatrix_export_binary
Matthew Fernandez [Sat, 22 May 2021 01:15:10 +0000 (18:15 -0700)]
remove unused SparseMatrix_export_binary

3 years agoremove unused SparseMatrix_multiply_by_scaler
Matthew Fernandez [Sat, 22 May 2021 01:07:38 +0000 (18:07 -0700)]
remove unused SparseMatrix_multiply_by_scaler

3 years agosquash -Wconversion warning in size_of_matrix_type
Matthew Fernandez [Sat, 22 May 2021 00:54:47 +0000 (17:54 -0700)]
squash -Wconversion warning in size_of_matrix_type

3 years agoremove PriorityQueue alternatives in libsparse
Matthew Fernandez [Sat, 22 May 2021 00:52:54 +0000 (17:52 -0700)]
remove PriorityQueue alternatives in libsparse

Nothing in the build defines PQ, required to enable this code. This is unused,
and has been so for some time.

3 years agosquash a number of -Wconversion warnings in pathexists
Matthew Fernandez [Sat, 22 May 2021 00:42:00 +0000 (17:42 -0700)]
squash a number of -Wconversion warnings in pathexists

3 years agoremove commented out code in visibiilty.c
Matthew Fernandez [Sat, 22 May 2021 00:31:01 +0000 (17:31 -0700)]
remove commented out code in visibiilty.c

3 years agoremove commented out code in route.c
Matthew Fernandez [Sat, 22 May 2021 00:24:03 +0000 (17:24 -0700)]
remove commented out code in route.c

3 years agosquash a -Wconversion warning in Pobspath
Matthew Fernandez [Sat, 22 May 2021 00:20:36 +0000 (17:20 -0700)]
squash a -Wconversion warning in Pobspath

3 years agoMerge branch 'smattr/096A8B9B-9E63-4926-BD55-81876BB90FE4' into 'main'
Matthew Fernandez [Fri, 28 May 2021 04:01:37 +0000 (04:01 +0000)]
Merge branch 'smattr/096A8B9B-9E63-4926-BD55-81876BB90FE4' into 'main'

remove unused fix_fc function

See merge request graphviz/graphviz!1966

3 years agoremove commented out code in gvdevice_webp.c
Matthew Fernandez [Tue, 18 May 2021 00:06:17 +0000 (17:06 -0700)]
remove commented out code in gvdevice_webp.c

3 years agoremove some unnecessary casts
Matthew Fernandez [Tue, 18 May 2021 00:05:49 +0000 (17:05 -0700)]
remove some unnecessary casts

These pointers implicitly coerce.

3 years agoremove commented out code in gvdevice_gd.c
Matthew Fernandez [Tue, 18 May 2021 00:05:32 +0000 (17:05 -0700)]
remove commented out code in gvdevice_gd.c

3 years agoremove unused fix_fc function
Matthew Fernandez [Tue, 18 May 2021 00:05:05 +0000 (17:05 -0700)]
remove unused fix_fc function

3 years agoMerge branch 'smattr/ea22ac16-db22-4ebb-9eaa-ce643d9cbd66' into 'main'
Matthew Fernandez [Fri, 28 May 2021 02:52:08 +0000 (02:52 +0000)]
Merge branch 'smattr/ea22ac16-db22-4ebb-9eaa-ce643d9cbd66' into 'main'

squash some -Wmissing-prototypes warnings

See merge request graphviz/graphviz!1964

3 years agomark create_filtered_list static
Matthew Fernandez [Sun, 16 May 2021 18:42:38 +0000 (11:42 -0700)]
mark create_filtered_list static

This function is not used outside of its containing file. Squashes a
-Wmissing-prototypes warning.

3 years agomark attr_compare static
Matthew Fernandez [Sun, 16 May 2021 18:41:37 +0000 (11:41 -0700)]
mark attr_compare static

This function is not used outside of its containing file. Squashes a
-Wmissing-prototypes warning.

3 years agomark new_attr_ref static
Matthew Fernandez [Sun, 16 May 2021 18:40:39 +0000 (11:40 -0700)]
mark new_attr_ref static

This function is not used outside of its containing file. Squashes a
-Wmissing-prototypes warning.

3 years agomark new_attr_with_ref static
Matthew Fernandez [Sun, 16 May 2021 18:39:39 +0000 (11:39 -0700)]
mark new_attr_with_ref static

This function is not used outside of its containing file. Squashes a
-Wmissing-prototypes warning.

3 years agomark vset static
Matthew Fernandez [Sun, 16 May 2021 18:37:23 +0000 (11:37 -0700)]
mark vset static

This function is not used outside of its containing file. Squashes a
-Wmissing-prototypes warning.

3 years agomark graphml_to_gv static
Matthew Fernandez [Sun, 16 May 2021 18:35:25 +0000 (11:35 -0700)]
mark graphml_to_gv static

This function is not used outside of its containing file. Squashes a
-Wmissing-prototypes warning.

3 years agomark binary() static
Matthew Fernandez [Sun, 16 May 2021 18:29:00 +0000 (11:29 -0700)]
mark binary() static

This function is unused outside of its containing file. Squashes a
-Wmissing-prototypes warning.

3 years agoremove unused newQueue and delQueue
Matthew Fernandez [Sun, 16 May 2021 18:25:42 +0000 (11:25 -0700)]
remove unused newQueue and delQueue

These functions were intended for callers who want to allocate a Queue on the
heap. However, this is unnecessary and callers all locate their Queue objects on
the stack and use mkQueue and freeQueue instead. This removal cleans up the code
a little and squashes two -Wmissing-prototypes warnings.

3 years agoremove unused taper0
Matthew Fernandez [Sun, 16 May 2021 18:15:06 +0000 (11:15 -0700)]
remove unused taper0

This function’s only use is in test code and the header declaring its prototype
is not shipped. It is simpler to omit this (and utility function halffunc) from
the libcommon build entirely. Squashes one -Wmissing-prototypes warning.

3 years agoMerge branch 'smattr/7df6badd-5417-4940-bfc5-1d83cd0ee93b' into 'main'
Matthew Fernandez [Thu, 27 May 2021 15:49:03 +0000 (15:49 +0000)]
Merge branch 'smattr/7df6badd-5417-4940-bfc5-1d83cd0ee93b' into 'main'

some clean up in plugin/core/gvloadimage_core.c

See merge request graphviz/graphviz!1960

3 years agosquash another -Wsign-conversion warning in core_loadimage_ps
Matthew Fernandez [Sat, 15 May 2021 00:42:05 +0000 (17:42 -0700)]
squash another -Wsign-conversion warning in core_loadimage_ps

us->datasize and statbuf.st_size are equal at this point, so we may as well use
the correctly typed one of them.

3 years agosquash a -Wsign-conversion warning in core_loadimage_ps
Matthew Fernandez [Sat, 15 May 2021 00:40:50 +0000 (17:40 -0700)]
squash a -Wsign-conversion warning in core_loadimage_ps

The st_size field is always positive, but is apparently an off_t which then
triggers -Wsign-conversion warnings when being converted to a size_t.

3 years agosquash -Wunused-parameter warnings in core_loadimage_null
Matthew Fernandez [Sat, 15 May 2021 00:37:03 +0000 (17:37 -0700)]
squash -Wunused-parameter warnings in core_loadimage_null

3 years agosquash -Wunused-parameter warning in core_loadimage_tk
Matthew Fernandez [Sat, 15 May 2021 00:36:15 +0000 (17:36 -0700)]
squash -Wunused-parameter warning in core_loadimage_tk

3 years agosquash -Wunused-parameter warning in core_loadimage_vml
Matthew Fernandez [Sat, 15 May 2021 00:35:46 +0000 (17:35 -0700)]
squash -Wunused-parameter warning in core_loadimage_vml

3 years agosquash -Wunused-parameter warning in core_loadimage_ps
Matthew Fernandez [Sat, 15 May 2021 00:35:02 +0000 (17:35 -0700)]
squash -Wunused-parameter warning in core_loadimage_ps

3 years agosquash -Wunused-parameter warnings in core_loadimage_vrml
Matthew Fernandez [Sat, 15 May 2021 00:34:16 +0000 (17:34 -0700)]
squash -Wunused-parameter warnings in core_loadimage_vrml

3 years agosquash -Wunused-parameter warning in core_loadimage_fig
Matthew Fernandez [Sat, 15 May 2021 00:33:19 +0000 (17:33 -0700)]
squash -Wunused-parameter warning in core_loadimage_fig

3 years agoSquash -Wunused-parameter warning in core_loadimage_svg
Matthew Fernandez [Sat, 15 May 2021 00:32:23 +0000 (17:32 -0700)]
Squash -Wunused-parameter warning in core_loadimage_svg

3 years agoMerge branch 'smattr/db55e7bf-5761-43ca-8645-0314c3920597' into 'main'
Matthew Fernandez [Thu, 27 May 2021 15:00:30 +0000 (15:00 +0000)]
Merge branch 'smattr/db55e7bf-5761-43ca-8645-0314c3920597' into 'main'

micro-optimizations in the SVG back end

See merge request graphviz/graphviz!1970

3 years agocompute the extent of some gvputs writes at compile time
Matthew Fernandez [Fri, 21 May 2021 03:50:11 +0000 (20:50 -0700)]
compute the extent of some gvputs writes at compile time

This change teaches the compiler how to unfold gvputs of a string literal into
gvwrite, computing the length of the literal at compile time. This is only
applied to the SVG back end in this commit.

On tests/regression_tests/large/long_chain, this drops the number of gvputs
calls from 2442066 to 363011, though obviously introduces the difference as
gvwrite calls. The total executed instructions drops from 8093310656 to
8009099650, a speed up of ~1%.

3 years agofuse some adjacent gvputs calls
Matthew Fernandez [Fri, 21 May 2021 03:25:00 +0000 (20:25 -0700)]
fuse some adjacent gvputs calls

On tests/regression_tests/large/long_chain this drops the number of gvputs calls
from 2475072 to 2442066, reducing the amount of the trace for which gvputs is
responsible from 6.60% to 6.53%. Total executed instructions are reduced from
8098098396 to 8093310656, a speed up of ~0.05%.

3 years agooptimize two calls to gvprintf with single characters
Matthew Fernandez [Fri, 21 May 2021 02:34:36 +0000 (19:34 -0700)]
optimize two calls to gvprintf with single characters

The expression `gvprintf(j, "%c", x)` is equivalent to `gvwrite(j, &x, 1)`.
However, it seems modern compilers, even with link-time optimization enabled,
are not clever enough to see this equivalence. By unraveling the gvprintf call
to what it eventually bottoms out to, we can accelerate SVG generation.

On tests/regression_tests/large/long_chain, this drops the number of gvprintf
calls from 297008 to 165008, reducing the amount of the trace for which gvprintf
is responsible from 3.27% to 2.24%. Total executed instructions are reduced from
8160974807 to 8098098396, a speed up of ~1%.

3 years agoconvert some gvprintf calls with no format codes to gvputs
Matthew Fernandez [Fri, 21 May 2021 02:21:21 +0000 (19:21 -0700)]
convert some gvprintf calls with no format codes to gvputs

This is equivalent, but gvputs is less expensive to call than gvprintf.
Surprisingly,¹ with link-time optimization a compiler is able to see this
optimization for itself, so this makes no difference to performance in an LTO
build. However, this should be a slight optimization in non-LTO builds.

¹ I say surprisingly because compilers generally do not attempt inter-procedural
  optimization across varargs calls. The calling convention and interpretation
  of arguments is complex enough that they generally conservatively leave such
  calls alone.

3 years agoMerge branch 'smattr/f159e34f-c340-45ea-9a09-9f15224b86fa' into 'main'
Matthew Fernandez [Thu, 27 May 2021 04:19:14 +0000 (04:19 +0000)]
Merge branch 'smattr/f159e34f-c340-45ea-9a09-9f15224b86fa' into 'main'

specialize and accelerate gv_trim_zeros

See merge request graphviz/graphviz!1961

3 years agospecialize and accelerate gv_trim_zeros
Matthew Fernandez [Sat, 15 May 2021 15:58:05 +0000 (08:58 -0700)]
specialize and accelerate gv_trim_zeros

This function trims unnecessary trailing zeros from a printed floating-point
number. It was written to be extremely general, however it is only ever used to
trim a number printed with the format string "%.02f". We can take advantage of
this fact to know that, if it can locate a period, there are exactly two digits
following this that need to be checked. This then allows implementing the
remainder of the function not as a loop but as simply a few branches.

Using tests/regression_tests/large/long_chain, which has been used for other
profiling in this area, this drops total executed instructions from 8160952787
to 8143275099, a speed up of ~2%.

3 years agobroaden 0 check in gvprintdouble
Matthew Fernandez [Sat, 15 May 2021 15:07:20 +0000 (08:07 -0700)]
broaden 0 check in gvprintdouble

The 0 path in this function is, as the comment says, to avoid printing confusing
numbers like -0.00. However, the remainder of the function prints the number to
2 decimal places. So actually any number that *rounds* to -0.00 is going to come
out this way. To avoid this, we can expand the cases where we take an early
exit. This is also a minor performance speed up in these cases, as the 0 path is
faster than the common path.

3 years agoMerge branch 'smattr/0d18cca6-492a-444a-becc-1629ed010728' into 'main'
Matthew Fernandez [Thu, 27 May 2021 03:24:36 +0000 (03:24 +0000)]
Merge branch 'smattr/0d18cca6-492a-444a-becc-1629ed010728' into 'main'

clean up cmd/gvmap/country_graph_coloring.c

See merge request graphviz/graphviz!1969

3 years agoremove initialization of int with a double
Matthew Fernandez [Thu, 20 May 2021 03:48:08 +0000 (20:48 -0700)]
remove initialization of int with a double

It is unclear what this was attempting to achieve.

3 years agoreplace use of ints as bools with C99 bools in country_graph_coloring.c
Matthew Fernandez [Thu, 20 May 2021 03:47:41 +0000 (20:47 -0700)]
replace use of ints as bools with C99 bools in country_graph_coloring.c

3 years agoreplace some use of MIN on doubles with standard fmin
Matthew Fernandez [Thu, 20 May 2021 03:40:51 +0000 (20:40 -0700)]
replace some use of MIN on doubles with standard fmin

3 years agoremove commented out code in country_graph_coloring.c
Matthew Fernandez [Thu, 20 May 2021 03:34:56 +0000 (20:34 -0700)]
remove commented out code in country_graph_coloring.c

3 years agomark country_graph_coloring_internal static
Matthew Fernandez [Thu, 20 May 2021 03:32:30 +0000 (20:32 -0700)]
mark country_graph_coloring_internal static

This function is not used outside of its containing file.

3 years agomark improve_antibandwidth_by_swapping_cheap static
Matthew Fernandez [Thu, 20 May 2021 03:31:19 +0000 (20:31 -0700)]
mark improve_antibandwidth_by_swapping_cheap static

This function is not used outside of its containing file.

3 years agoremove unused pq argument from check_swap
Matthew Fernandez [Thu, 20 May 2021 03:27:41 +0000 (20:27 -0700)]
remove unused pq argument from check_swap

3 years agoremove unused improve_antibandwidth_by_swapping_for_fortran
Matthew Fernandez [Thu, 20 May 2021 03:25:03 +0000 (20:25 -0700)]
remove unused improve_antibandwidth_by_swapping_for_fortran

3 years agoremove unused country_graph_coloring_general
Matthew Fernandez [Thu, 20 May 2021 03:24:02 +0000 (20:24 -0700)]
remove unused country_graph_coloring_general

3 years agoremove unused improve_antibandwidth_by_swapping_for_fortran_
Matthew Fernandez [Thu, 20 May 2021 03:08:53 +0000 (20:08 -0700)]
remove unused improve_antibandwidth_by_swapping_for_fortran_

3 years agoremove unused IMPROVE_ANTIBANDWIDTH_BY_SWAPPING_FOR_FORTRAN
Matthew Fernandez [Thu, 20 May 2021 03:08:39 +0000 (20:08 -0700)]
remove unused IMPROVE_ANTIBANDWIDTH_BY_SWAPPING_FOR_FORTRAN

3 years agoremove unused IMPROVE_ANTIBANDWIDTH_BY_SWAPPING_FOR_FORTRAN_
Matthew Fernandez [Thu, 20 May 2021 03:08:26 +0000 (20:08 -0700)]
remove unused IMPROVE_ANTIBANDWIDTH_BY_SWAPPING_FOR_FORTRAN_

3 years agoMerge branch 'smattr/1D1FAD3C-12A8-4BE5-979D-6425E993C151' into 'main'
Matthew Fernandez [Thu, 27 May 2021 01:47:01 +0000 (01:47 +0000)]
Merge branch 'smattr/1D1FAD3C-12A8-4BE5-979D-6425E993C151' into 'main'

Move back to 2.47 development series

See merge request graphviz/graphviz!1977

3 years agoMove back to 2.47 development series
Matthew Fernandez [Thu, 27 May 2021 00:58:41 +0000 (17:58 -0700)]
Move back to 2.47 development series

3 years agoMerge branch 'smattr/0F3EB13A-FB8F-4B18-BA3B-2C77172988E0' into 'main' 2.47.2
Matthew Fernandez [Thu, 27 May 2021 00:53:31 +0000 (00:53 +0000)]
Merge branch 'smattr/0F3EB13A-FB8F-4B18-BA3B-2C77172988E0' into 'main'

Stable Release 2.47.2

See merge request graphviz/graphviz!1963

3 years agoStable Release 2.47.2
Matthew Fernandez [Sun, 16 May 2021 17:36:11 +0000 (10:36 -0700)]
Stable Release 2.47.2

3 years agoMerge branch 'dll-data' into 'main'
Matthew Fernandez [Fri, 21 May 2021 00:36:24 +0000 (00:36 +0000)]
Merge branch 'dll-data' into 'main'

sfio: remove uwin specific handling

See merge request graphviz/graphviz!1959

3 years agosfio: remove uwin specific handling
Saleem Abdulrasool [Fri, 14 May 2021 22:40:58 +0000 (15:40 -0700)]
sfio: remove uwin specific handling

The indirection of the data through the IAT is implicitly handled by
modern linkers and compilers when the data symbol is annotated with
`__declspec(dll{import,export})`.  This removes the support for the
older toolchains as part of the work to properly annotate symbols for
improvements to the Windows port.

3 years agoMerge branch 'smattr/7B3F1422-4C87-4B72-8CBB-F395FF5AAB87' into 'main'
Matthew Fernandez [Thu, 20 May 2021 03:42:57 +0000 (03:42 +0000)]
Merge branch 'smattr/7B3F1422-4C87-4B72-8CBB-F395FF5AAB87' into 'main'

optimize 0 case in xdot_fmt_num

See merge request graphviz/graphviz!1958

3 years agooptimize 0 case in xdot_fmt_num
Matthew Fernandez [Fri, 14 May 2021 00:07:53 +0000 (17:07 -0700)]
optimize 0 case in xdot_fmt_num

Commit 894e94c66340187ff6f8ea97c9336ea048a3d6ad applied a performance
optimization to gvprintdouble that was contributing to a performance issue in a
user’s graph. The code touched in this commit has the same pattern as that in
gvprintdouble, and the same corresponding (latent) performance issue. While it
is not known to cause any problems currently, we may as well proactively apply
the same optimization here.

This preserves the same functionality, but simply takes an early exit from the
function when we already know precisely how to print the resulting string.

3 years agoMerge branch 'fix-msvc-linkage-errors' into 'main'
Magnus Jacobsson [Wed, 19 May 2021 19:29:24 +0000 (19:29 +0000)]
Merge branch 'fix-msvc-linkage-errors' into 'main'

Remove MSVC linkage warnings

See merge request graphviz/graphviz!1931

3 years agoRemove duplicated declarations in smyrna topviewfuncs.h
Magnus Jacobsson [Fri, 23 Apr 2021 05:44:50 +0000 (07:44 +0200)]
Remove duplicated declarations in smyrna topviewfuncs.h

3 years agoCorrect MSVC storage-class in gvpr.h. Removes one warning
Magnus Jacobsson [Mon, 19 Apr 2021 20:35:42 +0000 (22:35 +0200)]
Correct MSVC storage-class in gvpr.h. Removes one warning

Only set __declspec(dllexport) or __declspec(dllimport) when the gvpr
library is dynamically linked. This is defined by GVDLL which is set
in the Windows MSBuild builds which use dynamic linking, but unset in
the Windows CMake builds which use static linking.

Removes the following warning from the Windows CMake builds:

C:\GitLab-Runner\builds\graphviz\graphviz\lib\gvpr\gvpr.c(931,1): warning C4273: 'gvpr': inconsistent dll linkage [C:\GitLab-Runner\builds\graphviz\graphviz\build\lib\gvpr\gvpr.vcxproj]

3 years agoAdd missing GVDLL define in lib/gvpr Windows MSBuild Debug build
Magnus Jacobsson [Mon, 26 Apr 2021 11:36:13 +0000 (13:36 +0200)]
Add missing GVDLL define in lib/gvpr Windows MSBuild Debug build

GVDLL is used by the autotools and MSBuild build systems to specify
dynamic linking on Windows.

3 years agoCorrect MSVC storage-class in geomprocs.h. Removes 19 warnings
Magnus Jacobsson [Mon, 19 Apr 2021 19:21:55 +0000 (21:21 +0200)]
Correct MSVC storage-class in geomprocs.h. Removes 19 warnings

Avoid setting __declspec(dllimport) when gvc is being exported.

Removes the following warnings from the Windows CMake builds:

C:\Users\magja\graphviz\lib\common\geom.c(20,1): warning C4273: 'mkbox': inconsistent dll linkage [C:\Users\magja\graphviz\build\lib\common\common_obj.vcxproj]
C:\Users\magja\graphviz\lib\common\geom.c(41,1): warning C4273: 'mkboxf': inconsistent dll linkage [C:\Users\magja\graphviz\build\lib\common\common_obj.vcxproj]
C:\Users\magja\graphviz\lib\common\geom.c(84,1): warning C4273: 'lineToBox': inconsistent dll linkage [C:\Users\magja\graphviz\build\lib\common\common_obj.vcxproj]
C:\Users\magja\graphviz\lib\common\geom.c(194,1): warning C4273: 'rect2poly': inconsistent dll linkage [C:\Users\magja\graphviz\build\lib\common\common_obj.vcxproj]
C:\Users\magja\graphviz\lib\common\geom.c(229,1): warning C4273: 'cwrotatep': inconsistent dll linkage [C:\Users\magja\graphviz\build\lib\common\common_obj.vcxproj]
C:\Users\magja\graphviz\lib\common\geom.c(257,1): warning C4273: 'cwrotatepf': inconsistent dll linkage [C:\Users\magja\graphviz\build\lib\common\common_obj.vcxproj]
C:\Users\magja\graphviz\lib\common\geom.c(285,1): warning C4273: 'ccwrotatep': inconsistent dll linkage [C:\Users\magja\graphviz\build\lib\common\common_obj.vcxproj]
C:\Users\magja\graphviz\lib\common\geom.c(313,1): warning C4273: 'ccwrotatepf': inconsistent dll linkage [C:\Users\magja\graphviz\build\lib\common\common_obj.vcxproj]
C:\Users\magja\graphviz\lib\common\geom.c(341,1): warning C4273: 'flip_rec_box': inconsistent dll linkage [C:\Users\magja\graphviz\build\lib\common\common_obj.vcxproj]
C:\Users\magja\graphviz\lib\common\geom.c(357,1): warning C4273: 'flip_rec_boxf': inconsistent dll linkage [C:\Users\magja\graphviz\build\lib\common\common_obj.vcxproj]
C:\Users\magja\graphviz\lib\common\geom.c(378,1): warning C4273: 'ptToLine2': inconsistent dll linkage [C:\Users\magja\graphviz\build\lib\common\common_obj.vcxproj]
C:\Users\magja\graphviz\lib\common\geom.c(395,1): warning C4273: 'line_intersect': inconsistent dll linkage [C:\Users\magja\graphviz\build\lib\common\common_obj.vcxproj]
LINK : warning LNK4217: symbol 'ptToLine2' defined in 'geom.obj' is imported by 'emit.obj' in function 'check_control_points' [C:\Users\magja\graphviz\build\lib\gvc\gvc.vcxproj]
LINK : warning LNK4217: symbol 'rect2poly' defined in 'geom.obj' is imported by 'emit.obj' in function 'emit_map_rect' [C:\Users\magja\graphviz\build\lib\gvc\gvc.vcxproj]
LINK : warning LNK4217: symbol 'ccwrotatepf' defined in 'geom.obj' is imported by 'postproc.obj' in function 'gv_postprocess' [C:\Users\magja\graphviz\build\lib\gvc\gvc.vcxproj]
LINK : warning LNK4286: symbol 'ccwrotatepf' defined in 'geom.obj' is imported by 'shapes.obj' [C:\Users\magja\graphviz\build\lib\gvc\gvc.vcxproj]
LINK : warning LNK4217: symbol 'flip_rec_boxf' defined in 'geom.obj' is imported by 'shapes.obj' in function 'record_path' [C:\Users\magja\graphviz\build\lib\gvc\gvc.vcxproj]
LINK : warning LNK4217: symbol 'cwrotatepf' defined in 'geom.obj' is imported by 'shapes.obj' in function 'compassPoint' [C:\Users\magja\graphviz\build\lib\gvc\gvc.vcxproj]
LINK : warning LNK4217: symbol 'lineToBox' defined in 'geom.obj' is imported by 'utils.obj' in function 'overlap_bezier' [C:\Users\magja\graphviz\build\lib\gvc\gvc.vcxproj]

3 years agoMerge branch 'smattr/5EE54780-9173-406B-8B95-DC903AD46E4F' into 'main'
Matthew Fernandez [Wed, 19 May 2021 15:27:14 +0000 (15:27 +0000)]
Merge branch 'smattr/5EE54780-9173-406B-8B95-DC903AD46E4F' into 'main'

remove diff and grep as Windows build and test dependencies

Closes #2069

See merge request graphviz/graphviz!1957

3 years agoremove Windows CI check for diff
Matthew Fernandez [Thu, 13 May 2021 02:44:13 +0000 (19:44 -0700)]
remove Windows CI check for diff

Following the prior changes, diff is no longer a test suite dependency on
Windows. Closes #2069.

3 years agoreplace use of diff in rtest with filecmp
Matthew Fernandez [Thu, 13 May 2021 02:42:11 +0000 (19:42 -0700)]
replace use of diff in rtest with filecmp

This is a step towards removing diff as a test dependency, so Windows users do
not need to install it. Related to #2069.

3 years agoreplace use of diff in test_reference with difflib
Matthew Fernandez [Thu, 13 May 2021 02:28:30 +0000 (19:28 -0700)]
replace use of diff in test_reference with difflib

This is a step towards removing diff as a test dependency, so Windows users do
not need to install it. Related to #2069.

3 years agoremove Windows CI check for grep
Matthew Fernandez [Thu, 13 May 2021 02:10:54 +0000 (19:10 -0700)]
remove Windows CI check for grep

Following the prior changes, grep is no longer a build dependency on Windows.
Related to #2069.

3 years agoreplace use of grep in Windows CI task with Select-String
Matthew Fernandez [Thu, 13 May 2021 01:49:25 +0000 (18:49 -0700)]
replace use of grep in Windows CI task with Select-String

This warning counting can be achieved without the use of grep. This is a step
towards removing grep as a Windows build dependency. Related to #2069.

3 years agoreplace use of grep in Windows build utility setup with Select-String
Matthew Fernandez [Thu, 13 May 2021 01:14:17 +0000 (18:14 -0700)]
replace use of grep in Windows build utility setup with Select-String

This is a built-in function in PowerShell with equivalent functionality for this
purpose. This change is a step towards removing grep as a build dependency on
Windows. Related to #2069.

3 years agoMerge branch 'smattr/4B36E297-A6E1-4C9A-A3AE-9D765264D73C' into 'main'
Matthew Fernandez [Wed, 19 May 2021 03:27:15 +0000 (03:27 +0000)]
Merge branch 'smattr/4B36E297-A6E1-4C9A-A3AE-9D765264D73C' into 'main'

some clean up in cmd/gvedit

See merge request graphviz/graphviz!1956

3 years agoreplace header guards in gvedit with more modern #pragma once
Matthew Fernandez [Thu, 13 May 2021 00:08:48 +0000 (17:08 -0700)]
replace header guards in gvedit with more modern #pragma once

3 years agoremove commented out code in gvedit
Matthew Fernandez [Thu, 13 May 2021 00:08:40 +0000 (17:08 -0700)]
remove commented out code in gvedit

3 years agouse isEmpty in preference to checking length against 0 in gvedit
Matthew Fernandez [Thu, 13 May 2021 00:08:31 +0000 (17:08 -0700)]
use isEmpty in preference to checking length against 0 in gvedit

Qt QStrings have two methods, isEmpty and length, analogous to empty and length
on std::string, respectively. Checking isEmpty is equivalent to checking length
against 0, is clearer, and has the potential to be more performant.

3 years agoMerge branch 'smattr/A7790D85-5D41-49CD-A9BC-38AE5FA3B570' into 'main'
Matthew Fernandez [Tue, 18 May 2021 04:19:41 +0000 (04:19 +0000)]
Merge branch 'smattr/A7790D85-5D41-49CD-A9BC-38AE5FA3B570' into 'main'

remove work around for stateful macOS CI runners

See merge request graphviz/graphviz!1955

3 years agoremove work around for stateful macOS CI runners
Matthew Fernandez [Wed, 12 May 2021 01:49:18 +0000 (18:49 -0700)]
remove work around for stateful macOS CI runners

Graphviz was part of a closed beta program for Gitlab macOS CI runners.¹ During
the beta period, Graphviz had access to a single macOS VM environment that was
stateful. That is, the effects of any macOS CI task would persist to the next
macOS CI task. To work around this, logic was introduced to manually remove the
Graphviz installed in the macOS CI environment by the prior run.

The Gitlab program will transition into open beta on 2021-05-22, however the
Graphviz configuration was already migrated to the open beta model on
2021-04-07.² This means the macOS runner are no longer stateful:

  To recap, for the closed beta, we provisioned a static macOS virtual machine
  for each project. This meant that we executed any pipeline job in your
  associated repository on the same virtual machine each time. Since the VM was
  dedicated to your project, this also meant that your pipeline job did not have
  to wait in a queue before running.

  For the open-beta, each job that requires a macOS build environment will run
  in its own ephemeral virtual machine provisioned on demand by the GitLab
  Runner macOS autoscaler. This means that you can’t rely on persistent storage
  anymore.

This change removes the work around that is no longer needed. This reverts
62165551efb389ea14a6709ffd89b2b5ed79e35c.

  ¹ https://gitlab.com/gitlab-com/macos-buildcloud-runners-beta/-/issues/3
  ² https://gitlab.com/gitlab-com/macos-buildcloud-runners-beta/-/issues/3#note_536852935

3 years agoMerge branch 'smattr/dc82b281-8d6d-492b-b2df-62c89447711e' into 'main'
Matthew Fernandez [Sun, 16 May 2021 17:28:17 +0000 (17:28 +0000)]
Merge branch 'smattr/dc82b281-8d6d-492b-b2df-62c89447711e' into 'main'

more warning squashing

See merge request graphviz/graphviz!1939

3 years agosquash some -Wfloat-conversion warnings
Matthew Fernandez [Sun, 2 May 2021 03:38:36 +0000 (20:38 -0700)]
squash some -Wfloat-conversion warnings

If we need -0.1 and -0.2 as floats (or the closest representation), we should
just say so. This improves the compiler’s ability to understand the intent of
this code.

3 years agouse float square root function withing getEdgeLength
Matthew Fernandez [Sun, 2 May 2021 03:36:35 +0000 (20:36 -0700)]
use float square root function withing getEdgeLength

Like prior commits in this series, this avoids using the double function with
float arguments.

3 years agomore explicit float computation in hsv2rgb
Matthew Fernandez [Sun, 2 May 2021 03:24:25 +0000 (20:24 -0700)]
more explicit float computation in hsv2rgb

Instead of being vague with ints, doubles, and floats, this commit standardizes
on float literals in hsv2rgb. This squashes a number of -Wfloat-conversion
compiler warnings.

3 years agouse hypotf to squash a -Wfloat-conversion warning
Matthew Fernandez [Sun, 2 May 2021 03:17:30 +0000 (20:17 -0700)]
use hypotf to squash a -Wfloat-conversion warning

For the same reason as the previous commit, this fixes an intermingling of
doubles and floats, and also abbreviates code.

3 years agouse floating point math functions to squash a -Wfloat-conversion warning
Matthew Fernandez [Sun, 2 May 2021 03:15:30 +0000 (20:15 -0700)]
use floating point math functions to squash a -Wfloat-conversion warning

The function sqrt operates on doubles, which was triggering a -Wfloat-conversion
compiler warning. The float version of this function is sqrtf, but we can
further abbreviate this operation by observing it is computing the hypotenuse of
a right-angled triangle and use the library function for that instead.

3 years agouse a float literal to squash a -Wfloat-conversion warning
Matthew Fernandez [Sun, 2 May 2021 03:14:37 +0000 (20:14 -0700)]
use a float literal to squash a -Wfloat-conversion warning

3 years agoavoid using double literals with a float variable
Matthew Fernandez [Sun, 2 May 2021 03:13:10 +0000 (20:13 -0700)]
avoid using double literals with a float variable

With -Wfloat-conversion, the compiler warns that going via double literals like
this resulted in an imprecise float. To squash this warning and be more precise,
we can use float literals instead.

3 years agoremove use of double literals with ydelta in make_flat_labeled_edge
Matthew Fernandez [Sun, 2 May 2021 03:03:51 +0000 (20:03 -0700)]
remove use of double literals with ydelta in make_flat_labeled_edge

Commit ebe7517ae4eb86ee4bf34e1af31a174f1f0a4049 altered these lines to use
double literals instead of integer literals for `5` and `6`. It is not clear why
it did this as ydelta is an integer variable. The effect of that change was to
ask the compiler to perform the computation itself using doubles and then reduce
it to an integer result. This commit reverts that part of the diff to simply use
integer computation throughout. This change was motivated by the compiler
diagnosing this issue with -Wfloat-conversion.

3 years agoremove some commented out code
Matthew Fernandez [Sun, 2 May 2021 02:57:20 +0000 (19:57 -0700)]
remove some commented out code

3 years agosquash a -Wfloat-conversion due to sqrt in distBetweenPts
Matthew Fernandez [Sun, 2 May 2021 02:52:43 +0000 (19:52 -0700)]
squash a -Wfloat-conversion due to sqrt in distBetweenPts

There is a dedicated libc function for doing square root of floats, but this
code was incorrectly calling the version for doubles instead. This updated code
is more appropriate and could even be more efficient.

3 years agosquash some -Wfloat-conversion warnings in lib/glcomp
Matthew Fernandez [Sun, 2 May 2021 02:50:50 +0000 (19:50 -0700)]
squash some -Wfloat-conversion warnings in lib/glcomp

These literals were doubles, but being implicitly converted to floats. This
resulted in precision loss. E.g. the compiler diagnoses:

  conversion from ‘double’ to ‘GLfloat’ {aka ‘float’} changes value from
  ‘-1.0e-3’ to ‘-1.00000005e-3’

By writing these as float literals to begin with, we can get a more precise
value.