diff options
author | Nicolas George <nicolas.george@normalesup.org> | 2012-07-11 12:01:19 +0200 |
---|---|---|
committer | Nicolas George <nicolas.george@normalesup.org> | 2012-07-20 11:40:26 +0200 |
commit | b34ce5a26b41b8f94ef0cf226561252585f2071b (patch) | |
tree | d5660c59e8f744ef1d8d4b23b4d4522d0f3d3fe9 /doc/faq.texi | |
parent | 30549294ef0f796d48b1ffa482bd9315d4dbb83c (diff) | |
download | ffmpeg-b34ce5a26b41b8f94ef0cf226561252585f2071b.tar.gz |
faq: explain dependency problems with static libs.
Diffstat (limited to 'doc/faq.texi')
-rw-r--r-- | doc/faq.texi | 18 |
1 files changed, 18 insertions, 0 deletions
diff --git a/doc/faq.texi b/doc/faq.texi index da44adbb94..d10faa1278 100644 --- a/doc/faq.texi +++ b/doc/faq.texi @@ -383,6 +383,24 @@ Yes, as long as the code is optional and can easily and cleanly be placed under #if CONFIG_GPL without breaking anything. So, for example, a new codec or filter would be OK under GPL while a bug fix to LGPL code would not. +@section I'm using FFmpeg from within my C application but the linker complains about missing symbols from the libraries themselves. + +FFmpeg builds static libraries by default. In static libraries, dependencies +are not handled. That has two consequences. First, you must specify the +libraries in dependency order: @code{-lavdevice} must come before +@code{-lavformat}, @code{-lavutil} must come after everything else, etc. +Second, external libraries that are used in FFmpeg have to be specified too. + +An easy way to get the full list of required libraries in dependency order +is to use @code{pkg-config}. + +@example + c99 -o program program.c $(pkg-config --cflags --libs libavformat libavcodec) +@end example + +See @file{doc/example/Makefile} and @file{doc/example/pc-uninstalled} for +more details. + @section I'm using FFmpeg from within my C++ application but the linker complains about missing symbols which seem to be available. FFmpeg is a pure C project, so to use the libraries within your C++ application |