diff --git a/Emby.Drawing/Common/ImageHeader.cs b/Emby.Drawing/Common/ImageHeader.cs
index b66bd71ea5..266dcdfb8e 100644
--- a/Emby.Drawing/Common/ImageHeader.cs
+++ b/Emby.Drawing/Common/ImageHeader.cs
@@ -5,6 +5,7 @@ using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
+using CommonIO;
namespace Emby.Drawing.Common
{
@@ -220,4 +221,4 @@ namespace Emby.Drawing.Common
throw new ArgumentException(ErrorMessage);
}
}
-}
+}
\ No newline at end of file
diff --git a/Emby.Drawing/Emby.Drawing.csproj b/Emby.Drawing/Emby.Drawing.csproj
index ab53f75500..e9911a12d9 100644
--- a/Emby.Drawing/Emby.Drawing.csproj
+++ b/Emby.Drawing/Emby.Drawing.csproj
@@ -12,7 +12,6 @@
v4.5512..\
- truetrue
@@ -32,10 +31,20 @@
4
+
+ False
+ ..\packages\CommonIO.1.0.0.5\lib\net45\CommonIO.dll
+ False..\packages\ImageMagickSharp.1.0.0.16\lib\net45\ImageMagickSharp.dll
+
+ ..\packages\Patterns.Logging.1.0.0.2\lib\portable-net45+sl4+wp71+win8+wpa81\Patterns.Logging.dll
+
+
+ ..\packages\taglib.2.1.0.0\lib\policy.2.0.taglib-sharp.dll
+
@@ -44,11 +53,15 @@
+
+ ..\packages\taglib.2.1.0.0\lib\taglib-sharp.dll
+
Properties\SharedVersion.cs
+
@@ -56,13 +69,13 @@
-
+
@@ -87,6 +100,9 @@
+
+
+
-
-
-
- This project references NuGet package(s) that are missing on this computer. Enable NuGet Package Restore to download them. For more information, see http://go.microsoft.com/fwlink/?LinkID=322105. The missing file is {0}.
-
-
-
\ No newline at end of file
diff --git a/MediaBrowser.ServerApplication/Native/Autorun.cs b/MediaBrowser.ServerApplication/Native/Autorun.cs
index dd2a775655..2cacaae8ed 100644
--- a/MediaBrowser.ServerApplication/Native/Autorun.cs
+++ b/MediaBrowser.ServerApplication/Native/Autorun.cs
@@ -1,6 +1,7 @@
using MediaBrowser.Common.IO;
using System;
using System.IO;
+using CommonIO;
namespace MediaBrowser.ServerApplication.Native
{
diff --git a/MediaBrowser.ServerApplication/Native/NativeFileSystem.cs b/MediaBrowser.ServerApplication/Native/NativeFileSystem.cs
deleted file mode 100644
index 90ebe7e2d0..0000000000
--- a/MediaBrowser.ServerApplication/Native/NativeFileSystem.cs
+++ /dev/null
@@ -1,419 +0,0 @@
-using MediaBrowser.Common.Implementations.IO;
-using MediaBrowser.Model.Logging;
-using System;
-using System.IO;
-using System.Runtime.InteropServices;
-using System.Security;
-using System.Text;
-
-namespace MediaBrowser.ServerApplication.Native
-{
- public class NativeFileSystem : CommonFileSystem
- {
- public NativeFileSystem(ILogger logger, bool usePresetInvalidFileNameChars)
- : base(logger, true, usePresetInvalidFileNameChars)
- {
- }
-
- public override bool IsShortcut(string filename)
- {
- return base.IsShortcut(filename) ||
- string.Equals(Path.GetExtension(filename), ".lnk", StringComparison.OrdinalIgnoreCase);
- }
-
- public override string ResolveShortcut(string filename)
- {
- var path = base.ResolveShortcut(filename);
-
- if (!string.IsNullOrEmpty(path))
- {
- return path;
- }
-
- if (string.Equals(Path.GetExtension(filename), ".lnk", StringComparison.OrdinalIgnoreCase))
- {
- return ResolveLnk(filename);
- }
-
- return null;
- }
-
- private string ResolveLnk(string filename)
- {
- var link = new ShellLink();
- ((IPersistFile)link).Load(filename, NativeMethods.STGM_READ);
- // ((IShellLinkW)link).Resolve(hwnd, 0)
- var sb = new StringBuilder(NativeMethods.MAX_PATH);
- WIN32_FIND_DATA data;
- ((IShellLinkW)link).GetPath(sb, sb.Capacity, out data, 0);
- return sb.ToString();
- }
- }
-
- ///
- /// Class NativeMethods
- ///
- [SuppressUnmanagedCodeSecurity]
- public static class NativeMethods
- {
- ///
- /// The MA x_ PATH
- ///
- public const int MAX_PATH = 260;
- ///
- /// The MA x_ ALTERNATE
- ///
- public const int MAX_ALTERNATE = 14;
- ///
- /// The INVALI d_ HANDL e_ VALUE
- ///
- public static IntPtr INVALID_HANDLE_VALUE = new IntPtr(-1);
- ///
- /// The STG m_ READ
- ///
- public const uint STGM_READ = 0;
- }
-
- ///
- /// Struct FILETIME
- ///
- [StructLayout(LayoutKind.Sequential)]
- public struct FILETIME
- {
- ///
- /// The dw low date time
- ///
- public uint dwLowDateTime;
- ///
- /// The dw high date time
- ///
- public uint dwHighDateTime;
- }
-
- ///
- /// Struct WIN32_FIND_DATA
- ///
- [StructLayout(LayoutKind.Sequential, CharSet = CharSet.Unicode)]
- public struct WIN32_FIND_DATA
- {
- ///
- /// The dw file attributes
- ///
- public FileAttributes dwFileAttributes;
- ///
- /// The ft creation time
- ///
- public FILETIME ftCreationTime;
- ///
- /// The ft last access time
- ///
- public FILETIME ftLastAccessTime;
- ///
- /// The ft last write time
- ///
- public FILETIME ftLastWriteTime;
- ///
- /// The n file size high
- ///
- public int nFileSizeHigh;
- ///
- /// The n file size low
- ///
- public int nFileSizeLow;
- ///
- /// The dw reserved0
- ///
- public int dwReserved0;
- ///
- /// The dw reserved1
- ///
- public int dwReserved1;
-
- ///
- /// The c file name
- ///
- [MarshalAs(UnmanagedType.ByValTStr, SizeConst = NativeMethods.MAX_PATH)]
- public string cFileName;
-
- ///
- /// This will always be null when FINDEX_INFO_LEVELS = basic
- ///
- [MarshalAs(UnmanagedType.ByValTStr, SizeConst = NativeMethods.MAX_ALTERNATE)]
- public string cAlternate;
-
- ///
- /// Gets or sets the path.
- ///
- /// The path.
- public string Path { get; set; }
-
- ///
- /// Returns a that represents this instance.
- ///
- /// A that represents this instance.
- public override string ToString()
- {
- return Path ?? string.Empty;
- }
- }
-
- ///
- /// Enum SLGP_FLAGS
- ///
- [Flags]
- public enum SLGP_FLAGS
- {
- ///
- /// Retrieves the standard short (8.3 format) file name
- ///
- SLGP_SHORTPATH = 0x1,
- ///
- /// Retrieves the Universal Naming Convention (UNC) path name of the file
- ///
- SLGP_UNCPRIORITY = 0x2,
- ///
- /// Retrieves the raw path name. A raw path is something that might not exist and may include environment variables that need to be expanded
- ///
- SLGP_RAWPATH = 0x4
- }
- ///
- /// Enum SLR_FLAGS
- ///
- [Flags]
- public enum SLR_FLAGS
- {
- ///
- /// Do not display a dialog box if the link cannot be resolved. When SLR_NO_UI is set,
- /// the high-order word of fFlags can be set to a time-out value that specifies the
- /// maximum amount of time to be spent resolving the link. The function returns if the
- /// link cannot be resolved within the time-out duration. If the high-order word is set
- /// to zero, the time-out duration will be set to the default value of 3,000 milliseconds
- /// (3 seconds). To specify a value, set the high word of fFlags to the desired time-out
- /// duration, in milliseconds.
- ///
- SLR_NO_UI = 0x1,
- ///
- /// Obsolete and no longer used
- ///
- SLR_ANY_MATCH = 0x2,
- ///
- /// If the link object has changed, update its path and list of identifiers.
- /// If SLR_UPDATE is set, you do not need to call IPersistFile::IsDirty to determine
- /// whether or not the link object has changed.
- ///
- SLR_UPDATE = 0x4,
- ///
- /// Do not update the link information
- ///
- SLR_NOUPDATE = 0x8,
- ///
- /// Do not execute the search heuristics
- ///
- SLR_NOSEARCH = 0x10,
- ///
- /// Do not use distributed link tracking
- ///
- SLR_NOTRACK = 0x20,
- ///
- /// Disable distributed link tracking. By default, distributed link tracking tracks
- /// removable media across multiple devices based on the volume name. It also uses the
- /// Universal Naming Convention (UNC) path to track remote file systems whose drive letter
- /// has changed. Setting SLR_NOLINKINFO disables both types of tracking.
- ///
- SLR_NOLINKINFO = 0x40,
- ///
- /// Call the Microsoft Windows Installer
- ///
- SLR_INVOKE_MSI = 0x80
- }
-
- ///
- /// The IShellLink interface allows Shell links to be created, modified, and resolved
- ///
- [ComImport, InterfaceType(ComInterfaceType.InterfaceIsIUnknown), Guid("000214F9-0000-0000-C000-000000000046")]
- public interface IShellLinkW
- {
- ///
- /// Retrieves the path and file name of a Shell link object
- ///
- /// The PSZ file.
- /// The CCH max path.
- /// The PFD.
- /// The f flags.
- void GetPath([Out, MarshalAs(UnmanagedType.LPWStr)] StringBuilder pszFile, int cchMaxPath, out WIN32_FIND_DATA pfd, SLGP_FLAGS fFlags);
- ///
- /// Retrieves the list of item identifiers for a Shell link object
- ///
- /// The ppidl.
- void GetIDList(out IntPtr ppidl);
- ///
- /// Sets the pointer to an item identifier list (PIDL) for a Shell link object.
- ///
- /// The pidl.
- void SetIDList(IntPtr pidl);
- ///
- /// Retrieves the description string for a Shell link object
- ///
- /// Name of the PSZ.
- /// Name of the CCH max.
- void GetDescription([Out, MarshalAs(UnmanagedType.LPWStr)] StringBuilder pszName, int cchMaxName);
- ///
- /// Sets the description for a Shell link object. The description can be any application-defined string
- ///
- /// Name of the PSZ.
- void SetDescription([MarshalAs(UnmanagedType.LPWStr)] string pszName);
- ///
- /// Retrieves the name of the working directory for a Shell link object
- ///
- /// The PSZ dir.
- /// The CCH max path.
- void GetWorkingDirectory([Out, MarshalAs(UnmanagedType.LPWStr)] StringBuilder pszDir, int cchMaxPath);
- ///
- /// Sets the name of the working directory for a Shell link object
- ///
- /// The PSZ dir.
- void SetWorkingDirectory([MarshalAs(UnmanagedType.LPWStr)] string pszDir);
- ///
- /// Retrieves the command-line arguments associated with a Shell link object
- ///
- /// The PSZ args.
- /// The CCH max path.
- void GetArguments([Out, MarshalAs(UnmanagedType.LPWStr)] StringBuilder pszArgs, int cchMaxPath);
- ///
- /// Sets the command-line arguments for a Shell link object
- ///
- /// The PSZ args.
- void SetArguments([MarshalAs(UnmanagedType.LPWStr)] string pszArgs);
- ///
- /// Retrieves the hot key for a Shell link object
- ///
- /// The pw hotkey.
- void GetHotkey(out short pwHotkey);
- ///
- /// Sets a hot key for a Shell link object
- ///
- /// The w hotkey.
- void SetHotkey(short wHotkey);
- ///
- /// Retrieves the show command for a Shell link object
- ///
- /// The pi show CMD.
- void GetShowCmd(out int piShowCmd);
- ///
- /// Sets the show command for a Shell link object. The show command sets the initial show state of the window.
- ///
- /// The i show CMD.
- void SetShowCmd(int iShowCmd);
- ///
- /// Retrieves the location (path and index) of the icon for a Shell link object
- ///
- /// The PSZ icon path.
- /// The CCH icon path.
- /// The pi icon.
- void GetIconLocation([Out, MarshalAs(UnmanagedType.LPWStr)] StringBuilder pszIconPath,
- int cchIconPath, out int piIcon);
- ///
- /// Sets the location (path and index) of the icon for a Shell link object
- ///
- /// The PSZ icon path.
- /// The i icon.
- void SetIconLocation([MarshalAs(UnmanagedType.LPWStr)] string pszIconPath, int iIcon);
- ///
- /// Sets the relative path to the Shell link object
- ///
- /// The PSZ path rel.
- /// The dw reserved.
- void SetRelativePath([MarshalAs(UnmanagedType.LPWStr)] string pszPathRel, int dwReserved);
- ///
- /// Attempts to find the target of a Shell link, even if it has been moved or renamed
- ///
- /// The HWND.
- /// The f flags.
- void Resolve(IntPtr hwnd, SLR_FLAGS fFlags);
- ///
- /// Sets the path and file name of a Shell link object
- ///
- /// The PSZ file.
- void SetPath([MarshalAs(UnmanagedType.LPWStr)] string pszFile);
-
- }
-
- ///
- /// Interface IPersist
- ///
- [ComImport, Guid("0000010c-0000-0000-c000-000000000046"),
- InterfaceType(ComInterfaceType.InterfaceIsIUnknown)]
- public interface IPersist
- {
- ///
- /// Gets the class ID.
- ///
- /// The p class ID.
- [PreserveSig]
- void GetClassID(out Guid pClassID);
- }
-
- ///
- /// Interface IPersistFile
- ///
- [ComImport, Guid("0000010b-0000-0000-C000-000000000046"),
- InterfaceType(ComInterfaceType.InterfaceIsIUnknown)]
- public interface IPersistFile : IPersist
- {
- ///
- /// Gets the class ID.
- ///
- /// The p class ID.
- new void GetClassID(out Guid pClassID);
- ///
- /// Determines whether this instance is dirty.
- ///
- [PreserveSig]
- int IsDirty();
-
- ///
- /// Loads the specified PSZ file name.
- ///
- /// Name of the PSZ file.
- /// The dw mode.
- [PreserveSig]
- void Load([In, MarshalAs(UnmanagedType.LPWStr)]
- string pszFileName, uint dwMode);
-
- ///
- /// Saves the specified PSZ file name.
- ///
- /// Name of the PSZ file.
- /// if set to true [remember].
- [PreserveSig]
- void Save([In, MarshalAs(UnmanagedType.LPWStr)] string pszFileName,
- [In, MarshalAs(UnmanagedType.Bool)] bool remember);
-
- ///
- /// Saves the completed.
- ///
- /// Name of the PSZ file.
- [PreserveSig]
- void SaveCompleted([In, MarshalAs(UnmanagedType.LPWStr)] string pszFileName);
-
- ///
- /// Gets the cur file.
- ///
- /// Name of the PPSZ file.
- [PreserveSig]
- void GetCurFile([In, MarshalAs(UnmanagedType.LPWStr)] string ppszFileName);
- }
-
- // CLSID_ShellLink from ShlGuid.h
- ///
- /// Class ShellLink
- ///
- [
- ComImport,
- Guid("00021401-0000-0000-C000-000000000046")
- ]
- public class ShellLink
- {
- }
-
-}
diff --git a/MediaBrowser.ServerApplication/Native/WindowsApp.cs b/MediaBrowser.ServerApplication/Native/WindowsApp.cs
index bad1aaf35e..bff342d01f 100644
--- a/MediaBrowser.ServerApplication/Native/WindowsApp.cs
+++ b/MediaBrowser.ServerApplication/Native/WindowsApp.cs
@@ -1,11 +1,11 @@
-using MediaBrowser.Common.IO;
-using MediaBrowser.Common.Net;
+using MediaBrowser.Common.Net;
using MediaBrowser.IsoMounter;
using MediaBrowser.Model.Logging;
using MediaBrowser.Server.Startup.Common;
using MediaBrowser.ServerApplication.Networking;
using System.Collections.Generic;
using System.Reflection;
+using CommonIO;
namespace MediaBrowser.ServerApplication.Native
{
@@ -22,7 +22,10 @@ namespace MediaBrowser.ServerApplication.Native
{
var list = new List();
- list.Add(typeof(PismoIsoManager).Assembly);
+ if (!System.Environment.Is64BitProcess)
+ {
+ list.Add(typeof(PismoIsoManager).Assembly);
+ }
list.Add(GetType().Assembly);
@@ -47,6 +50,11 @@ namespace MediaBrowser.ServerApplication.Native
}
}
+ public bool SupportsLibraryMonitor
+ {
+ get { return true; }
+ }
+
public bool SupportsRunningAsService
{
get
diff --git a/MediaBrowser.ServerApplication/ServerNotifyIcon.cs b/MediaBrowser.ServerApplication/ServerNotifyIcon.cs
index ad0bd8a1af..e9a7d59857 100644
--- a/MediaBrowser.ServerApplication/ServerNotifyIcon.cs
+++ b/MediaBrowser.ServerApplication/ServerNotifyIcon.cs
@@ -11,7 +11,7 @@ namespace MediaBrowser.ServerApplication
public class ServerNotifyIcon : IDisposable
{
bool IsDisposing = false;
-
+
private NotifyIcon notifyIcon1;
private ContextMenuStrip contextMenuStrip1;
private ToolStripMenuItem cmdExit;
@@ -21,9 +21,6 @@ namespace MediaBrowser.ServerApplication
private ToolStripMenuItem cmdRestart;
private ToolStripSeparator toolStripSeparator1;
private ToolStripMenuItem cmdCommunity;
- private ToolStripMenuItem cmdApiDocs;
- private ToolStripMenuItem cmdSwagger;
- private ToolStripMenuItem cmdGtihub;
private readonly ILogger _logger;
private readonly IServerApplicationHost _appHost;
@@ -43,8 +40,8 @@ namespace MediaBrowser.ServerApplication
}
}
- public ServerNotifyIcon(ILogManager logManager,
- IServerApplicationHost appHost,
+ public ServerNotifyIcon(ILogManager logManager,
+ IServerApplicationHost appHost,
IServerConfigurationManager configurationManager,
ILocalizationManager localization)
{
@@ -52,13 +49,13 @@ namespace MediaBrowser.ServerApplication
_localization = localization;
_appHost = appHost;
_configurationManager = configurationManager;
-
+
var components = new System.ComponentModel.Container();
-
+
var resources = new System.ComponentModel.ComponentResourceManager(typeof(MainForm));
contextMenuStrip1 = new ContextMenuStrip(components);
notifyIcon1 = new NotifyIcon(components);
-
+
cmdExit = new ToolStripMenuItem();
cmdCommunity = new ToolStripMenuItem();
toolStripSeparator1 = new ToolStripSeparator();
@@ -66,10 +63,7 @@ namespace MediaBrowser.ServerApplication
toolStripSeparator2 = new ToolStripSeparator();
cmdConfigure = new ToolStripMenuItem();
cmdBrowse = new ToolStripMenuItem();
- cmdApiDocs = new ToolStripMenuItem();
- cmdSwagger = new ToolStripMenuItem();
- cmdGtihub = new ToolStripMenuItem();
-
+
//
// notifyIcon1
//
@@ -86,7 +80,6 @@ namespace MediaBrowser.ServerApplication
toolStripSeparator2,
cmdRestart,
toolStripSeparator1,
- cmdApiDocs,
cmdCommunity,
cmdExit});
contextMenuStrip1.Name = "contextMenuStrip1";
@@ -128,24 +121,6 @@ namespace MediaBrowser.ServerApplication
//
cmdBrowse.Name = "cmdBrowse";
cmdBrowse.Size = new System.Drawing.Size(208, 22);
- //
- // cmdApiDocs
- //
- cmdApiDocs.DropDownItems.AddRange(new ToolStripItem[] {
- cmdSwagger,
- cmdGtihub});
- cmdApiDocs.Name = "cmdApiDocs";
- cmdApiDocs.Size = new System.Drawing.Size(208, 22);
- //
- // cmdSwagger
- //
- cmdSwagger.Name = "cmdSwagger";
- cmdSwagger.Size = new System.Drawing.Size(136, 22);
- //
- // cmdGtihub
- //
- cmdGtihub.Name = "cmdGtihub";
- cmdGtihub.Size = new System.Drawing.Size(136, 22);
cmdExit.Click += cmdExit_Click;
cmdRestart.Click += cmdRestart_Click;
@@ -153,20 +128,10 @@ namespace MediaBrowser.ServerApplication
cmdCommunity.Click += cmdCommunity_Click;
cmdBrowse.Click += cmdBrowse_Click;
- cmdSwagger.Click += cmdSwagger_Click;
- cmdGtihub.Click += cmdGtihub_Click;
-
_configurationManager.ConfigurationUpdated += Instance_ConfigurationUpdated;
LocalizeText();
- if (_appHost.IsFirstRun)
- {
- Action action = () => notifyIcon1.ShowBalloonTip(5000, "Emby", "Welcome to Emby Server!", ToolTipIcon.Info);
-
- contextMenuStrip1.Invoke(action);
- }
-
notifyIcon1.DoubleClick += notifyIcon1_DoubleClick;
Application.ApplicationExit += Application_ApplicationExit;
}
@@ -194,9 +159,6 @@ namespace MediaBrowser.ServerApplication
cmdExit.Text = _localization.GetLocalizedString("LabelExit");
cmdCommunity.Text = _localization.GetLocalizedString("LabelVisitCommunity");
- cmdGtihub.Text = _localization.GetLocalizedString("LabelGithub");
- cmdSwagger.Text = _localization.GetLocalizedString("LabelApiDocumentation");
- cmdApiDocs.Text = _localization.GetLocalizedString("LabelDeveloperResources");
cmdBrowse.Text = _localization.GetLocalizedString("LabelBrowseLibrary");
cmdConfigure.Text = _localization.GetLocalizedString("LabelConfigureServer");
cmdRestart.Text = _localization.GetLocalizedString("LabelRestartServer");
@@ -242,16 +204,6 @@ namespace MediaBrowser.ServerApplication
_appHost.Shutdown();
}
- void cmdGtihub_Click(object sender, EventArgs e)
- {
- BrowserLauncher.OpenGithub(_logger);
- }
-
- void cmdSwagger_Click(object sender, EventArgs e)
- {
- BrowserLauncher.OpenSwagger(_appHost, _logger);
- }
-
~ServerNotifyIcon()
{
Dispose();
@@ -265,4 +217,4 @@ namespace MediaBrowser.ServerApplication
}
}
}
-}
+}
\ No newline at end of file
diff --git a/MediaBrowser.ServerApplication/packages.config b/MediaBrowser.ServerApplication/packages.config
index 5007cf8af3..dec8199cc2 100644
--- a/MediaBrowser.ServerApplication/packages.config
+++ b/MediaBrowser.ServerApplication/packages.config
@@ -1,6 +1,8 @@
+
+
\ No newline at end of file
diff --git a/MediaBrowser.Tests/MediaEncoding/Subtitles/TestSubtitles/unit.srt b/MediaBrowser.Tests/MediaEncoding/Subtitles/TestSubtitles/unit.srt
index 5f6e5636ec..1ce811bcb6 100644
--- a/MediaBrowser.Tests/MediaEncoding/Subtitles/TestSubtitles/unit.srt
+++ b/MediaBrowser.Tests/MediaEncoding/Subtitles/TestSubtitles/unit.srt
@@ -35,7 +35,7 @@ Unclosed but supported HTML tags are left in, {\i1} SSA italics aren't
9
00:00:36,000 --> 00:00:36,999
-Multiple {\pos(142,120)\b1}SSA tags are stripped
+Multiple {\bord-3.7\clip(1,m 50 0 b 100 0 100 100 50 100 b 0 100 0 0 50 0)\pos(142,120)\t(0,500,\fscx100\fscy100)\b1\c&H000000&}SSA tags are stripped
10
00:00:37,000 --> 00:00:37,999
diff --git a/MediaBrowser.WebDashboard/Api/DashboardService.cs b/MediaBrowser.WebDashboard/Api/DashboardService.cs
index 69c4417cb7..030dc7f33e 100644
--- a/MediaBrowser.WebDashboard/Api/DashboardService.cs
+++ b/MediaBrowser.WebDashboard/Api/DashboardService.cs
@@ -17,6 +17,7 @@ using System.IO;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
+using CommonIO;
using WebMarkupMin.Core.Minifiers;
namespace MediaBrowser.WebDashboard.Api
@@ -274,8 +275,8 @@ namespace MediaBrowser.WebDashboard.Api
private void CopyFile(string src, string dst)
{
- Directory.CreateDirectory(Path.GetDirectoryName(dst));
- File.Copy(src, dst, true);
+ _fileSystem.CreateDirectory(Path.GetDirectoryName(dst));
+ _fileSystem.CopyFile(src, dst, true);
}
public async Task