diff --git a/NBTExplorer.csproj b/NBTExplorer.csproj
index 5c1d29d..298bba1 100644
--- a/NBTExplorer.csproj
+++ b/NBTExplorer.csproj
@@ -194,6 +194,7 @@
+
CancelSearchForm.cs
diff --git a/SearchWorker.cs b/SearchWorker.cs
index b424e79..ae2238c 100644
--- a/SearchWorker.cs
+++ b/SearchWorker.cs
@@ -1,35 +1,32 @@
using System;
using System.Collections.Generic;
-using System.Windows.Forms;
using NBTExplorer.Model;
namespace NBTExplorer
{
- internal class SearchState
+ internal interface ISearchState
{
- public DataNode RootNode { get; set; }
- public string SearchName { get; set; }
- public string SearchValue { get; set; }
+ DataNode RootNode { get; set; }
+ string SearchName { get; set; }
+ string SearchValue { get; set; }
- public IEnumerator State { get; set; }
+ IEnumerator State { get; set; }
- public Action DiscoverCallback { get; set; }
- public Action ProgressCallback { get; set; }
- public Action CollapseCallback { get; set; }
- public Action EndCallback { get; set; }
+ void InvokeDiscoverCallback (DataNode node);
+ void InvokeProgressCallback (DataNode node);
+ void InvokeCollapseCallback (DataNode node);
+ void InvokeEndCallback (DataNode node);
}
internal class SearchWorker
{
- private ContainerControl _sender;
- private SearchState _state;
+ private ISearchState _state;
private bool _cancel;
private object _lock;
- public SearchWorker (SearchState state, ContainerControl sender)
+ public SearchWorker (ISearchState state)
{
_state = state;
- _sender = sender;
_lock = new object();
}
@@ -102,20 +99,17 @@ namespace NBTExplorer
private void InvokeDiscoverCallback (DataNode node)
{
- if (_sender != null && _state.DiscoverCallback != null)
- _sender.BeginInvoke(_state.DiscoverCallback, new object[] { node });
+ _state.InvokeDiscoverCallback(node);
}
private void InvokeCollapseCallback (DataNode node)
{
- if (_sender != null && _state.CollapseCallback != null)
- _sender.BeginInvoke(_state.CollapseCallback, new object[] { node });
+ _state.InvokeCollapseCallback(node);
}
private void InvokeEndCallback ()
{
- if (_sender != null && _state.EndCallback != null)
- _sender.BeginInvoke(_state.EndCallback, new object[] { null });
+ _state.InvokeEndCallback(null);
}
}
}
diff --git a/Windows/MainForm.cs b/Windows/MainForm.cs
index 5580722..968bfcb 100644
--- a/Windows/MainForm.cs
+++ b/Windows/MainForm.cs
@@ -470,7 +470,7 @@ namespace NBTExplorer.Windows
}
private CancelSearchForm _searchForm;
- private SearchState _searchState;
+ private SearchStateWin _searchState;
private void SearchNode (TreeNode node)
{
@@ -485,7 +485,7 @@ namespace NBTExplorer.Windows
if (form.ShowDialog() != DialogResult.OK)
return;
- _searchState = new SearchState() {
+ _searchState = new SearchStateWin(this) {
RootNode = dataNode,
SearchName = form.NameToken,
SearchValue = form.ValueToken,
@@ -502,7 +502,7 @@ namespace NBTExplorer.Windows
if (_searchState == null)
return;
- SearchWorker worker = new SearchWorker(_searchState, this);
+ SearchWorker worker = new SearchWorker(_searchState);
Thread t = new Thread(new ThreadStart(worker.Run));
t.IsBackground = true;
diff --git a/Windows/SearchStateWin.cs b/Windows/SearchStateWin.cs
new file mode 100644
index 0000000..8a15581
--- /dev/null
+++ b/Windows/SearchStateWin.cs
@@ -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 DiscoverCallback { get; set; }
+ public Action ProgressCallback { get; set; }
+ public Action CollapseCallback { get; set; }
+ public Action EndCallback { get; set; }
+
+ #region ISearchState
+
+ public DataNode RootNode { get; set; }
+ public string SearchName { get; set; }
+ public string SearchValue { get; set; }
+
+ public IEnumerator 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
+ }
+}