Commit 7d978084 authored by Hiroshi Ichikawa's avatar Hiroshi Ichikawa Committed by Thomas Van Lenten

[objectivec] Fix memory leak of exceptions raised by RaiseException() (#4556)

* Fix memory leak of exceptions raised by RaiseException()

Currently exceptions raised by RaiseException() is never deallocated because:

* ARC is disabled for this library: https://github.com/google/protobuf/blob/master/BUILD#L913
* It is constructed with `+alloc` but is never `-release`d.

This change fixes the issue by using `-[NSException exceptionWithName:...]` instead, which returns an autoreleased instance, so it is deallocated properly.

* Fix format.
parent fc922d16
...@@ -63,9 +63,9 @@ static void RaiseException(NSInteger code, NSString *reason) { ...@@ -63,9 +63,9 @@ static void RaiseException(NSInteger code, NSString *reason) {
NSDictionary *exceptionInfo = NSDictionary *exceptionInfo =
@{ GPBCodedInputStreamUnderlyingErrorKey: error }; @{ GPBCodedInputStreamUnderlyingErrorKey: error };
[[[NSException alloc] initWithName:GPBCodedInputStreamException [[NSException exceptionWithName:GPBCodedInputStreamException
reason:reason reason:reason
userInfo:exceptionInfo] raise]; userInfo:exceptionInfo] raise];
} }
static void CheckRecursionLimit(GPBCodedInputStreamState *state) { static void CheckRecursionLimit(GPBCodedInputStreamState *state) {
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment