<HTML>
<HEAD>
<TITLE>Re: [Freeswitch-users] Debian packaging - some questions</TITLE>
</HEAD>
<BODY>
<FONT FACE="Monaco, Courier New"><SPAN STYLE='font-size:11pt'>The problem is currently the changelogs are not updated on a regular basis, we could use some help in the area. If they were updated routinely it wouldn&#8217;t really be out of day in the tarballs<BR>
<BR>
<BR>
On 3/12/13 8:45 AM, &quot;Steven Ayre&quot; &lt;<a href="steveayre@gmail.com">steveayre@gmail.com</a>&gt; wrote:<BR>
<BR>
</SPAN></FONT><BLOCKQUOTE><FONT FACE="Monaco, Courier New"><SPAN STYLE='font-size:11pt'>Debian's policy is to keep the changelog entries pretty short. Debian changelogs are frequently just lots of 'Updated upstream version' entries, 'Closes bug' entries when there's a Debian bug that's patched because it's not fixed upstream yet, and packaging change notes. 'git log' or 'Docs/changelog' would be too verbose. The correct thing to do according to Debian policy would be to have a short 'Updated upstream version' entry and ship the docs/ChangeLog file so a more complete history can be found in the doc folder.<BR>
<BR>
freeswitch/build/next-release.txt is pretty good at generating a version for Git versions, and I'd say sufficient.<BR>
<BR>
The issue for me is specifically when tarball releases are rolled. I believe there's a script that's run to generate them? Could that update the debian/changelog file too? Submitting ChangeLog entries against a tarball won't work unless the developers are willing to recreate the tarball. If it only gets committed to Git then it's not going to make it into a tarball until the next release, at which point it'll be out of date.<BR>
<BR>
-Steve<BR>
<BR>
<BR>
<BR>
<BR>
On 12 March 2013 14:37, Ken Rice &lt;<a href="krice@freeswitch.org">krice@freeswitch.org</a>&gt; wrote:<BR>
</SPAN></FONT><BLOCKQUOTE><FONT FACE="Monaco, Courier New"><SPAN STYLE='font-size:11pt'>There are 2 change logs already that can be used to update debian/changelog<BR>
<BR>
</SPAN></FONT><OL><LI><FONT FACE="Monaco, Courier New"><SPAN STYLE='font-size:11pt'>git log  (yes I know not really a changelog but it can be derived from there) 
</SPAN></FONT><LI><FONT FACE="Monaco, Courier New"><SPAN STYLE='font-size:11pt'>docs/ChangeLog this is the main changelog. Its not always 100% up to date but its there<BR>
</SPAN></FONT></OL><FONT FACE="Monaco, Courier New"><SPAN STYLE='font-size:11pt'><BR>
If you wish to contribute patches to the ChangeLog please do so they are welcomed the main committers don&#8217;t always have time to update these things...<BR>
<BR>
One of the biggest things the project as a whole needs is dedicated documenters that will help with these things.<BR>
<BR>
K<BR>
<BR>
<BR>
<BR>
On 3/12/13 7:15 AM, &quot;Steven Ayre&quot; &lt;<a href="steveayre@gmail.com">steveayre@gmail.com</a> &lt;<a href="http://steveayre@gmail.com">http://steveayre@gmail.com</a>&gt; &gt; wrote:<BR>
<BR>
</SPAN></FONT><BLOCKQUOTE><FONT FACE="Monaco, Courier New"><SPAN STYLE='font-size:11pt'>Another big problem you're likely to get is that pbuilder expects debian/changelog to be kept updated. That's not practical for the number of commits Git gets, hence generating a new entry from next-release.txt + the date.<BR>
<BR>
IMO the release tarballs should get the debian/changelog updated for version releases - there is a Jira on that: <a href="http://jira.freeswitch.org/browse/FS-4778">http://jira.freeswitch.org/browse/FS-4778</a><BR>
<BR>
-Steve<BR>
<BR>
<BR>
<BR>
<BR>
On 12 March 2013 12:59, Steven Ayre &lt;<a href="steveayre@gmail.com">steveayre@gmail.com</a> &lt;<a href="http://steveayre@gmail.com">http://steveayre@gmail.com</a>&gt; &gt; wrote:<BR>
</SPAN></FONT><BLOCKQUOTE><BLOCKQUOTE><FONT FACE="Monaco, Courier New"><SPAN STYLE='font-size:11pt'>The second problem is that the build resulted in nearly 100 different *.deb files This also poses somewhat of an annoyance in automated deployment environments, for example saltstack, where the configuration would have to list each individual FreeSWITCH module. It also feels very untidy. I understand that certain packages (such as libfreeswitch, libfreeswitch-dev, freeswitch-server etc) should be separated. But having a package for each module, the only use I could think of for this, would be if the Debian package compiles absolutely every module possible, and is then linked dynamically, rather than compiled static. This means enabling/disabling modules would be a matter of simply adding/removing a package. However I'm not entirely convinced if this is what it is doing.. when compiling absolutely every package possible, FreeSWITCH will usually fail to compile, due to collision etc.<BR>
</SPAN></FONT></BLOCKQUOTE><FONT FACE="Monaco, Courier New"><SPAN STYLE='font-size:11pt'><BR>
That's exactly what it's trying to do. It attempts to build every package, allowing you to install only what you need.<BR>
<BR>
Modules are created as .so packages that are loaded dynamically when FreeSWICH loads the module. They're all linked against the shared libfreeswitch library which provides the core API. Modules such as mod_sofia link statically against that library (so libsofia is in mod_sofia.so not freeswitch itself). Any system libraries used may be linked by the module dynamically (libjpeg by mod_spandsp etc).<BR>
<BR>
If you want to limit the modules built create a debian/modules.conf file and list them in there (same format as modules.conf). The debian/bootstrap.sh script reads that file and generates the packaging from that.<BR>
<BR>
<BR>
</SPAN></FONT><BLOCKQUOTE><FONT FACE="Monaco, Courier New"><SPAN STYLE='font-size:11pt'>2) Are there any reasons to not be using pbuilder?<BR>
</SPAN></FONT></BLOCKQUOTE><FONT FACE="Monaco, Courier New"><SPAN STYLE='font-size:11pt'><BR>
The debian/bootstrap.sh is probably the primary reason it doesn't play well with pbuilder - debian tools will often assume the packaging is usable without any bootstrap step.<BR>
<BR>
The bootstrap is necessary for two reasons: 1) it allows the module build list to be customised by the builder 2) it makes that list manageable by automating the package generation.<BR>
<BR>
<BR>
-Steve<BR>
<BR>
<BR>
<BR>
On 12 March 2013 12:44, Cal Leeming [Simplicity Media Ltd] &lt;<a href="cal.leeming@simplicitymedialtd.co.uk">cal.leeming@simplicitymedialtd.co.uk</a> &lt;<a href="http://cal.leeming@simplicitymedialtd.co.uk">http://cal.leeming@simplicitymedialtd.co.uk</a>&gt; &gt; wrote:<BR>
</SPAN></FONT><BLOCKQUOTE><FONT FACE="Monaco, Courier New"><SPAN STYLE='font-size:11pt'>Hey,<BR>
<BR>
So today I went to go and create a Debian package for FreeSWITCH using the existing packaging structure;<BR>
<BR>
<a href="https://github.com/traviscross/freeswitch/blob/master/debian/">https://github.com/traviscross/freeswitch/blob/master/debian/</a><BR>
<a href="http://wiki.freeswitch.org/wiki/Debian_packages_buildscript">http://wiki.freeswitch.org/wiki/Debian_packages_buildscript</a><BR>
<BR>
The first problem is that neither the helper or the debian/ dir have been configured for compatibility with pbuilder, which makes it untidy/non-sane to place this onto an automated production build system (it also impacts security slightly due to untrusted external code being ran outside of a chroot - but that's possibly an entirely different debate).<BR>
<BR>
The second problem is that the build resulted in nearly 100 different *.deb files This also poses somewhat of an annoyance in automated deployment environments, for example saltstack, where the configuration would have to list each individual FreeSWITCH module. It also feels very untidy. I understand that certain packages (such as libfreeswitch, libfreeswitch-dev, freeswitch-server etc) should be separated. But having a package for each module, the only use I could think of for this, would be if the Debian package compiles absolutely every module possible, and is then linked dynamically, rather than compiled static. This means enabling/disabling modules would be a matter of simply adding/removing a package. However I'm not entirely convinced if this is what it is doing.. when compiling absolutely every package possible, FreeSWITCH will usually fail to compile, due to collision etc.<BR>
<BR>
So I have a couple of questions;<BR>
<BR>
1) Why are the modules separated into individual files? <BR>
<BR>
2) Are there any reasons to not be using pbuilder?<BR>
<BR>
I have also CC'd Travis Cross who appears to a major contributor on the Debian packaging code.<BR>
<BR>
Thanks<BR>
<FONT COLOR="#888888"><BR>
Cal<BR>
</FONT><BR>
_________________________________________________________________________<BR>
Professional FreeSWITCH Consulting Services:<BR>
<a href="consulting@freeswitch.org">consulting@freeswitch.org</a> &lt;<a href="http://consulting@freeswitch.org">http://consulting@freeswitch.org</a>&gt; <BR>
<a href="http://www.freeswitchsolutions.com">http://www.freeswitchsolutions.com</a><BR>
<BR>
FreeSWITCH-powered IP PBX: The CudaTel Communication Server<BR>
<a href="http://www.cudatel.com">http://www.cudatel.com</a><BR>
<BR>
Official FreeSWITCH Sites<BR>
<a href="http://www.freeswitch.org">http://www.freeswitch.org</a><BR>
<a href="http://wiki.freeswitch.org">http://wiki.freeswitch.org</a><BR>
<a href="http://www.cluecon.com">http://www.cluecon.com</a><BR>
<BR>
FreeSWITCH-users mailing list<BR>
<a href="FreeSWITCH-users@lists.freeswitch.org">FreeSWITCH-users@lists.freeswitch.org</a> &lt;<a href="http://FreeSWITCH-users@lists.freeswitch.org">http://FreeSWITCH-users@lists.freeswitch.org</a>&gt; <BR>
<a href="http://lists.freeswitch.org/mailman/listinfo/freeswitch-users">http://lists.freeswitch.org/mailman/listinfo/freeswitch-users</a><BR>
UNSUBSCRIBE:<a href="http://lists.freeswitch.org/mailman/options/freeswitch-users">http://lists.freeswitch.org/mailman/options/freeswitch-users</a><BR>
<a href="http://www.freeswitch.org">http://www.freeswitch.org</a><BR>
<BR>
</SPAN></FONT></BLOCKQUOTE><FONT FACE="Monaco, Courier New"><SPAN STYLE='font-size:11pt'><BR>
</SPAN></FONT></BLOCKQUOTE><FONT FACE="Monaco, Courier New"><SPAN STYLE='font-size:11pt'><BR>
<BR>
<HR ALIGN=CENTER SIZE="3" WIDTH="95%"></SPAN></FONT><FONT SIZE="2"><FONT FACE="Consolas, Courier New, Courier"><SPAN STYLE='font-size:10pt'>_________________________________________________________________________<BR>
Professional FreeSWITCH Consulting Services:<BR>
<a href="consulting@freeswitch.org">consulting@freeswitch.org</a> &lt;<a href="http://consulting@freeswitch.org">http://consulting@freeswitch.org</a>&gt; <BR>
<a href="http://www.freeswitchsolutions.com">http://www.freeswitchsolutions.com</a><BR>
<BR>
FreeSWITCH-powered IP PBX: The CudaTel Communication Server<BR>
<a href="http://www.cudatel.com">http://www.cudatel.com</a><BR>
<BR>
Official FreeSWITCH Sites<BR>
<a href="http://www.freeswitch.org">http://www.freeswitch.org</a><BR>
<a href="http://wiki.freeswitch.org">http://wiki.freeswitch.org</a><BR>
<a href="http://www.cluecon.com">http://www.cluecon.com</a><BR>
<BR>
FreeSWITCH-users mailing list<BR>
<a href="FreeSWITCH-users@lists.freeswitch.org">FreeSWITCH-users@lists.freeswitch.org</a> &lt;<a href="http://FreeSWITCH-users@lists.freeswitch.org">http://FreeSWITCH-users@lists.freeswitch.org</a>&gt; <BR>
<a href="http://lists.freeswitch.org/mailman/listinfo/freeswitch-users">http://lists.freeswitch.org/mailman/listinfo/freeswitch-users</a><BR>
UNSUBSCRIBE:<a href="http://lists.freeswitch.org/mailman/options/freeswitch-users">http://lists.freeswitch.org/mailman/options/freeswitch-users</a><BR>
<a href="http://www.freeswitch.org">http://www.freeswitch.org</a><BR>
</SPAN></FONT></FONT></BLOCKQUOTE></BLOCKQUOTE></BLOCKQUOTE><FONT SIZE="2"><FONT FACE="Consolas, Courier New, Courier"><SPAN STYLE='font-size:10pt'><BR>
</SPAN></FONT></FONT><FONT FACE="Monaco, Courier New"><SPAN STYLE='font-size:11pt'>-- <BR>
Ken<BR>
<FONT COLOR="#0000FF"><U><a href="http://www.FreeSWITCH.org">http://www.FreeSWITCH.org</a><BR>
<a href="http://www.ClueCon.com">http://www.ClueCon.com</a><BR>
<a href="http://www.OSTAG.org">http://www.OSTAG.org</a><BR>
</U></FONT>irc.freenode.net #freeswitch<BR>
</SPAN></FONT>
</BODY>
</HTML>