I use RUNTIME_DEPENDENCIES to copy all dlls. But it doesn’t find all. In particular, it doesn’t find postgresql dlls. They are on my PATH though.
Adding postgreql to the DIRECTORIES options gives me the lib directory, but I need the bin directory DIRECTORIES $<TARGET_FILE_DIR:PostgreSQL::PostgreSQL>
Using $<TARGET_RUNTIME_DLLS:PostgreSQL::PostgreSQL> doesn’t work either. FindPostgresql.cmake does set IMPORTED_LOCATION, but also sets the target to UNKNOWN, so according to the documentation it is not considered.
Questions therefore are:
Is the PATH not considered by file(RUNTIME_DEPENDENCIES)? Can I change it
Why is the PostgreSQL::PostgreSQL target set to Unknown? Or why is it ignored by TARGET_RUNTIME_DLLS even though it has IMPORTED_LOCATION set
I could also not generate the RUNTIME_DEPENDENCIES as they are on the PATH anyway in this case, but how would I ignore all the dlls without listing each explicitly in POST_EXCLUDE_REGEXES as Postgresql as many dlls.
On an UNKNOWN library, the IMPORTED_LOCATION is the .lib file, not the DLL. There’s nowhere to put the DLL path on an UNKNOWN library. Someday I’d like to get back to this MR to help reduce the number of UNKNOWN imported libraries. The docs were updated recently to clarify this situation.
So is there any solution to my problem? Do I need to hardcode the path to Postgresql dlls so that file(GET_RUNTIME_DEPENDENCIES) works on Windows? That’s not very nice
Yep, wrong clipboard; I’ve updated the link. I’d say that FindPostgreSQL should be improved to know that it found a SHARED or STATIC library. Then you can use $<TARGET_DIR> for the relevant targets to get the search paths.