|
@@ -169,14 +169,15 @@ namespace Emby.Common.Implementations
|
|
|
{
|
|
|
_deviceId = new DeviceId(ApplicationPaths, LogManager.GetLogger("SystemId"), FileSystemManager);
|
|
|
}
|
|
|
-
|
|
|
+
|
|
|
return _deviceId.Value;
|
|
|
}
|
|
|
}
|
|
|
|
|
|
public PackageVersionClass SystemUpdateLevel
|
|
|
{
|
|
|
- get {
|
|
|
+ get
|
|
|
+ {
|
|
|
|
|
|
#if BETA
|
|
|
return PackageVersionClass.Beta;
|
|
@@ -216,7 +217,7 @@ namespace Emby.Common.Implementations
|
|
|
|
|
|
// hack alert, until common can target .net core
|
|
|
BaseExtensions.CryptographyProvider = CryptographyProvider;
|
|
|
-
|
|
|
+
|
|
|
XmlSerializer = new MyXmlSerializer(fileSystem, logManager.GetLogger("XmlSerializer"));
|
|
|
FailedAssemblies = new List<string>();
|
|
|
|
|
@@ -565,7 +566,10 @@ namespace Emby.Common.Implementations
|
|
|
|
|
|
try
|
|
|
{
|
|
|
- return assembly.GetTypes();
|
|
|
+ // This null checking really shouldn't be needed but adding it due to some
|
|
|
+ // unhandled exceptions in mono 5.0 that are a little hard to hunt down
|
|
|
+ var types = assembly.GetTypes() ?? new Type[] { };
|
|
|
+ return types.Where(t => t != null);
|
|
|
}
|
|
|
catch (ReflectionTypeLoadException ex)
|
|
|
{
|
|
@@ -578,7 +582,14 @@ namespace Emby.Common.Implementations
|
|
|
}
|
|
|
|
|
|
// If it fails we can still get a list of the Types it was able to resolve
|
|
|
- return ex.Types.Where(t => t != null);
|
|
|
+ var types = ex.Types ?? new Type[] { };
|
|
|
+ return types.Where(t => t != null);
|
|
|
+ }
|
|
|
+ catch (Exception ex)
|
|
|
+ {
|
|
|
+ Logger.ErrorException("Error loading types from assembly", ex);
|
|
|
+
|
|
|
+ return new List<Type>();
|
|
|
}
|
|
|
}
|
|
|
|