]>
granicus.if.org Git - graphviz/log
Matthew Fernandez [Tue, 11 Jan 2022 04:28:34 +0000 (20:28 -0800)]
nodeIntersect: take a C99 bool for 'explicit_tooltip'
Matthew Fernandez [Tue, 11 Jan 2022 04:23:37 +0000 (20:23 -0800)]
nodeIntersect: take a C99 bool for 'explicit_iurl'
Matthew Fernandez [Tue, 11 Jan 2022 04:17:50 +0000 (20:17 -0800)]
handle_keypress: return a C99 bool instead of boolean
Magnus Jacobsson [Tue, 11 Jan 2022 18:51:39 +0000 (18:51 +0000)]
Merge branch 'install-cygwin-from-cygwin.com' into 'main'
CI: install Cygwin from cygwin.com instead of with choco
See merge request graphviz/graphviz!2395
Magnus Jacobsson [Sun, 9 Jan 2022 22:40:41 +0000 (23:40 +0100)]
ci: install cygwin from cygwin.com instead of with choco
Matthew Fernandez [Tue, 11 Jan 2022 16:48:49 +0000 (16:48 +0000)]
Merge branch 'smattr/
9e86e6dc -0b65-411e-af31-
5cb7d722ec63 ' into 'main'
move lib/mingle/nearest_neighbor_graph.c into C++
See merge request graphviz/graphviz!2384
Matthew Fernandez [Sat, 8 Jan 2022 19:04:08 +0000 (11:04 -0800)]
nearest_neighbor_graph_ann: take array parameters as vector instead of C arrays
Now that all calls to this function are in C++, there is no need to degrade to C
data types when calling into it.
Gitlab: #2154
Matthew Fernandez [Sat, 8 Jan 2022 18:59:48 +0000 (10:59 -0800)]
nearest_neighbor_graph_ann: remove forcing of C linkage
The only calls into this function are from C++ code now, so there is no need to
require C calling conventions.
Gitlab: #2154
Matthew Fernandez [Sat, 8 Jan 2022 18:57:35 +0000 (10:57 -0800)]
nearest_neighbor_graph: remove manual memory management
Gitlab: #2154
Matthew Fernandez [Sat, 8 Jan 2022 18:54:46 +0000 (10:54 -0800)]
nearest_neighbor_graph_ann: remove a level of indirection on array parameters
None of these parameters are updated during `nearest_neighbor_graph_ann`, so
taking them by pointer is irrelevant.
Matthew Fernandez [Sat, 8 Jan 2022 18:46:01 +0000 (10:46 -0800)]
move lib/mingle/nearest_neighbor_graph.c to C++
This is straight renaming; no C++ adaptations made yet.
Gitlab: #2154
Matthew Fernandez [Sat, 8 Jan 2022 18:47:32 +0000 (10:47 -0800)]
nearest_neighbor_graph: cast the result of calls to 'malloc'
This pre-emptively suppresses some `-fpermissive` warnings when transitioning
this code to C++ in an upcoming commit.
Gitlab: #2154
Magnus Jacobsson [Tue, 11 Jan 2022 07:15:49 +0000 (07:15 +0000)]
Merge branch 'unify-storage-class-declarations-in-gvc++' into 'main'
Unify storage class declarations in gvc++
See merge request graphviz/graphviz!2394
Magnus Jacobsson [Mon, 10 Jan 2022 15:36:14 +0000 (16:36 +0100)]
gvc++: [nfc] align storage-class declarations to Graphviz standard in GVRenderData.h
Magnus Jacobsson [Mon, 10 Jan 2022 15:35:57 +0000 (16:35 +0100)]
gvc++: use GVDLL instead of _WIN32 to control storage-class attributes in GVRenderData.h
Towards https://gitlab.com/graphviz/graphviz/-/issues/2173.
Magnus Jacobsson [Mon, 10 Jan 2022 15:35:37 +0000 (16:35 +0100)]
gvc++: [nfc] align storage-class declarations to Graphviz standard in GVLayout.h
Magnus Jacobsson [Mon, 10 Jan 2022 15:35:24 +0000 (16:35 +0100)]
gvc++: use GVDLL instead of _WIN32 to control storage-class attributes in GVLayout.h
Towards https://gitlab.com/graphviz/graphviz/-/issues/2173.
Magnus Jacobsson [Mon, 10 Jan 2022 15:34:56 +0000 (16:34 +0100)]
gvc++: [nfc] align storage-class declarations to Graphviz standard in GVContext.h
Magnus Jacobsson [Mon, 10 Jan 2022 15:33:35 +0000 (16:33 +0100)]
gvc++: use GVDLL instead of _WIN32 to control storage-class attributes in GVContext.h
Towards https://gitlab.com/graphviz/graphviz/-/issues/2173.
Matthew Fernandez [Tue, 11 Jan 2022 06:01:42 +0000 (06:01 +0000)]
Merge branch 'smattr/
F5A2D01F -EFF0-42DC-81F5-
2985BE24E104 ' into 'main'
Revert Perl CFLAG mangling in tclpkg
Closes #2177
See merge request graphviz/graphviz!2388
Matthew Fernandez [Sun, 9 Jan 2022 16:32:02 +0000 (08:32 -0800)]
Revert "sed cleanup of CFLAGS from perl which break on opencsw - should be harmless elsewhere"
This reverts commit
a750d28463a9248fe5a42d3dae5768d38853d837 . It is unclear to
me exactly what flag the original code was attempting to suppress, but this
regex is too broad. The specific case causing problems right now is that it
incorrectly mangled `-mno-xop -mbmi` into `-mno-mbmi`. Given the original code
appears to have been working around a 2011 OpenCSW packaging mistake, lets
assume this was fixed sometime in the last decade and see if anyone downstream
complains when we remove the work around.
Gitlab: fixes #2177
Matthew Fernandez [Sun, 9 Jan 2022 16:27:59 +0000 (08:27 -0800)]
Revert "clang doesn't support -fstack-clash-protection"
This reverts commit
e50fd757a297e9917f801cd2781559535f03ce13 . Clang added
`-ftack-clash-protection` in 2020.¹
Gitlab: #2177
¹ https://reviews.llvm.org/D68720
Magnus Jacobsson [Mon, 10 Jan 2022 22:49:04 +0000 (22:49 +0000)]
Merge branch 'unify-storage-class-declarations-in-plugins' into 'main'
Unify storage class declarations in plugins
See merge request graphviz/graphviz!2393
Magnus Jacobsson [Mon, 10 Jan 2022 15:41:11 +0000 (16:41 +0100)]
plugin/pango: use GVDLL instead of _WIN32 to enable dllexport storage-class attribute in gvplugin_pango.c
Magnus Jacobsson [Mon, 10 Jan 2022 15:40:31 +0000 (16:40 +0100)]
plugin/pango: [nfc] remove whitespace in preprocessor directives in gvplugin_pango.c
Magnus Jacobsson [Sun, 2 Jan 2022 18:30:11 +0000 (19:30 +0100)]
plugin/neato_layout: [nfc] remove whitespace in preprocessor directives in gvplugin_neato_layout.cpp
Magnus Jacobsson [Sun, 2 Jan 2022 18:29:21 +0000 (19:29 +0100)]
plugin/gdiplus: use GVDLL instead of _WIN32 to enable dllexport storage-class attribute in gvplugin_gdiplus.c
Towards https://gitlab.com/graphviz/graphviz/-/issues/2173.
Magnus Jacobsson [Sun, 2 Jan 2022 21:11:48 +0000 (22:11 +0100)]
plugin/gdiplus: define GVDLL to ensure correct storage-class attributes
An upcoming commit will change the storage-class attributes to be
controlled by the GVDLL symbol in gvplugin_gdiplus.c.
Without this change, errors like this would occur:
EXEC : error : failed to resolve gvplugin_gdiplus_LTX_library in C:\Users\magja\graphviz\Debug\Graphviz\bin\gvplugin_gdiplus.dll
Towards https://gitlab.com/graphviz/graphviz/-/issues/2173.
Magnus Jacobsson [Sun, 2 Jan 2022 18:28:35 +0000 (19:28 +0100)]
plugin/gdiplus: [nfc] remove whitespace in preprocessor directives in gvplugin_gdiplus.cpp
Magnus Jacobsson [Mon, 10 Jan 2022 15:39:28 +0000 (16:39 +0100)]
plugin/gd: [nfc] align storage-class declarations to Graphviz standard in gvrender_gd.c
Magnus Jacobsson [Mon, 10 Jan 2022 15:38:45 +0000 (16:38 +0100)]
plugin/gd: use GVDLL instead of _WIN32 to control storage-class attributes in gvrender_gd.c
Magnus Jacobsson [Sun, 2 Jan 2022 18:27:32 +0000 (19:27 +0100)]
plugin/gd: [nfc] remove whitespace in preprocessor directives in gvrender_gd.c
Magnus Jacobsson [Sun, 2 Jan 2022 18:24:52 +0000 (19:24 +0100)]
plugin/gd: use GVDLL instead of _WIN32 to enable dllexport storage-class attribute in gvplugin_gd.c
Towards https://gitlab.com/graphviz/graphviz/-/issues/2173.
Magnus Jacobsson [Sun, 2 Jan 2022 21:11:48 +0000 (22:11 +0100)]
plugin/gd: define GVDLL to ensure correct storage-class attributes
An upcoming commit will change the storage-class attributes to be
controlled by the GVDLL symbol in gvplugin_gd.c.
Without this change, errors like this would occur:
EXEC : error : failed to resolve gvplugin_gd_LTX_library in C:\Users\magja\graphviz\Debug\Graphviz\bin\gvplugin_gd.dll
Towards https://gitlab.com/graphviz/graphviz/-/issues/2173.
Magnus Jacobsson [Sun, 2 Jan 2022 18:23:28 +0000 (19:23 +0100)]
plugin/gd: [nfc] remove whitespace in preprocessor directives in gvplugin_gd.c
Magnus Jacobsson [Sun, 2 Jan 2022 18:21:54 +0000 (19:21 +0100)]
plugin/dot_layout: use GVDLL instead of _WIN32 to enable dllexport storage-class attribute in gvplugin_dot_layout.c
Towards https://gitlab.com/graphviz/graphviz/-/issues/2173.
Magnus Jacobsson [Sun, 2 Jan 2022 21:11:48 +0000 (22:11 +0100)]
plugin/dot_layout: define GVDLL to ensure correct storage-class attributes
An upcoming commit will change the storage-class attributes to be
controlled by the GVDLL symbol in gvplugin_dot_layout.c.
Without this change, errors like this would occur:
EXEC : error : failed to resolve gvplugin_dot_layout_LTX_library in C:\Users\magja\graphviz\Debug\Graphviz\bin\gvplugin_dot_layout.dll
Towards https://gitlab.com/graphviz/graphviz/-/issues/2173.
Magnus Jacobsson [Sun, 2 Jan 2022 18:21:09 +0000 (19:21 +0100)]
plugin/dot_layout: [nfc] remove whitespace in preprocessor directives in gvplugin_dot_layout.c
Magnus Jacobsson [Sun, 2 Jan 2022 18:13:30 +0000 (19:13 +0100)]
plugin/core: use GVDLL instead of _WIN32 to enable dllexport storage-class attribute in gvplugin_core.c
Towards https://gitlab.com/graphviz/graphviz/-/issues/2173.
Magnus Jacobsson [Sun, 2 Jan 2022 18:13:30 +0000 (19:13 +0100)]
plugin/core: [nfc] remove whitespace in preprocessor directives in gvplugin_core.c
Magnus Jacobsson [Mon, 10 Jan 2022 17:10:56 +0000 (17:10 +0000)]
Merge branch 'install-python-with-nuget' into 'main'
CI: install Python with nuget instead of with choco
See merge request graphviz/graphviz!2392
Matthew Fernandez [Mon, 10 Jan 2022 16:48:16 +0000 (16:48 +0000)]
Merge branch 'smattr/
DFDACC2F -624B-4360-BC9C-
9B2A116EB11C ' into 'main'
more boolean → modernization
See merge request graphviz/graphviz!2391
Magnus Jacobsson [Sun, 9 Jan 2022 22:34:55 +0000 (23:34 +0100)]
ci: install python with nuget in windows-cygwin-build-using-autogen job
Magnus Jacobsson [Sun, 9 Jan 2022 22:32:45 +0000 (23:32 +0100)]
ci: remove now obsolete choco cache from windows-msbuild-Win32-debug-build job
Magnus Jacobsson [Sun, 9 Jan 2022 22:31:55 +0000 (23:31 +0100)]
ci: remove now obsolete choco cache from windows-msbuild-Win32-release-build job
Magnus Jacobsson [Sun, 9 Jan 2022 22:31:40 +0000 (23:31 +0100)]
ci: remove now obsolete choco cache from windows-cmake-x64-debug-build job
Magnus Jacobsson [Sun, 9 Jan 2022 22:31:26 +0000 (23:31 +0100)]
ci: remove now obsolete choco cache from windows-cmake-x64-release-build job
Magnus Jacobsson [Sun, 9 Jan 2022 22:31:06 +0000 (23:31 +0100)]
ci: remove now obsolete choco cache from windows-cmake-Win32-debug-build job
Magnus Jacobsson [Sun, 9 Jan 2022 22:30:54 +0000 (23:30 +0100)]
ci: remove now obsolete choco cache from windows-cmake-Win32-release-build job
Magnus Jacobsson [Sun, 9 Jan 2022 17:02:12 +0000 (18:02 +0100)]
ci: install python with nuget in windows_build_definition job template
Magnus Jacobsson [Sun, 9 Jan 2022 22:34:02 +0000 (23:34 +0100)]
ci: remove now obsolete choco cache from windows-mingw64-cmake-build job
Commit
3f4d8dfc07899d113ddc49e2610b669113ea2810 removed the use of the
choco cache, but missed to remove the cache itself from this job.
Magnus Jacobsson [Sun, 9 Jan 2022 22:33:04 +0000 (23:33 +0100)]
ci: remove now obsolete choco cache from windows-mingw32-cmake-build job
Commit
3f4d8dfc07899d113ddc49e2610b669113ea2810 removed the use of the
choco cache, but missed to remove the cache itself from this job.
Magnus Jacobsson [Sun, 9 Jan 2022 22:30:10 +0000 (23:30 +0100)]
ci: remove now obsolete choco cache from windows-mingw64-build-step2-make job
Commit
3f4d8dfc07899d113ddc49e2610b669113ea2810 removed the use of the
choco cache, but missed to remove the cache itself from this job.
Magnus Jacobsson [Sun, 9 Jan 2022 22:30:01 +0000 (23:30 +0100)]
ci: remove now obsolete choco cache from windows-mingw64-build-step1-configure job
Commit
3f4d8dfc07899d113ddc49e2610b669113ea2810 removed the use of the
choco cache, but missed to remove the cache itself from this job.
Magnus Jacobsson [Sun, 9 Jan 2022 22:29:45 +0000 (23:29 +0100)]
ci: remove now obsolete choco cache from windows-mingw32-build-step2-make job
Commit
3f4d8dfc07899d113ddc49e2610b669113ea2810 removed the use of the
choco cache, but missed to remove the cache itself from this job.
Magnus Jacobsson [Sun, 9 Jan 2022 22:29:25 +0000 (23:29 +0100)]
ci: remove now obsolete choco cache from windows-mingw32-build-step1-configure job
Commit
3f4d8dfc07899d113ddc49e2610b669113ea2810 removed the use of the
choco cache, but missed to remove the cache itself from this job.
Matthew Fernandez [Mon, 10 Jan 2022 00:49:59 +0000 (16:49 -0800)]
is_internal_to_cluster; return a C99 bool instead of an ambiguous int
Matthew Fernandez [Mon, 10 Jan 2022 00:49:14 +0000 (16:49 -0800)]
is_nonconstraint: return a C99 bool instead of an ambiguous int
Matthew Fernandez [Mon, 10 Jan 2022 00:48:35 +0000 (16:48 -0800)]
is_empty: return a C99 bool instead of an ambigous int
Matthew Fernandez [Mon, 10 Jan 2022 00:47:26 +0000 (16:47 -0800)]
is_cluster: return a C99 bool instead of an ambiguous int
Matthew Fernandez [Mon, 10 Jan 2022 00:46:00 +0000 (16:46 -0800)]
is_a_cluster: return a C99 bool instead of ambiguous int
This function was already morally returning a boolean value.
Matthew Fernandez [Mon, 10 Jan 2022 00:44:32 +0000 (16:44 -0800)]
mapbool: take a 'const char*' parameter instead of 'char*'
This parameter is not modified internally.
Matthew Fernandez [Mon, 10 Jan 2022 00:43:32 +0000 (16:43 -0800)]
mapbool: return a C99 bool instead of a boolean
Matthew Fernandez [Mon, 10 Jan 2022 00:34:27 +0000 (16:34 -0800)]
mapBool: take a 'const char*' parameter instead of 'char*'
This parameter is not modified within the function.
Matthew Fernandez [Mon, 10 Jan 2022 00:32:23 +0000 (16:32 -0800)]
mapBool: use C99 bools for boolean parameters
Note that this required a somewhat awkward work around in `getAdjustMode` that
was abusing being able to fit something other than a boolean into the type used
for booleans.
Matthew Fernandez [Mon, 10 Jan 2022 00:16:21 +0000 (16:16 -0800)]
late_bool: use C99 bools for boolean parameters
Matthew Fernandez [Mon, 10 Jan 2022 00:08:35 +0000 (16:08 -0800)]
ortho segment: remove unused 'flipped' member
Matthew Fernandez [Sun, 9 Jan 2022 16:56:53 +0000 (08:56 -0800)]
node_distinct_coloring: take 'weightedQ' parameter as a C99 bool
Matthew Fernandez [Sun, 9 Jan 2022 16:50:52 +0000 (08:50 -0800)]
gvmap plot_dot_map: use a C99 bool for local 'plot_polyQ'
Matthew Fernandez [Sun, 9 Jan 2022 16:50:20 +0000 (08:50 -0800)]
gvprintpointflist: replace a boolean literal with C99 bool 'true'
Magnus Jacobsson [Mon, 10 Jan 2022 15:05:06 +0000 (15:05 +0000)]
Merge branch 'unify-storage-class-declarations-in-xdot' into 'main'
Unify storage class declarations in xdot
See merge request graphviz/graphviz!2390
Magnus Jacobsson [Sun, 2 Jan 2022 18:05:22 +0000 (19:05 +0100)]
xdot: [nfc] align storage-class declarations to Graphviz standard in xdot.h
Magnus Jacobsson [Sun, 2 Jan 2022 18:04:22 +0000 (19:04 +0100)]
xdot: [nfc] remove useless default extern declaration of functions in xdot.h
Magnus Jacobsson [Sun, 2 Jan 2022 18:01:59 +0000 (19:01 +0100)]
xdot: use GVDLL instead of _WIN32 to control storage-class attributes in xdot.h
Towards https://gitlab.com/graphviz/graphviz/-/issues/2173.
Magnus Jacobsson [Sun, 2 Jan 2022 17:36:33 +0000 (18:36 +0100)]
xdot: [nfc] remove whitespace in preprocessor directives in xdot.h
Magnus Jacobsson [Mon, 3 Jan 2022 06:20:54 +0000 (07:20 +0100)]
xdot: MSBuild: define GVDLL to ensure correct storage-class attributes
An upcoming commit will change the storage-class attributes in
xdot.h to be controlled by the GVDLL symbol.
Without this change, errors like this would occur in lib/gvc:
LINK : fatal error LNK1104: cannot open file 'C:\Users\magja\graphviz\Debug\Graphviz\bin\xdot.lib'
Done building project "gvc.vcxproj" -- FAILED.
Towards https://gitlab.com/graphviz/graphviz/-/issues/2173.
Magnus Jacobsson [Mon, 10 Jan 2022 14:01:54 +0000 (14:01 +0000)]
Merge branch 'misc-nfc-unify-storage-class-declarations' into 'main'
Miscellaneous non-functional changes to unify storage class declarations
See merge request graphviz/graphviz!2389
Magnus Jacobsson [Sun, 2 Jan 2022 17:28:39 +0000 (18:28 +0100)]
sfio: [nfc] rename EXTERN macro to SFIO_API in sfio.h
Magnus Jacobsson [Sun, 2 Jan 2022 17:07:18 +0000 (18:07 +0100)]
ortho: [nfc] align storage-class declarations to Graphviz standard in ortho.h
Magnus Jacobsson [Sun, 2 Jan 2022 17:05:36 +0000 (18:05 +0100)]
lib/gvpr: [nfc] remove extra _WIN32 condition to apply storage-class attributes in gvpr.h
This is a non-functional change since this code is guarded with GVDLL
which is only ever defined when _WIN32 is defined.
Magnus Jacobsson [Sun, 2 Jan 2022 17:04:19 +0000 (18:04 +0100)]
lib/gvpr: [nfc] remove whitespace in preprocessor directives in gvpr.h
Magnus Jacobsson [Sun, 2 Jan 2022 17:02:13 +0000 (18:02 +0100)]
gvc: [nfc] remove useless default extern declaration of functions in gvc.h
Magnus Jacobsson [Sun, 2 Jan 2022 16:28:35 +0000 (17:28 +0100)]
edgepaint: [nfc] align storage-class declarations to Graphviz standard in lab_gamut.h
Magnus Jacobsson [Sun, 2 Jan 2022 16:26:52 +0000 (17:26 +0100)]
edgepaint: [nfc] rename EXTERN macro to LAB_GAMUT_API in lab_gamut.h
Magnus Jacobsson [Sun, 2 Jan 2022 17:12:32 +0000 (18:12 +0100)]
pathutil: [nfc] remove useless default extern declaration of functions in vis.h
Magnus Jacobsson [Sun, 2 Jan 2022 17:11:52 +0000 (18:11 +0100)]
pathplan: [nfc] remove useless comments in vis.h
Magnus Jacobsson [Sun, 2 Jan 2022 17:10:26 +0000 (18:10 +0100)]
pathplan: [nfc] remove useless default extern declaration of functions in pathutil.h
Magnus Jacobsson [Sun, 2 Jan 2022 17:08:29 +0000 (18:08 +0100)]
pathplan: [nfc] remove useless comments in pathutil.h
Magnus Jacobsson [Sun, 2 Jan 2022 16:07:13 +0000 (17:07 +0100)]
pathplan: CMake: [nfc] remove useless definition of _BLD_pathplan
This symbol is not used anywhere.
Magnus Jacobsson [Sun, 2 Jan 2022 16:07:13 +0000 (17:07 +0100)]
pathplan: [nfc] remove useless definition of _BLD_pathplan in pathutil.h
This symbol is not used anywhere.
Magnus Jacobsson [Mon, 10 Jan 2022 13:02:24 +0000 (13:02 +0000)]
Merge branch 'fix-mingw-cmake-builds-and-add-tests' into 'main'
Fix MinGW CMake builds and add tests
Closes #2176 and #1780
See merge request graphviz/graphviz!2387
Magnus Jacobsson [Tue, 4 Jan 2022 14:16:13 +0000 (15:16 +0100)]
ci: add windows-mingw32-cmake-test job
Magnus Jacobsson [Tue, 4 Jan 2022 14:16:13 +0000 (15:16 +0100)]
ci: add windows-mingw64-cmake-test job
Magnus Jacobsson [Thu, 6 Jan 2022 13:39:29 +0000 (14:39 +0100)]
add ci/mingw-test.sh
Magnus Jacobsson [Tue, 4 Jan 2022 08:01:27 +0000 (09:01 +0100)]
ci/mingw-install.sh: install python-pip
Magnus Jacobsson [Fri, 7 Jan 2022 14:58:35 +0000 (15:58 +0100)]
test_1408: don't expect failure on MinGW
It's unclear why this test does not fail on MinGW when if fails on
other OSes. The NDEBUG symbols is not defined in MinGW builds and
assertions have been verified to be enabled.
Magnus Jacobsson [Tue, 4 Jan 2022 09:37:12 +0000 (10:37 +0100)]
gvtest.py: correct compiler used on MinGW
Magnus Jacobsson [Sun, 9 Jan 2022 11:28:42 +0000 (12:28 +0100)]
CMake: ensure PangoCairo is found on MinGW
This makes the PNG format available in CMake builds with MinGW.
Magnus Jacobsson [Fri, 7 Jan 2022 19:17:49 +0000 (20:17 +0100)]
CMake: ensure Cairo is found on MinGW
Magnus Jacobsson [Fri, 7 Jan 2022 21:42:20 +0000 (22:42 +0100)]
plugin/pango: print font map when verbose for all platforms
This effectively reverts commit
2029d4bf76360aba04a0ca779058caba7682e1e9 .
Fixes this error with CMake on MinGW when compiled with -Werror:
C:/Users/magja/graphviz/plugin/pango/gvgetfontlist_pango.c:477:1: error: 'printFontMap' defined but not used [-Werror=unused-function]
477 | printFontMap (gv_font_map*gv_fmap, int sz)
| ^~~~~~~~~~~~