Idan Horowitz 
								
							 
						 
						
							
							
								
							
							
	110136b862  
						 
						
							
							
								
								
								LibCrypto: Convert SignedBigInteger::import_data to accept Bytes  
							
							... 
							
							
	
		
			
	 
	
	
		
	
	
		
			
				
	CI / macOS, arm64, Sanitizer, Clang (push) Waiting to run 
				
			 
		
			
				
	CI / Linux, x86_64, Fuzzers, 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 
				
			 
		
		
	 
 
	 
							
							This brings it up to par with UnsignedBigInteger. 
							
						 
						
							2025-08-05 09:08:56 +02:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									Idan Horowitz 
								
							 
						 
						
							
							
								
							
							
	2a3b072d0e  
						 
						
							
							
								
								
								LibCrypto: Convert SignedBigInteger::export_data to return a span  
							
							... 
							
							
							
							This brings it up to par with UnsignedBigInteger. 
							
						 
						
							2025-08-05 09:08:56 +02:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									Timothy Flynn 
								
							 
						 
						
							
							
								
							
							
	8600c5149b  
						 
						
							
							
								
								
								LibCrypto: Allow moving SignedBigInteger / UnsignedBigInteger  
							
							... 
							
							
							
							We defined copy operations but not move operations, so every existing
move() resulted in a copy. 
							
						 
						
							2025-07-21 15:17:53 +02:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									Timothy Flynn 
								
							 
						 
						
							
							
								
							
							
	cd73c70ad6  
						 
						
							
							
								
								
								LibCrypto: Copy the cached hash in SignedBigInteger / UnsignedBigInteger  
							
							... 
							
							
							
							The hash computation for big integers is pretty expensive, so if we have
a cached hash when copying a big int, let's also copy the hash. 
							
						 
						
							2025-07-21 15:17:53 +02:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									devgianlu 
								
							 
						 
						
							
							
								
							
							
	4b3715ccba  
						 
						
							
							
								
								
								LibCrypto: Replace {Unsigned,Signed}BigInteger impl with LibTomMath  
							
							... 
							
							
	
		
			
	 
	
	
		
	
	
		
			
				
	CI / Lagom (arm64, Sanitizer_CI, false, macos-15, macOS, Clang) (push) Waiting to run 
				
			 
		
			
				
	CI / Lagom (x86_64, Fuzzers_CI, false, ubuntu-24.04, Linux, Clang) (push) Waiting to run 
				
			 
		
			
				
	CI / Lagom (x86_64, Sanitizer_CI, false, ubuntu-24.04, Linux, GNU) (push) Waiting to run 
				
			 
		
			
				
	CI / Lagom (x86_64, Sanitizer_CI, true, ubuntu-24.04, Linux, Clang) (push) Waiting to run 
				
			 
		
			
				
	Build Dev Container Image / build (push) Waiting to run 
				
			 
		
			
				
	Package the js repl as a binary artifact / build-and-package (arm64, macos-15, macOS, macOS-universal2) (push) Waiting to run 
				
			 
		
			
				
	Package the js repl as a binary artifact / build-and-package (x86_64, ubuntu-24.04, Linux, 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 
				
			 
		
		
	 
 
	 
							
							Replace the implementation of maths in `UnsignedBigInteger`
and `SignedBigInteger` with LibTomMath. This gives benefits in terms of
less code to maintain, correctness and speed.
These changes also remove now-unsued methods and improve the error
propagation for functions allocating lots of memory. Additionally, the
new implementation is always trimmed and won't have dangling zeros when
exporting it. 
							
						 
						
							2025-05-23 11:57:21 +02:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									devgianlu 
								
							 
						 
						
							
							
								
							
							
	5a4cfd05d0  
						 
						
							
							
								
								
								LibCrypto+LibJS: Move Power to method of {Unsigned,Signed}BigInteger  
							
							... 
							
							
							
							Having it as a method instead of a free function is necessary for the
next commits and generally allows for optimizations that require deeper
access into the `UnsignedBigInteger` / `SignedBigInteger`.
Also restrict the exponent to 32 bits to avoid huge memory allocations. 
							
						 
						
							2025-05-23 11:57:21 +02:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									devgianlu 
								
							 
						 
						
							
							
								
							
							
	5f1a30197c  
						 
						
							
							
								
								
								LibCrypto: Remove the concept of invalid big integers  
							
							... 
							
							
							
							This concept is rarely used in codebase and very much error-prone
if you forget to check it.
Instead, make it so that operations that would produce invalid integers
return an error instead. 
							
						 
						
							2025-04-28 12:05:26 +02:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									devgianlu 
								
							 
						 
						
							
							
								
							
							
	a019efb24b  
						 
						
							
							
								
								
								LibCrypto+LibJS: Remove {Signed,Unsigned}BigInteger to_base_deprecated  
							
							... 
							
							
							
							Use `to_base` instead. 
							
						 
						
							2025-04-28 12:05:26 +02:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									Jess 
								
							 
						 
						
							
							
								
							
							
	12cbefbee7  
						 
						
							
							
								
								
								LibJS+LibCrypto: Use a bitwise approach for BigInt's as*IntN methods  
							
							... 
							
							
							
							This speeds up expressions such as `BigInt.asIntN(0x4000000000000, 1n)`
(#3615 ). And those involving very large bigints. 
							
						 
						
							2025-03-20 09:44:12 +01:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									Jess 
								
							 
						 
						
							
							
								
							
							
	8fda05d8b7  
						 
						
							
							
								
								
								LibCrypto: Introduce a falible API for SignedBigInteger::shift_left  
							
							
							
						 
						
							2025-02-19 09:00:59 -05:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									Timothy Flynn 
								
							 
						 
						
							
							
								
							
							
	93712b24bf  
						 
						
							
							
								
								
								Everywhere: Hoist the Libraries folder to the top-level  
							
							
							
						 
						
							2024-11-10 12:50:45 +01:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									Andreas Kling 
								
							 
						 
						
							
							
								
							
							
	13d7c09125  
						 
						
							
							
								
								
								Libraries: Move to Userland/Libraries/  
							
							
							
						 
						
							2021-01-12 12:17:46 +01:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									Andreas Kling 
								
							 
						 
						
							
							
								
							
							
	7ed89703fe  
						 
						
							
							
								
								
								LibCrypto+LibJS: Fix broken subtraction of two negative signed bigints  
							
							... 
							
							
							
							Found by oss-fuzz: https://bugs.chromium.org/p/oss-fuzz/issues/detail?id=29326  
							
						 
						
							2021-01-07 08:57:37 +01:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									AnotherTest 
								
							 
						 
						
							
							
								
							
							
	b00ffc860b  
						 
						
							
							
								
								
								LibCrypto: Do not trim leading zeros in export_data by default  
							
							... 
							
							
							
							This fixes the issue with the exported data having a leading zero,
causing RSA::encrypt to trim the block down, and ruining the encryption.
Fixes  #2691  :^) 
							
						 
						
							2020-07-31 18:25:20 +02:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									asynts 
								
							 
						 
						
							
							
								
							
							
	4709b700bd  
						 
						
							
							
								
								
								LibCrypto: Change [XXX]BigInteger::export_data() to use Span.  
							
							
							
						 
						
							2020-07-27 19:58:09 +02:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									AnotherTest 
								
							 
						 
						
							
							
								
							
							
	02c53fd1f9  
						 
						
							
							
								
								
								LibCrypto: Add bitwise operations (and/or/xor)  
							
							
							
						 
						
							2020-06-07 19:29:40 +02:00 
							
								 
							
							
								 
							
						 
					 
				
					
						
							
								
								
									AnotherTest 
								
							 
						 
						
							
							
								
							
							
	d8208fd37c  
						 
						
							
							
								
								
								LibCrypto: Add a simple SignedBigInteger  
							
							... 
							
							
							
							This patchset adds a simple SignedBigInteger that is entirely defined in
terms of UnsignedBigInteger.
It also adds a NumberTheory::Power function, which is terribly
inefficient, but since the use of exponentiation is very much
discouraged for large inputs, no particular attempts were made
to make it more performant. 
							
						 
						
							2020-06-05 13:29:44 +02:00