Fairly simple question:
I have an init method on my class that has the potential to go wrong. If it does, I plan to “return nil”, but I would also like to return an error. Is it bad practice to have an NSError** parameter to an init method? My method declaration would look like this:
- (id) initWithArgs:(NSString*) args andError:(NSError**)error;
Many thanks,
Nick
It’s unusual, but I don’t think it’s necessarily a bad practice. I’d name the second part of the method just “error” instead of “andError:”, though. You don’t need to connect the parts of a method name with ‘and’, and in this case it also gives the impression that the error is being used to initialize the object. Just make it:
Also, don’t forget to release the allocated object if you plan to return something else (like nil):