Ready for search and replace beta release (no replace-all yet)

This commit is contained in:
Justin Aquadro 2013-08-10 02:11:04 -04:00
parent 152213e2cf
commit db1662dc9b
15 changed files with 380 additions and 116 deletions

View file

@ -62,12 +62,6 @@ namespace NBTExplorer.Controllers
public string VirtualRootDisplay public string VirtualRootDisplay
{ {
get { return _rootData.NodeDisplay; } get { return _rootData.NodeDisplay; }
/*set
{
_rootData.SetDisplayName(value);
if (ShowVirtualRoot && _nodeTree.Nodes.Count > 0)
UpdateNodeText(_nodeTree.Nodes[0]);
}*/
} }
public void DeleteSelection () public void DeleteSelection ()
@ -80,25 +74,20 @@ namespace NBTExplorer.Controllers
if (node == null || !(node.Tag is SearchRule)) if (node == null || !(node.Tag is SearchRule))
return; return;
SearchRule dataNode = node.Tag as SearchRule; TreeNode parent = node.Parent;
//if (!dataNode.CanDeleteNode) if (parent == null || !(parent.Tag is GroupRule))
// return; return;
/*if (dataNode.DeleteNode()) { GroupRule parentData = parent.Tag as GroupRule;
UpdateNodeText(node.Parent); SearchRule nodeData = node.Tag as SearchRule;
node.Remove();
RemoveNodeFromSelection(node); parentData.Rules.Remove(nodeData);
OnSelectionInvalidated(); parent.Nodes.Remove(node);
}*/
} }
private TreeNode SelectedNode private TreeNode SelectedNode
{ {
get get { return _nodeTree.SelectedNode; }
{
return _nodeTree.SelectedNode;
}
} }
private TreeNode CreateIntegralNode<T, K> (string typeName) private TreeNode CreateIntegralNode<T, K> (string typeName)
@ -125,6 +114,26 @@ namespace NBTExplorer.Controllers
return node; return node;
} }
private void EditIntegralNode<T, K> (TreeNode node, T rule, string typeName)
where K : TagNode
where T : IntegralTagRule<K>
{
using (ValueRuleForm form = new ValueRuleForm(SearchRule.NumericOpStrings) {
Text = "Edit " + typeName + " Tag Rule",
TagName = rule.Name,
TagValue = rule.Value.ToString(),
Operator = rule.Operator,
}) {
if (form.ShowDialog() == DialogResult.OK) {
rule.Name = form.TagName;
rule.Value = form.TagValueAsLong;
rule.Operator = form.Operator;
}
}
node.Text = rule.NodeDisplay;
}
private TreeNode CreateFloatNode<T, K> (string typeName) private TreeNode CreateFloatNode<T, K> (string typeName)
where K : TagNode where K : TagNode
where T : FloatTagRule<K>, new() where T : FloatTagRule<K>, new()
@ -149,6 +158,26 @@ namespace NBTExplorer.Controllers
return node; return node;
} }
private void EditFloatNode<T, K> (TreeNode node, T rule, string typeName)
where K : TagNode
where T : FloatTagRule<K>
{
using (ValueRuleForm form = new ValueRuleForm(SearchRule.NumericOpStrings) {
Text = "Edit " + typeName + " Tag Rule",
TagName = rule.Name,
TagValue = rule.Value.ToString(),
Operator = rule.Operator,
}) {
if (form.ShowDialog() == DialogResult.OK) {
rule.Name = form.TagName;
rule.Value = form.TagValueAsDouble;
rule.Operator = form.Operator;
}
}
node.Text = rule.NodeDisplay;
}
private TreeNode CreateStringNode (string typeName) private TreeNode CreateStringNode (string typeName)
{ {
StringTagRule rule = new StringTagRule(); StringTagRule rule = new StringTagRule();
@ -171,6 +200,24 @@ namespace NBTExplorer.Controllers
return node; return node;
} }
private void EditStringNode (TreeNode node, StringTagRule rule, string typeName)
{
using (StringRuleForm form = new StringRuleForm(SearchRule.StringOpStrings) {
Text = "Edit " + typeName + " Tag Rule",
TagName = rule.Name,
TagValue = rule.Value,
Operator = rule.Operator,
}) {
if (form.ShowDialog() == DialogResult.OK) {
rule.Name = form.TagName;
rule.Value = form.TagValue;
rule.Operator = form.Operator;
}
}
node.Text = rule.NodeDisplay;
}
private TreeNode CreateWildcardNode (string typeName) private TreeNode CreateWildcardNode (string typeName)
{ {
WildcardRule rule = new WildcardRule(); WildcardRule rule = new WildcardRule();
@ -193,6 +240,24 @@ namespace NBTExplorer.Controllers
return node; return node;
} }
private void EditWildcardNode (TreeNode node, WildcardRule rule, string typeName)
{
using (WildcardRuleForm form = new WildcardRuleForm(SearchRule.WildcardOpStrings) {
Text = "Edit " + typeName + " Rule",
TagName = rule.Name,
TagValue = rule.Value,
Operator = rule.Operator,
}) {
if (form.ShowDialog() == DialogResult.OK) {
rule.Name = form.TagName;
rule.Value = form.TagValue;
rule.Operator = form.Operator;
}
}
node.Text = rule.NodeDisplay;
}
public void CreateNode (TreeNode node, TagType type) public void CreateNode (TreeNode node, TagType type)
{ {
if (node == null || !(node.Tag is GroupRule)) if (node == null || !(node.Tag is GroupRule))
@ -231,12 +296,39 @@ namespace NBTExplorer.Controllers
node.Expand(); node.Expand();
} }
}
/*if (dataNode.CreateNode(type)) { public void EditNode (TreeNode node)
node.Text = dataNode.NodeDisplay; {
RefreshChildNodes(node, dataNode); if (node == null || !(node.Tag is SearchRule))
OnSelectionInvalidated(); return;
}*/
SearchRule rule = node.Tag as SearchRule;
if (rule is ByteTagRule)
EditIntegralNode<ByteTagRule, TagNodeByte>(node, rule as ByteTagRule, "Byte");
else if (rule is ShortTagRule)
EditIntegralNode<ShortTagRule, TagNodeShort>(node, rule as ShortTagRule, "Short");
else if (rule is IntTagRule)
EditIntegralNode<IntTagRule, TagNodeInt>(node, rule as IntTagRule, "Int");
else if (rule is LongTagRule)
EditIntegralNode<LongTagRule, TagNodeLong>(node, rule as LongTagRule, "Long");
else if (rule is FloatTagRule)
EditFloatNode<FloatTagRule, TagNodeFloat>(node, rule as FloatTagRule, "Float");
else if (rule is DoubleTagRule)
EditFloatNode<DoubleTagRule, TagNodeDouble>(node, rule as DoubleTagRule, "Double");
else if (rule is StringTagRule)
EditStringNode(node, rule as StringTagRule, "String");
else if (rule is WildcardRule)
EditWildcardNode(node, rule as WildcardRule, "Wildcard");
}
public void EditSelection ()
{
if (_nodeTree.SelectedNode == null)
return;
EditNode(_nodeTree.SelectedNode);
} }
public void CreateWildcardNode (TreeNode node) public void CreateWildcardNode (TreeNode node)

View file

@ -41,6 +41,11 @@ namespace NBTExplorer.Model
get { return !IsExpanded; } get { return !IsExpanded; }
} }
public override string NodePathName
{
get { return Path.GetFileName(_path); }
}
public override string NodeDisplay public override string NodeDisplay
{ {
get { return Path.GetFileName(_path); } get { return Path.GetFileName(_path); }

View file

@ -174,6 +174,22 @@ namespace NBTExplorer.Model
get { return ""; } get { return ""; }
} }
public string NodePath
{
get {
string name = NodePathName;
if (string.IsNullOrEmpty(name))
name = "*";
return (Parent != null) ? Parent.NodePath + '/' + name : '/' + name;
}
}
public virtual string NodePathName
{
get { return NodeName; }
}
public virtual string NodeDisplay public virtual string NodeDisplay
{ {
get { return ""; } get { return ""; }

View file

@ -1,5 +1,6 @@
using System.IO; using System.IO;
using System.Collections.Generic; using System.Collections.Generic;
using System;
namespace NBTExplorer.Model namespace NBTExplorer.Model
{ {
@ -21,6 +22,17 @@ namespace NBTExplorer.Model
} }
} }
public override string NodePathName
{
get
{
string name = Path.GetDirectoryName(_path);
int sepIndex = Math.Max(name.LastIndexOf('/'), name.LastIndexOf('\\'));
return (sepIndex > 0) ? name.Substring(sepIndex + 1) : name;
}
}
public override string NodeDisplay public override string NodeDisplay
{ {
get { return Path.GetFileName(_path); } get { return Path.GetFileName(_path); }

View file

@ -70,6 +70,11 @@ namespace NBTExplorer.Model
get { return Path.GetFileName(_path); } get { return Path.GetFileName(_path); }
} }
public override string NodePathName
{
get { return Path.GetFileName(_path); }
}
public override string NodeDisplay public override string NodeDisplay
{ {
get get

View file

@ -36,6 +36,11 @@ namespace NBTExplorer.Model
get { return !IsExpanded; } get { return !IsExpanded; }
} }
public override string NodePathName
{
get { return _x + "." + _z; }
}
public override string NodeDisplay public override string NodeDisplay
{ {
get { return "Chunk [" + _x + ", " + _z + "]"; } get { return "Chunk [" + _x + ", " + _z + "]"; }

View file

@ -42,6 +42,11 @@ namespace NBTExplorer.Model
get { return !IsExpanded; } get { return !IsExpanded; }
} }
public override string NodePathName
{
get { return Path.GetFileName(_path); }
}
public override string NodeDisplay public override string NodeDisplay
{ {
get { return Path.GetFileName(_path); } get { return Path.GetFileName(_path); }

View file

@ -170,13 +170,31 @@ namespace NBTExplorer.Model.Search
TagDataNode childNode = GetChild(container, Name); TagDataNode childNode = GetChild(container, Name);
T data = LookupTag<T>(container, Name); T data = LookupTag<T>(container, Name);
if (data != null && data.ToTagLong() == Value) { if (data != null) {
if (!matchedNodes.Contains(childNode)) switch (Operator) {
matchedNodes.Add(childNode); case NumericOperator.Equals:
return true; if (data.ToTagLong() != Value)
return false;
break;
case NumericOperator.NotEquals:
if (data.ToTagLong() == Value)
return false;
break;
case NumericOperator.GreaterThan:
if (data.ToTagLong() <= Value)
return false;
break;
case NumericOperator.LessThan:
if (data.ToTagLong() >= Value)
return false;
break;
}
} }
return false; if (!matchedNodes.Contains(childNode))
matchedNodes.Add(childNode);
return true;
} }
} }
@ -209,13 +227,31 @@ namespace NBTExplorer.Model.Search
TagDataNode childNode = GetChild(container, Name); TagDataNode childNode = GetChild(container, Name);
T data = LookupTag<T>(container, Name); T data = LookupTag<T>(container, Name);
if (data != null && data.ToTagDouble() == Value) { if (data != null) {
if (!matchedNodes.Contains(childNode)) switch (Operator) {
matchedNodes.Add(childNode); case NumericOperator.Equals:
return true; if (data.ToTagDouble() != Value)
return false;
break;
case NumericOperator.NotEquals:
if (data.ToTagDouble() == Value)
return false;
break;
case NumericOperator.GreaterThan:
if (data.ToTagDouble() <= Value)
return false;
break;
case NumericOperator.LessThan:
if (data.ToTagDouble() >= Value)
return false;
break;
}
} }
return false; if (!matchedNodes.Contains(childNode))
matchedNodes.Add(childNode);
return true;
} }
} }
@ -241,13 +277,39 @@ namespace NBTExplorer.Model.Search
TagDataNode childNode = GetChild(container, Name); TagDataNode childNode = GetChild(container, Name);
TagNodeString data = LookupTag<TagNodeString>(container, Name); TagNodeString data = LookupTag<TagNodeString>(container, Name);
if (data != null && data.ToTagString() == Value) { if (data != null) {
if (!matchedNodes.Contains(childNode)) switch (Operator) {
matchedNodes.Add(childNode); case StringOperator.Equals:
return true; if (data.ToTagString().Data != Value)
return false;
break;
case StringOperator.NotEquals:
if (data.ToTagString().Data == Value)
return false;
break;
case StringOperator.Contains:
if (!data.ToTagString().Data.Contains(Value))
return false;
break;
case StringOperator.NotContains:
if (data.ToTagString().Data.Contains(Value))
return false;
break;
case StringOperator.StartsWith:
if (!data.ToTagString().Data.StartsWith(Value))
return false;
break;
case StringOperator.EndsWith:
if (!data.ToTagString().Data.EndsWith(Value))
return false;
break;
}
} }
return false; if (!matchedNodes.Contains(childNode))
matchedNodes.Add(childNode);
return true;
} }
} }
@ -276,27 +338,51 @@ namespace NBTExplorer.Model.Search
case TagType.TAG_INT: case TagType.TAG_INT:
case TagType.TAG_LONG: case TagType.TAG_LONG:
case TagType.TAG_SHORT: case TagType.TAG_SHORT:
if (long.Parse(Value) == tag.ToTagLong()) { switch (Operator) {
if (!matchedNodes.Contains(childNode)) case WildcardOperator.Equals:
matchedNodes.Add(childNode); if (long.Parse(Value) != tag.ToTagLong())
return true; return false;
break;
case WildcardOperator.NotEquals:
if (long.Parse(Value) == tag.ToTagLong())
return false;
break;
} }
break;
if (!matchedNodes.Contains(childNode))
matchedNodes.Add(childNode);
return true;
case TagType.TAG_FLOAT: case TagType.TAG_FLOAT:
case TagType.TAG_DOUBLE: case TagType.TAG_DOUBLE:
if (double.Parse(Value) == tag.ToTagDouble()) { switch (Operator) {
if (!matchedNodes.Contains(childNode)) case WildcardOperator.Equals:
matchedNodes.Add(childNode); if (double.Parse(Value) != tag.ToTagDouble())
return true; return false;
break;
case WildcardOperator.NotEquals:
if (double.Parse(Value) == tag.ToTagDouble())
return false;
break;
} }
break;
if (!matchedNodes.Contains(childNode))
matchedNodes.Add(childNode);
return true;
case TagType.TAG_STRING: case TagType.TAG_STRING:
if (Value == tag.ToTagString()) { switch (Operator) {
if (!matchedNodes.Contains(childNode)) case WildcardOperator.Equals:
matchedNodes.Add(childNode); if (Value != tag.ToTagString().Data)
return true; return false;
break;
case WildcardOperator.NotEquals:
if (Value == tag.ToTagString().Data)
return false;
break;
} }
break;
if (!matchedNodes.Contains(childNode))
matchedNodes.Add(childNode);
return true;
} }
} }
catch { } catch { }

View file

@ -194,6 +194,20 @@ namespace NBTExplorer.Model
} }
} }
public override string NodePathName
{
get
{
if (Parent is TagDataNode.Container) {
TagDataNode.Container container = Parent as TagDataNode.Container;
if (container.IsOrderedContainer)
return container.OrderedTagContainer.GetTagIndex(Tag).ToString();
}
return base.NodePathName;
}
}
protected string NodeDisplayPrefix protected string NodeDisplayPrefix
{ {
get get

View file

@ -32,5 +32,5 @@ using System.Runtime.InteropServices;
// You can specify all the values or you can default the Build and Revision Numbers // You can specify all the values or you can default the Build and Revision Numbers
// by using the '*' as shown below: // by using the '*' as shown below:
// [assembly: AssemblyVersion("1.0.*")] // [assembly: AssemblyVersion("1.0.*")]
[assembly: AssemblyVersion("2.4.0.0")] [assembly: AssemblyVersion("2.5.0.0")]
[assembly: AssemblyFileVersion("2.4.0.0")] [assembly: AssemblyFileVersion("2.5.0.0")]

View file

@ -1,6 +1,7 @@
using System; using System;
using System.Collections.Generic; using System.Collections.Generic;
using NBTExplorer.Model; using NBTExplorer.Model;
using System.Diagnostics;
namespace NBTExplorer namespace NBTExplorer
{ {
@ -11,6 +12,8 @@ namespace NBTExplorer
IEnumerator<DataNode> State { get; set; } IEnumerator<DataNode> State { get; set; }
bool TerminateOnDiscover { get; set; } bool TerminateOnDiscover { get; set; }
float ProgressRate { get; set; }
void InvokeDiscoverCallback (DataNode node); void InvokeDiscoverCallback (DataNode node);
void InvokeProgressCallback (DataNode node); void InvokeProgressCallback (DataNode node);
void InvokeCollapseCallback (DataNode node); void InvokeCollapseCallback (DataNode node);
@ -27,6 +30,7 @@ namespace NBTExplorer
public DataNode RootNode { get; set; } public DataNode RootNode { get; set; }
public IEnumerator<DataNode> State { get; set; } public IEnumerator<DataNode> State { get; set; }
public bool TerminateOnDiscover { get; set; } public bool TerminateOnDiscover { get; set; }
public float ProgressRate { get; set; }
public abstract void InvokeDiscoverCallback (DataNode node); public abstract void InvokeDiscoverCallback (DataNode node);
public abstract void InvokeProgressCallback (DataNode node); public abstract void InvokeProgressCallback (DataNode node);
@ -36,6 +40,7 @@ namespace NBTExplorer
protected NameValueSearchState () protected NameValueSearchState ()
{ {
TerminateOnDiscover = true; TerminateOnDiscover = true;
ProgressRate = .5f;
} }
public bool TestNode (DataNode node) public bool TestNode (DataNode node)
@ -68,6 +73,10 @@ namespace NBTExplorer
private bool _cancel; private bool _cancel;
private object _lock; private object _lock;
private Stopwatch _progressWatch;
private float _progressTime;
private float _lastSampleTime;
public SearchWorker (ISearchState state) public SearchWorker (ISearchState state)
{ {
_state = state; _state = state;
@ -83,11 +92,16 @@ namespace NBTExplorer
public void Run () public void Run ()
{ {
_progressWatch = new Stopwatch();
_progressWatch.Start();
if (_state.State == null) if (_state.State == null)
_state.State = FindNode(_state.RootNode).GetEnumerator(); _state.State = FindNode(_state.RootNode).GetEnumerator();
if (!_state.State.MoveNext()) if (!_state.State.MoveNext())
InvokeEndCallback(); InvokeEndCallback();
_progressWatch.Stop();
} }
private IEnumerable<DataNode> FindNode (DataNode node) private IEnumerable<DataNode> FindNode (DataNode node)
@ -108,7 +122,14 @@ namespace NBTExplorer
TagDataNode tagNode = node as TagDataNode; TagDataNode tagNode = node as TagDataNode;
if (tagNode != null) { if (tagNode != null) {
InvokeProgressCallback(node); float currentSampleTime = (float)_progressWatch.Elapsed.TotalSeconds;
_progressTime += (currentSampleTime - _lastSampleTime);
_lastSampleTime = currentSampleTime;
if (_progressTime > _state.ProgressRate) {
InvokeProgressCallback(node);
_progressTime -= _state.ProgressRate;
}
if (_state.TestNode(tagNode)) { if (_state.TestNode(tagNode)) {
InvokeDiscoverCallback(node); InvokeDiscoverCallback(node);

View file

@ -34,7 +34,7 @@
// _buttonCancel // _buttonCancel
// //
this._buttonCancel.DialogResult = System.Windows.Forms.DialogResult.Cancel; this._buttonCancel.DialogResult = System.Windows.Forms.DialogResult.Cancel;
this._buttonCancel.Location = new System.Drawing.Point(167, 57); this._buttonCancel.Location = new System.Drawing.Point(232, 45);
this._buttonCancel.Name = "_buttonCancel"; this._buttonCancel.Name = "_buttonCancel";
this._buttonCancel.Size = new System.Drawing.Size(75, 23); this._buttonCancel.Size = new System.Drawing.Size(75, 23);
this._buttonCancel.TabIndex = 0; this._buttonCancel.TabIndex = 0;
@ -45,17 +45,16 @@
// //
this._searchPathLabel.Location = new System.Drawing.Point(12, 19); this._searchPathLabel.Location = new System.Drawing.Point(12, 19);
this._searchPathLabel.Name = "_searchPathLabel"; this._searchPathLabel.Name = "_searchPathLabel";
this._searchPathLabel.Size = new System.Drawing.Size(385, 23); this._searchPathLabel.Size = new System.Drawing.Size(514, 23);
this._searchPathLabel.TabIndex = 1; this._searchPathLabel.TabIndex = 1;
this._searchPathLabel.Text = "..."; this._searchPathLabel.Text = "...";
this._searchPathLabel.TextAlign = System.Drawing.ContentAlignment.MiddleCenter;
// //
// CancelSearchForm // CancelSearchForm
// //
this.AutoScaleDimensions = new System.Drawing.SizeF(6F, 13F); this.AutoScaleDimensions = new System.Drawing.SizeF(6F, 13F);
this.AutoScaleMode = System.Windows.Forms.AutoScaleMode.Font; this.AutoScaleMode = System.Windows.Forms.AutoScaleMode.Font;
this.CancelButton = this._buttonCancel; this.CancelButton = this._buttonCancel;
this.ClientSize = new System.Drawing.Size(409, 92); this.ClientSize = new System.Drawing.Size(538, 84);
this.Controls.Add(this._searchPathLabel); this.Controls.Add(this._searchPathLabel);
this.Controls.Add(this._buttonCancel); this.Controls.Add(this._buttonCancel);
this.FormBorderStyle = System.Windows.Forms.FormBorderStyle.FixedDialog; this.FormBorderStyle = System.Windows.Forms.FormBorderStyle.FixedDialog;

View file

@ -171,7 +171,7 @@
this._tbFindEdit.ImageTransparentColor = System.Drawing.Color.Magenta; this._tbFindEdit.ImageTransparentColor = System.Drawing.Color.Magenta;
this._tbFindEdit.Name = "_tbFindEdit"; this._tbFindEdit.Name = "_tbFindEdit";
this._tbFindEdit.Size = new System.Drawing.Size(23, 22); this._tbFindEdit.Size = new System.Drawing.Size(23, 22);
this._tbFindEdit.Text = "toolStripButton1"; this._tbFindEdit.Text = "Edit Selected Rule";
this._tbFindEdit.Click += new System.EventHandler(this._tbFindEdit_Click); this._tbFindEdit.Click += new System.EventHandler(this._tbFindEdit_Click);
// //
// _tbFindDelete // _tbFindDelete
@ -181,7 +181,7 @@
this._tbFindDelete.ImageTransparentColor = System.Drawing.Color.Magenta; this._tbFindDelete.ImageTransparentColor = System.Drawing.Color.Magenta;
this._tbFindDelete.Name = "_tbFindDelete"; this._tbFindDelete.Name = "_tbFindDelete";
this._tbFindDelete.Size = new System.Drawing.Size(23, 22); this._tbFindDelete.Size = new System.Drawing.Size(23, 22);
this._tbFindDelete.Text = "toolStripButton1"; this._tbFindDelete.Text = "Delete Selected Rule";
this._tbFindDelete.Click += new System.EventHandler(this._tbFindDelete_Click); this._tbFindDelete.Click += new System.EventHandler(this._tbFindDelete_Click);
// //
// toolStripSeparator1 // toolStripSeparator1
@ -364,7 +364,7 @@
this._tbReplaceEdit.ImageTransparentColor = System.Drawing.Color.Magenta; this._tbReplaceEdit.ImageTransparentColor = System.Drawing.Color.Magenta;
this._tbReplaceEdit.Name = "_tbReplaceEdit"; this._tbReplaceEdit.Name = "_tbReplaceEdit";
this._tbReplaceEdit.Size = new System.Drawing.Size(23, 22); this._tbReplaceEdit.Size = new System.Drawing.Size(23, 22);
this._tbReplaceEdit.Text = "toolStripButton1"; this._tbReplaceEdit.Text = "Edit Selected Tag";
this._tbReplaceEdit.Click += new System.EventHandler(this._tbReplaceEdit_Click); this._tbReplaceEdit.Click += new System.EventHandler(this._tbReplaceEdit_Click);
// //
// _tbReplaceDelete // _tbReplaceDelete
@ -374,7 +374,7 @@
this._tbReplaceDelete.ImageTransparentColor = System.Drawing.Color.Magenta; this._tbReplaceDelete.ImageTransparentColor = System.Drawing.Color.Magenta;
this._tbReplaceDelete.Name = "_tbReplaceDelete"; this._tbReplaceDelete.Name = "_tbReplaceDelete";
this._tbReplaceDelete.Size = new System.Drawing.Size(23, 22); this._tbReplaceDelete.Size = new System.Drawing.Size(23, 22);
this._tbReplaceDelete.Text = "toolStripButton2"; this._tbReplaceDelete.Text = "Delete Selected Tag";
this._tbReplaceDelete.Click += new System.EventHandler(this._tbReplaceDelete_Click); this._tbReplaceDelete.Click += new System.EventHandler(this._tbReplaceDelete_Click);
// //
// toolStripSeparator2 // toolStripSeparator2
@ -389,7 +389,7 @@
this._tbReplaceByte.ImageTransparentColor = System.Drawing.Color.Magenta; this._tbReplaceByte.ImageTransparentColor = System.Drawing.Color.Magenta;
this._tbReplaceByte.Name = "_tbReplaceByte"; this._tbReplaceByte.Name = "_tbReplaceByte";
this._tbReplaceByte.Size = new System.Drawing.Size(23, 22); this._tbReplaceByte.Size = new System.Drawing.Size(23, 22);
this._tbReplaceByte.Text = "toolStripButton11"; this._tbReplaceByte.Text = "Add Byte Tag";
this._tbReplaceByte.Click += new System.EventHandler(this._tbReplaceByte_Click); this._tbReplaceByte.Click += new System.EventHandler(this._tbReplaceByte_Click);
// //
// _tbReplaceShort // _tbReplaceShort
@ -399,7 +399,7 @@
this._tbReplaceShort.ImageTransparentColor = System.Drawing.Color.Magenta; this._tbReplaceShort.ImageTransparentColor = System.Drawing.Color.Magenta;
this._tbReplaceShort.Name = "_tbReplaceShort"; this._tbReplaceShort.Name = "_tbReplaceShort";
this._tbReplaceShort.Size = new System.Drawing.Size(23, 22); this._tbReplaceShort.Size = new System.Drawing.Size(23, 22);
this._tbReplaceShort.Text = "toolStripButton12"; this._tbReplaceShort.Text = "Add Short Tag";
this._tbReplaceShort.Click += new System.EventHandler(this._tbReplaceShort_Click); this._tbReplaceShort.Click += new System.EventHandler(this._tbReplaceShort_Click);
// //
// _tbReplaceInt // _tbReplaceInt
@ -409,7 +409,7 @@
this._tbReplaceInt.ImageTransparentColor = System.Drawing.Color.Magenta; this._tbReplaceInt.ImageTransparentColor = System.Drawing.Color.Magenta;
this._tbReplaceInt.Name = "_tbReplaceInt"; this._tbReplaceInt.Name = "_tbReplaceInt";
this._tbReplaceInt.Size = new System.Drawing.Size(23, 22); this._tbReplaceInt.Size = new System.Drawing.Size(23, 22);
this._tbReplaceInt.Text = "toolStripButton13"; this._tbReplaceInt.Text = "Add Int Tag";
this._tbReplaceInt.Click += new System.EventHandler(this._tbReplaceInt_Click); this._tbReplaceInt.Click += new System.EventHandler(this._tbReplaceInt_Click);
// //
// _tbReplaceLong // _tbReplaceLong
@ -419,7 +419,7 @@
this._tbReplaceLong.ImageTransparentColor = System.Drawing.Color.Magenta; this._tbReplaceLong.ImageTransparentColor = System.Drawing.Color.Magenta;
this._tbReplaceLong.Name = "_tbReplaceLong"; this._tbReplaceLong.Name = "_tbReplaceLong";
this._tbReplaceLong.Size = new System.Drawing.Size(23, 22); this._tbReplaceLong.Size = new System.Drawing.Size(23, 22);
this._tbReplaceLong.Text = "toolStripButton14"; this._tbReplaceLong.Text = "Add Long Tag";
this._tbReplaceLong.Click += new System.EventHandler(this._tbReplaceLong_Click); this._tbReplaceLong.Click += new System.EventHandler(this._tbReplaceLong_Click);
// //
// _tbReplaceFloat // _tbReplaceFloat
@ -429,7 +429,7 @@
this._tbReplaceFloat.ImageTransparentColor = System.Drawing.Color.Magenta; this._tbReplaceFloat.ImageTransparentColor = System.Drawing.Color.Magenta;
this._tbReplaceFloat.Name = "_tbReplaceFloat"; this._tbReplaceFloat.Name = "_tbReplaceFloat";
this._tbReplaceFloat.Size = new System.Drawing.Size(23, 22); this._tbReplaceFloat.Size = new System.Drawing.Size(23, 22);
this._tbReplaceFloat.Text = "toolStripButton15"; this._tbReplaceFloat.Text = "Add Float Tag";
this._tbReplaceFloat.Click += new System.EventHandler(this._tbReplaceFloat_Click); this._tbReplaceFloat.Click += new System.EventHandler(this._tbReplaceFloat_Click);
// //
// _tbReplaceDouble // _tbReplaceDouble
@ -439,7 +439,7 @@
this._tbReplaceDouble.ImageTransparentColor = System.Drawing.Color.Magenta; this._tbReplaceDouble.ImageTransparentColor = System.Drawing.Color.Magenta;
this._tbReplaceDouble.Name = "_tbReplaceDouble"; this._tbReplaceDouble.Name = "_tbReplaceDouble";
this._tbReplaceDouble.Size = new System.Drawing.Size(23, 22); this._tbReplaceDouble.Size = new System.Drawing.Size(23, 22);
this._tbReplaceDouble.Text = "toolStripButton16"; this._tbReplaceDouble.Text = "Add Double Tag";
this._tbReplaceDouble.Click += new System.EventHandler(this._tbReplaceDouble_Click); this._tbReplaceDouble.Click += new System.EventHandler(this._tbReplaceDouble_Click);
// //
// _tbReplaceByteArray // _tbReplaceByteArray
@ -449,7 +449,7 @@
this._tbReplaceByteArray.ImageTransparentColor = System.Drawing.Color.Magenta; this._tbReplaceByteArray.ImageTransparentColor = System.Drawing.Color.Magenta;
this._tbReplaceByteArray.Name = "_tbReplaceByteArray"; this._tbReplaceByteArray.Name = "_tbReplaceByteArray";
this._tbReplaceByteArray.Size = new System.Drawing.Size(23, 22); this._tbReplaceByteArray.Size = new System.Drawing.Size(23, 22);
this._tbReplaceByteArray.Text = "toolStripButton17"; this._tbReplaceByteArray.Text = "Add Byte Array Tag";
this._tbReplaceByteArray.Click += new System.EventHandler(this._tbReplaceByteArray_Click); this._tbReplaceByteArray.Click += new System.EventHandler(this._tbReplaceByteArray_Click);
// //
// _tbReplaceIntArray // _tbReplaceIntArray
@ -459,7 +459,7 @@
this._tbReplaceIntArray.ImageTransparentColor = System.Drawing.Color.Magenta; this._tbReplaceIntArray.ImageTransparentColor = System.Drawing.Color.Magenta;
this._tbReplaceIntArray.Name = "_tbReplaceIntArray"; this._tbReplaceIntArray.Name = "_tbReplaceIntArray";
this._tbReplaceIntArray.Size = new System.Drawing.Size(23, 22); this._tbReplaceIntArray.Size = new System.Drawing.Size(23, 22);
this._tbReplaceIntArray.Text = "toolStripButton18"; this._tbReplaceIntArray.Text = "Add Int Array Tag";
this._tbReplaceIntArray.Click += new System.EventHandler(this._tbReplaceIntArray_Click); this._tbReplaceIntArray.Click += new System.EventHandler(this._tbReplaceIntArray_Click);
// //
// _tbReplaceString // _tbReplaceString
@ -469,7 +469,7 @@
this._tbReplaceString.ImageTransparentColor = System.Drawing.Color.Magenta; this._tbReplaceString.ImageTransparentColor = System.Drawing.Color.Magenta;
this._tbReplaceString.Name = "_tbReplaceString"; this._tbReplaceString.Name = "_tbReplaceString";
this._tbReplaceString.Size = new System.Drawing.Size(23, 22); this._tbReplaceString.Size = new System.Drawing.Size(23, 22);
this._tbReplaceString.Text = "toolStripButton19"; this._tbReplaceString.Text = "Add String Tag";
this._tbReplaceString.Click += new System.EventHandler(this._tbReplaceString_Click); this._tbReplaceString.Click += new System.EventHandler(this._tbReplaceString_Click);
// //
// _tbReplaceList // _tbReplaceList
@ -479,7 +479,7 @@
this._tbReplaceList.ImageTransparentColor = System.Drawing.Color.Magenta; this._tbReplaceList.ImageTransparentColor = System.Drawing.Color.Magenta;
this._tbReplaceList.Name = "_tbReplaceList"; this._tbReplaceList.Name = "_tbReplaceList";
this._tbReplaceList.Size = new System.Drawing.Size(23, 22); this._tbReplaceList.Size = new System.Drawing.Size(23, 22);
this._tbReplaceList.Text = "toolStripButton20"; this._tbReplaceList.Text = "Add List Tag";
this._tbReplaceList.Click += new System.EventHandler(this._tbReplaceList_Click); this._tbReplaceList.Click += new System.EventHandler(this._tbReplaceList_Click);
// //
// _tbReplaceCompound // _tbReplaceCompound
@ -489,7 +489,7 @@
this._tbReplaceCompound.ImageTransparentColor = System.Drawing.Color.Magenta; this._tbReplaceCompound.ImageTransparentColor = System.Drawing.Color.Magenta;
this._tbReplaceCompound.Name = "_tbReplaceCompound"; this._tbReplaceCompound.Name = "_tbReplaceCompound";
this._tbReplaceCompound.Size = new System.Drawing.Size(23, 22); this._tbReplaceCompound.Size = new System.Drawing.Size(23, 22);
this._tbReplaceCompound.Text = "toolStripButton21"; this._tbReplaceCompound.Text = "Add Compound Tag";
this._tbReplaceCompound.Click += new System.EventHandler(this._tbReplaceCompound_Click); this._tbReplaceCompound.Click += new System.EventHandler(this._tbReplaceCompound_Click);
// //
// _buttonFind // _buttonFind
@ -549,7 +549,7 @@
this.Controls.Add(this.groupBox2); this.Controls.Add(this.groupBox2);
this.Controls.Add(this.groupBox1); this.Controls.Add(this.groupBox1);
this.Name = "FindReplace"; this.Name = "FindReplace";
this.Text = "Replace"; this.Text = "Find and Replace";
this.groupBox1.ResumeLayout(false); this.groupBox1.ResumeLayout(false);
this.panel1.ResumeLayout(false); this.panel1.ResumeLayout(false);
this.panel1.PerformLayout(); this.panel1.PerformLayout();

View file

@ -239,8 +239,10 @@ namespace NBTExplorer.Windows
private void SearchProgressCallback (DataNode node) private void SearchProgressCallback (DataNode node)
{ {
if (node is TagCompoundDataNode && !string.IsNullOrEmpty(node.NodeName) && node.NodeName != _searchForm.SearchPathLabel) try {
_searchForm.SearchPathLabel = node.NodeName; _searchForm.SearchPathLabel = node.NodePath;
}
catch { }
} }
private void SearchCollapseCallback (DataNode node) private void SearchCollapseCallback (DataNode node)
@ -296,7 +298,7 @@ namespace NBTExplorer.Windows
private void _tbFindEdit_Click (object sender, EventArgs e) private void _tbFindEdit_Click (object sender, EventArgs e)
{ {
//_findController.EditSelection(); _findController.EditSelection();
} }
private void _tbReplaceEdit_Click (object sender, EventArgs e) private void _tbReplaceEdit_Click (object sender, EventArgs e)
@ -312,6 +314,7 @@ namespace NBTExplorer.Windows
public DataNode RootNode { get; set; } public DataNode RootNode { get; set; }
public IEnumerator<DataNode> State { get; set; } public IEnumerator<DataNode> State { get; set; }
public bool TerminateOnDiscover { get; set; } public bool TerminateOnDiscover { get; set; }
public float ProgressRate { get; set; }
public abstract void InvokeDiscoverCallback (DataNode node); public abstract void InvokeDiscoverCallback (DataNode node);
public abstract void InvokeProgressCallback (DataNode node); public abstract void InvokeProgressCallback (DataNode node);
@ -321,6 +324,7 @@ namespace NBTExplorer.Windows
protected ContainerRuleSearchState () protected ContainerRuleSearchState ()
{ {
TerminateOnDiscover = true; TerminateOnDiscover = true;
ProgressRate = .5f;
} }
public bool TestNode (DataNode node) public bool TestNode (DataNode node)

View file

@ -125,7 +125,7 @@
AAEAAAD/////AQAAAAAAAAAMAgAAAFdTeXN0ZW0uV2luZG93cy5Gb3JtcywgVmVyc2lvbj0yLjAuMC4w AAEAAAD/////AQAAAAAAAAAMAgAAAFdTeXN0ZW0uV2luZG93cy5Gb3JtcywgVmVyc2lvbj0yLjAuMC4w
LCBDdWx0dXJlPW5ldXRyYWwsIFB1YmxpY0tleVRva2VuPWI3N2E1YzU2MTkzNGUwODkFAQAAACZTeXN0 LCBDdWx0dXJlPW5ldXRyYWwsIFB1YmxpY0tleVRva2VuPWI3N2E1YzU2MTkzNGUwODkFAQAAACZTeXN0
ZW0uV2luZG93cy5Gb3Jtcy5JbWFnZUxpc3RTdHJlYW1lcgEAAAAERGF0YQcCAgAAAAkDAAAADwMAAABA ZW0uV2luZG93cy5Gb3Jtcy5JbWFnZUxpc3RTdHJlYW1lcgEAAAAERGF0YQcCAgAAAAkDAAAADwMAAABA
QgAAAk1TRnQBSQFMAgEBFAEAAYABAQGAAQEBEAEAARABAAT/ARkBAAj/AUIBTQE2BwABNgMAASgDAAFA QgAAAk1TRnQBSQFMAgEBFAEAAZABAQGQAQEBEAEAARABAAT/ARkBAAj/AUIBTQE2BwABNgMAASgDAAFA
AwABYAMAAQEBAAEYBgABSP8A/wD/AP8A/wD/AP8A/wD/AP8A/wD/AOEAA/8D/AP6GPgD+QP6A/wMAAP9 AwABYAMAAQEBAAEYBgABSP8A/wD/AP8A/wD/AP8A/wD/AP8A/wD/AOEAA/8D/AP6GPgD+QP6A/wMAAP9
A/oS+AP5A/0D/2kAA/4D+QPxAboBogGKAbYBhgFWAbYBhgFWAbYBhgFWAbYBhgFWAbYBhgFWAbYBhgFW A/oS+AP5A/0D/2kAA/4D+QPxAboBogGKAbYBhgFWAbYBhgFWAbYBhgFWAbYBhgFWAbYBhgFWAbYBhgFW
AbYBhgFWAbYBhgFWAbwBpAGNA/cMAAP8A/YD8wG8AcoBzQFVAZUBowFVAZUBowHQAdcB2QPzA/UD+wP/ AbYBhgFWAbYBhgFWAbwBpAGNA/cMAAP8A/YD8wG8AcoBzQFVAZUBowFVAZUBowHQAdcB2QPzA/UD+wP/
@ -443,48 +443,48 @@
<data name="_tbFindGroupAnd.Image" type="System.Drawing.Bitmap, System.Drawing" mimetype="application/x-microsoft.net.object.bytearray.base64"> <data name="_tbFindGroupAnd.Image" type="System.Drawing.Bitmap, System.Drawing" mimetype="application/x-microsoft.net.object.bytearray.base64">
<value> <value>
iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAYAAAAf8/9hAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8 iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAYAAAAf8/9hAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8
YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAJPSURBVDhPzZHdT1JxHMbPqqsuwpdq5kVrqzbW9CZj66Ju YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAJPSURBVDhPzZHdT1JxHMbPqqsuwpdq5kVrqzbW9CZja23d
aulFW671MtpSt9asxVbhAnux0JqzQHtBXhrDpqYlCIOAwh0MY6EhGWVFih4EPIAIaoJRN110Hjpt/Qf1 1NKLtlzrZbSlbq1Zi63CBfZioTVngfaCvDSGTU1LEAYBhTsYxkJDMsqKFD0IeAAR1ASjbrroPHTa+g/q
2z473z3P89nYIP6fV1bv4OwUk7uZb2XZZfIEvhWS8UPg74zdcFjt92OCzRW3hqr6hmlVOPV9IJX+4esd t312vnue57OxQfw/r6zewdkpJncz38qyy+QJfCsk44fA3xm74bDa78cEmytuDVX1DdOqcOr7QCr9w9c7
XHKfbqHTADcydNhgC+ePzDnQ6KzxR9KGyELWGUpmyeGPSx5+A5VRGOcjADcydNhgCyf3S0ovWvc+ds2o uOQ+3UKnAW5k6LDBFs4fmXOg0Vnjj6QNkYWsM5TMksMflzz8BiqjMM5HAG5k6LDBFk7ul5RetO597JpR
mNJBzWXsM8nsoED2KXRBOpnocXz9AnAjQ4cNtnDgEtzzZv5ENGP7zBKczw6VHran73THJ+4bU+7mJ0nH MaWDmsvYZ5LZQYHsU+iCdDLR4/j6BeBGhg4bbOHAJbjnzfyJaMb2mSU4nx0qPWxP3+mOT9w3ptzNT5KO
dU3oLY9vWbb54u09r8PNRg/dOhJY6IZLcAWmWirxzfUhvGwCk3SG3Lan/2ebPuW61hG3AJk+9QqZdSz2 65rQWx7fsmzzxdt7XoebjR66dSSw0A2X4ApMtVTim+tDeNkEJukMuW1P/882fcp1rSNuATJ96hUy61js
UElSN1QDlOTFuzkNXGLrGX31WHDRPDq9aLC/T2hN3piae9CYFslD3nptzApwI9OP0Ip7zwONwOChlXCJ oZKkbqgGKMmLd3MauMTWM/rqseCieXR60WB/n9CavDE196AxLZKHvPXamBXgRqYfoRX3ngcagcFDK+ES
Laeelj+w+TVmL62VWQI31WRQWil0Tx0R+2avdkTtADcydNJngSaFffq2pM93Fy5RXNVVWCLQ1XU5qfY2 W049LX9g82vMXlorswRuqsmgtFLonjoi9s1e7YjaAW5k6KTPAk0K+/RtSZ/vLlyiuKqrsESgq+tyUu1t
a6Clqd/f2GqgdLyToysieXQc4EaGDhtsd5zTCeHm/srC8ivc7bW9InGnR/7IGVQb3sx2ihRTL3k1oRWA 1kBLU7+/sdVA6XgnR1dE8ug4wI0MHTbY7jinE8LN/ZWF5Ve422t7ReJOj/yRM6g2vJntFCmmXvJqQisA
Gxk6bLCFk5OZt5ph/Zqikl15+y9V5x9V1hUc1zQUHFMLi/ZJzgLcyNBhgy0c1iVWMaxlg2KGTQwbGPIY NzJ02GALJyczbzXD+jVFJbvy9l+qzj+qrCs4rmkoOKYWFu2TnAW4kaHDBls4rEusYljLBsUMmxg2MOQx
1rHkM2xkQIcNtnDg/tNHEL8AacmTsOs1fTEAAAAASUVORK5CYII= rGPJZ9jIgA4bbOHA/aePIH4BYSWTrEIU7H8AAAAASUVORK5CYII=
</value> </value>
</data> </data>
<data name="_tbFindGroupOr.Image" type="System.Drawing.Bitmap, System.Drawing" mimetype="application/x-microsoft.net.object.bytearray.base64"> <data name="_tbFindGroupOr.Image" type="System.Drawing.Bitmap, System.Drawing" mimetype="application/x-microsoft.net.object.bytearray.base64">
<value> <value>
iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAYAAAAf8/9hAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8 iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAYAAAAf8/9hAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8
YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAI8SURBVDhPzZHda1JxHMYPdddFFLRgXUaEsCC6ChYRvSBR YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAI+SURBVDhPzZHvaxJxHMePetaDKGjBehgRwoLoUbCI6AcS
xECL3HpjtIvAQcTSkTIqp1bOjS5qDFNn5k6ohKRuNmfbXNpYLI6Wc6eV6RHPyzwObZdedR4zor+gfvDh jRhotbV+MdqDwEHE0pEyKqdWzo0e1Bimt8vchUpI6mZzts2lxWJxupyzlemJd+c8h7aHPureZkR/QX3h
PDzf53N1iP/nXTOJsh6j6Lw+KOY777J1fHuMFTf4uxOd2Da1X+/inbyiS8fwOluZfxasfPO//VF84Bap xb15f96vR0f8P++aUZT1GETy+qCY7bjL1fDtMZQd4O9OJLFtaL9ex52sokvLClprSXjmK3/zvP2Rf+AQ
S4ZCGiCjww0bbOE0ZHnvsuzcTYq3kOUcGd2kPbFq1jVdXem25AKOcC0DkNHhhg22cOAS7V3zTrWR5j0z mUv6XAIgo8MNG2zh1GV575Ls7E1GMNOlDB3aTDvDlRQ1XVnpNme89kA1CZDR4YYNtnDgEq1d86TKkBac
1eyLaC1Dxqqr/TZm1ujhkugAMjrcsEEHBy7RdjaYHya5Ndeb2ifgiW1+URlXQ/bXFerxKzFhIsszVq+w M5XUi1A1SYcrq/1Wdtbg5GPoADI63LBBBwcu0dLmyw7T/Br1proMnOHNL52GVb/tdZl5/EqMGunSjMVV
cN6wEhzyrs8a3MKU2VOODo4zKbhEq9xfHw9vfLVPVijgjlSzZ3SpwLBPjOsdXBAM+cR5dFbvn+4hySfg XDinX/ENudZn9Y7ilMlZCg2Os3G4RLPcUxsPbHy1TZYZ4AhWUme0ce+wW4zo7LwPDLnFeXQW15/uIS1E
EntP+vNmF0OPBjY+Wn1i4hEpxpX3Pk+aSCHeb2dDALnRTazP/e76nuSX4BL7T085L+vTnOVl+Z3GxoYH 4RJ7T3qyJopNj3o3PlncYvQRLUaU9z5PGulipN/G+QFyvZtYn/vd9T3JLsIl9p+eIi/rErz5Zemd2soF
nPz0jZG12K2nuTmdoxQByOhw046xIXQXNKkCXOKAIik7pFwSeq0MpbWVIn1jxZDBxS10DKQj911cEiCj Bkhh+sbIWvjW08yc1l4IAmR0uGnGOD+68+p4Di5xQBGTHVIuFnstLKOxFoJ9Y3m/nuIX2gcSwfsUHwPI
w01rL0WwPdiR4OE2fmXbqeeKI1dooVPPMLdHSx/ME+yieuT78gl1hgbI6DTSDRts4TRk6W2V2NWyTyk/ 6HDT2ApBbA+2RwW49V/Zcuq54siVdPGijmVvjxY+mia4D6qR70snVMk0QEanlm7YYAunLktvq8Supn1K
rHzvP9bNMMdVbP3o1WKhXUX5ADI63LDBFk7TJbZIbGsWeyRaJVokdkhsb7JTYrcEbthgCwfuP30E8RMF +WHle8+xbpY9foGrHb2az7V2Mm6AjA43bLCF03CJLRLbGsUeiWaJJokdEtsb7JTYLYEbNtjCgftPH0H8
76m+HADFNQAAAABJRU5ErkJggg== BPSUqbbrmUHrAAAAAElFTkSuQmCC
</value> </value>
</data> </data>
<data name="_tbFindAny.Image" type="System.Drawing.Bitmap, System.Drawing" mimetype="application/x-microsoft.net.object.bytearray.base64"> <data name="_tbFindAny.Image" type="System.Drawing.Bitmap, System.Drawing" mimetype="application/x-microsoft.net.object.bytearray.base64">
<value> <value>
iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAYAAAAf8/9hAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8 iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAYAAAAf8/9hAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8
YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAIHSURBVDhPY6AZ2LWY2XnXYsa9ILxzMVM8VBg/2DKfQQLK YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAIHSURBVDhPY6AZ2LWY2XnXYsa9ILxzMVM8VBg/2DKfQQLK
ZNg2j3Hf+9f93z8+7v2zbQHjLqgwihoUsHEOU8KmuYz7Ns1lXr5xNrMHiP373cz/r27m/UWIMS8HiYPU ZNg2j3Hf+9f9398/7P6zbQHjLqgwihoUsHEOU8KmuYz7Ns1lXr5xNrMHiP373cz/L67n/EWIMS8HiYPU
QrUhwIaZjPu/v5r8//3D9u8HN+ieB/G/vej///JM9I91MxlXH1yjc/7tlYbvX551/QfJQbUhwOrJTAfu QrUhwIaZjPu/v5r8//3D9u8HN+ieB/G/vej///JU9I91MxlXH1yjc/7tpYbvX551/QfJQbUhwOrJTAfu
nwj/8fRK4v9Xt4r/71+lceH9w+b/t08GftoHZL+8WfAfJAdSA1IL1YYAyycyWC3vZ1y5Z4XyzZPbLF48 nwj/8fRK4v9Xt4r/71+lceH9w+b/t08GftoHZL+8WfAfJAdSA1IL1YYAyycyWC3vZ1y5Z4XyzZPbLF48
upT6H4TvnA7+//Bi8n+QGEgOpAakFqoNEyzsYnZZ0M106PAmqw/Xjnr8B2EQGyQGkoMqwwSzWxms57Qx upT6H4TvnA7+//Bi8n+QGEgOpAakFqoNEyzsYnZZ0M106PAmqw/Xjnr8B2EQGyQGkoMqwwSzWxms57Qx
rt6x0ujmyc32L68cdvkPwjdO+IPpY5utX+5YonUTpAakFqoNAabWMx25eyL6x62T3v+vH3P5v3SS8OWT rt6x0ujmyc32L68cdvkPwjdO+IPpY5utX+5YonUTpAakFqoNAabWMx25eyL6x62T3v+vH3P5v3SS8OWT
W0w/3zsXBmaDxG6c8Ph/+qjPD5BaqDYE6KtgOnrntMv/E4fMfizqFrrSX8m44dRhsx/3zwf+B8mBxEBy W0w/3zsXBmaDxG6c8Ph/8qjPD5BaqDYE6KtgOnrntMv/E4fMfizqFrrSX8m44cRhsx/3zwf+B8mBxEBy
IDUgPlQbArQXMKS05DCeaMllXA9ke4Poq0fs/z694vMfJA4Tg7JToNpQgZUhgxSUyVCZzHjs1kn7v3cP IDUgPlQbArQXMKS05DCeaMllXA9ke4Poy4fs/z694vMfJA4Tg7JToNpQgZUhgxSUyVCZzHjsxnH7v3f3
2P+sTGI8BRVGUYMN8AKxIhCr+9kzVNRlclwAYXsThkSQGBArA7EAEDMCMVbAAcRiQAyyBRsWB2IuIMZp 2/+sTGI8BRVGUYMN8AKxIhCr+9kzVNRlclwAYXsThkSQGBArA7EAEDMCMVbAAcRiQAyyBRsWB2IuIMZp
AImAgQEAGUocntp9HGkAAAAASUVORK5CYII= AImAgQEA1wkcgSmiF0cAAAAASUVORK5CYII=
</value> </value>
</data> </data>
<data name="_tbFindByte.Image" type="System.Drawing.Bitmap, System.Drawing" mimetype="application/x-microsoft.net.object.bytearray.base64"> <data name="_tbFindByte.Image" type="System.Drawing.Bitmap, System.Drawing" mimetype="application/x-microsoft.net.object.bytearray.base64">
@ -733,13 +733,13 @@
<data name="_tbReplaceCompound.Image" type="System.Drawing.Bitmap, System.Drawing" mimetype="application/x-microsoft.net.object.bytearray.base64"> <data name="_tbReplaceCompound.Image" type="System.Drawing.Bitmap, System.Drawing" mimetype="application/x-microsoft.net.object.bytearray.base64">
<value> <value>
iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAYAAAAf8/9hAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8 iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAYAAAAf8/9hAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8
YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAFzSURBVDhPrdFPRINxHMfx7+MZHTtGhy6dOqfrFKOS0qGS YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAFySURBVDhPrdE/SAJhHMbx33FCY2PQ0NLUHK1SIFRE0VAR
Sf8oIx1SjCbbOtRSJLaU0Q6tjU0zno3ZypJFZZJuHWaLipKVRnTIr33m9/w8z+2Zenh7+P0+r+fy0L88 Ev2DQoiGKBCSUBvKKIhAoxByyE5QEkEF0cIIgwpxaGsQDSoowv5B0BBvPvLey912UgdfDt73+dxy9C9P
WSeZstMm29mUvKnmNFNem/YOWxjOiU7HG1qvHW1H7ycbrJzx1PLbOnSp59hgC8M5UXpS7r739uW0Hwgv 1kmm7LTJdjYlb6o5zZTXpr3DFoZzotPxhtZrR9vR68kGq2Q8tfy2Dl3qOTbYwnBOlJ6Uu2+9fTntB0JL
dYmCC2bdB7CF4ZwoNWGaL4bmSs+Ki6kl3AOimKNHnCNsYTgnSo7Jvspt+IcVIkytELGL8vuz4hxhC8M5 XaLggln3AWxhOCdKTZjmS8pc+THuYmoJ94Ao6ugR5whbGM6JkmOy770Q+mHFMFMrhu2i/P6sOEfYwnBO
kWKV977vAqxy6RNlPMMixdWvu8MWhnOiuFX2f9342UduRwQYsVtq79Bip+4OWxjOiaKjcuDzape9ZbdE FLfKe983AfZ56RNlPMOiuKtfd4ctDOdEMavs/yr42VtuRwQYtltqb2WxU3eHLQznRJFROfBxtcteslsi
wNq3NmxhOCcKj8iH5fNt9pJeNxS2MJwTBYek0Gv1Fz0lVw2FLQznRIFBKfqYcLOH+IqhsIXhnMjbK6VK YO1bG7YwnBOFRuTDyvk2e0qvGwpbGM6JgkOS8lz9RQ/JVUNhC8M5UWBQitwn3OwutmIobGE4J/L2Sqly
MQcrHi8bClsYzqllpl06WLNIF/UEA4sPNFZrqtZcZzCwf3mIfgFEYd2QbOcxhgAAAABJRU5ErkJggg== 1MFKx8uGwhaGc2qZaZcO1izSRT3BwOIDjdWaqjXXGQzsXx6iXy8F3Ygxdd78AAAAAElFTkSuQmCC
</value> </value>
</data> </data>
</root> </root>