mirror of
				https://github.com/LadybirdBrowser/ladybird.git
				synced 2025-11-04 07:10:57 +00:00 
			
		
		
		
	This commit un-deprecates DeprecatedString, and repurposes it as a byte
string.
As the null state has already been removed, there are no other
particularly hairy blockers in repurposing this type as a byte string
(what it _really_ is).
This commit is auto-generated:
  $ xs=$(ack -l \bDeprecatedString\b\|deprecated_string AK Userland \
    Meta Ports Ladybird Tests Kernel)
  $ perl -pie 's/\bDeprecatedString\b/ByteString/g;
    s/deprecated_string/byte_string/g' $xs
  $ clang-format --style=file -i \
    $(git diff --name-only | grep \.cpp\|\.h)
  $ gn format $(git ls-files '*.gn' '*.gni')
		
	
			
		
			
				
	
	
		
			40 lines
		
	
	
	
		
			971 B
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			40 lines
		
	
	
	
		
			971 B
		
	
	
	
		
			C++
		
	
	
	
	
	
/*
 | 
						|
 * Copyright (c) 2020-2022, Linus Groh <linusg@serenityos.org>
 | 
						|
 *
 | 
						|
 * SPDX-License-Identifier: BSD-2-Clause
 | 
						|
 */
 | 
						|
 | 
						|
#pragma once
 | 
						|
 | 
						|
#include <AK/Error.h>
 | 
						|
#include <AK/String.h>
 | 
						|
#include <AK/StringView.h>
 | 
						|
#include <LibCrypto/BigInt/SignedBigInteger.h>
 | 
						|
#include <LibJS/Heap/Cell.h>
 | 
						|
#include <LibJS/Heap/CellAllocator.h>
 | 
						|
 | 
						|
namespace JS {
 | 
						|
 | 
						|
class BigInt final : public Cell {
 | 
						|
    JS_CELL(BigInt, Cell);
 | 
						|
    JS_DECLARE_ALLOCATOR(BigInt);
 | 
						|
 | 
						|
public:
 | 
						|
    [[nodiscard]] static NonnullGCPtr<BigInt> create(VM&, Crypto::SignedBigInteger);
 | 
						|
 | 
						|
    virtual ~BigInt() override = default;
 | 
						|
 | 
						|
    Crypto::SignedBigInteger const& big_integer() const { return m_big_integer; }
 | 
						|
 | 
						|
    ErrorOr<String> to_string() const;
 | 
						|
    ByteString to_byte_string() const { return ByteString::formatted("{}n", m_big_integer.to_base_deprecated(10)); }
 | 
						|
 | 
						|
private:
 | 
						|
    explicit BigInt(Crypto::SignedBigInteger);
 | 
						|
 | 
						|
    Crypto::SignedBigInteger m_big_integer;
 | 
						|
};
 | 
						|
 | 
						|
ThrowCompletionOr<BigInt*> number_to_bigint(VM&, Value);
 | 
						|
 | 
						|
}
 |