- Add the
GetOtherEnds()
method to the GamePiece class:public string[] GetOtherEnds(string startingEnd) { List<string> opposites = new List<string>(); foreach (string end in pieceType.Split(',')) { if (end != startingEnd) opposites.Add(end); } return opposites.ToArray(); }
- Add the
HasConnector()
method to the GamePiece class:public bool HasConnector(string direction) { return pieceType.Contains(direction); }
The GetOtherEnds()
method creates an empty List object for holding the ends we want to return to the calling code. It then uses the Split()
method of the string class to get each end listed in the pieceType
. For example, the Top,Bottom
piece will return an array with two elements. The first element will contain Top
and the second will contain Bottom
. The comma delimiter will not be returned with either string.
If the end in question is not the same as the startingEnd
parameter that was passed to the method, it is added to the list. After all of the items in the string have been examined, the list is converted to an array and returned to the calling code.
In the previous example, requesting GetOtherEnds("Top")
from a GamePiece with a pieceType
value of Top,Bottom
will return a string array with a single element containing Bottom
.
We will need this information in a few moments when we have to figure out which pipes are filled with water and which are empty.
The second function, HasConnector()
simply returns "true" if the pieceType
string contains the string value passed in as the direction parameter. This will allow code outside the GamePiece class to determine if the piece has a connector facing in any particular direction.