mirror of
https://github.com/ppy/osu.git
synced 2025-01-28 00:02:56 +08:00
Group large drag drop imports into a single operation
This commit is contained in:
parent
e848444d74
commit
30cae46cbd
@ -2,6 +2,7 @@
|
|||||||
// See the LICENCE file in the repository root for full licence text.
|
// See the LICENCE file in the repository root for full licence text.
|
||||||
|
|
||||||
using System;
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
using System.IO;
|
using System.IO;
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
using System.Reflection;
|
using System.Reflection;
|
||||||
@ -18,6 +19,7 @@ using osu.Framework.Screens;
|
|||||||
using osu.Game.Screens.Menu;
|
using osu.Game.Screens.Menu;
|
||||||
using osu.Game.Updater;
|
using osu.Game.Updater;
|
||||||
using osu.Desktop.Windows;
|
using osu.Desktop.Windows;
|
||||||
|
using osu.Framework.Threading;
|
||||||
using osu.Game.IO;
|
using osu.Game.IO;
|
||||||
|
|
||||||
namespace osu.Desktop
|
namespace osu.Desktop
|
||||||
@ -144,13 +146,39 @@ namespace osu.Desktop
|
|||||||
desktopWindow.DragDrop += f => fileDrop(new[] { f });
|
desktopWindow.DragDrop += f => fileDrop(new[] { f });
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private readonly List<string> importableFiles = new List<string>();
|
||||||
|
private ScheduledDelegate importSchedule;
|
||||||
|
|
||||||
private void fileDrop(string[] filePaths)
|
private void fileDrop(string[] filePaths)
|
||||||
|
{
|
||||||
|
lock (importableFiles)
|
||||||
{
|
{
|
||||||
var firstExtension = Path.GetExtension(filePaths.First());
|
var firstExtension = Path.GetExtension(filePaths.First());
|
||||||
|
|
||||||
if (filePaths.Any(f => Path.GetExtension(f) != firstExtension)) return;
|
if (filePaths.Any(f => Path.GetExtension(f) != firstExtension)) return;
|
||||||
|
|
||||||
Task.Factory.StartNew(() => Import(filePaths), TaskCreationOptions.LongRunning);
|
importableFiles.AddRange(filePaths);
|
||||||
|
|
||||||
|
Logger.Log($"Adding {filePaths.Length} files for import");
|
||||||
|
|
||||||
|
// File drag drop operations can potentially trigger hundreds or thousands of these calls on some platforms.
|
||||||
|
// In order to avoid spawning multiple import tasks for a single drop operation, debounce a touch.
|
||||||
|
importSchedule?.Cancel();
|
||||||
|
importSchedule = Scheduler.AddDelayed(handlePendingImports, 100);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void handlePendingImports()
|
||||||
|
{
|
||||||
|
lock (importableFiles)
|
||||||
|
{
|
||||||
|
Logger.Log($"Handling batch import of {importableFiles.Count} files");
|
||||||
|
|
||||||
|
var paths = importableFiles.ToArray();
|
||||||
|
importableFiles.Clear();
|
||||||
|
|
||||||
|
Task.Factory.StartNew(() => Import(paths), TaskCreationOptions.LongRunning);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -429,6 +429,9 @@ namespace osu.Game
|
|||||||
|
|
||||||
public async Task Import(params string[] paths)
|
public async Task Import(params string[] paths)
|
||||||
{
|
{
|
||||||
|
if (paths.Length == 0)
|
||||||
|
return;
|
||||||
|
|
||||||
var extension = Path.GetExtension(paths.First())?.ToLowerInvariant();
|
var extension = Path.GetExtension(paths.First())?.ToLowerInvariant();
|
||||||
|
|
||||||
foreach (var importer in fileImporters)
|
foreach (var importer in fileImporters)
|
||||||
|
Loading…
Reference in New Issue
Block a user