mirror of
https://git.do.srb2.org/STJr/UltimateZoneBuilder.git
synced 2024-12-11 12:51:20 +00:00
120 lines
3.9 KiB
C#
Executable file
120 lines
3.9 KiB
C#
Executable file
|
|
#region ================== Copyright (c) 2007 Pascal vd Heiden
|
|
|
|
/*
|
|
* Copyright (c) 2007 Pascal vd Heiden, www.codeimp.com
|
|
* This program is released under GNU General Public License
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*
|
|
*/
|
|
|
|
#endregion
|
|
|
|
#region ================== Namespaces
|
|
|
|
using System;
|
|
using System.Collections.Generic;
|
|
using System.Collections.ObjectModel;
|
|
using System.Windows.Forms;
|
|
using CodeImp.DoomBuilder.Config;
|
|
using CodeImp.DoomBuilder.Map;
|
|
using System.Drawing;
|
|
|
|
#endregion
|
|
|
|
namespace CodeImp.DoomBuilder.BuilderModes
|
|
{
|
|
[FindReplace("Sidedef Texture (Any)", BrowseButton = true)]
|
|
internal class FindSidedefTexture : BaseFindSidedef
|
|
{
|
|
#region ================== Constants
|
|
|
|
#endregion
|
|
|
|
#region ================== Variables
|
|
|
|
#endregion
|
|
|
|
#region ================== Properties
|
|
|
|
public override Image BrowseImage { get { return Properties.Resources.List; } }
|
|
public override string UsageHint { get { return "Supported wildcards:" + Environment.NewLine
|
|
+ "* - zero or more characters" + Environment.NewLine
|
|
+ "? - one character"; }}
|
|
|
|
#endregion
|
|
|
|
#region ================== Constructor / Destructor
|
|
|
|
#endregion
|
|
|
|
#region ================== Methods
|
|
|
|
// This is called when the browse button is pressed
|
|
public override string Browse(string initialvalue)
|
|
{
|
|
return General.Interface.BrowseTexture(BuilderPlug.Me.FindReplaceForm, initialvalue);
|
|
}
|
|
|
|
|
|
// This is called to perform a search (and replace)
|
|
// Returns a list of items to show in the results list
|
|
// replacewith is null when not replacing
|
|
public override FindReplaceObject[] Find(string value, bool withinselection, bool replace, string replacewith, bool keepselection)
|
|
{
|
|
List<FindReplaceObject> objs = new List<FindReplaceObject>();
|
|
|
|
// Interpret the replacement
|
|
if(replace && (string.IsNullOrEmpty(replacewith) || replacewith.Length > General.Map.Config.MaxTextureNameLength))
|
|
{
|
|
MessageBox.Show("Invalid replace value for this search type!", "Find and Replace", MessageBoxButtons.OK, MessageBoxIcon.Error);
|
|
return objs.ToArray();
|
|
}
|
|
|
|
// Interpret the find
|
|
bool isregex = (value.IndexOf('*') != -1 || value.IndexOf('?') != -1); //mxd
|
|
MatchingTextureSet set = new MatchingTextureSet(new Collection<string> { value.Trim() }); //mxd
|
|
|
|
// Where to search?
|
|
ICollection<Sidedef> sidelist = withinselection ? General.Map.Map.GetSidedefsFromSelectedLinedefs(true) : General.Map.Map.Sidedefs;
|
|
|
|
// Go for all sidedefs
|
|
foreach(Sidedef sd in sidelist)
|
|
{
|
|
string side = sd.IsFront ? "front" : "back";
|
|
|
|
if(set.IsMatch(sd.HighTexture) && (value != "-" || sd.HighRequired()))
|
|
{
|
|
// Replace and add to list
|
|
if(replace) sd.SetTextureHigh(replacewith);
|
|
objs.Add(new FindReplaceObject(sd, "Sidedef " + sd.Index + " (" + side + ", high)" + (isregex ? " - " + sd.HighTexture : null)));
|
|
}
|
|
|
|
if(set.IsMatch(sd.MiddleTexture) && (value != "-" || sd.MiddleRequired()))
|
|
{
|
|
// Replace and add to list
|
|
if(replace) sd.SetTextureMid(replacewith);
|
|
objs.Add(new FindReplaceObject(sd, "Sidedef " + sd.Index + " (" + side + ", middle)" + (isregex ? " - " + sd.MiddleTexture : null)));
|
|
}
|
|
|
|
if(set.IsMatch(sd.LowTexture) && (value != "-" || sd.LowRequired()))
|
|
{
|
|
// Replace and add to list
|
|
if(replace) sd.SetTextureLow(replacewith);
|
|
objs.Add(new FindReplaceObject(sd, "Sidedef " + sd.Index + " (" + side + ", low)" + (isregex ? " - " + sd.LowTexture : null)));
|
|
}
|
|
}
|
|
|
|
// When replacing, make sure we keep track of used textures
|
|
if(replace) General.Map.Data.UpdateUsedTextures();
|
|
|
|
return objs.ToArray();
|
|
}
|
|
|
|
#endregion
|
|
}
|
|
}
|