private async Task ConsumerTask(CancellationToken token) { while (true) { //Forcefully queue removal of cache entries //TODO: more than anything this is a hack, needs proper debounce logic instead of using memorycache. memoryCache.Trim(100); if (token.IsCancellationRequested) { return; } if (filesChanged.TryDequeue(out var fsArgs)) { _settings.Add(_names.LoadingRawBeatmaps.Name, true); Interlocked.Increment(ref _numberOfBeatmapsCurrentlyBeingLoaded); _logger.Log($">Processing beatmap located at {fsArgs.FullPath}", LogLevel.Debug); var beatmap = await BeatmapHelpers.ReadBeatmap(fsArgs.FullPath); _databaseController.StoreTempBeatmap(beatmap); _logger.Log(">Added new Temporary beatmap {0} - {1} [{2}]", LogLevel.Information, beatmap.ArtistRoman, beatmap.TitleRoman, beatmap.DiffName); if (Interlocked.Decrement(ref _numberOfBeatmapsCurrentlyBeingLoaded) == 0) { _settings.Add(_names.LoadingRawBeatmaps.Name, false); } if (lastMapSearchArgs != null && ( (lastMapSearchArgs.Artist == beatmap.Artist && lastMapSearchArgs.Title == beatmap.Title && lastMapSearchArgs.Diff == beatmap.DiffName ) || lastMapSearchArgs.MapId == beatmap.MapId )) { NewOsuEvent?.Invoke(this, new MapSearchArgs($"OsuMemory-FolderWatcherReplay", OsuEventType.MapChange) { Artist = beatmap.Artist, MapHash = beatmap.Md5, Title = beatmap.Title, Diff = beatmap.DiffName, EventType = OsuEventType.MapChange, PlayMode = beatmap.PlayMode, Status = lastMapSearchArgs.Status, MapId = beatmap.MapId > 0 ? beatmap.MapId : -123 }); } } Thread.Sleep(5); } }
private void ConsumerTask() { try { while (true) { memoryCache.Get("dummy"); if (filesChanged.TryDequeue(out var fsArgs)) { _settings.Add(_names.LoadingRawBeatmaps.Name, true); Interlocked.Increment(ref _numberOfBeatmapsCurrentlyBeingLoaded); _logger.Log($">Processing beatmap located at {fsArgs.FullPath}", LogLevel.Debug); var beatmap = BeatmapHelpers.ReadBeatmap(fsArgs.FullPath); _databaseController.StoreTempBeatmap(beatmap); _logger.Log(">Added new Temporary beatmap {0} - {1} [{2}]", LogLevel.Information, beatmap.ArtistRoman, beatmap.TitleRoman, beatmap.DiffName); if (Interlocked.Decrement(ref _numberOfBeatmapsCurrentlyBeingLoaded) == 0) { _settings.Add(_names.LoadingRawBeatmaps.Name, false); } if (fsArgs.ChangeType == WatcherChangeTypes.Changed && lastMapSearchArgs != null && ( (lastMapSearchArgs.Artist == beatmap.Artist && lastMapSearchArgs.Title == beatmap.Title && lastMapSearchArgs.Diff == beatmap.DiffName ) || lastMapSearchArgs.MapId == beatmap.MapId )) { NewOsuEvent?.Invoke(this, new MapSearchArgs($"OsuMemory-FolderWatcherReplay", OsuEventType.MapChange) { Artist = beatmap.Artist, MapHash = beatmap.Md5, Title = beatmap.Title, Diff = beatmap.DiffName, EventType = OsuEventType.MapChange, PlayMode = beatmap.PlayMode, Status = lastMapSearchArgs.Status, MapId = beatmap.MapId > 0 ? beatmap.MapId : -123 }); } } Thread.Sleep(5); } } catch (ThreadAbortException) { } }
private void ConsumerTask() { try { while (true) { if (_filesChanged.TryDequeue(out var fsArgs)) { Beatmap beatmap = null; _settings.Add(_names.LoadingRawBeatmaps.Name, true); Interlocked.Increment(ref _numberOfBeatmapsCurrentlyBeingLoaded); _logger.Log("Processing new beatmap", LogLevel.Debug); beatmap = BeatmapHelpers.ReadBeatmap(fsArgs.FullPath); _databaseController.StoreTempBeatmap(beatmap); _logger.Log("Added new Temporary beatmap {0} - {1} [{2}]", LogLevel.Debug, beatmap.ArtistRoman, beatmap.TitleRoman, beatmap.DiffName); if (Interlocked.Decrement(ref _numberOfBeatmapsCurrentlyBeingLoaded) == 0) { _settings.Add(_names.LoadingRawBeatmaps.Name, false); } if (fsArgs.ChangeType == WatcherChangeTypes.Changed && lastMapSearchArgs != null) { var l = lastMapSearchArgs; NewOsuEvent?.Invoke(this, new MapSearchArgs($"OsuMemory-FolderWatcherReplay") { Artist = beatmap.Artist, MapHash = beatmap.Md5, Title = beatmap.Title, Diff = beatmap.DiffName, EventType = OsuEventType.MapChange, PlayMode = beatmap.PlayMode, Status = l.Status, MapId = -123//bogus id to force string search }); } } Thread.Sleep(5); } } catch (ThreadAbortException) { return; } }