db/simple: handle exception in Open() properly, fix memory leak
This commit is contained in:
		| @@ -198,7 +198,7 @@ SimpleDatabase::Load(Error &error) | ||||
|  | ||||
| bool | ||||
| SimpleDatabase::Open(Error &error) | ||||
| try { | ||||
| { | ||||
| 	assert(prefixed_light_song == nullptr); | ||||
|  | ||||
| 	root = Directory::NewRoot(); | ||||
| @@ -208,6 +208,7 @@ try { | ||||
| 	borrowed_song_count = 0; | ||||
| #endif | ||||
|  | ||||
| 	try { | ||||
| 		Error error2; | ||||
| 		if (!Load(error2)) { | ||||
| 			LogError(error2); | ||||
| @@ -219,11 +220,18 @@ try { | ||||
|  | ||||
| 			root = Directory::NewRoot(); | ||||
| 		} | ||||
| 	} catch (const std::exception &e) { | ||||
| 		LogError(e); | ||||
|  | ||||
| 		delete root; | ||||
|  | ||||
| 		if (!Check(error)) | ||||
| 			return false; | ||||
|  | ||||
| 		root = Directory::NewRoot(); | ||||
| 	} | ||||
|  | ||||
| 	return true; | ||||
| } catch (const std::exception &e) { | ||||
| 	error.Set(std::current_exception()); | ||||
| 	return false; | ||||
| } | ||||
|  | ||||
| void | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Max Kellermann
					Max Kellermann