Local install vs install for CPack generator

If we rerun cmake after make install in our project, we get CMake warnings

Cannot generate a safe runtime search path for target ... because
  files in some directories may conflict with libraries in implicit
  directories:

    runtime library [libtiff.so.6] in /usr/lib/x86_64-linux-gnu may be hidden by files in:
      /usr/local/lib
   ...

  Some of these libraries may not be found correctly.

This is because make install copies installed libraries to another location (/usr/local/lib) that is also in our LD_LIBRARY_PATH [1].

The root cause for this is that we are confounding two different uses of the install command: For local installation, and for generating binary installers.

For local installation (compilation and installation on the same machine), we should install only our own artifacts, not third-party library dependencies that are already installed on our system.

For generating binary installers, however, we need to copy our own shared libraries and those we depend on to the same lib/ directory.

How to disentangle these two cases? Should we make the install statements conditional on a CMake option?

[1] CMake cannot resolve runtime directory path - Stack Overflow

What I’ve found that works well is to make the install target for the project be just the project. For packaging with dependencies and all that fun stuff, make a separate (CMake) project (it can live in the same repo) that consumes an install prefix of what you want to package and then bundles up dependencies that way. This also makes it easy to package up related tooling (e.g., a Python environment) without having to pollute the main project’s logic with such decisions.

You should be able to use file(GET_RUNTIME_DEPENDENCIES) to do the library traversal. Alas, CMake doesn’t yet have nicer ways of rewriting RPATH (Linux) and library id/references (macOS) yet. You can see the prototype scripts for file(GRD) in this directory which also do the inter-library reference fixups.