I’m getting an infrequent null reference exception in one of my coroutines. I’m sure I can figure out where the problem lies myself after a bit of testing, but I have a question about the error message which results from this crash:
DETAILED EXCEPTION END
System.NullReferenceException: Object reference not set to an instance of an object
PilotInterceptor+<SelectNewTarget>__6:MoveNext ()
(Filename: Line: 538357416)
(That’s probably not the correct line number. )
I’m wondering how I should interpret the above message. PilotInterceptor is the name of the class and SelectNewTarget is the coroutine, but what does the __6 and MoveNext refer to? The latter is presumably an internal Unity symbol since it doesn’t appear in my code. It there any useful information that can be extracted from this?
It says that it happens in the script PilotInterceptor and it’s function SelectNewTarget.
This is just a bug where stacktraces for coroutines aren’t generated correctly.
One way to get to the exact stacktrace is to call another function from the coroutine.
And yes, we are fixing stacktraces to always report the exact line number with the next major release. Also we will include a lot of information about why exactly you got that null reference exception.
You should not be able to crash the editor though, if you can, please report a bug.
No, it was just my code causing Mono to crash. I found my mistake a few seconds after I posted - I forgot to check if my target finding method was returning null when nothing was in range.
Thanks for the hint about calling another method to get a better stack trace, that’s very helpful.
Yes, that’s what I meant. It was just a crash in my script (which caused the Apple crash reporter to appear), and Unity continued to work without problems.
The stacktrace means that the error happens in the IEnumerator’s MoveNext method. It should also include the line number that shows where inside your IEnumerator the error is thrown.
A lot of stuff happens with a coroutine, but in essence, the IEnumerator you define in your method is generated, and MoveNext is called on it every Update until it’s done. So your coroutine is throwing an error during that.