Added warps to tshock, edited some region commands
This commit is contained in:
parent
ad352492a9
commit
517b4ea69c
3 changed files with 231 additions and 7 deletions
|
|
@ -140,6 +140,9 @@ namespace TShockAPI
|
||||||
ChatCommands.Add(new Command("rules", "", Rules));
|
ChatCommands.Add(new Command("rules", "", Rules));
|
||||||
ChatCommands.Add(new Command("whitelist", "maintenance", Whitelist));
|
ChatCommands.Add(new Command("whitelist", "maintenance", Whitelist));
|
||||||
ChatCommands.Add(new Command("region", "editspawn", Region));
|
ChatCommands.Add(new Command("region", "editspawn", Region));
|
||||||
|
ChatCommands.Add(new Command("warp", "", UseWarp));
|
||||||
|
ChatCommands.Add(new Command("setwarp", "cfg", SetWarp));
|
||||||
|
ChatCommands.Add(new Command("delwarp", "cfg", DeleteWarp));
|
||||||
if (ConfigurationManager.DistributationAgent != "terraria-online")
|
if (ConfigurationManager.DistributationAgent != "terraria-online")
|
||||||
{
|
{
|
||||||
ChatCommands.Add(new Command("kill", "kill", Kill));
|
ChatCommands.Add(new Command("kill", "kill", Kill));
|
||||||
|
|
@ -747,6 +750,58 @@ namespace TShockAPI
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private static void SetWarp(CommandArgs args)
|
||||||
|
{
|
||||||
|
if (args.Parameters.Count > 0)
|
||||||
|
if (WarpsManager.AddWarp(args.Player.TileX, args.Player.TileY, args.Parameters[0]))
|
||||||
|
{
|
||||||
|
args.Player.SendMessage("Set warp " + args.Parameters[0], Color.Yellow);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
args.Player.SendMessage("Warp " + args.Parameters[0] + " already exists", Color.Red);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
args.Player.SendMessage("Invalid syntax! Proper syntax: /setwarp [name]", Color.Red);
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void DeleteWarp(CommandArgs args)
|
||||||
|
{
|
||||||
|
if (args.Parameters.Count > 0)
|
||||||
|
{
|
||||||
|
if (WarpsManager.DeleteWarp(args.Parameters[0]))
|
||||||
|
args.Player.SendMessage("Deleted warp " + args.Parameters[0], Color.Yellow);
|
||||||
|
else
|
||||||
|
args.Player.SendMessage("Could not find specified warp", Color.Red);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void UseWarp(CommandArgs args)
|
||||||
|
{
|
||||||
|
if (args.Parameters.Count > 0)
|
||||||
|
{
|
||||||
|
if (WarpsManager.FindWarp(args.Parameters[0]) != Vector2.Zero)
|
||||||
|
{
|
||||||
|
args.Player.Teleport((int)WarpsManager.FindWarp(args.Parameters[0]).X, (int)WarpsManager.FindWarp(args.Parameters[0]).Y);
|
||||||
|
args.Player.SendMessage("Warped to " + args.Parameters[0], Color.Yellow);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
args.Player.SendMessage("Specified warp not found", Color.Yellow);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
args.Player.SendMessage("Current Warps:", Color.Green);
|
||||||
|
|
||||||
|
//Someone needs to make it list
|
||||||
|
for (int i = 0; i < (WarpsManager.Warps.Count); i++)
|
||||||
|
{
|
||||||
|
args.Player.SendMessage(WarpsManager.Warps[i].WarpName, Color.Yellow);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
#endregion Teleport Commands
|
#endregion Teleport Commands
|
||||||
|
|
||||||
#region Server Config Commands
|
#region Server Config Commands
|
||||||
|
|
@ -980,6 +1035,8 @@ namespace TShockAPI
|
||||||
else
|
else
|
||||||
args.Player.SendMessage("Could not find specified region", Color.Red);
|
args.Player.SendMessage("Could not find specified region", Color.Red);
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
args.Player.SendMessage("Invalid syntax! Proper syntax: /region delete [name]", Color.Red);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case "clear":
|
case "clear":
|
||||||
|
|
|
||||||
|
|
@ -15,7 +15,7 @@ namespace TShockAPI
|
||||||
{
|
{
|
||||||
foreach (Region nametest in Regions)
|
foreach (Region nametest in Regions)
|
||||||
{
|
{
|
||||||
if (name.ToLower() == nametest.Name.ToLower())
|
if (name.ToLower() == nametest.RegionName.ToLower())
|
||||||
{
|
{
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
@ -28,7 +28,7 @@ namespace TShockAPI
|
||||||
{
|
{
|
||||||
foreach (Region nametest in Regions)
|
foreach (Region nametest in Regions)
|
||||||
{
|
{
|
||||||
if (name.ToLower() == nametest.Name.ToLower())
|
if (name.ToLower() == nametest.RegionName.ToLower())
|
||||||
{
|
{
|
||||||
Regions.Remove(nametest);
|
Regions.Remove(nametest);
|
||||||
WriteSettings();
|
WriteSettings();
|
||||||
|
|
@ -42,7 +42,7 @@ namespace TShockAPI
|
||||||
{
|
{
|
||||||
foreach (Region nametest in Regions)
|
foreach (Region nametest in Regions)
|
||||||
{
|
{
|
||||||
if (name.ToLower() == nametest.Name.ToLower())
|
if (name.ToLower() == nametest.RegionName.ToLower())
|
||||||
{
|
{
|
||||||
nametest.DisableBuild = state;
|
nametest.DisableBuild = state;
|
||||||
WriteSettings();
|
WriteSettings();
|
||||||
|
|
@ -80,7 +80,7 @@ namespace TShockAPI
|
||||||
foreach (Region region in Regions)
|
foreach (Region region in Regions)
|
||||||
{
|
{
|
||||||
settingsw.WriteStartElement("ProtectedRegion");
|
settingsw.WriteStartElement("ProtectedRegion");
|
||||||
settingsw.WriteElementString("RegionName", region.Name);
|
settingsw.WriteElementString("RegionName", region.RegionName);
|
||||||
settingsw.WriteElementString("Point1X", region.RegionArea.X.ToString());
|
settingsw.WriteElementString("Point1X", region.RegionArea.X.ToString());
|
||||||
settingsw.WriteElementString("Point1Y", region.RegionArea.Y.ToString());
|
settingsw.WriteElementString("Point1Y", region.RegionArea.Y.ToString());
|
||||||
settingsw.WriteElementString("Point2X", region.RegionArea.Width.ToString());
|
settingsw.WriteElementString("Point2X", region.RegionArea.Width.ToString());
|
||||||
|
|
@ -194,20 +194,20 @@ namespace TShockAPI
|
||||||
public class Region
|
public class Region
|
||||||
{
|
{
|
||||||
public Rectangle RegionArea { get; set; }
|
public Rectangle RegionArea { get; set; }
|
||||||
public string Name { get; set; }
|
public string RegionName { get; set; }
|
||||||
public bool DisableBuild { get; set; }
|
public bool DisableBuild { get; set; }
|
||||||
|
|
||||||
public Region(Rectangle region, string name, bool disablebuild)
|
public Region(Rectangle region, string name, bool disablebuild)
|
||||||
{
|
{
|
||||||
RegionArea = region;
|
RegionArea = region;
|
||||||
Name = name;
|
RegionName = name;
|
||||||
DisableBuild = disablebuild;
|
DisableBuild = disablebuild;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Region()
|
public Region()
|
||||||
{
|
{
|
||||||
RegionArea = Rectangle.Empty;
|
RegionArea = Rectangle.Empty;
|
||||||
Name = string.Empty;
|
RegionName = string.Empty;
|
||||||
DisableBuild = true;
|
DisableBuild = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
167
TShockAPI/WarpsManager.cs
Normal file
167
TShockAPI/WarpsManager.cs
Normal file
|
|
@ -0,0 +1,167 @@
|
||||||
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.Linq;
|
||||||
|
using System.Text;
|
||||||
|
using Microsoft.Xna.Framework;
|
||||||
|
using System.Xml;
|
||||||
|
|
||||||
|
namespace TShockAPI
|
||||||
|
{
|
||||||
|
class WarpsManager
|
||||||
|
{
|
||||||
|
public static List<Warp> Warps = new List<Warp>();
|
||||||
|
|
||||||
|
public static bool AddWarp(int x, int y, string name)
|
||||||
|
{
|
||||||
|
foreach (Warp nametest in Warps)
|
||||||
|
{
|
||||||
|
if (name.ToLower() == nametest.WarpName.ToLower())
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Warps.Add(new Warp(new Vector2(x, y), name));
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static bool DeleteWarp(string name)
|
||||||
|
{
|
||||||
|
foreach (Warp nametest in Warps)
|
||||||
|
{
|
||||||
|
if (name.ToLower() == nametest.WarpName.ToLower())
|
||||||
|
{
|
||||||
|
Warps.Remove(nametest);
|
||||||
|
WriteSettings();
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Vector2 FindWarp(string name)
|
||||||
|
{
|
||||||
|
foreach (Warp nametest in Warps)
|
||||||
|
{
|
||||||
|
if (name.ToLower() == nametest.WarpName.ToLower())
|
||||||
|
{
|
||||||
|
return nametest.WarpPos;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return Vector2.Zero;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void WriteSettings()
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
XmlWriterSettings xmlWriterSettings = new XmlWriterSettings();
|
||||||
|
xmlWriterSettings.Indent = true;
|
||||||
|
xmlWriterSettings.NewLineChars = Environment.NewLine;
|
||||||
|
|
||||||
|
using (XmlWriter settingsw = XmlWriter.Create("warps.xml", xmlWriterSettings))
|
||||||
|
{
|
||||||
|
settingsw.WriteStartDocument();
|
||||||
|
settingsw.WriteStartElement("Warps");
|
||||||
|
|
||||||
|
foreach (Warp warp in Warps)
|
||||||
|
{
|
||||||
|
settingsw.WriteStartElement("Warp");
|
||||||
|
settingsw.WriteElementString("WarpName", warp.WarpName);
|
||||||
|
settingsw.WriteElementString("X", warp.WarpPos.X.ToString());
|
||||||
|
settingsw.WriteElementString("Y", warp.WarpPos.Y.ToString());
|
||||||
|
settingsw.WriteEndElement();
|
||||||
|
}
|
||||||
|
|
||||||
|
settingsw.WriteEndElement();
|
||||||
|
settingsw.WriteEndDocument();
|
||||||
|
}
|
||||||
|
Log.Info("Wrote Warps");
|
||||||
|
}
|
||||||
|
catch
|
||||||
|
{
|
||||||
|
Log.Info("Could not write Warps");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void ReadAllSettings()
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
XmlReaderSettings xmlReaderSettings = new XmlReaderSettings();
|
||||||
|
xmlReaderSettings.IgnoreWhitespace = true;
|
||||||
|
|
||||||
|
using (XmlReader settingr = XmlReader.Create("warps.xml", xmlReaderSettings))
|
||||||
|
{
|
||||||
|
while (settingr.Read())
|
||||||
|
{
|
||||||
|
if (settingr.IsStartElement())
|
||||||
|
{
|
||||||
|
switch (settingr.Name)
|
||||||
|
{
|
||||||
|
case "Warps":
|
||||||
|
{
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case "Warp":
|
||||||
|
{
|
||||||
|
if (settingr.Read())
|
||||||
|
{
|
||||||
|
string name;
|
||||||
|
int x = 0;
|
||||||
|
int y = 0;
|
||||||
|
|
||||||
|
settingr.Read();
|
||||||
|
name = settingr.Value;
|
||||||
|
|
||||||
|
settingr.Read();
|
||||||
|
settingr.Read();
|
||||||
|
settingr.Read();
|
||||||
|
if (settingr.Value != "" || settingr.Value != null)
|
||||||
|
Int32.TryParse(settingr.Value, out x);
|
||||||
|
else
|
||||||
|
Console.WriteLine("Could not parse x");
|
||||||
|
|
||||||
|
settingr.Read();
|
||||||
|
settingr.Read();
|
||||||
|
settingr.Read();
|
||||||
|
if (settingr.Value != "" || settingr.Value != null)
|
||||||
|
Int32.TryParse(settingr.Value, out y);
|
||||||
|
else
|
||||||
|
Console.WriteLine("Could not parse y");
|
||||||
|
|
||||||
|
AddWarp(x, y, name);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Log.Info("Read Warps");
|
||||||
|
}
|
||||||
|
catch
|
||||||
|
{
|
||||||
|
Log.Info("Could not read Warps");
|
||||||
|
WriteSettings();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public class Warp
|
||||||
|
{
|
||||||
|
public Vector2 WarpPos { get; set; }
|
||||||
|
public string WarpName { get; set; }
|
||||||
|
|
||||||
|
public Warp(Vector2 warppos, string name)
|
||||||
|
{
|
||||||
|
WarpPos = warppos;
|
||||||
|
WarpName = name;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Warp()
|
||||||
|
{
|
||||||
|
WarpPos = Vector2.Zero;
|
||||||
|
WarpName = null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
Loading…
Add table
Add a link
Reference in a new issue