In SQLite errors, include the database path
This is necessary because we have multiple SQLite databases (e.g. the binary cache cache).
This commit is contained in:
		
							parent
							
								
									7251d048fa
								
							
						
					
					
						commit
						80027144ae
					
				
					 1 changed files with 8 additions and 4 deletions
				
			
		|  | @ -8,13 +8,17 @@ namespace nix { | ||||||
| [[noreturn]] void throwSQLiteError(sqlite3 * db, const format & f) | [[noreturn]] void throwSQLiteError(sqlite3 * db, const format & f) | ||||||
| { | { | ||||||
|     int err = sqlite3_errcode(db); |     int err = sqlite3_errcode(db); | ||||||
|  | 
 | ||||||
|  |     auto path = sqlite3_db_filename(db, nullptr); | ||||||
|  |     if (!path) path = "(in-memory)"; | ||||||
|  | 
 | ||||||
|     if (err == SQLITE_BUSY || err == SQLITE_PROTOCOL) { |     if (err == SQLITE_BUSY || err == SQLITE_PROTOCOL) { | ||||||
|         if (err == SQLITE_PROTOCOL) |         if (err == SQLITE_PROTOCOL) | ||||||
|             printError("warning: SQLite database is busy (SQLITE_PROTOCOL)"); |             printError("warning: SQLite database ‘%s’ is busy (SQLITE_PROTOCOL)", path); | ||||||
|         else { |         else { | ||||||
|             static bool warned = false; |             static bool warned = false; | ||||||
|             if (!warned) { |             if (!warned) { | ||||||
|                 printError("warning: SQLite database is busy"); |                 printError("warning: SQLite database ‘%s’ is busy", path); | ||||||
|                 warned = true; |                 warned = true; | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|  | @ -29,10 +33,10 @@ namespace nix { | ||||||
| #else | #else | ||||||
|         sleep(1); |         sleep(1); | ||||||
| #endif | #endif | ||||||
|         throw SQLiteBusy(format("%1%: %2%") % f.str() % sqlite3_errmsg(db)); |         throw SQLiteBusy("%s: %s (in ‘%s’)", f.str(), sqlite3_errstr(err), path); | ||||||
|     } |     } | ||||||
|     else |     else | ||||||
|         throw SQLiteError(format("%1%: %2%") % f.str() % sqlite3_errmsg(db)); |         throw SQLiteError("%s: %s (in ‘%s’)", f.str(), sqlite3_errstr(err), path); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| SQLite::SQLite(const Path & path) | SQLite::SQLite(const Path & path) | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue