Separated Winforms from SearchWorker

This commit is contained in:
Justin Aquadro 2012-11-10 14:00:11 -05:00
parent e0bc93eb59
commit eb020611b1
4 changed files with 75 additions and 23 deletions

View file

@ -194,6 +194,7 @@
<Compile Include="Vendor\Be.Windows.Forms.HexBox\Util.cs" /> <Compile Include="Vendor\Be.Windows.Forms.HexBox\Util.cs" />
<Compile Include="Windows\FormHandlers.cs" /> <Compile Include="Windows\FormHandlers.cs" />
<Compile Include="Windows\NbtClipboardControllerWin.cs" /> <Compile Include="Windows\NbtClipboardControllerWin.cs" />
<Compile Include="Windows\SearchStateWin.cs" />
<EmbeddedResource Include="Windows\CancelSearchForm.resx"> <EmbeddedResource Include="Windows\CancelSearchForm.resx">
<DependentUpon>CancelSearchForm.cs</DependentUpon> <DependentUpon>CancelSearchForm.cs</DependentUpon>
</EmbeddedResource> </EmbeddedResource>

View file

@ -1,35 +1,32 @@
using System; using System;
using System.Collections.Generic; using System.Collections.Generic;
using System.Windows.Forms;
using NBTExplorer.Model; using NBTExplorer.Model;
namespace NBTExplorer namespace NBTExplorer
{ {
internal class SearchState internal interface ISearchState
{ {
public DataNode RootNode { get; set; } DataNode RootNode { get; set; }
public string SearchName { get; set; } string SearchName { get; set; }
public string SearchValue { get; set; } string SearchValue { get; set; }
public IEnumerator<DataNode> State { get; set; } IEnumerator<DataNode> State { get; set; }
public Action<DataNode> DiscoverCallback { get; set; } void InvokeDiscoverCallback (DataNode node);
public Action<DataNode> ProgressCallback { get; set; } void InvokeProgressCallback (DataNode node);
public Action<DataNode> CollapseCallback { get; set; } void InvokeCollapseCallback (DataNode node);
public Action<DataNode> EndCallback { get; set; } void InvokeEndCallback (DataNode node);
} }
internal class SearchWorker internal class SearchWorker
{ {
private ContainerControl _sender; private ISearchState _state;
private SearchState _state;
private bool _cancel; private bool _cancel;
private object _lock; private object _lock;
public SearchWorker (SearchState state, ContainerControl sender) public SearchWorker (ISearchState state)
{ {
_state = state; _state = state;
_sender = sender;
_lock = new object(); _lock = new object();
} }
@ -102,20 +99,17 @@ namespace NBTExplorer
private void InvokeDiscoverCallback (DataNode node) private void InvokeDiscoverCallback (DataNode node)
{ {
if (_sender != null && _state.DiscoverCallback != null) _state.InvokeDiscoverCallback(node);
_sender.BeginInvoke(_state.DiscoverCallback, new object[] { node });
} }
private void InvokeCollapseCallback (DataNode node) private void InvokeCollapseCallback (DataNode node)
{ {
if (_sender != null && _state.CollapseCallback != null) _state.InvokeCollapseCallback(node);
_sender.BeginInvoke(_state.CollapseCallback, new object[] { node });
} }
private void InvokeEndCallback () private void InvokeEndCallback ()
{ {
if (_sender != null && _state.EndCallback != null) _state.InvokeEndCallback(null);
_sender.BeginInvoke(_state.EndCallback, new object[] { null });
} }
} }
} }

View file

@ -470,7 +470,7 @@ namespace NBTExplorer.Windows
} }
private CancelSearchForm _searchForm; private CancelSearchForm _searchForm;
private SearchState _searchState; private SearchStateWin _searchState;
private void SearchNode (TreeNode node) private void SearchNode (TreeNode node)
{ {
@ -485,7 +485,7 @@ namespace NBTExplorer.Windows
if (form.ShowDialog() != DialogResult.OK) if (form.ShowDialog() != DialogResult.OK)
return; return;
_searchState = new SearchState() { _searchState = new SearchStateWin(this) {
RootNode = dataNode, RootNode = dataNode,
SearchName = form.NameToken, SearchName = form.NameToken,
SearchValue = form.ValueToken, SearchValue = form.ValueToken,
@ -502,7 +502,7 @@ namespace NBTExplorer.Windows
if (_searchState == null) if (_searchState == null)
return; return;
SearchWorker worker = new SearchWorker(_searchState, this); SearchWorker worker = new SearchWorker(_searchState);
Thread t = new Thread(new ThreadStart(worker.Run)); Thread t = new Thread(new ThreadStart(worker.Run));
t.IsBackground = true; t.IsBackground = true;

57
Windows/SearchStateWin.cs Normal file
View file

@ -0,0 +1,57 @@
using System;
using System.Collections.Generic;
using System.Text;
using NBTExplorer.Model;
using System.Windows.Forms;
namespace NBTExplorer.Windows
{
internal class SearchStateWin : ISearchState
{
private ContainerControl _sender;
public SearchStateWin (ContainerControl sender)
{
_sender = sender;
}
public Action<DataNode> DiscoverCallback { get; set; }
public Action<DataNode> ProgressCallback { get; set; }
public Action<DataNode> CollapseCallback { get; set; }
public Action<DataNode> EndCallback { get; set; }
#region ISearchState
public DataNode RootNode { get; set; }
public string SearchName { get; set; }
public string SearchValue { get; set; }
public IEnumerator<DataNode> State { get; set; }
public void InvokeDiscoverCallback (DataNode node)
{
if (_sender != null && DiscoverCallback != null)
_sender.BeginInvoke(DiscoverCallback, new object[] { node });
}
public void InvokeProgressCallback (DataNode node)
{
if (_sender != null && ProgressCallback != null)
_sender.BeginInvoke(ProgressCallback, new object[] { node });
}
public void InvokeCollapseCallback (DataNode node)
{
if (_sender != null && CollapseCallback != null)
_sender.BeginInvoke(CollapseCallback, new object[] { node });
}
public void InvokeEndCallback (DataNode node)
{
if (_sender != null && EndCallback != null)
_sender.BeginInvoke(EndCallback, new object[] { node });
}
#endregion
}
}