Looks like most of shuffle issues are resolved

This commit is contained in:
Théo Marchal 2022-11-11 17:57:50 +01:00
parent 06207d9791
commit 5a43a1284e
5 changed files with 152 additions and 95 deletions

View File

@ -67,7 +67,7 @@ namespace unison
private MpcConnection _commandConnection; private MpcConnection _commandConnection;
private IPEndPoint _mpdEndpoint; private IPEndPoint _mpdEndpoint;
private CancellationTokenSource _cancelCommand; public CancellationTokenSource _cancelCommand;
private CancellationTokenSource _cancelConnect; private CancellationTokenSource _cancelConnect;
public MPDHandler() public MPDHandler()

View File

@ -75,7 +75,6 @@ namespace unison.Handlers
public async Task<List<StationInfo>> AdvancedSearch(AdvancedSearchOptions options) public async Task<List<StationInfo>> AdvancedSearch(AdvancedSearchOptions options)
{ {
return await _radioBrowser.Search.AdvancedAsync(options); return await _radioBrowser.Search.AdvancedAsync(options);
} }
} }

View File

@ -1,14 +1,16 @@
using MpcNET.Commands.Database; using System;
using MpcNET.Commands.Queue;
using MpcNET.Tags;
using MpcNET.Types;
using MpcNET.Types.Filters;
using System;
using System.Collections.Generic; using System.Collections.Generic;
using System.Diagnostics; using System.Diagnostics;
using System.Linq; using System.Linq;
using System.Threading;
using System.Threading.Tasks; using System.Threading.Tasks;
using System.Windows; using System.Windows;
using MpcNET.Commands.Database;
using MpcNET.Commands.Queue;
using MpcNET.Commands.Reflection;
using MpcNET.Tags;
using MpcNET.Types;
using MpcNET.Types.Filters;
namespace unison namespace unison
{ {
@ -24,109 +26,129 @@ namespace unison
_mpd = (MPDHandler)Application.Current.Properties["mpd"]; _mpd = (MPDHandler)Application.Current.Properties["mpd"];
} }
private bool IsOnMainThread() /*private bool IsOnMainThread()
{ {
return Application.Current.Dispatcher.Thread == System.Threading.Thread.CurrentThread; return Application.Current.Dispatcher.Thread == System.Threading.Thread.CurrentThread;
} }*/
public async Task GetSongsFromFilter(List<IFilter> filter) public async Task GetSongsFromFilter(List<IFilter> filter, CancellationToken token)
{ {
Debug.WriteLine("[GetSongsFromFilterBefore] is on main thread => " + IsOnMainThread()); //Debug.WriteLine("[GetSongsFromFilterBefore] is on main thread => " + IsOnMainThread());
await Task.Run(async() => //await Task.Run(async() =>
//{
//Debug.WriteLine("[GetSongsFromFilterAfter] is on main thread => " + IsOnMainThread());
if (token.IsCancellationRequested)
return;
_songList.Clear();
int song = _mpd.GetStats().Songs;
Debug.WriteLine("before search command / song == " + song);
//var response = await Task.Run(async () =>
//{
/*return*/ IEnumerable<IMpdFile> response = await _mpd.SafelySendCommandAsync(new SearchCommand(filter, 0, song + 1));
//});
Debug.WriteLine("got response => " + response.Count());
foreach (IMpdFile file in response)
{ {
Debug.WriteLine("[GetSongsFromFilterAfter] is on main thread => " + IsOnMainThread()); _songList.Add(file.Path);
//Debug.WriteLine(file.Path);
_songList.Clear(); }
int song = _mpd.GetStats().Songs; //});
IEnumerable<IMpdFile> response = await _mpd.SafelySendCommandAsync(new SearchCommand(filter, 0, song + 1));
Debug.WriteLine("got response => " + response.Count());
foreach (IMpdFile file in response)
{
_songList.Add(file.Path);
Debug.WriteLine(file.Path);
}
});
} }
public async Task AddToQueueRandom(int SongNumber) public async Task AddToQueueRandom(int SongNumber, CancellationToken token)
{ {
Debug.WriteLine("Add To Queue Random"); Debug.WriteLine("Add To Queue Random");
await Task.Run(async () => if (token.IsCancellationRequested)
return;
//await Task.Run(async () =>
//{
int AddedSongs = 0;
Debug.WriteLine("song to add => " + SongNumber);
for (int i = 0; i < SongNumber; i++)
{ {
int AddedSongs = 0; // generate random number
int song = new Random().Next(0, _mpd.GetStats().Songs - 1);
Debug.WriteLine("song " + song + " - song total " + _mpd.GetStats().Songs);
IEnumerable<IMpdFile> Response = await _mpd.SafelySendCommandAsync(new SearchCommand(new FilterTag(MpdTags.Title, "", FilterOperator.Contains), song, song + 1));
Debug.WriteLine("song to add => " + SongNumber); Debug.WriteLine("got response");
for (int i = 0; i < SongNumber; i++)
await Task.Delay(1);
if (Response.Count() > 0)
{ {
// generate random number string filePath = Response.First().Path;
int song = new Random().Next(0, _mpd.GetStats().Songs - 1); _mpd.AddSong(filePath);
Debug.WriteLine("song " + song + " - song total " + _mpd.GetStats().Songs); Debug.WriteLine("song path => " + filePath);
IEnumerable<IMpdFile> Response = await _mpd.SafelySendCommandAsync(new SearchCommand(new FilterTag(MpdTags.Title, "", FilterOperator.Contains), song, song + 1));
Debug.WriteLine("got response"); if (i == 0)
await Task.Delay(1);
if (Response.Count() > 0)
{ {
string filePath = Response.First().Path; if (!_mpd.IsPlaying())
_mpd.AddSong(filePath); _mpd.Play(0);
Debug.WriteLine("song path => " + filePath);
if (i == 0)
{
if (!_mpd.IsPlaying())
_mpd.Play(0);
}
AddedSongs++;
} }
AddedSongs++;
} }
}); }
//});
Debug.WriteLine("Add To Queue Random - finished"); Debug.WriteLine("Add To Queue Random - finished");
} }
public async Task AddToQueueFilter(int SongNumber) public async Task AddToQueueFilter(int SongNumber, CancellationToken token)
{ {
Debug.WriteLine("Add To Queue Filter"); Debug.WriteLine("Add To Queue Filter");
await Task.Run(async () => if (token.IsCancellationRequested)
return;
//await Task.Run(async () =>
//{
int AddedSongs = 0;
Debug.WriteLine("song to add => " + SongNumber);
// more requested songs than available => add everything
if (SongNumber > _songList.Count)
{ {
int AddedSongs = 0; var commandList = new CommandList();
Debug.WriteLine("song to add => " + SongNumber); foreach (string path in _songList)
// more requested songs than available => add everything
if (SongNumber > _songList.Count)
{ {
foreach (string path in _songList) commandList.Add(new AddCommand(path));
{ AddedSongs++;
await Task.Delay(1);
_mpd.AddSong(path);
Debug.WriteLine("song path => " + path);
AddedSongs++;
}
} }
// more available songs than requested => Trace.WriteLine("Added " + AddedSongs + " songs");
// we add unique indexes until we reach the requested amount await _mpd.SafelySendCommandAsync(commandList);
else }
// more available songs than requested =>
// we add unique indexes until we reach the requested amount
else
{
HashSet<int> SongIndex = new();
Debug.WriteLine("while - before");
while (SongIndex.Count < SongNumber)//_songList.Count - 1)//SongNumber)
{ {
HashSet<int> SongIndex = new(); int MaxIndex = new Random().Next(0, _songList.Count - 1);
Debug.WriteLine("while - before"); SongIndex.Add(MaxIndex);
while (SongIndex.Count < SongNumber) }
{ Debug.WriteLine("while - middle");
int MaxIndex = new Random().Next(0, _songList.Count - 1); var commandList = new CommandList();
SongIndex.Add(MaxIndex);
}
foreach (int index in SongIndex) foreach (int index in SongIndex)
_mpd.AddSong(_songList[index]); commandList.Add(new AddCommand(_songList[index]));
Debug.WriteLine("while - after"); await _mpd.SafelySendCommandAsync(commandList);
} //_mpd.AddSong(_songList[index]);
}); Debug.WriteLine("while - after");
}
//});
Debug.WriteLine("Add To Queue Filter - finished"); Debug.WriteLine("Add To Queue Filter - finished");
} }

View File

@ -14,6 +14,7 @@ using System.Windows.Media;
using System.Linq; using System.Linq;
using System.Windows.Input; using System.Windows.Input;
using System.Text.RegularExpressions; using System.Text.RegularExpressions;
using System.Threading;
namespace unison namespace unison
{ {
@ -40,15 +41,18 @@ namespace unison
public void Initialize() public void Initialize()
{ {
ListGenre(); ListGenre(_mpd._cancelCommand.Token);
ListFolder(); ListFolder(_mpd._cancelCommand.Token);
} }
public async void ListGenre() public async void ListGenre(CancellationToken token)
{ {
if (_genreList.Count != 0) if (_genreList.Count != 0)
return; return;
if (token.IsCancellationRequested)
return;
List<string> Response = await _mpd.SafelySendCommandAsync(new ListCommand(MpdTags.Genre, null, null)); List<string> Response = await _mpd.SafelySendCommandAsync(new ListCommand(MpdTags.Genre, null, null));
if (Response == null) if (Response == null)
@ -58,11 +62,14 @@ namespace unison
_genreList.Add(genre); _genreList.Add(genre);
} }
public async void ListFolder() public async void ListFolder(CancellationToken token)
{ {
if (_folderList.Count != 0) if (_folderList.Count != 0)
return; return;
if (token.IsCancellationRequested)
return;
IEnumerable<IMpdFilePath> Response = await _mpd.SafelySendCommandAsync(new LsInfoCommand("")); IEnumerable<IMpdFilePath> Response = await _mpd.SafelySendCommandAsync(new LsInfoCommand(""));
if (Response == null) if (Response == null)
@ -92,10 +99,10 @@ namespace unison
helper.EnsureHandle(); helper.EnsureHandle();
} }
private bool IsOnMainThread() /*private bool IsOnMainThread()
{ {
return App.Current.Dispatcher.Thread == System.Threading.Thread.CurrentThread; return App.Current.Dispatcher.Thread == System.Threading.Thread.CurrentThread;
} }*/
private T FindParent<T>(DependencyObject child) where T : DependencyObject private T FindParent<T>(DependencyObject child) where T : DependencyObject
{ {
@ -170,7 +177,7 @@ namespace unison
_filters.Clear(); _filters.Clear();
Debug.WriteLine("is on main thread => " + IsOnMainThread()); //Debug.WriteLine("is on main thread => " + IsOnMainThread());
foreach (ContentPresenter superChild in FilterPanel.Children) foreach (ContentPresenter superChild in FilterPanel.Children)
{ {
@ -179,12 +186,17 @@ namespace unison
string value = ""; string value = "";
bool isDir = false; bool isDir = false;
Debug.WriteLine("update filter => part 1");
StackPanel stackPanel = VisualTreeHelper.GetChild(superChild, 0) as StackPanel; StackPanel stackPanel = VisualTreeHelper.GetChild(superChild, 0) as StackPanel;
foreach (TextBox child in stackPanel.Children.OfType<TextBox>()) foreach (TextBox child in stackPanel.Children.OfType<TextBox>())
{ {
if (child.Name == "FilterValue") if (child.Name == "FilterValue")
value = child.Text; value = child.Text;
} }
Debug.WriteLine("update filter => part 2");
foreach (ComboBox child in stackPanel.Children.OfType<ComboBox>()) foreach (ComboBox child in stackPanel.Children.OfType<ComboBox>())
{ {
if (child.Name == "FilterType") if (child.Name == "FilterType")
@ -202,6 +214,8 @@ namespace unison
value = child.SelectedItem.ToString(); value = child.SelectedItem.ToString();
} }
Debug.WriteLine("update filter => part 3");
if (value != "") if (value != "")
{ {
if (!isDir) if (!isDir)
@ -209,10 +223,15 @@ namespace unison
else else
_filters.Add(new FilterBase(value, FilterOperator.None)); _filters.Add(new FilterBase(value, FilterOperator.None));
await _shuffle.GetSongsFromFilter(_filters); await Task.Run(async () =>
{
await _shuffle.GetSongsFromFilter(_filters, _mpd._cancelCommand.Token);
});
SongFilterPanel.Visibility = Visibility.Visible; SongFilterPanel.Visibility = Visibility.Visible;
SongFilterNumber.Text = _shuffle._songList.Count.ToString(); SongFilterNumber.Text = _shuffle._songList.Count.ToString();
} }
Debug.WriteLine("update filter => part 4");
} }
Debug.WriteLine("update filter => stop"); Debug.WriteLine("update filter => stop");
@ -309,6 +328,8 @@ namespace unison
// start dispatcher // start dispatcher
// write _shuffle.AddedSongs in dispatcher // write _shuffle.AddedSongs in dispatcher
await UpdateFilter();
await AddToQueue(int.Parse(SongNumber.Text)); await AddToQueue(int.Parse(SongNumber.Text));
Debug.WriteLine("add to queue finished"); Debug.WriteLine("add to queue finished");
@ -318,16 +339,24 @@ namespace unison
private async Task AddToQueue(int NumberToAdd) private async Task AddToQueue(int NumberToAdd)
{ {
await UpdateFilter(); //await UpdateFilter();
Debug.WriteLine("check filters"); Debug.WriteLine("check filters");
if (IsFilterEmpty()) if (IsFilterEmpty())
await _shuffle.AddToQueueRandom(NumberToAdd); {
await Task.Run(async () =>
{
await _shuffle.AddToQueueRandom(NumberToAdd, _mpd._cancelCommand.Token);
});
}
else else
{ {
Debug.WriteLine("add to queue filter - before"); Debug.WriteLine("add to queue filter - before");
await _shuffle.AddToQueueFilter(NumberToAdd); await Task.Run(async () =>
{
await _shuffle.AddToQueueFilter(NumberToAdd, _mpd._cancelCommand.Token);
});
Debug.WriteLine("add to queue filter - after"); Debug.WriteLine("add to queue filter - after");
} }
@ -348,7 +377,11 @@ namespace unison
} }
Debug.WriteLine("continuous __before__ add to queue"); Debug.WriteLine("continuous __before__ add to queue");
await AddToQueue(5); await UpdateFilter();
await Task.Run(async () =>
{
await AddToQueue(5);
});
Debug.WriteLine("continuous __after__ add to queue"); Debug.WriteLine("continuous __after__ add to queue");
} }
@ -359,7 +392,10 @@ namespace unison
else else
_continuous = false; _continuous = false;
if (_mpd.GetStatus().PlaylistLength < 5) int Length = _mpd.GetStatus().PlaylistLength;
Trace.WriteLine("Length is " + Length);
if (/*_mpd.GetStatus().PlaylistLength*/Length < 5)
await HandleContinuous(); await HandleContinuous();
} }
} }

View File

@ -7,7 +7,7 @@
<ApplicationIcon>Resources\icon-full.ico</ApplicationIcon> <ApplicationIcon>Resources\icon-full.ico</ApplicationIcon>
<Win32Resource></Win32Resource> <Win32Resource></Win32Resource>
<StartupObject>unison.App</StartupObject> <StartupObject>unison.App</StartupObject>
<Version>1.3.1</Version> <Version>1.4</Version>
<Company /> <Company />
<Authors>Théo Marchal</Authors> <Authors>Théo Marchal</Authors>
<PackageLicenseFile>LICENSE</PackageLicenseFile> <PackageLicenseFile>LICENSE</PackageLicenseFile>