Changed Group. This isn't java. Don't use accessor/mutator methods. Use properties.

This commit is contained in:
high 2011-06-14 17:06:17 -04:00
parent c3bf304c0c
commit fff6e1bcbc
3 changed files with 69 additions and 86 deletions

View file

@ -22,30 +22,16 @@ namespace TShockAPI
{ {
public class Group public class Group
{ {
private string name; private readonly List<string> permissions = new List<string>();
private Group parent; private readonly List<string> negatedpermissions = new List<string>();
private List<string> permissions = new List<string>();
private List<string> negatedPermissions = new List<string>();
public Group(string groupName, Group parentGroup = null) public string Name { get; protected set; }
{ public Group Parent { get; protected set; }
name = groupName;
parent = parentGroup;
}
public Group() public Group(string groupname, Group parentgroup = null)
{ {
throw new Exception("Called Group constructor with no parameters"); Name = groupname;
} Parent = parentgroup;
public string GetName()
{
return name;
}
public Group GetParent()
{
return parent;
} }
public virtual bool HasPermission(string permission) public virtual bool HasPermission(string permission)
@ -54,25 +40,25 @@ namespace TShockAPI
{ {
return true; return true;
} }
if (negatedPermissions.Contains(permission)) if (negatedpermissions.Contains(permission))
{ {
return false; return false;
} }
else if (permissions.Contains(permission)) if (permissions.Contains(permission))
{ {
return true; return true;
} }
else if (parent != null) if (Parent != null)
{ {
//inception //inception
return parent.HasPermission(permission); return Parent.HasPermission(permission);
} }
return false; return false;
} }
public void NegatePermission(string permission) public void NegatePermission(string permission)
{ {
negatedPermissions.Add(permission); negatedpermissions.Add(permission);
} }
public void AddPermission(string permission) public void AddPermission(string permission)
@ -83,11 +69,8 @@ namespace TShockAPI
public class SuperAdminGroup : Group public class SuperAdminGroup : Group
{ {
public SuperAdminGroup(string groupName, Group parentGroup = null) : base(groupName, parentGroup) public SuperAdminGroup(string groupName, Group parentGroup = null)
{ : base(groupName, parentGroup)
}
public SuperAdminGroup()
{ {
} }

View file

@ -570,7 +570,7 @@ namespace TShockAPI
if (Main.netMode != 2) if (Main.netMode != 2)
return; return;
Log.Info(string.Format("{0} ({1}) from '{2}' group joined.", Tools.FindPlayer(who), Tools.GetPlayerIP(who), players[who].Group.GetName())); Log.Info(string.Format("{0} ({1}) from '{2}' group joined.", Tools.FindPlayer(who), Tools.GetPlayerIP(who), players[who].Group.Name));
Tools.ShowMOTD(who); Tools.ShowMOTD(who);
if (HackedHealth(who)) if (HackedHealth(who))

View file

@ -415,7 +415,7 @@ namespace TShockAPI
{ {
for (int j = 0; j < groups.Count; j++) for (int j = 0; j < groups.Count; j++)
{ {
if (groups[j].GetName().Equals(parent)) if (groups[j].Name.Equals(parent))
{ {
group = new Group(name, groups[j]); group = new Group(name, groups[j]);
break; break;
@ -455,7 +455,7 @@ namespace TShockAPI
//first attempt on cached groups //first attempt on cached groups
for (int i = 0; i < groups.Count; i++) for (int i = 0; i < groups.Count; i++)
{ {
if (groups[i].GetName().Equals(groupName)) if (groups[i].Name.Equals(groupName))
{ {
return groups[i]; return groups[i];
} }
@ -465,7 +465,7 @@ namespace TShockAPI
for (int i = 0; i < groups.Count; i++) for (int i = 0; i < groups.Count; i++)
{ {
if (groups[i].GetName().Equals(groupName)) if (groups[i].Name.Equals(groupName))
{ {
return groups[i]; return groups[i];
} }