aboutsummaryrefslogtreecommitdiffstats
path: root/libavformat/hls_sample_encryption.c
diff options
context:
space:
mode:
authorKacper Michajłow <kasper93@gmail.com>2025-08-03 20:59:23 +0200
committerJames Almer <jamrial@gmail.com>2025-08-13 13:17:53 +0000
commit8eca3fa619a7fb2190a3d4203e01a0d2661e7f91 (patch)
treea42c6aea5910e80b9f0d276c3f57879e6bb62bf3 /libavformat/hls_sample_encryption.c
parentb8d5f65b9e89d893f27cf00799dbc15fc0ca2f8e (diff)
downloadffmpeg-8eca3fa619a7fb2190a3d4203e01a0d2661e7f91.tar.gz
configure: use proper Windows-style static library naming
On Windows, static libraries are typically named with a .lib extension. An exception to this is MinGW targets, which are treated as a distinct target-os. Using Windows-style naming allows `clang` to be used as the linker driver, instead of invoking link or lld-link directly. The latter approach requires manually specifying standard libraries when compiling with `clang` rather than `clang-cl`, and manually specifying standard libraries may be error-prone or incomplete. Using Windows-style naming allows Clang to be used as the linker driver, instead of invoking link or lld-link directly. The latter approach requires manually specifying standard libraries, which may be error-prone or incomplete. This change also improves support for LTO and sanitizer builds, where it's significantly easier to let the compiler driver manage the necessary linker flags. It fixes issues where Clang is asked to link `-lavcodec`, which gets passed to the linker as avcodec.lib, resulting in an error like: lld-link: error: could not open 'avcodec.lib': no such file or directory This happens because `libavcodec.a` was unexpectedly generated, not `avcodec.lib` expected by tooling. Additionally, using `clang` (not `clang-cl`) is simplified, as it does not use autolinking like MSVC/clang-cl does. Now `--ld=clang` can be used to add all the required libraries. Previously, building with `clang` was only possible by using `--ld=lld-link` and manually specifying system dependencies in `extra-ldflags`. Note that those changes doesn't affect mingw build. MSVC builds will produce .lib static libraries now, but the linking process itself is not affected, because filenames are passed directly. To summarize in Windows non-mingw builds: Static builds now produce `lib/avcodec.lib` instead of `lib/libavcodec.a`. Shared builds remain unchanged, producing `bin/avcodec.lib` together with `bin/avcodec-62.dll`. This also removes setting LD_LIB from Win32/64 target as there is one type of .lib in practice. We cannot build both shared and static at the same time as noted by the next line. Signed-off-by: Kacper Michajłow <kasper93@gmail.com>
Diffstat (limited to 'libavformat/hls_sample_encryption.c')
0 files changed, 0 insertions, 0 deletions