From cb17eca3a4f2153289c5b18b7cc8d6c16770a3a0 Mon Sep 17 00:00:00 2001 From: Eric Reed Date: Sat, 2 Mar 2013 11:10:06 -0500 Subject: [PATCH] Full cmdline support for installer --- MediaBrowser.Installer/MainWindow.xaml.cs | 22 +++++++++++++++---- .../MediaBrowser.Installer.csproj | 2 +- 2 files changed, 19 insertions(+), 5 deletions(-) diff --git a/MediaBrowser.Installer/MainWindow.xaml.cs b/MediaBrowser.Installer/MainWindow.xaml.cs index 6445663251..6f64ded86d 100644 --- a/MediaBrowser.Installer/MainWindow.xaml.cs +++ b/MediaBrowser.Installer/MainWindow.xaml.cs @@ -76,11 +76,25 @@ namespace MediaBrowser.Installer protected void GetArgs() { - var product = ConfigurationManager.AppSettings["product"] ?? "server"; - PackageClass = (PackageVersionClass) Enum.Parse(typeof (PackageVersionClass), ConfigurationManager.AppSettings["class"] ?? "Release"); + //cmd line args should be name/value pairs like: product=server archive="c:\.." caller=34552 var cmdArgs = Environment.GetCommandLineArgs(); - Archive = cmdArgs.Length > 1 ? cmdArgs[1] : null; - var callerId = cmdArgs.Length > 2 ? cmdArgs[2] : null; + var args = new Dictionary(StringComparer.OrdinalIgnoreCase); + foreach (var pair in cmdArgs) + { + var nameValue = pair.Split('='); + if (nameValue.Length == 2) + { + args[nameValue[0]] = nameValue[1]; + } + } + + Archive = args.GetValueOrDefault("archive", null); + + var product = args.GetValueOrDefault("product", null) ?? ConfigurationManager.AppSettings["product"] ?? "server"; + PackageClass = (PackageVersionClass) Enum.Parse(typeof (PackageVersionClass), args.GetValueOrDefault("class", null) ?? ConfigurationManager.AppSettings["class"] ?? "Release"); + PackageVersion = new Version(args.GetValueOrDefault("version", "4.0")); + + var callerId = args.GetValueOrDefault("caller", null); if (callerId != null) { // Wait for our caller to exit diff --git a/MediaBrowser.Installer/MediaBrowser.Installer.csproj b/MediaBrowser.Installer/MediaBrowser.Installer.csproj index 3a7d9102ee..2d95ae5ad1 100644 --- a/MediaBrowser.Installer/MediaBrowser.Installer.csproj +++ b/MediaBrowser.Installer/MediaBrowser.Installer.csproj @@ -29,7 +29,7 @@ Media Browser Team Media Browser false - 32 + 34 0.1.1.%2a false true