{"id":570,"date":"2008-06-15T21:30:29","date_gmt":"2008-06-16T05:30:29","guid":{"rendered":"http:\/\/multimedia.cx\/eggs\/the-downside-of-contributions\/"},"modified":"2008-06-15T21:30:29","modified_gmt":"2008-06-16T05:30:29","slug":"the-downside-of-contributions","status":"publish","type":"post","link":"https:\/\/multimedia.cx\/eggs\/the-downside-of-contributions\/","title":{"rendered":"The Downside Of Contributions"},"content":{"rendered":"<p>The prolific Jeff Atwood has a blog post entitled <a href=\"http:\/\/www.codinghorror.com\/blog\/archives\/001134.html\">Don&#8217;t Go Dark<\/a> which describes the issue of programmers retreating into their chambers for months on end to create the perfect feature; at the conclusion, said programmers drop the feature on the community at large hoping for its immediate and wholesale incorporation into the project&#8217;s mainline codebase. As you can imagine, <a href=\"http:\/\/ffmpeg.org\/\">FFmpeg<\/a> lends itself well to this style of lone-wolf development. Unfortunately, it also conflicts with FFmpeg&#8217;s level of code maturity which necessitates that every line of code be carefully scrutinized before it is allowed possible immortality in the mainline tree.  This leads to a tremendous amount of <a href=\"http:\/\/wiki.multimedia.cx\/index.php?title=Interesting_Patches\">orphaned patches<\/a>. Should FFmpeg maintain such a strict policy? Personally, I agree with <a href=\"http:\/\/guru.multimedia.cx\/\">the project leader<\/a> in his position that, if the changes are not made before inclusion, the changes will likely never be made.<\/p>\n<p>There&#8217;s another angle that I don&#8217;t think was addressed by Jeff&#8217;s post. It&#8217;s a problem we saw repeatedly on the <a href=\"http:\/\/www.xinehq.de\/\">xine<\/a> project. Companies who were doing things like set-top media boxes were understandably eager to incorporate xine&#8217;s superior &#8212; and fee-free &#8211; media playback architecture. Naturally, it took some&#8230; tweaking and customizations (read: ad-hoc hacks) in order to get the stuff to work just right with a specific setup, and within a deadline. When the project was complete, an engineer would drop a mega-patch with all of their changes to the xine codebase, as mandated by the GNU GPL. And it was quite useless to us.<\/p>\n<p>I&#8217;m not sure what to do about the latter case. With the former, it is useful to at least anticipate developing your module in somewhat bite-sized phases that can perhaps be incorporated in separate patches.<\/p>\n","protected":false},"excerpt":{"rendered":"<p>The prolific Jeff Atwood has a blog post entitled Don&#8217;t Go Dark which describes the issue of programmers retreating into their chambers for months on end to create the perfect feature; at the conclusion, said programmers drop the feature on the community at large hoping for its immediate and wholesale incorporation into the project&#8217;s mainline [&hellip;]<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[28],"tags":[],"class_list":["post-570","post","type-post","status-publish","format-standard","hentry","category-programming"],"aioseo_notices":[],"_links":{"self":[{"href":"https:\/\/multimedia.cx\/eggs\/wp-json\/wp\/v2\/posts\/570","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/multimedia.cx\/eggs\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/multimedia.cx\/eggs\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/multimedia.cx\/eggs\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/multimedia.cx\/eggs\/wp-json\/wp\/v2\/comments?post=570"}],"version-history":[{"count":0,"href":"https:\/\/multimedia.cx\/eggs\/wp-json\/wp\/v2\/posts\/570\/revisions"}],"wp:attachment":[{"href":"https:\/\/multimedia.cx\/eggs\/wp-json\/wp\/v2\/media?parent=570"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/multimedia.cx\/eggs\/wp-json\/wp\/v2\/categories?post=570"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/multimedia.cx\/eggs\/wp-json\/wp\/v2\/tags?post=570"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}