Instruments is pointing out that this is a memory leak, however I'm unsure how to release it properly, or when it should be released. Is there a better convention for assigning properties with new objects that are only needed inside a loop? The specific line is the "expense.addedDate = [NSDate new];".
- (void) addObjects:(NSString *)itemDescription withItemAmount:(NSString *)itemAmount {
// Add a new expense to the persistent store.
NSString *expenseDescription = itemDescription;
NSString *expenseAmount = itemAmount;
if (!expenseDescription.length || !expenseAmount.length) {
UIAlertView *invalidEntry = [[[UIAlertView alloc] initWithTitle:@"Invalid Entry"
message:@"You must include a description and cost."
delegate:self
cancelButtonTitle:@"OK"
otherButtonTitles:nil] autorelease];
[invalidEntry show];
} else {
Expense *expense = (Expense *)[NSEntityDescription insertNewObjectForEntityForName:@"Expense"
inManagedObjectContext:self.managedObjectContext];
expense.addedDate = [NSDate new];
expense.itemDescription = expenseDescription;
expense.cost = [NSNumber numberWithInt:[expenseAmount intValue]];
NSError *error;
if (![self.managedObjectContext save:&error]) {
NSLog(@"Error %@", [error localizedDescription]);
UIAlertView *errorSave = [[[UIAlertView alloc] initWithTitle:@"Unable to Save!"
message:@"Money manager was not able to save this entry."
delegate:self
cancelButtonTitle:@"OK"
otherButtonTitles:nil] autorelease];
[errorSave show];
} else {
NSLog(@"Saved Expense to Database.");
}
}
}