forked from mirrors/NBTExplorer
253 lines
7.1 KiB
C#
253 lines
7.1 KiB
C#
using System;
|
|
using System.Collections.Generic;
|
|
using System.Text;
|
|
using System.Windows.Forms;
|
|
using NBTExplorer.Windows;
|
|
using NBTExplorer.Model.Search;
|
|
using Substrate.Nbt;
|
|
|
|
namespace NBTExplorer.Controllers
|
|
{
|
|
public class RuleTreeController
|
|
{
|
|
private TreeView _nodeTree;
|
|
private IconRegistry _iconRegistry;
|
|
|
|
private RootRule _rootData;
|
|
|
|
public RuleTreeController (TreeView nodeTree)
|
|
{
|
|
_nodeTree = nodeTree;
|
|
|
|
InitializeIconRegistry();
|
|
ShowVirtualRoot = true;
|
|
|
|
_rootData = new RootRule();
|
|
|
|
RefreshTree();
|
|
}
|
|
|
|
private void InitializeIconRegistry ()
|
|
{
|
|
_iconRegistry = new IconRegistry();
|
|
_iconRegistry.DefaultIcon = 15;
|
|
|
|
_iconRegistry.Register(typeof(RootRule), 16);
|
|
_iconRegistry.Register(typeof(UnionRule), 19);
|
|
_iconRegistry.Register(typeof(IntersectRule), 18);
|
|
_iconRegistry.Register(typeof(WildcardRule), 17);
|
|
_iconRegistry.Register(typeof(ByteTagRule), 0);
|
|
_iconRegistry.Register(typeof(ShortTagRule), 1);
|
|
_iconRegistry.Register(typeof(IntTagRule), 2);
|
|
_iconRegistry.Register(typeof(LongTagRule), 3);
|
|
_iconRegistry.Register(typeof(FloatTagRule), 4);
|
|
_iconRegistry.Register(typeof(DoubleTagRule), 5);
|
|
_iconRegistry.Register(typeof(StringTagRule), 7);
|
|
}
|
|
|
|
public RootRule Root
|
|
{
|
|
get { return _rootData; }
|
|
}
|
|
|
|
public TreeView Tree
|
|
{
|
|
get { return _nodeTree; }
|
|
}
|
|
|
|
public bool ShowVirtualRoot { get; set; }
|
|
|
|
public string VirtualRootDisplay
|
|
{
|
|
get { return _rootData.NodeDisplay; }
|
|
/*set
|
|
{
|
|
_rootData.SetDisplayName(value);
|
|
if (ShowVirtualRoot && _nodeTree.Nodes.Count > 0)
|
|
UpdateNodeText(_nodeTree.Nodes[0]);
|
|
}*/
|
|
}
|
|
|
|
public void DeleteSelection ()
|
|
{
|
|
DeleteNode(SelectedNode);
|
|
}
|
|
|
|
public void DeleteNode (TreeNode node)
|
|
{
|
|
if (node == null || !(node.Tag is SearchRule))
|
|
return;
|
|
|
|
SearchRule dataNode = node.Tag as SearchRule;
|
|
//if (!dataNode.CanDeleteNode)
|
|
// return;
|
|
|
|
/*if (dataNode.DeleteNode()) {
|
|
UpdateNodeText(node.Parent);
|
|
node.Remove();
|
|
|
|
RemoveNodeFromSelection(node);
|
|
OnSelectionInvalidated();
|
|
}*/
|
|
}
|
|
|
|
private TreeNode SelectedNode
|
|
{
|
|
get
|
|
{
|
|
return _nodeTree.SelectedNode;
|
|
}
|
|
}
|
|
|
|
public void CreateNode (TreeNode node, TagType type)
|
|
{
|
|
if (node == null || !(node.Tag is GroupRule))
|
|
return;
|
|
|
|
GroupRule dataNode = node.Tag as GroupRule;
|
|
//if (!dataNode.CanCreateTag(type))
|
|
// return;
|
|
|
|
TreeNode newNode = null;
|
|
|
|
switch (type) {
|
|
case TagType.TAG_BYTE:
|
|
newNode = CreateNode(new ByteTagRule());
|
|
(newNode.Tag as ByteTagRule).Name = "raining";
|
|
newNode.Text = (newNode.Tag as SearchRule).NodeDisplay;
|
|
break;
|
|
case TagType.TAG_SHORT:
|
|
newNode = CreateNode(new ShortTagRule());
|
|
break;
|
|
case TagType.TAG_INT:
|
|
newNode = CreateNode(new IntTagRule());
|
|
break;
|
|
case TagType.TAG_LONG:
|
|
newNode = CreateNode(new LongTagRule());
|
|
break;
|
|
case TagType.TAG_FLOAT:
|
|
newNode = CreateNode(new FloatTagRule());
|
|
break;
|
|
case TagType.TAG_DOUBLE:
|
|
newNode = CreateNode(new DoubleTagRule());
|
|
break;
|
|
case TagType.TAG_STRING:
|
|
newNode = CreateNode(new StringTagRule());
|
|
break;
|
|
}
|
|
|
|
if (newNode != null) {
|
|
node.Nodes.Add(newNode);
|
|
dataNode.Rules.Add(newNode.Tag as SearchRule);
|
|
|
|
node.Expand();
|
|
}
|
|
|
|
/*if (dataNode.CreateNode(type)) {
|
|
node.Text = dataNode.NodeDisplay;
|
|
RefreshChildNodes(node, dataNode);
|
|
OnSelectionInvalidated();
|
|
}*/
|
|
}
|
|
|
|
public void CreateWildcardNode (TreeNode node)
|
|
{
|
|
if (node == null || !(node.Tag is GroupRule))
|
|
return;
|
|
|
|
GroupRule dataNode = node.Tag as GroupRule;
|
|
|
|
TreeNode newNode = CreateNode(new WildcardRule());
|
|
node.Nodes.Add(newNode);
|
|
dataNode.Rules.Add(newNode.Tag as SearchRule);
|
|
|
|
node.Expand();
|
|
}
|
|
|
|
public void CreateWildcardNode ()
|
|
{
|
|
CreateWildcardNode(SelectedNode);
|
|
}
|
|
|
|
public void CreateUnionNode (TreeNode node)
|
|
{
|
|
if (node == null || !(node.Tag is GroupRule))
|
|
return;
|
|
|
|
GroupRule dataNode = node.Tag as GroupRule;
|
|
|
|
TreeNode newNode = CreateNode(new UnionRule());
|
|
node.Nodes.Add(newNode);
|
|
dataNode.Rules.Add(newNode.Tag as SearchRule);
|
|
|
|
node.Expand();
|
|
}
|
|
|
|
public void CreateUnionNode ()
|
|
{
|
|
CreateUnionNode(SelectedNode);
|
|
}
|
|
|
|
public void CreateIntersectNode (TreeNode node)
|
|
{
|
|
if (node == null || !(node.Tag is GroupRule))
|
|
return;
|
|
|
|
GroupRule dataNode = node.Tag as GroupRule;
|
|
|
|
TreeNode newNode = CreateNode(new IntersectRule());
|
|
node.Nodes.Add(newNode);
|
|
dataNode.Rules.Add(newNode.Tag as SearchRule);
|
|
|
|
node.Expand();
|
|
}
|
|
|
|
public void CreateIntersectNode ()
|
|
{
|
|
CreateIntersectNode(SelectedNode);
|
|
}
|
|
|
|
public void CreateNode (TagType type)
|
|
{
|
|
if (_nodeTree.SelectedNode == null)
|
|
return;
|
|
|
|
CreateNode(_nodeTree.SelectedNode, type);
|
|
}
|
|
|
|
private TreeNode CreateNode (SearchRule rule)
|
|
{
|
|
TreeNode frontNode = new TreeNode(rule.NodeDisplay);
|
|
frontNode.ImageIndex = _iconRegistry.Lookup(rule.GetType());
|
|
frontNode.SelectedImageIndex = frontNode.ImageIndex;
|
|
frontNode.Tag = rule;
|
|
|
|
return frontNode;
|
|
}
|
|
|
|
private void ExpandNode (TreeNode node, bool recurse)
|
|
{
|
|
GroupRule rule = node.Tag as GroupRule;
|
|
if (rule == null)
|
|
return;
|
|
|
|
foreach (var subRule in rule.Rules) {
|
|
TreeNode subNode = CreateNode(subRule);
|
|
node.Nodes.Add(subNode);
|
|
|
|
if (recurse)
|
|
ExpandNode(subNode, recurse);
|
|
}
|
|
}
|
|
|
|
private void RefreshTree ()
|
|
{
|
|
_nodeTree.Nodes.Clear();
|
|
_nodeTree.Nodes.Add(CreateNode(_rootData));
|
|
|
|
ExpandNode(_nodeTree.Nodes[0], true);
|
|
|
|
_nodeTree.ExpandAll();
|
|
}
|
|
}
|
|
}
|