mirror of
				https://github.com/yuzu-emu/yuzu-android
				synced 2025-10-24 19:50:29 -07:00 
			
		
		
		
	General: Make use of std::nullopt where applicable
Allows some implementations to avoid completely zeroing out the internal buffer of the optional, and instead only set the validity byte within the structure. This also makes it consistent how we return empty optionals.
This commit is contained in:
		| @@ -323,7 +323,7 @@ bool NCA::ReadRomFSSection(const NCASectionHeader& section, const NCASectionTabl | ||||
|         subsection_buckets.back().entries.push_back({section.bktr.relocation.offset, {0}, ctr_low}); | ||||
|         subsection_buckets.back().entries.push_back({size, {0}, 0}); | ||||
|  | ||||
|         std::optional<Core::Crypto::Key128> key = {}; | ||||
|         std::optional<Core::Crypto::Key128> key; | ||||
|         if (encrypted) { | ||||
|             if (has_rights_id) { | ||||
|                 status = Loader::ResultStatus::Success; | ||||
| @@ -442,18 +442,18 @@ std::optional<Core::Crypto::Key128> NCA::GetTitlekey() { | ||||
|     memcpy(rights_id.data(), header.rights_id.data(), 16); | ||||
|     if (rights_id == u128{}) { | ||||
|         status = Loader::ResultStatus::ErrorInvalidRightsID; | ||||
|         return {}; | ||||
|         return std::nullopt; | ||||
|     } | ||||
|  | ||||
|     auto titlekey = keys.GetKey(Core::Crypto::S128KeyType::Titlekey, rights_id[1], rights_id[0]); | ||||
|     if (titlekey == Core::Crypto::Key128{}) { | ||||
|         status = Loader::ResultStatus::ErrorMissingTitlekey; | ||||
|         return {}; | ||||
|         return std::nullopt; | ||||
|     } | ||||
|  | ||||
|     if (!keys.HasKey(Core::Crypto::S128KeyType::Titlekek, master_key_id)) { | ||||
|         status = Loader::ResultStatus::ErrorMissingTitlekek; | ||||
|         return {}; | ||||
|         return std::nullopt; | ||||
|     } | ||||
|  | ||||
|     Core::Crypto::AESCipher<Core::Crypto::Key128> cipher( | ||||
| @@ -477,7 +477,7 @@ VirtualFile NCA::Decrypt(const NCASectionHeader& s_header, VirtualFile in, u64 s | ||||
|     case NCASectionCryptoType::BKTR: | ||||
|         LOG_TRACE(Crypto, "called with mode=CTR, starting_offset={:016X}", starting_offset); | ||||
|         { | ||||
|             std::optional<Core::Crypto::Key128> key = {}; | ||||
|             std::optional<Core::Crypto::Key128> key; | ||||
|             if (has_rights_id) { | ||||
|                 status = Loader::ResultStatus::Success; | ||||
|                 key = GetTitlekey(); | ||||
|   | ||||
| @@ -169,11 +169,12 @@ VfsDirectory::~VfsDirectory() = default; | ||||
|  | ||||
| std::optional<u8> VfsFile::ReadByte(std::size_t offset) const { | ||||
|     u8 out{}; | ||||
|     std::size_t size = Read(&out, 1, offset); | ||||
|     if (size == 1) | ||||
|     const std::size_t size = Read(&out, sizeof(u8), offset); | ||||
|     if (size == 1) { | ||||
|         return out; | ||||
|     } | ||||
|  | ||||
|     return {}; | ||||
|     return std::nullopt; | ||||
| } | ||||
|  | ||||
| std::vector<u8> VfsFile::ReadBytes(std::size_t size, std::size_t offset) const { | ||||
|   | ||||
| @@ -58,10 +58,11 @@ std::size_t OffsetVfsFile::Write(const u8* data, std::size_t length, std::size_t | ||||
| } | ||||
|  | ||||
| std::optional<u8> OffsetVfsFile::ReadByte(std::size_t r_offset) const { | ||||
|     if (r_offset < size) | ||||
|         return file->ReadByte(offset + r_offset); | ||||
|     if (r_offset >= size) { | ||||
|         return std::nullopt; | ||||
|     } | ||||
|  | ||||
|     return {}; | ||||
|     return file->ReadByte(offset + r_offset); | ||||
| } | ||||
|  | ||||
| std::vector<u8> OffsetVfsFile::ReadBytes(std::size_t r_size, std::size_t r_offset) const { | ||||
|   | ||||
| @@ -54,9 +54,11 @@ public: | ||||
|     } | ||||
|  | ||||
|     std::optional<u8> ReadByte(std::size_t offset) const override { | ||||
|         if (offset < size) | ||||
|             return value; | ||||
|         return {}; | ||||
|         if (offset >= size) { | ||||
|             return std::nullopt; | ||||
|         } | ||||
|  | ||||
|         return value; | ||||
|     } | ||||
|  | ||||
|     std::vector<u8> ReadBytes(std::size_t length, std::size_t offset) const override { | ||||
|   | ||||
		Reference in New Issue
	
	Block a user