From 27fc5c1407e2c75d5589aa07e3ec9ebf5462620e Mon Sep 17 00:00:00 2001 From: abeloin Date: Sat, 11 Jan 2014 20:01:27 -0500 Subject: [PATCH] Added Mac sqlite3. Added mac detect. Mac ffmpeg --- .../MediaBrowser.Server.Mono.csproj | 13 ++- .../System.Data.SQLite.dll.config | 5 +- .../FFMpeg/FFMpegDownloadInfo.cs | 94 +++++++++++++++---- 3 files changed, 91 insertions(+), 21 deletions(-) diff --git a/MediaBrowser.Server.Mono/MediaBrowser.Server.Mono.csproj b/MediaBrowser.Server.Mono/MediaBrowser.Server.Mono.csproj index 2b2ccbe991..0bd2a775b9 100644 --- a/MediaBrowser.Server.Mono/MediaBrowser.Server.Mono.csproj +++ b/MediaBrowser.Server.Mono/MediaBrowser.Server.Mono.csproj @@ -134,13 +134,20 @@ PreserveNewest - lib\libsqlite3.so.0.8.6 + sqlite3\linux\lib\libsqlite3.so.0.8.6 PreserveNewest - lib64\libsqlite3.so.0.8.6 + sqlite3\linux\lib64\libsqlite3.so.0.8.6 + PreserveNewest + + + sqlite3\mac\libsqlite3.0.dylib + PreserveNewest + + + System.Data.SQLite.dll.config PreserveNewest - \ No newline at end of file diff --git a/MediaBrowser.Server.Mono/System.Data.SQLite.dll.config b/MediaBrowser.Server.Mono/System.Data.SQLite.dll.config index df4189b566..c1868d88d0 100644 --- a/MediaBrowser.Server.Mono/System.Data.SQLite.dll.config +++ b/MediaBrowser.Server.Mono/System.Data.SQLite.dll.config @@ -1,4 +1,5 @@ - - + + + diff --git a/MediaBrowser.ServerApplication/FFMpeg/FFMpegDownloadInfo.cs b/MediaBrowser.ServerApplication/FFMpeg/FFMpegDownloadInfo.cs index 596c9d2347..7ac15dff90 100644 --- a/MediaBrowser.ServerApplication/FFMpeg/FFMpegDownloadInfo.cs +++ b/MediaBrowser.ServerApplication/FFMpeg/FFMpegDownloadInfo.cs @@ -1,4 +1,7 @@ using System; +#if __MonoCS__ +using System.Runtime.InteropServices; +#endif namespace MediaBrowser.ServerApplication.FFMpeg { @@ -35,20 +38,41 @@ namespace MediaBrowser.ServerApplication.FFMpeg return "7z"; } break; + + #if __MonoCS__ case PlatformID.Unix: - case PlatformID.MacOSX: - switch (arg) + if (IsRunningOnMac()) { - case "Version": - return "20140104"; - 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 + { + // Linux + switch (arg) + { + case "Version": + return "20140104"; + case "FFMpegFilename": + return "ffmpeg"; + case "FFProbeFilename": + return "ffprobe"; + case "ArchiveType": + return "gz"; + } + break; + } + #endif } return ""; } @@ -66,16 +90,54 @@ namespace MediaBrowser.ServerApplication.FFMpeg "https://www.dropbox.com/s/oghurnp5zh292ry/ffmpeg-20140105-git-70937d9-win32-static.7z?dl=1" }; + #if __MonoCS__ case PlatformID.Unix: - case PlatformID.MacOSX: - return new[] + if (IsRunningOnMac()) { - "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" - }; + // Mac OS X Intel 64bit + return new[] + { + "https://copy.com/ylAUbbQHYE7x/ffall-2.1.1.7z?download=1" + }; + } + else + { + // Linux + return new[] + { + "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" + }; + } + #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); + + static bool IsRunningOnMac() + { + 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; + } + } catch { + } finally { + if (buf != IntPtr.Zero) + Marshal.FreeHGlobal (buf); + } + return false; + } + #endif } }