mirror of
				https://github.com/LadybirdBrowser/ladybird.git
				synced 2025-10-20 15:09:42 +00:00 
			
		
		
		
	LibWeb+LibXML: Make Listener::set_source(ByteString) fallible
	
		
			
	
		
	
	
		
	
		
			Some checks are pending
		
		
	
	
		
			
				
	
				CI / Linux, x86_64, Fuzzers, Clang (push) Waiting to run
				
			
		
			
				
	
				CI / macOS, arm64, Sanitizer, Clang (push) Waiting to run
				
			
		
			
				
	
				CI / Linux, x86_64, Sanitizer, GNU (push) Waiting to run
				
			
		
			
				
	
				CI / Linux, x86_64, Sanitizer, Clang (push) Waiting to run
				
			
		
			
				
	
				Package the js repl as a binary artifact / Linux, arm64 (push) Waiting to run
				
			
		
			
				
	
				Package the js repl as a binary artifact / macOS, arm64 (push) Waiting to run
				
			
		
			
				
	
				Package the js repl as a binary artifact / Linux, x86_64 (push) Waiting to run
				
			
		
			
				
	
				Run test262 and test-wasm / run_and_update_results (push) Waiting to run
				
			
		
			
				
	
				Lint Code / lint (push) Waiting to run
				
			
		
			
				
	
				Label PRs with merge conflicts / auto-labeler (push) Waiting to run
				
			
		
			
				
	
				Push notes / build (push) Waiting to run
				
			
		
		
	
	
		
	
		
			Some checks are pending
		
		
	
	CI / Linux, x86_64, Fuzzers, Clang (push) Waiting to run
				
			CI / macOS, arm64, Sanitizer, Clang (push) Waiting to run
				
			CI / Linux, x86_64, Sanitizer, GNU (push) Waiting to run
				
			CI / Linux, x86_64, Sanitizer, Clang (push) Waiting to run
				
			Package the js repl as a binary artifact / Linux, arm64 (push) Waiting to run
				
			Package the js repl as a binary artifact / macOS, arm64 (push) Waiting to run
				
			Package the js repl as a binary artifact / Linux, x86_64 (push) Waiting to run
				
			Run test262 and test-wasm / run_and_update_results (push) Waiting to run
				
			Lint Code / lint (push) Waiting to run
				
			Label PRs with merge conflicts / auto-labeler (push) Waiting to run
				
			Push notes / build (push) Waiting to run
				
			`set_source` takes a ByteString but the implementation might require a specific encoding. Make it fallible so that we don't need to crash in the case of invalid UTF-8 or similar. The test includes a sequence of invalid UTF-8 bytes that crash the browser without this change.
This commit is contained in:
		
					parent
					
						
							
								2397ae4af5
							
						
					
				
			
			
				commit
				
					
						b9554038ff
					
				
			
		
		
		Notes:
		
			github-actions[bot]
		
		2025-10-02 00:27:16 +00:00 
		
	
	Author: https://github.com/rmg-x
Commit: b9554038ff
Pull-request: https://github.com/LadybirdBrowser/ladybird/pull/6353
Reviewed-by: https://github.com/alimpfard ✅
Reviewed-by: https://github.com/trflynn89
	
					 7 changed files with 25 additions and 5 deletions
				
			
		|  | @ -62,9 +62,10 @@ XMLDocumentBuilder::XMLDocumentBuilder(DOM::Document& document, XMLScriptingSupp | |||
|     m_namespace_stack.append({ {}, 1 }); | ||||
| } | ||||
| 
 | ||||
| void XMLDocumentBuilder::set_source(ByteString source) | ||||
| ErrorOr<void> XMLDocumentBuilder::set_source(ByteString source) | ||||
| { | ||||
|     m_document->set_source(MUST(String::from_byte_string(source))); | ||||
|     m_document->set_source(TRY(String::from_byte_string(source))); | ||||
|     return {}; | ||||
| } | ||||
| 
 | ||||
| void XMLDocumentBuilder::set_doctype(XML::Doctype doctype) | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue