added docs about new gstreamer
[larjonas-mediagoblin.git] / extlib / README
blob45ee5b46125cbb11faff888b79a8e9006c8d8ed3
1 =========================
2  External Library README
3 =========================
5 DO NOT "FIX" CODE IN THIS DIRECTORY.
7 ONLY UPSTREAM VERSIONS OF SOFTWARE GO IN THIS DIRECTORY.
9 This directory is provided as a courtesy to our users who might be
10 unable or unwilling to find and install libraries we depend on.
12 If we "fix" software in this directory, we hamstring users who do the
13 right thing and keep a single version of upstream libraries in a
14 system-wide library.  We introduce subtle and maddening bugs where
15 our code is "accidentally" using the "wrong" library version.  We may
16 unwittingly interfere with other software that depends on the
17 canonical release versions of those same libraries!
19 Forking upstream software for trivial reasons makes us bad citizens in
20 the Free Software community and adds unnecessary heartache for our
21 users.  Don't make us "that" project.
24 FAQ
25 ===
27 :Q: What should we do when we find a bug in upstream software?
29 :A: First and foremost, REPORT THE BUG, and if possible send in a patch.
31     Watch for a release of the upstream software and integrate with it
32     when it's released.
34     In the meantime, work around the bug, if at all possible.  Usually,
35     it's quite possible, if slightly harder or less efficient.
37 :Q: What if the bug can't be worked around?
39 :A: If the upstream developers have accepted a bug patch, it's
40     undesirable but acceptable to apply that patch to the library in
41     the ``extlib/`` dir.  Ideally, use a release version for upstream or a
42     version control system snapshot.
44     Note that this is a last resort.
46 :Q: What if upstream is unresponsive or won't accept a patch?
48 :A: Try again.
50 :Q: I tried again, and upstream is still unresponsive and nobody's
51     checked on my patch.  Now what?
53 :A: If the upstream project is moribund and there's a way to adopt it,
54     propose having the MediaGoblin dev team adopt the project.  Or, adopt
55     it yourself.
57 :Q: What if there's no upstream authority and it can't be adopted?
59 :A: Then we fork it.  Make a new name and a new version. Include it in
60     ``lib/`` instead of ``extlib/``, and use the GMG_* prefix to change
61     the namespace to avoid collisions (or something like that).
63     This is a last resort; consult with the rest of the dev group
64     before taking this radical step.
66 :Q: What about submodules?
68 :A: pdf.js is supplied as a submodule, and other software may use that too,
69     to add a new submodule:
70      git submodule add <git-repo-of-fun-project> extlib/fun-project
72     Use it just like a snapshotted extlib directory. When a new clone of mediagoblin
73     is made you need to run
75      git submodule init
76      git submodule update
78     As noted in HackingHowto
80 Thanks
81 ======
83 This policy originally copied from Status.net.  Many many thanks to them
84 for working out such a nice system for doing things.