Better way to detect OS and Machine arch

pull/702/head
abeloin 11 years ago
parent a29e1eb036
commit 17834ef5ab

@ -1,6 +1,8 @@
using System;
#if __MonoCS__
using System.Runtime.InteropServices;
using Mono.Unix.Native;
using System.Text.RegularExpressions;
using System.IO;
#endif
namespace MediaBrowser.ServerApplication.FFMpeg
@ -39,40 +41,63 @@ namespace MediaBrowser.ServerApplication.FFMpeg
}
break;
#if __MonoCS__
#if __MonoCS__
case PlatformID.Unix:
if (IsRunningOnMac())
if (PlatformDetection.IsMac)
{
switch (arg)
if (PlatformDetection.IsX86_64)
{
case "Version":
return "20131121";
case "FFMpegFilename":
return "ffmpeg";
case "FFProbeFilename":
return "ffprobe";
case "ArchiveType":
return "gz";
switch (arg)
{
case "Version":
return "20131121";
case "FFMpegFilename":
return "ffmpeg";
case "FFProbeFilename":
return "ffprobe";
case "ArchiveType":
return "gz";
}
break;
}
break;
}
else
if (PlatformDetection.IsLinux)
{
// Linux
switch (arg)
if (PlatformDetection.IsX86)
{
switch (arg)
{
case "Version":
return "linux_x86_20140118";
case "FFMpegFilename":
return "ffmpeg";
case "FFProbeFilename":
return "ffprobe";
case "ArchiveType":
return "gz";
}
break;
}
else if (PlatformDetection.IsX86_64)
{
case "Version":
return "20140104";
case "FFMpegFilename":
return "ffmpeg";
case "FFProbeFilename":
return "ffprobe";
case "ArchiveType":
return "gz";
// Linux on x86 or x86_64
switch (arg)
{
case "Version":
return "linux_x86_64_20140118";
case "FFMpegFilename":
return "ffmpeg";
case "FFProbeFilename":
return "ffprobe";
case "ArchiveType":
return "gz";
}
break;
}
break;
}
#endif
// Unsupported Unix platform
return "";
#endif
}
return "";
}
@ -92,52 +117,81 @@ namespace MediaBrowser.ServerApplication.FFMpeg
#if __MonoCS__
case PlatformID.Unix:
if (IsRunningOnMac())
if (PlatformDetection.IsMac && PlatformDetection.IsX86_64)
{
// Mac OS X Intel 64bit
return new[]
{
"https://copy.com/IB0W4efS6t9A/ffall-2.1.1.tar.gz?download=1"
};
}
else
if (PlatformDetection.IsLinux)
{
// Linux
return new[]
if (PlatformDetection.IsX86)
{
"http://ffmpeg.gusari.org/static/32bit/ffmpeg.static.32bit.2014-01-04.tar.gz",
"https://www.dropbox.com/s/b7nkg71sil812hp/ffmpeg.static.32bit.2014-01-04.tar.gz?dl=1"
};
return new[]
{
"http://ffmpeg.gusari.org/static/32bit/ffmpeg.static.32bit.2014-01-18.tar.gz",
"https://www.dropbox.com/s/b7nkg71sil812hp/ffmpeg.static.32bit.2014-01-04.tar.gz?dl=1"
};
}
if (PlatformDetection.IsX86_64)
{
return new[]
{
"http://ffmpeg.gusari.org/static/64bit/ffmpeg.static.64bit.2014-01-18.tar.gz"
};
}
}
//No Unix version available
return new string[] {};
#endif
}
return new string[] {};
}
}
#if __MonoCS__
// From mono/mcs/class/Managed.Windows.Forms/System.Windows.Forms/XplatUI.cs
[DllImport ("libc")]
static extern int uname (IntPtr buf);
#if __MonoCS__
public static class PlatformDetection
{
public readonly static bool IsWindows;
public readonly static bool IsMac;
public readonly static bool IsLinux;
public readonly static bool IsX86;
public readonly static bool IsX86_64;
public readonly static bool IsArm;
static bool IsRunningOnMac()
static PlatformDetection ()
{
IntPtr buf = IntPtr.Zero;
try {
buf = Marshal.AllocHGlobal (8192);
// This is a hacktastic way of getting sysname from uname ()
if (uname (buf) == 0) {
string os = Marshal.PtrToStringAnsi (buf);
if (os == "Darwin")
return true;
IsWindows = Path.DirectorySeparatorChar == '\\';
//Don't call uname on windows
if (!IsWindows)
{
Utsname uname;
var callResult = Syscall.uname(out uname);
if (callResult == 0)
{
IsMac = uname.sysname == "Darwin";
IsLinux = !IsMac && uname.sysname == "Linux";
Regex archX86 = new Regex("(i|I)[3-6]86");
IsX86 = archX86.IsMatch(uname.machine);
IsX86_64 = !IsX86 && uname.machine == "x86_64";
IsArm = !IsX86 && !IsX86 && uname.machine.StartsWith("arm");
}
} catch {
} finally {
if (buf != IntPtr.Zero)
Marshal.FreeHGlobal (buf);
}
return false;
else
{
if (System.Environment.Is64BitOperatingSystem)
IsX86_64 = true;
else
IsX86 = true;
}
}
#endif
}
#endif
}

Loading…
Cancel
Save