New Windows installer nearly ready

dinkypumpkin dinkypumpkin at gmail.com
Sun Aug 21 16:20:49 EDT 2011


Thanks to a very delayed and very long flight with a very broken 
in-flight entertainment system, I finally had an opportunity to finish 
up and document some work I've been doing on a new Windows installer for 
get_iplayer.  It should be ready to go as soon as it can be tested with 
a new release of get_iplayer and the associated server infrastructure. 
For the few who may be interested, some info about the changes is below. 
  If you have any comments, questions, bugs - please reply to this thread.

Main Goals:

1. Update the installer to use more recent versions of Perl and the 
various helper applications.
2. Incorporate additional Perl modules used for MP3 tagging.
2. Automate and document the installer build process.
3. Make it possible to to build the installer on Windows with a minimum 
of additional dependencies.
4. Incorporate some improvements from a "private label" installer I put 
together a while back.

Changes/Additions:

1. The main improvement is in how the installer handles the download and 
install of the helper applications.  The goal was to enable the 
installer to deal with changes in format or structure of the helper app 
distributions without the need to change the actual installer code.

a. It should now handle PKZIP and 7-ZIP archives, as well as standalone 
EXE files, without the need to know the file type beforehand.

b. In the case of archives, it can do a simple search for the relevant 
EXE in the expanded archive, so it doesn't need to know the archive 
structure beforehand.

c. There are limitations.  I've restricted it to only locate 32-bit 
Windows executables.  I needed some way to disambiguate 
multi-architecture archives, and I thought it simplest to keep 
get_iplayer a 32-bit zone.  It also only looks for simple EXE names 
(ffmpeg.exe, rtmpdump.exe, etc.).

2. The new installer should look and work the same for an end user.  It 
should also be capable of performing a clean update install over a clean 
install of the previous version.

3. Although it isn't visible in the end product, I did a fair amount of 
code cleanup in the installer script.   I also instrumented the 
installer script so it is more configurable and a little easier to work 
with in development.

4. The build scripts are bog-standard Windows batch files that hopefully 
should run anywhere (I used WinXP SP3).  They work in various 
permutations, but the bottom line is that they should make it possible 
for someone to:

- install the prerequisites
- download a snapshot of get_iplayer
- run a single command
- get a ready-to-run installer

See the link to documentation below.

5. It is also possible to build just the required Perl support with a 
single command. The archived Perl support can then be kept and used for 
builds on other platforms.  I also adjusted the Linux/OSX build script 
accordingly.

Code/Documentation:

A pre-release version of the code can be found in the "installer" branch 
of my Github repository:

https://github.com/dinkypumpkin/get_iplayer/tree/installer

The new code is in the "windows" folder.  I've also moved the installer 
script (get_iplayer_setup.nsi) from "windows\get_iplayer" to "windows" 
in order to keep all the installer source together.

Also in the "windows" folder is documentation in Markdown format 
(INSTALLER.md).  The documentation can also be viewed here:

https://github.com/dinkypumpkin/get_iplayer/wiki/installer

I've kept everything in a separate branch for now.  I'll squash the 
final release version into a single commit before bringing it back into 
the master branch.

A Warning to the Brave:

If you should decide to try out the build process for yourself, be aware 
that this pre-release version of the code hard-wires the installer in 
several ways:

- It pops up a "pre-release version" warning message on launch
- It does not check infreadead.org for updated versions of itself.
- The download URLs for the helper applications are fixed in the 
installer code, rather than using the CGI redirect system at 
infradead.org.  The resources currently referenced by the redirects have 
not yet been updated.
- It embeds the latest patched version of get_iplayer, along with the 
web pvr manager and plugins.  It will not download or update those files 
from the internet.  Not much point in using the old code with a new 
installer and new helper apps.




More information about the get_iplayer mailing list