aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorLuke <luke.pulverenti@gmail.com>2014-11-26 15:23:52 -0500
committerLuke <luke.pulverenti@gmail.com>2014-11-26 15:23:52 -0500
commitfb0c07aa9317997612161523f5955e249f4b6ea3 (patch)
tree5546b119b9141d55e7d5b0df6a330a0792fb565c
parent13cef31b4f52ff61595bd2e4a12e217b022a2705 (diff)
update mac project
-rw-r--r--MediaBrowser.Common/app.config15
-rw-r--r--MediaBrowser.Server.Mac.sln16
-rw-r--r--MediaBrowser.Server.Mac.userprefs29
-rw-r--r--MediaBrowser.Server.Mac/Imazen.WebP.dll.config3
-rw-r--r--MediaBrowser.Server.Mac/MediaBrowser.MediaInfo.dll.config3
-rw-r--r--MediaBrowser.Server.Mac/MediaBrowser.Server.Mac.csproj98
-rw-r--r--MediaBrowser.Server.Mac/Native/BaseMonoApp.cs165
-rw-r--r--MediaBrowser.Server.Mac/Native/NativeApp.cs1
-rw-r--r--MediaBrowser.Server.Mac/Native/NetworkManager.cs39
-rw-r--r--MediaBrowser.Server.Mac/packages.config4
10 files changed, 314 insertions, 59 deletions
diff --git a/MediaBrowser.Common/app.config b/MediaBrowser.Common/app.config
deleted file mode 100644
index 037800f7f..000000000
--- a/MediaBrowser.Common/app.config
+++ /dev/null
@@ -1,15 +0,0 @@
-<?xml version="1.0" encoding="utf-8"?>
-<configuration>
- <runtime>
- <assemblyBinding xmlns="urn:schemas-microsoft-com:asm.v1">
- <dependentAssembly>
- <assemblyIdentity name="System.Reactive.Core" publicKeyToken="f300afd708cefcd3" culture="neutral" />
- <bindingRedirect oldVersion="0.0.0.0-2.0.20823.0" newVersion="2.0.20823.0" />
- </dependentAssembly>
- <dependentAssembly>
- <assemblyIdentity name="System.Reactive.Interfaces" publicKeyToken="f300afd708cefcd3" culture="neutral" />
- <bindingRedirect oldVersion="0.0.0.0-2.0.20823.0" newVersion="2.0.20823.0" />
- </dependentAssembly>
- </assemblyBinding>
- </runtime>
-</configuration> \ No newline at end of file
diff --git a/MediaBrowser.Server.Mac.sln b/MediaBrowser.Server.Mac.sln
index 91d76ca6d..1813c2029 100644
--- a/MediaBrowser.Server.Mac.sln
+++ b/MediaBrowser.Server.Mac.sln
@@ -25,8 +25,6 @@ Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "MediaBrowser.Providers", "M
EndProject
Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "MediaBrowser.Server.Implementations", "MediaBrowser.Server.Implementations\MediaBrowser.Server.Implementations.csproj", "{2E781478-814D-4A48-9D80-BFF206441A65}"
EndProject
-Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "MediaBrowser.Server.Mono", "MediaBrowser.Server.Mono\MediaBrowser.Server.Mono.csproj", "{175A9388-F352-4586-A6B4-070DED62B644}"
-EndProject
Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "MediaBrowser.Server.Startup.Common", "MediaBrowser.Server.Startup.Common\MediaBrowser.Server.Startup.Common.csproj", "{B90AB8F2-1BFF-4568-A3FD-2A338A435A75}"
EndProject
Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "MediaBrowser.WebDashboard", "MediaBrowser.WebDashboard\MediaBrowser.WebDashboard.csproj", "{5624B7B5-B5A7-41D8-9F10-CC5611109619}"
@@ -60,20 +58,6 @@ Global
{0BD82FA6-EB8A-4452-8AF5-74F9C3849451}.Release|Any CPU.Build.0 = Release|Any CPU
{0BD82FA6-EB8A-4452-8AF5-74F9C3849451}.Release|x86.ActiveCfg = Release|Any CPU
{0BD82FA6-EB8A-4452-8AF5-74F9C3849451}.Release|x86.Build.0 = Release|Any CPU
- {175A9388-F352-4586-A6B4-070DED62B644}.AppStore|Any CPU.ActiveCfg = Release|Any CPU
- {175A9388-F352-4586-A6B4-070DED62B644}.AppStore|Any CPU.Build.0 = Release|Any CPU
- {175A9388-F352-4586-A6B4-070DED62B644}.Debug|Any CPU.ActiveCfg = Debug|x86
- {175A9388-F352-4586-A6B4-070DED62B644}.Debug|Any CPU.Build.0 = Debug|x86
- {175A9388-F352-4586-A6B4-070DED62B644}.Debug|x86.ActiveCfg = Debug|x86
- {175A9388-F352-4586-A6B4-070DED62B644}.Debug|x86.Build.0 = Debug|x86
- {175A9388-F352-4586-A6B4-070DED62B644}.Release Mono|Any CPU.ActiveCfg = Release Mono|Any CPU
- {175A9388-F352-4586-A6B4-070DED62B644}.Release Mono|Any CPU.Build.0 = Release Mono|Any CPU
- {175A9388-F352-4586-A6B4-070DED62B644}.Release Mono|x86.ActiveCfg = Release Mono|x86
- {175A9388-F352-4586-A6B4-070DED62B644}.Release Mono|x86.Build.0 = Release Mono|x86
- {175A9388-F352-4586-A6B4-070DED62B644}.Release|Any CPU.ActiveCfg = Release|Any CPU
- {175A9388-F352-4586-A6B4-070DED62B644}.Release|Any CPU.Build.0 = Release|Any CPU
- {175A9388-F352-4586-A6B4-070DED62B644}.Release|x86.ActiveCfg = Release|x86
- {175A9388-F352-4586-A6B4-070DED62B644}.Release|x86.Build.0 = Release|x86
{17E1F4E6-8ABD-4FE5-9ECF-43D4B6087BA2}.AppStore|Any CPU.ActiveCfg = Release|Any CPU
{17E1F4E6-8ABD-4FE5-9ECF-43D4B6087BA2}.AppStore|Any CPU.Build.0 = Release|Any CPU
{17E1F4E6-8ABD-4FE5-9ECF-43D4B6087BA2}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
diff --git a/MediaBrowser.Server.Mac.userprefs b/MediaBrowser.Server.Mac.userprefs
index 4e0fb8a83..233d19c5b 100644
--- a/MediaBrowser.Server.Mac.userprefs
+++ b/MediaBrowser.Server.Mac.userprefs
@@ -1,32 +1,15 @@
<Properties>
- <MonoDevelop.Ide.Workspace ActiveConfiguration="Release" />
+ <MonoDevelop.Ide.Workspace ActiveConfiguration="Debug" />
<MonoDevelop.Ide.Workbench ActiveDocument="MediaBrowser.Server.Mac/Main.cs">
<Files>
- <File FileName="MediaBrowser.Server.Mac/AppController.cs" Line="4" Column="4" />
- <File FileName="MediaBrowser.Server.Mac/Main.cs" Line="4" Column="4" />
- <File FileName="MediaBrowser.Common.Implementations/BaseApplicationPaths.cs" Line="13" Column="13" />
- <File FileName="MediaBrowser.Server.Mac/app.config" Line="56" Column="56" />
- <File FileName="MediaBrowser.WebDashboard/Api/PackageCreator.cs" Line="99" Column="99" />
- <File FileName="MediaBrowser.Server.Mac/EmptyXmlFile.xml" Line="1" Column="1" />
- <File FileName="MediaBrowser.Server.Mono/Program.cs" Line="9" Column="9" />
- <File FileName="MediaBrowser.Server.Mac/AppDelegate.cs" Line="1" Column="1" />
- <File FileName="MediaBrowser.Server.Mono/Networking/NetworkManager.cs" Line="1" Column="1" />
- <File FileName="MediaBrowser.Server.Mono/Native/NativeApp.cs" Line="37" Column="37" />
+ <File FileName="MediaBrowser.Server.Mac/Main.cs" Line="120" Column="120" />
</Files>
<Pads>
<Pad Id="ProjectPad">
- <State expanded="True" selected="True">
- <Node name="MediaBrowser.Common.Implementations" expanded="True">
- <Node name="Devices" expanded="True" />
- </Node>
- <Node name="MediaBrowser.Server.Implementations" expanded="True" />
- <Node name="MediaBrowser.Server.Mac" expanded="True">
- <Node name="Native" expanded="True" />
- </Node>
- <Node name="MediaBrowser.Server.Mono" expanded="True">
- <Node name="Networking" expanded="True" />
- </Node>
- <Node name="MediaBrowser.Server.Startup.Common" expanded="True" />
+ <State expanded="True">
+ <Node name="MediaBrowser.Server.Mac" expanded="True" />
+ <Node name="MediaBrowser.Server.Mono" expanded="True" />
+ <Node name="MediaBrowser.Server.Startup.Common" expanded="True" selected="True" />
<Node name="MediaBrowser.WebDashboard" expanded="True">
<Node name="Api" expanded="True" />
</Node>
diff --git a/MediaBrowser.Server.Mac/Imazen.WebP.dll.config b/MediaBrowser.Server.Mac/Imazen.WebP.dll.config
new file mode 100644
index 000000000..1b6270fd5
--- /dev/null
+++ b/MediaBrowser.Server.Mac/Imazen.WebP.dll.config
@@ -0,0 +1,3 @@
+<configuration>
+ <dllmap dll="libwebp" target="libwebp.5.dylib" os="osx"/>
+</configuration> \ No newline at end of file
diff --git a/MediaBrowser.Server.Mac/MediaBrowser.MediaInfo.dll.config b/MediaBrowser.Server.Mac/MediaBrowser.MediaInfo.dll.config
new file mode 100644
index 000000000..e600a2f2d
--- /dev/null
+++ b/MediaBrowser.Server.Mac/MediaBrowser.MediaInfo.dll.config
@@ -0,0 +1,3 @@
+<configuration>
+ <dllmap dll="MediaInfo" target="libmediainfo.dylib" os="osx"/>
+</configuration> \ No newline at end of file
diff --git a/MediaBrowser.Server.Mac/MediaBrowser.Server.Mac.csproj b/MediaBrowser.Server.Mac/MediaBrowser.Server.Mac.csproj
index 648bdca05..c64cf598d 100644
--- a/MediaBrowser.Server.Mac/MediaBrowser.Server.Mac.csproj
+++ b/MediaBrowser.Server.Mac/MediaBrowser.Server.Mac.csproj
@@ -69,10 +69,14 @@
<Reference Include="System.Xml.Linq" />
<Reference Include="System.Drawing" />
<Reference Include="XamMac" />
+ <Reference Include="Mono.Posix">
+ <HintPath>..\packages\Mono.Posix.4.0.0.0\lib\net40\Mono.Posix.dll</HintPath>
+ </Reference>
</ItemGroup>
<ItemGroup>
<Folder Include="Resources\" />
<Folder Include="Native\" />
+ <Folder Include="Resources\swagger-ui\" />
</ItemGroup>
<ItemGroup>
<Compile Include="AppDelegate.cs" />
@@ -85,19 +89,24 @@
</Compile>
<Compile Include="Main.cs" />
<Compile Include="Native\NativeApp.cs" />
+ <Compile Include="Native\BaseMonoApp.cs" />
+ <Compile Include="Native\NetworkManager.cs" />
</ItemGroup>
<ItemGroup>
<InterfaceDefinition Include="MainMenu.xib" />
</ItemGroup>
<ItemGroup>
<None Include="Info.plist" />
+ <None Include="MediaBrowser.MediaInfo.dll.config">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </None>
+ <None Include="Imazen.WebP.dll.config">
+ <CopyToOutputDirectory>PreserveNewest</CopyToOutputDirectory>
+ </None>
+ <None Include="packages.config" />
</ItemGroup>
<Import Project="$(MSBuildBinPath)\Microsoft.CSharp.targets" />
<ItemGroup>
- <ProjectReference Include="..\MediaBrowser.Server.Mono\MediaBrowser.Server.Mono.csproj">
- <Project>{175A9388-F352-4586-A6B4-070DED62B644}</Project>
- <Name>MediaBrowser.Server.Mono</Name>
- </ProjectReference>
<ProjectReference Include="..\MediaBrowser.Model\MediaBrowser.Model.csproj">
<Project>{7EEEB4BB-F3E8-48FC-B4C5-70F0FFF8329B}</Project>
<Name>MediaBrowser.Model</Name>
@@ -126,4 +135,85 @@
<ItemGroup>
<Content Include="touchicon.png" />
</ItemGroup>
+ <ItemGroup>
+ <NativeReference Include="..\ThirdParty\MediaInfo\osx\libmediainfo.dylib">
+ <IsCxx>False</IsCxx>
+ <Kind>Dynamic</Kind>
+ </NativeReference>
+ <NativeReference Include="..\ThirdParty\libwebp\osx\libwebp.5.dylib">
+ <IsCxx>False</IsCxx>
+ <Kind>Dynamic</Kind>
+ </NativeReference>
+ <NativeReference Include="..\ThirdParty\SQLite3\osx\libsqlite3.0.dylib">
+ <IsCxx>False</IsCxx>
+ <Kind>Dynamic</Kind>
+ </NativeReference>
+ <NativeReference Include="..\ThirdParty\SQLite3\osx\libsqlite3.dylib">
+ <IsCxx>False</IsCxx>
+ <Kind>Dynamic</Kind>
+ </NativeReference>
+ <NativeReference Include="..\ThirdParty\libgdiplus\osx\libgdiplus.dylib">
+ <IsCxx>False</IsCxx>
+ <Kind>Dynamic</Kind>
+ </NativeReference>
+ </ItemGroup>
+ <ItemGroup>
+ <BundleResource Include="..\ThirdParty\ServiceStack\swagger-ui\index.html">
+ <Link>Resources\swagger-ui\index.html</Link>
+ </BundleResource>
+ <BundleResource Include="..\ThirdParty\ServiceStack\swagger-ui\swagger-ui.js">
+ <Link>Resources\swagger-ui\swagger-ui.js</Link>
+ </BundleResource>
+ <BundleResource Include="..\ThirdParty\ServiceStack\swagger-ui\swagger-ui.min.js">
+ <Link>Resources\swagger-ui\swagger-ui.min.js</Link>
+ </BundleResource>
+ <BundleResource Include="..\ThirdParty\ServiceStack\swagger-ui\css\screen.css">
+ <Link>Resources\swagger-ui\css\screen.css</Link>
+ </BundleResource>
+ <BundleResource Include="..\ThirdParty\ServiceStack\swagger-ui\images\logo_small.png">
+ <Link>Resources\swagger-ui\images\logo_small.png</Link>
+ </BundleResource>
+ <BundleResource Include="..\ThirdParty\ServiceStack\swagger-ui\images\pet_store_api.png">
+ <Link>Resources\swagger-ui\images\pet_store_api.png</Link>
+ </BundleResource>
+ <BundleResource Include="..\ThirdParty\ServiceStack\swagger-ui\images\throbber.gif">
+ <Link>Resources\swagger-ui\images\throbber.gif</Link>
+ </BundleResource>
+ <BundleResource Include="..\ThirdParty\ServiceStack\swagger-ui\images\wordnik_api.png">
+ <Link>Resources\swagger-ui\images\wordnik_api.png</Link>
+ </BundleResource>
+ <BundleResource Include="..\ThirdParty\ServiceStack\swagger-ui\lib\backbone-min.js">
+ <Link>Resources\swagger-ui\lib\backbone-min.js</Link>
+ </BundleResource>
+ <BundleResource Include="..\ThirdParty\ServiceStack\swagger-ui\lib\handlebars-1.0.0.js">
+ <Link>Resources\swagger-ui\lib\handlebars-1.0.0.js</Link>
+ </BundleResource>
+ <BundleResource Include="..\ThirdParty\ServiceStack\swagger-ui\lib\highlight.7.3.pack.js">
+ <Link>Resources\swagger-ui\lib\highlight.7.3.pack.js</Link>
+ </BundleResource>
+ <BundleResource Include="..\ThirdParty\ServiceStack\swagger-ui\lib\jquery-1.8.0.min.js">
+ <Link>Resources\swagger-ui\lib\jquery-1.8.0.min.js</Link>
+ </BundleResource>
+ <BundleResource Include="..\ThirdParty\ServiceStack\swagger-ui\lib\jquery.ba-bbq.min.js">
+ <Link>Resources\swagger-ui\lib\jquery.ba-bbq.min.js</Link>
+ </BundleResource>
+ <BundleResource Include="..\ThirdParty\ServiceStack\swagger-ui\lib\jquery.slideto.min.js">
+ <Link>Resources\swagger-ui\lib\jquery.slideto.min.js</Link>
+ </BundleResource>
+ <BundleResource Include="..\ThirdParty\ServiceStack\swagger-ui\lib\jquery.wiggle.min.js">
+ <Link>Resources\swagger-ui\lib\jquery.wiggle.min.js</Link>
+ </BundleResource>
+ <BundleResource Include="..\ThirdParty\ServiceStack\swagger-ui\lib\shred.bundle.js">
+ <Link>Resources\swagger-ui\lib\shred.bundle.js</Link>
+ </BundleResource>
+ <BundleResource Include="..\ThirdParty\ServiceStack\swagger-ui\lib\swagger.js">
+ <Link>Resources\swagger-ui\lib\swagger.js</Link>
+ </BundleResource>
+ <BundleResource Include="..\ThirdParty\ServiceStack\swagger-ui\lib\underscore-min.js">
+ <Link>Resources\swagger-ui\lib\underscore-min.js</Link>
+ </BundleResource>
+ <BundleResource Include="..\ThirdParty\ServiceStack\swagger-ui\lib\shred\content.js">
+ <Link>Resources\swagger-ui\lib\shred\content.js</Link>
+ </BundleResource>
+ </ItemGroup>
</Project> \ No newline at end of file
diff --git a/MediaBrowser.Server.Mac/Native/BaseMonoApp.cs b/MediaBrowser.Server.Mac/Native/BaseMonoApp.cs
new file mode 100644
index 000000000..a2c860413
--- /dev/null
+++ b/MediaBrowser.Server.Mac/Native/BaseMonoApp.cs
@@ -0,0 +1,165 @@
+using MediaBrowser.Common.Net;
+using MediaBrowser.Model.Logging;
+using MediaBrowser.Server.Startup.Common;
+using Mono.Unix.Native;
+using System;
+using System.Collections.Generic;
+using System.Reflection;
+using System.Text.RegularExpressions;
+
+namespace MediaBrowser.Server.Mac
+{
+ public abstract class BaseMonoApp : INativeApp
+ {
+ /// <summary>
+ /// Shutdowns this instance.
+ /// </summary>
+ public abstract void Shutdown();
+
+ /// <summary>
+ /// Restarts this instance.
+ /// </summary>
+ public void Restart()
+ {
+
+ }
+
+ /// <summary>
+ /// Determines whether this instance [can self restart].
+ /// </summary>
+ /// <returns><c>true</c> if this instance [can self restart]; otherwise, <c>false</c>.</returns>
+ public bool CanSelfRestart
+ {
+ get
+ {
+ return false;
+ }
+ }
+
+ /// <summary>
+ /// Gets a value indicating whether this instance can self update.
+ /// </summary>
+ /// <value><c>true</c> if this instance can self update; otherwise, <c>false</c>.</value>
+ public bool CanSelfUpdate
+ {
+ get
+ {
+ return false;
+ }
+ }
+
+ public bool SupportsAutoRunAtStartup
+ {
+ get { return false; }
+ }
+
+ public void PreventSystemStandby()
+ {
+
+ }
+
+ public List<Assembly> GetAssembliesWithParts()
+ {
+ var list = new List<Assembly>();
+
+ list.Add(GetType().Assembly);
+
+ return list;
+ }
+
+ public void AuthorizeServer(int httpServerPort, string httpServerUrlPrefix, int udpPort, string tempDirectory)
+ {
+ }
+
+ private NativeEnvironment _nativeEnvironment;
+ public NativeEnvironment Environment
+ {
+ get { return _nativeEnvironment ?? (_nativeEnvironment = GetEnvironmentInfo()); }
+ }
+
+ public bool SupportsRunningAsService
+ {
+ get
+ {
+ return false;
+ }
+ }
+
+ public bool IsRunningAsService
+ {
+ get
+ {
+ return false;
+ }
+ }
+
+ public void ConfigureAutoRun(bool autorun)
+ {
+ }
+
+ public INetworkManager CreateNetworkManager(ILogger logger)
+ {
+ return new NetworkManager(logger);
+ }
+
+ private NativeEnvironment GetEnvironmentInfo()
+ {
+ var info = new NativeEnvironment
+ {
+ OperatingSystem = Startup.Common.OperatingSystem.Linux
+ };
+
+ var uname = GetUnixName();
+
+ var sysName = uname.sysname ?? string.Empty;
+
+ info.OperatingSystem = Startup.Common.OperatingSystem.Osx;
+
+ var archX86 = new Regex("(i|I)[3-6]86");
+
+ if (archX86.IsMatch(uname.machine))
+ {
+ info.SystemArchitecture = Architecture.X86;
+ }
+ else if (string.Equals(uname.machine, "x86_64", StringComparison.OrdinalIgnoreCase))
+ {
+ info.SystemArchitecture = Architecture.X86_X64;
+ }
+ else if (uname.machine.StartsWith("arm", StringComparison.OrdinalIgnoreCase))
+ {
+ info.SystemArchitecture = Architecture.Arm;
+ }
+
+ info.OperatingSystemVersionString = string.IsNullOrWhiteSpace(sysName) ?
+ System.Environment.OSVersion.VersionString :
+ sysName;
+
+ return info;
+ }
+
+ private Uname _unixName;
+ private Uname GetUnixName()
+ {
+ if (_unixName == null)
+ {
+ var uname = new Uname();
+ Utsname utsname;
+ var callResult = Syscall.uname(out utsname);
+ if (callResult == 0)
+ {
+ uname.sysname = utsname.sysname;
+ uname.machine = utsname.machine;
+ }
+
+ _unixName = uname;
+ }
+ return _unixName;
+ }
+
+ private class Uname
+ {
+ public string sysname = string.Empty;
+ public string machine = string.Empty;
+ }
+ }
+}
diff --git a/MediaBrowser.Server.Mac/Native/NativeApp.cs b/MediaBrowser.Server.Mac/Native/NativeApp.cs
index aedce3d66..f7c2dd4c9 100644
--- a/MediaBrowser.Server.Mac/Native/NativeApp.cs
+++ b/MediaBrowser.Server.Mac/Native/NativeApp.cs
@@ -1,5 +1,4 @@
using System;
-using MediaBrowser.Server.Mono.Native;
namespace MediaBrowser.Server.Mac
{
diff --git a/MediaBrowser.Server.Mac/Native/NetworkManager.cs b/MediaBrowser.Server.Mac/Native/NetworkManager.cs
new file mode 100644
index 000000000..6e4e055a2
--- /dev/null
+++ b/MediaBrowser.Server.Mac/Native/NetworkManager.cs
@@ -0,0 +1,39 @@
+using MediaBrowser.Common.Implementations.Networking;
+using MediaBrowser.Common.Net;
+using MediaBrowser.Model.IO;
+using MediaBrowser.Model.Logging;
+using MediaBrowser.Model.Net;
+using System.Collections.Generic;
+
+namespace MediaBrowser.Server.Mac
+{
+ /// <summary>
+ /// Class NetUtils
+ /// </summary>
+ public class NetworkManager : BaseNetworkManager, INetworkManager
+ {
+ public NetworkManager(ILogger logger)
+ : base(logger)
+ {
+ }
+
+ /// <summary>
+ /// Gets the network shares.
+ /// </summary>
+ /// <param name="path">The path.</param>
+ /// <returns>IEnumerable{NetworkShare}.</returns>
+ public IEnumerable<NetworkShare> GetNetworkShares(string path)
+ {
+ return new List<NetworkShare> ();
+ }
+
+ /// <summary>
+ /// Gets available devices within the domain
+ /// </summary>
+ /// <returns>PC's in the Domain</returns>
+ public IEnumerable<FileSystemEntryInfo> GetNetworkDevices()
+ {
+ return new List<FileSystemEntryInfo> ();
+ }
+ }
+}
diff --git a/MediaBrowser.Server.Mac/packages.config b/MediaBrowser.Server.Mac/packages.config
new file mode 100644
index 000000000..a87b88341
--- /dev/null
+++ b/MediaBrowser.Server.Mac/packages.config
@@ -0,0 +1,4 @@
+<?xml version="1.0" encoding="utf-8"?>
+<packages>
+ <package id="Mono.Posix" version="4.0.0.0" targetFramework="net45" />
+</packages> \ No newline at end of file