add hacking notes

Original commit message from CVS:
add hacking notes
This commit is contained in:
Thomas Vander Stichele 2004-03-12 10:18:31 +00:00
parent 87324f82f0
commit b51bb8f341
2 changed files with 55 additions and 22 deletions

75
HACKING
View file

@ -1,3 +1,5 @@
THE GOAL
--------
What we are trying to achieve: What we are trying to achieve:
satisfy: satisfy:
@ -8,32 +10,63 @@ satisfy:
make distcheck make distcheck
non-srcdir build (ie, mkdir build; cd build; ../configure; make) non-srcdir build (ie, mkdir build; cd build; ../configure; make)
How it works: THE SETUP
---------
There is a "mirror" root CVS module that contains "ffmpeg".
This directory contains a vendor-branch checkout of upstream FFmpeg CVS
of a given day.
* configure checks whether or not it should update ffmpeg from CVS by looking On head, the following things have been commited on top of this:
at the nano version number * patches/, which is a directory with a set of patches, and a series file
- if it's 1, we're in cvs mode, and it should check it out listing the order, as generated by quilt
- if it's not 1, we're in prerel or rel mode, and the code should already * .pc/, which is a tree of files that quilt uses to keep control of its state.
be on disk It contains a list of applied patches, and one directory per patch,
FIXME: we could change this to really check out the source code if some containing a tree of hardlinked files that were added to the patchset, and
required files aren't there just in case someone checks out from CVS a .pc file listing all files part of the patchset.
but CVS is not at nano 1 * the result of having all these patches commited (ie, quilt push -a) to the
ffmpeg tree.
* patching of the checked-out copy happens at Both the actually patched CVS ffmpeg code as well as the .pc dir need to be
commited to CVS so the state of quilt wrt. the source is in sync.
Axioms under which we work: THE WAY
- the dist tarball needs to include either -------
- the pristine ffmpeg checkout + our patches + a patch mechanism on make
or
- the ffmpeg checkout with patches already applied
- configure/make is not allowed to touch files that already live in the source - If you want to hack on our copy of the FFmpeg code, there are some basic
tree; if they need to then they need to be copied first and cleaned rules you need to respect:
afterward - you need to use quilt. If you don't use quilt, you can't hack on it.
- we separate patches based on the functionality they patch, and whether
- it would be very nice if, on update of either the Tag file or the patch set, or not we want to send stuff upstream. Make sure you work in the right
make would know exactly what to do with it. patch. use "quilt applied" to check which patches are applied.
- before starting to hack, run cvs diff. There should be NO diffs, and
NO files listed with question mark. If there are, somebody before you
probably made a mistake. To manage the state correctly, it is vital that
none of the files are unknown to CVS.
- if you want to add a file to a patchset, you need to:
- be in the right patchset
- quilt add (file)
- cvs add .pc/(patchsetname)/(file)
- cvs commit .pc/(patchsetname) (to update the state of quilt in cvs)
- edit the file
- quilt refresh
- quilt push -a (This one is IMPORTANT, otherwise you'll have a huge diff)
- cvs commit
- if you want to add a patchset, you need to:
- go over the procedure with thomas to check it's correct
- decide where in the stack to put it. ask for help if you don't know.
- go there in the patch stack (use quilt pop/push)
- quilt new (patchsetname).patch (don't forget .patch !)
- quilt add (files)
- cvs add .pc/(patchsetname) the whole tree
- cvs commit .pc/(patchsetname)
- quilt refresh
- quilt push -a
- cvs commit
- cvs diff (to check if any of the files are unknown to CVS; if they are,
you need to add them to CVS)
THE PLUGIN
----------
Some notes on how ffmpeg wrapping inside GStreamer currently works: Some notes on how ffmpeg wrapping inside GStreamer currently works:
* gstffmpeg{dec,enc,demux,mux}.c are wrappers for specific element types from * gstffmpeg{dec,enc,demux,mux}.c are wrappers for specific element types from
their ffmpeg counterpart. If you want to wrap a new type of element in their ffmpeg counterpart. If you want to wrap a new type of element in