The hardware and bandwidth for this mirror is donated by dogado GmbH, the Webhosting and Full Service-Cloud Provider. Check out our Wordpress Tutorial.
If you wish to report a bug, or if you are interested in having us mirror your free-software or open-source project, please feel free to contact us at mirror[@]dogado.de.
rvtk is an infrastructure package that makes the Visualization Toolkit (VTK) available to
other R packages that need to link against it. It provides four utility
functions — CppFlags(), LdFlags(),
LdFlagsFile(), and VtkVersion() — that return
the correct compiler and linker flags for however VTK was found or
installed on the current machine.
The configure script tries each strategy in order,
stopping as soon as one succeeds:
VTK_DIR (path to a VTK build
or install tree).brew --prefix vtk) — macOS only.pkg-config (vtk-9.5, vtk-9.4,
…, vtk-9.1)./usr,
/usr/local) — Linux only.The configure.win script also tries each strategy in
order:
VTK_DIR.pacman (queries installed packages; never
installs automatically)./x86_64-w64-mingw32.static.posix, /ucrt64,
/mingw64, …).x86_64-w64-mingw32.static.posix toolchain from https://github.com/astamm/rvtk/releases as a
fallback.Windows — disabled modules. The Rtools45
static.posixsysroot does not providenetcdforlibproj. Consequently, the following VTK modules are disabled in the Windows pre-built libraries:VTK_IONetCDF,VTK_IOHDF,VTK_GeovisCore,VTK_RenderingCore. Downstream packages that require any of these modules cannot currently be built on Windows.
| Platform | VTK strategy | Supported |
|---|---|---|
| macOS | System (Homebrew, shared) | ✔ |
| macOS | Pre-built static (automatic fallback) | ✔ |
| macOS | Custom VTK_DIR (static or shared) |
✔ |
| Linux | System (apt / pkg-config, shared) | ✔ |
| Linux | Pre-built static (automatic fallback) | ✔ |
| Linux | Custom VTK_DIR (static or shared) |
✔ |
| Windows | Pre-built static (automatic fallback) | ✔ |
| Windows | Pre-built shared DLLs (VTK_LINK_TYPE=shared) |
✔ |
| Windows | Custom VTK_DIR with static .a libs |
✔ |
| Windows | Custom VTK_DIR / pacman / MSYS2 with static
.a libs |
✔ |
| Windows | Custom VTK_DIR / pacman / MSYS2 with shared libs
only |
✔ |
[!NOTE]
Windows: choosing static vs. shared on the pre-built fallback
By default the pre-built fallback downloads static
.alibraries, which is the right choice for CRAN packages (no DLL dependencies for end users, no run-time path configuration).To opt into the pre-built shared-DLL build instead, set the
VTK_LINK_TYPEenvironment variable before installing rvtk:VTK_LINK_TYPE=shared Rscript -e 'pak::pak("astamm/rvtk")'or in an R session:
Sys.setenv(VTK_LINK_TYPE = "shared") pak::pak("astamm/rvtk")When
VTK_LINK_TYPE=sharedthe installer downloadsvtk-X.Y.Z-shared-posix-x64.zip, places the DLLs ininst/vtk-dlls/, and recordsVTK_LINK=sharedinvtk.conf. An.onLoadhook prepends that directory toPATHviaSys.setenv()when rvtk is loaded, so downstream packages require no extra configuration.Configuration results are stored in
inst/vtk.confand read at run time byCppFlags(),LdFlags(), andVtkVersion().
[!IMPORTANT]
Downstream package developers using Windows shared VTK
When rvtk is installed with
VTK_LINK_TYPE=shared(or when a system installation with only shared libs is detected), downstream packages link against VTK.dll.aimport libraries and load the VTK DLLs from rvtk’sinst/vtk-dlls/at run time.This has two implications that downstream package authors should communicate to their users:
rvtk and the downstream package must be kept in sync. The downstream package is compiled against the specific VTK version (and DLL ABI) shipped with the rvtk version installed at compile time. If rvtk is later updated to a new VTK version (e.g. 9.5 → 9.6), the downstream package must be recompiled against the new rvtk to match the new DLL names (e.g.
vtkCommonCore-9.6.dll). Binary packages compiled against an older rvtk will fail to load.DLL footprint grows in rvtk only. The VTK DLLs are staged inside rvtk’s own
inst/vtk-dlls/directory. Downstream packages do not receive a copy — they rely on rvtk’s.onLoadhook prepending that directory toPATHat run time. Each additional VTK module added to the pre-built DLL set therefore increases the install-time and CRAN size cost of rvtk only, not of downstream packages. To request additional modules, open an issue on the rvtk repository.For CRAN submissions, the static pre-built build (default) is recommended because it has no run-time coupling to rvtk’s DLLs and is self-contained within the downstream package binary.
# install.packages("pak")
pak::pak("astamm/rvtk")A system VTK installation (≥ 9.1.0) is not required: if none is found the package downloads pre-built static libraries automatically.
Add rvtk to the Imports field of your
DESCRIPTION:
Imports: rvtk
Because $(shell ...) is a GNU make extension that is
not allowed in Makevars, the correct
approach is to query rvtk::CppFlags() and
rvtk::LdFlagsFile() from a configure /
configure.win script and write the results into
src/Makevars at install time.
LdFlagsFile() is preferred over LdFlags()
for the linker flags because the full set of VTK -l flags
can exceed the 8 191-character Windows command-line limit, which causes
the linker to silently drop flags at the end of the list.
LdFlagsFile(path) writes the flags to a response file and
returns @path — the short token the linker reads instead.
GNU ld and LLVM lld both support this syntax. On macOS and Linux the
flags are also written to the file so the calling convention is
identical on all platforms.
src/Makevars.in (template, committed to version
control)PKG_CPPFLAGS = @VTK_CPPFLAGS@
PKG_LIBS = @VTK_LIBS@configure(.win)# configure (macOS/Linux/Windows)
#!/bin/sh
set -e
: "${R_HOME:=$(R RHOME)}"
VTK_CPPFLAGS="$("${R_HOME}/bin/Rscript" --vanilla -e "rvtk::CppFlags()")"
# LdFlagsFile() writes all linker flags to a response file (src/vtk_libs.rsp)
# and returns the short token @vtk_libs.rsp that is safe on all platforms,
# including Windows where the full flag string can exceed the 8191-char limit.
VTK_LIBS="$("${R_HOME}/bin/Rscript" --vanilla -e "rvtk::LdFlagsFile('src/vtk_libs.rsp')")"
sed -e "s|@VTK_CPPFLAGS@|${VTK_CPPFLAGS}|g" \
-e "s|@VTK_LIBS@|${VTK_LIBS}|g" \
src/Makevars.in > src/Makevars# configure.win (Windows)
#!/bin/sh
./configureMake them executable:
chmod +x configure configure.win.gitignore / .RbuildignoreAdd the generated files to .gitignore and
.Rbuildignore so they are not committed:
src/Makevars
src/vtk_libs.rsp
cleanup(.win)Add a cleanup / cleanup.win script that
removes the generated Makevars after installation so it is
not accidentally committed:
# cleanup (macOS/Linux/Windows)
#!/bin/sh
rm -f src/Makevars src/vtk_libs.rsp# cleanup.win (Windows)
#!/bin/sh
./cleanupMake them executable:
chmod +x cleanup cleanup.winThe rvtk package is meant to be used by downstream
packages that link against VTK. It is most likely that its R functions
will only be called from configure /
configure.win scripts. R CMD check will
complain because it means that you must list rvtk in
the Imports field of your DESCRIPTION but do
not actually import any of its functions in your R code. The solution is
to import at least one of the functions in a dummy R script that is not
used for anything else:
# R/rvtk_imports.R
#' @importFrom rvtk CppFlags LdFlagsFile
NULLYou can verify the detected installation at any time:
library(rvtk)
CppFlags()
#> -isystem/opt/homebrew/opt/vtk/include/vtk-9.5
LdFlagsFile(tempfile(fileext = ".rsp"))
#> -L/opt/homebrew/opt/vtk/lib -lvtkIOLegacy-9.5 -lvtkIOXML-9.5 -lvtkIOXMLParser-9.5 -lvtkIOCore-9.5 -lvtkCommonCore-9.5 -lvtkCommonDataModel-9.5 -lvtkCommonExecutionModel-9.5 -lvtkCommonMath-9.5 -lvtkCommonMisc-9.5 -lvtkCommonSystem-9.5 -lvtkCommonTransforms-9.5 -lvtksys-9.5
VtkVersion()
#> [1] "9.5.0"These binaries (installable software) and packages are in development.
They may not be fully stable and should be used with caution. We make no claims about them.
Health stats visible at Monitor.