[demux/avi] Enable dirac support (Set PTS on first output block)
[vlc/davidf-public.git] / HACKING
blob50035406a11752fabdba090f5f8d7d45f477c469
1 Hacking vlc
2 ===========
4 First
5 -----
7  - Read this file
9  - Read the information present on http://www.videolan.org/developers/
12 Requirements
13 ____________
15 You will need the following tools if you plan to use the GIT version of vlc:
17  - Autoconf version 2.60 or later
18  - Automake version 1.9 or later
19  - gettext version 0.16.1 or later
20  - pkg-config
21  - libgcrypt 1.2 (or compatible)
23 After retrieving the GIT tree, you need to run the bootstrap script to
24 generate all the files needed to build vlc. You can then run configure.
25 Run ./configure --help for a description of the available options.
27 If you do not have the correct version of these tools, or if they are
28 simply not available for the operating system you plan to develop on,
29 you can check out a GIT tree on an OS that provides these tools (such
30 as a recent Linux distribution), run bootstrap, and then copy the whole
31 tree to your retarded OS.
33 There is a possibility that, at some point, automake might segfault. The
34 reason is unsufficient stack size, and can be easily fixed with the
35 `ulimit` command (or an equivalent) available in most shells. For instance
36 on bash 2.0, the following command solves the automake crash on Mac OS X :
37 ulimit -s 20000
40 The bootstrap sequence
41 ----------------------
43 The bootstrap script does the following actions:
45  - parse configure.ac for all Makefiles in the modules/ directory that need
46    to be generated, and look for available modules in the corresponding
47    Modules.am file. A module "foo" exists if there is a Modules.am file in
48    the modules/ directory which defines SOURCES_foo.
50  - create a top-level Modules.am file (which will be included by Makefile.am)
51    which contains additional build rules for modules, and includes all the
52    Modules.am files that were found in modules/
54  - create an m4/private.m4 from configure.ac, generating m4 macros that will
55    be needed by configure.ac.
57  - create a Makefile.am file for each Modules.am file found in modules/ .
59  - run autopoint (previously gettextize) to create an intl/ directory,
60    needed when libgettext is not available.
62  - run the usual aclocal, autoheader, automake and autoconf, which create
63    the various Makefile.in files from the corresponding Makefile.am and the
64    configure script from configure.ac.
66  - fix a few files in the vlc repository that may have been altered.
69 How to add a module
70 -------------------
72 To add a module to the repository, just add its sources to a Modules.am
73 file. If you add a new directory you will need to create a new Modules.am,
74 inside that directory. Do not forget to add a corresponding
75 Makefile line at the end of configure.ac for this new Modules.am file.
77 To have the module built, you need to add a call to VLC_ADD_PLUGIN or
78 VLC_ADD_BUILTINS to configure.ac with your new module name as argument.
79 Look at other modules for guidelines on how to add build and linkage options.
81 After changing configure.ac you will always need to rerun bootstrap and 
82 configure.
84 VLC keeps a cache of its modules (in ~/.cache/vlc/ on Linux), so you'll have to
85 delete it (or use vlc --reset-plugins-cache). Then use vlc -vvv --color --list
86 to check that your plugin is seen by VLC.