mirror of
				https://github.com/RGBCube/serenity
				synced 2025-10-31 17:02:45 +00:00 
			
		
		
		
	LibSQL+SQLServer: Return a NonnullRefPtr from Database::get_table
Database::get_table currently either returns a RefPtr to an existing table, a nullptr if the table doesn't exist, or an Error if some internal error occured. Change this to return a NonnullRefPtr to an exisiting table, or a SQL::Result with any error, including if the table was not found. Callers can then handle that specific error code if they want. Returning a NonnullRefPtr will enable some further cleanup. This had some fallout of needing to change some other methods' return types from AK::ErrorOr to SQL::Result so that TRY may continue to be used.
This commit is contained in:
		
							parent
							
								
									56843baff9
								
							
						
					
					
						commit
						4b70908dc4
					
				
					 8 changed files with 56 additions and 79 deletions
				
			
		|  | @ -24,8 +24,6 @@ ResultOr<ResultSet> Select::execute(ExecutionContext& context) const | |||
|             return Result { SQLCommand::Select, SQLErrorCode::NotYetImplemented, "Sub-selects are not yet implemented"sv }; | ||||
| 
 | ||||
|         auto table_def = TRY(context.database->get_table(table_descriptor.schema_name(), table_descriptor.table_name())); | ||||
|         if (!table_def) | ||||
|             return Result { SQLCommand::Select, SQLErrorCode::TableDoesNotExist, table_descriptor.table_name() }; | ||||
| 
 | ||||
|         if (result_column_list.size() == 1 && result_column_list[0].type() == ResultType::All) { | ||||
|             for (auto& col : table_def->columns()) { | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Timothy Flynn
						Timothy Flynn