Go to file
Tom Finegan bab0a002c5 cmake: Set library and project name the proper way on Windows.
Revert previous hack and use target properties to correct project
and library names.

Change-Id: Ib35da1cedcedf86f3f020d879cd39199fd236572
2015-03-02 12:43:56 -08:00
build Add CMakeLists.txt and msvc_runtime.cmake. 2015-02-13 16:07:01 -08:00
.clang-format Change AlignTrailingComments to false in .clang-format 2014-04-29 00:38:14 -07:00
.gitattributes Enable auto CRLF for visual studio project and solution files. 2012-05-29 10:45:59 -04:00
.gitignore Ignore dependency files and build products. 2013-08-19 11:02:23 -07:00
Android.mk libwebm: Update Android build 2013-04-15 09:13:07 -07:00
AUTHORS.TXT Initial version 2010-06-02 10:25:33 -04:00
CMakeLists.txt cmake: Set library and project name the proper way on Windows. 2015-03-02 12:43:56 -08:00
dumpvtt.cc clang-format on dumpvtt.cc 2014-04-14 12:15:04 -07:00
LICENSE.TXT added new license files 2010-06-15 17:45:08 -04:00
Makefile.unix Add CMakeLists.txt and msvc_runtime.cmake. 2015-02-13 16:07:01 -08:00
mkvmuxer.cpp mkvmuxer: Fix MoveCuesBeforeClustersHelper recursive call. 2015-02-02 18:34:18 -08:00
mkvmuxer.hpp mkvmuxer: Fix MoveCuesBeforeClustersHelper recursive call. 2015-02-02 18:34:18 -08:00
mkvmuxertypes.hpp clang-format on mkvmuxertypes.hpp and webmids.hpp 2014-04-15 11:39:44 -07:00
mkvmuxerutil.cpp mkvmuxerutil: Use rand() in MSVC builds. 2014-07-18 11:37:06 -07:00
mkvmuxerutil.hpp clang-format on mkvmuxerutil.[ch]pp 2014-04-14 10:28:59 -07:00
mkvparser.cpp parser: Fix memory leak in Chapter parsing 2015-02-06 15:17:28 -08:00
mkvparser.hpp clang-format on mkvparser.[ch]pp 2014-04-29 11:30:00 -07:00
mkvreader.cpp clang-format on mkvreader.[ch]pp 2014-04-15 12:05:58 -07:00
mkvreader.hpp make Mkv(Reader|Writer)(FILE*) explicit 2014-05-02 11:47:44 -07:00
mkvwriter.cpp clang-format on mkvwriter.[ch]pp 2014-04-14 10:30:33 -07:00
mkvwriter.hpp make Mkv(Reader|Writer)(FILE*) explicit 2014-05-02 11:47:44 -07:00
PATENTS.TXT Update PATENTS to reflect s/VP8/WebM/g 2014-08-11 14:30:54 -07:00
README.libwebm Add CMakeLists.txt and msvc_runtime.cmake. 2015-02-13 16:07:01 -08:00
RELEASE.TXT Updated RELEASE.TXT 2010-11-03 13:46:44 -04:00
sample_muxer_metadata.cc clang-format on sample_muxer_metadata.(cc|h) 2014-04-14 12:09:20 -07:00
sample_muxer_metadata.h clang-format on sample_muxer_metadata.(cc|h) 2014-04-14 12:09:20 -07:00
sample_muxer.cpp mkvmuxer: Reject frames if invalid track number is passed. 2014-05-18 12:45:49 -07:00
sample.cpp clang-format on sample.cpp 2014-04-14 12:05:21 -07:00
vttdemux.cc clang-format re-run. 2014-04-29 11:27:31 -07:00
vttreader.cc clang-format on vttreader.cc 2014-04-14 12:11:27 -07:00
vttreader.h added dumpvtt app 2012-08-23 14:00:57 -07:00
webmids.hpp clang-format on mkvmuxertypes.hpp and webmids.hpp 2014-04-15 11:39:44 -07:00
webvttparser.cc clang-format re-run. 2014-04-29 11:27:31 -07:00
webvttparser.h clang-format on webvttparser.(cc|h) 2014-04-25 22:18:40 -07: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