Why TryParse would fail and how to Convert.ToInt

Hello everyone,

I’m currently working on a new project that works through Twitch.tv. The Script I’ll be posting grabs commands with int values. Since the text we’re parsing is always a type of “String”, in order to parse these values correctly into variables, I need to replace the command text with nothing, set up a variable to parse to and output just the integer value that the player has specified in chat.

Example: Player types “!aim 50” in chat .
The command “!aim” would get removed from the string, and “50” of type String would be left. I then attempt to convert that string value into an integer value that I can pass into the player’s instantiated prefab.

                //First we check if we're in the attack round.
                if (rm.phase == "Attack")
                {
                    GameObject playerGO = GameObject.Find(name);
                    string aimAngle = e.Command.ChatMessage.Message;
                    aimAngle = aimAngle.Replace("!aim ", "");
                    int aimAngleInt;
                    int.TryParse(aimAngle, out aimAngleInt);

                    //Do a check to see if the angle is within physics boundaries. If not, break.
                    if (aimAngleInt >= 0 && aimAngleInt <= 360)
                    {
                        //If the angle is acceptable, set the aim angle for the player.
                        //Get the player's instantiated prefab, and set angle on the attached aim script.
                        playerGO.GetComponent<Aim>().SetAimToAngle(aimAngleInt);
                        Debug.Log(aimAngleInt);
                    }
                    else
                    {
                        //The value specified was either too low or too high. Ignore the command.
                    }
                }
                else
                {
                    //Do nothing, because we're in the attack round.
                }
                break;

            case "fire":
                _client.SendMessage(e.Command.ChatMessage.Channel, $"Firing!");
                if (rm.phase == "Attack")
                {
                    string forceValue = e.Command.ChatMessage.Message;
                    forceValue = forceValue.Replace("!attack ", "");
                    int forceValueInt;
                    int.TryParse(forceValue, out forceValueInt);

With every case, except for fire, TryParse works perfectly - the string value is converted to an integer value and the int variable is assigned the int value. As mentioned, on line 36, TryParse returns a value of “0”, which if I understand correctly, means that TryParse failed to parse the string as an integer.

My questions are:

Why would every case but this one work? The code is exactly the same in terms of context, and nearly literally.
What could have changed to cause TryParse to fail in the first place?

It is absolutely necessary that the string value is converted to an integer value to pass into the player prefab’s attached Fire script.

What are some examples of other ways I could convert/parse the string as an integer knowing the answers to the above questions in mind?

so if you print out the forceValue, there is no special characters or anything there, just numbers?
int.TryParse will also return bool, so can check when it failed,
if (int.TryParse(…)==false) …

If I print the value of forceValue, it’s the entire string of the player’s chat command. IE: “!fire 50
If I print the value of forceValueInt, the value is “0”, which is the boolean return of TryParse as False.

I have put a conditional in the block of code to test:

            case "fire":
                _client.SendMessage(e.Command.ChatMessage.Channel, $"Firing!");
                if (rm.phase == "Attack")
                {
                    string forceValue = e.Command.ChatMessage.Message;
                    forceValue = forceValue.Replace("!attack ", "");
                    int forceValueInt;
                    if (int.TryParse(forceValue, out forceValueInt) == false)
                    {
                        Debug.Log("TryParse failed.");
                    }

I ran it, typed “!fire 50”, and got:
TryParse failed.

ok, then need to remove the "!fire "-part, like you do for replace "!attack "

1 Like

After hours of looking at this… it’s been a typo all along.
Face, meet palm. Palm, meet face.

You’re right, I do need to remove the !fire part, except the string to replace in that is “!attack”.

… it should be "!fire ".
I am so sorry I have missed this for two days.

debug.log() is always your best friend when things don’t work : )

you could also split using the space character, then parse the second part if split was successful,
so then no need to keep track of your replace commands if they change.

Could you give me a small snippet as an example in the context of my project? I was under the assumption that split was used to access an array, and I chose not to use this for simplicity’s sake. Is there another way?

im thinking something like,

string forceValue = e.Command.ChatMessage.Message;
                    var s = forceValue.split(' ');
                    if (s!=null && s.length>1)
                    {
                        int forceValueInt;
                        if (int.TryParse(s[1], out forceValueInt) == false)
                        {
                            Debug.Log("TryParse failed.");
                       }
                   }

actually could just take index of space, and parse substring something like

string forceValue = e.Command.ChatMessage.Message;
                    var space = forceValue.indexOf(' ')+1; // find where space is
                    if (space>0)
                    {
                        int forceValueInt;
                        if (int.TryParse(forceValue.subString(space,forceValue.length-space), out forceValueInt) == false)
                        {
                            Debug.Log("TryParse failed.");
                       }
                   }

Got it! Thanks so much for your help here. That’s making sense to me!