2015-02-13 11:23:40 -08:00
|
|
|
Building Libwebm
|
|
|
|
|
|
|
|
To build libwebm you must first create project files. To do this run cmake
|
|
|
|
and pass it the path to your libwebm repo.
|
|
|
|
|
|
|
|
Makefile.unix can be used as a fallback on systems that cmake does not
|
|
|
|
support.
|
|
|
|
|
|
|
|
|
|
|
|
CMake Basics
|
|
|
|
|
|
|
|
To generate project/make files for the default toolchain on your system simply
|
|
|
|
run cmake with the path to the libwebm repo:
|
|
|
|
|
|
|
|
$ cmake path/to/libwebm
|
|
|
|
|
|
|
|
On Windows the above command will produce Visual Studio project files for the
|
|
|
|
newest Visual Studio detected on the system. On Mac OS X and Linux systems, the
|
|
|
|
above command will produce a makefile.
|
|
|
|
|
|
|
|
To control what types of projects are generated the -G parameter is added to
|
|
|
|
the cmake command line. This argument must be followed by the name of a
|
|
|
|
generator. Running cmake with the --help argument will list the available
|
|
|
|
generators for your system.
|
|
|
|
|
|
|
|
On Mac OS X you would run the following command to generate Xcode projects:
|
|
|
|
|
|
|
|
$ cmake path/to/libwebm -G Xcode
|
|
|
|
|
|
|
|
On a Windows box you would run the following command to generate Visual Studio
|
|
|
|
2013 projects:
|
|
|
|
|
|
|
|
$ cmake path/to/libwebm -G "Visual Studio 12"
|
|
|
|
|
|
|
|
To generate 64-bit Windows Visual Studio 2013 projects:
|
|
|
|
|
|
|
|
$ cmake path/to/libwebm "Visual Studio 12 Win64"
|
|
|
|
|
|
|
|
|
|
|
|
CMake Makefiles: Debugging and Optimization
|
|
|
|
|
|
|
|
Unlike Visual Studio and Xcode projects, the build configuration for make builds
|
|
|
|
is controlled when you run cmake. The following examples demonstrate various
|
|
|
|
build configurations.
|
|
|
|
|
|
|
|
Omitting the build type produces makefiles that use build flags containing
|
|
|
|
neither optimization nor debug flags:
|
|
|
|
$ cmake path/to/libwebm
|
|
|
|
|
|
|
|
A makefile using release (optimized) flags is produced like this:
|
|
|
|
$ cmake path/to/libwebm -DCMAKE_BUILD_TYPE=release
|
|
|
|
|
|
|
|
A release build with debug info can be produced as well:
|
|
|
|
$ cmake path/to/libwebm -DCMAKE_BUILD_TYPE=relwithdebinfo
|
|
|
|
|
|
|
|
And your standard debug build will be produced using:
|
|
|
|
$ cmake path/to/libwebm -DCMAKE_BUILD_TYPE=debug
|
2016-01-11 18:46:55 -08:00
|
|
|
|
|
|
|
|
|
|
|
Tests
|
|
|
|
|
|
|
|
To enable libwebm tests add -DENABLE_TESTS=ON CMake generation command line. For
|
|
|
|
example:
|
|
|
|
|
|
|
|
$ cmake path/to/libwebm -G Xcode -DENABLE_TESTS=ON
|
|
|
|
|
|
|
|
Libwebm tests depend on googletest. By default googletest is expected to be a
|
|
|
|
sibling directory of the Libwebm repository. To change that, update your CMake
|
|
|
|
command to be similar to the following:
|
|
|
|
|
|
|
|
$ cmake path/to/libwebm -G Xcode -DENABLE_TESTS=ON \
|
|
|
|
-DGTEST_SRC_DIR=/path/to/googletest
|
|
|
|
|
|
|
|
The tests rely upon the LIBWEBM_TEST_DATA_PATH environment variable to locate
|
|
|
|
test input. The following example demonstrates running the muxer tests from the
|
|
|
|
build directory:
|
|
|
|
|
2017-03-07 11:34:39 -08:00
|
|
|
$ LIBWEBM_TEST_DATA_PATH=path/to/libwebm/testing/testdata ./mkvmuxer_tests
|
2016-01-11 18:46:55 -08:00
|
|
|
|
2016-01-25 15:13:34 -05:00
|
|
|
Note: Libwebm Googletest integration was built with googletest from
|
|
|
|
https://github.com/google/googletest.git at git revision
|
2016-01-11 18:46:55 -08:00
|
|
|
ddb8012eb48bc203aa93dcc2b22c1db516302b29.
|
|
|
|
|
2016-03-10 13:22:51 -08:00
|
|
|
|
|
|
|
CMake Include-what-you-use integration
|
|
|
|
|
|
|
|
Include-what-you-use is an analysis tool that helps ensure libwebm includes the
|
|
|
|
C/C++ header files actually in use. To enable the integration support
|
|
|
|
ENABLE_IWYU must be turned on at cmake run time:
|
|
|
|
|
|
|
|
$ cmake path/to/libwebm -G "Unix Makefiles" -DENABLE_IWYU=ON
|
|
|
|
|
|
|
|
This adds the iwyu target to the build. To run include-what-you-use:
|
|
|
|
|
|
|
|
$ make iwyu
|
|
|
|
|
|
|
|
The following requirements must be met for ENABLE_IWYU to enable the iwyu
|
|
|
|
target:
|
|
|
|
|
|
|
|
1. include-what-you-use and iwyu_tool.py must be in your PATH.
|
|
|
|
2. A python interpreter must be on the system and available to CMake.
|
|
|
|
|
|
|
|
The values of the following variables are used to determine if the requirements
|
|
|
|
have been met. Values to the right of the equals sign are what a successful run
|
|
|
|
might look like:
|
|
|
|
iwyu_path=/path/to/iwyu_tool.py
|
|
|
|
iwyu_tool_path=/path/to/include-what-you-use
|
|
|
|
PYTHONINTERP_FOUND=TRUE
|
|
|
|
|
|
|
|
An empty PYTHONINTERP_FOUND, or iwyu_path/iwyu_tool_path suffixed with NOTFOUND
|
|
|
|
are failures.
|
|
|
|
|
|
|
|
For Include-what-you-use setup instructions, see:
|
|
|
|
https://github.com/include-what-you-use/include-what-you-use/blob/master/docs/InstructionsForUsers.md
|
|
|
|
|
|
|
|
If, when building the iwyu target, compile errors reporting failures loading
|
|
|
|
standard include files occur, one solution can be found here:
|
|
|
|
https://github.com/include-what-you-use/include-what-you-use/issues/100
|
|
|
|
|
|
|
|
|
2016-04-01 11:58:28 -04:00
|
|
|
CMake cross compile
|
2016-04-07 10:46:24 -07:00
|
|
|
To cross compile libwebm for Windows using mingw-w64 run cmake with the
|
|
|
|
following arguments:
|
2016-04-01 11:58:28 -04:00
|
|
|
|
2016-04-07 10:46:24 -07:00
|
|
|
$ cmake -DCMAKE_TOOLCHAIN_FILE=path/to/libwebm/build/mingw-w64_toolchain.cmake \
|
2016-04-01 11:58:28 -04:00
|
|
|
path/to/libwebm
|
|
|
|
|
2016-04-07 10:46:24 -07:00
|
|
|
Note1: As of this writing googletest will not build via mingw-w64 without
|
2016-04-01 11:58:28 -04:00
|
|
|
disabling pthreads.
|
|
|
|
googletest hash: d225acc90bc3a8c420a9bcd1f033033c1ccd7fe0
|
|
|
|
|
2016-04-07 10:46:24 -07:00
|
|
|
To build with tests when using mingw-w64 use the following arguments when
|
|
|
|
running CMake:
|
2016-04-01 11:58:28 -04:00
|
|
|
|
2016-04-07 10:46:24 -07:00
|
|
|
$ cmake -DCMAKE_TOOLCHAIN_FILE=path/to/libwebm/build/mingw-w64_toolchain.cmake \
|
2016-04-01 11:58:28 -04:00
|
|
|
-DENABLE_TESTS=ON -Dgtest_disable_pthreads=ON path/to/libwebm
|
|
|
|
|
|
|
|
Note2: i686-w64-mingw32 is the default compiler. This can be controlled using
|
|
|
|
the MINGW_PREFIX variable:
|
|
|
|
|
2016-04-07 10:46:24 -07:00
|
|
|
$ cmake -DCMAKE_TOOLCHAIN_FILE=path/to/libwebm/build/mingw-w64_toolchain.cmake \
|
2016-04-01 11:58:28 -04:00
|
|
|
-DMINGW_PREFIX=x86_64-w64-mingw32 path/to/libwebm
|
2016-03-10 13:22:51 -08:00
|
|
|
|