From d89988e5b6cda4895b4af021384695234acd6c4a Mon Sep 17 00:00:00 2001 From: Simon McLoughlin Date: Wed, 14 Aug 2024 15:32:07 +0100 Subject: [PATCH] - bug fix: include ledger children in helper methods --- .../KukaiCoreSwift/Models/WalletMetadata.swift | 18 +++++++++++++++++- 1 file changed, 17 insertions(+), 1 deletion(-) diff --git a/Sources/KukaiCoreSwift/Models/WalletMetadata.swift b/Sources/KukaiCoreSwift/Models/WalletMetadata.swift index 2b4a816..0e1ccba 100644 --- a/Sources/KukaiCoreSwift/Models/WalletMetadata.swift +++ b/Sources/KukaiCoreSwift/Models/WalletMetadata.swift @@ -66,6 +66,10 @@ public class WalletMetadataList: Codable, Hashable { for metadata in ledgerWallets { if metadata.address == address { return metadata } + + for childMetadata in metadata.children { + if childMetadata.address == address { return childMetadata } + } } for metaData in watchWallets { @@ -104,6 +108,10 @@ public class WalletMetadataList: Codable, Hashable { for (index, metadata) in ledgerWallets.enumerated() { if metadata.address == address { ledgerWallets[index] = newMetadata; return true } + + for (childIndex, childMetadata) in metadata.children.enumerated() { + if childMetadata.address == address { hdWallets[index].children[childIndex] = newMetadata; return true } + } } for (index, metadata) in watchWallets.enumerated() { @@ -154,12 +162,16 @@ public class WalletMetadataList: Codable, Hashable { } public func count() -> Int { - var total = (socialWallets.count + linearWallets.count + ledgerWallets.count + watchWallets.count) + var total = (socialWallets.count + linearWallets.count + watchWallets.count) for wallet in hdWallets { total += (1 + wallet.children.count) } + for wallet in ledgerWallets { + total += (1 + wallet.children.count) + } + return total } @@ -184,6 +196,10 @@ public class WalletMetadataList: Codable, Hashable { for metadata in ledgerWallets { temp.append(metadata.address) + + for childMetadata in metadata.children { + temp.append(childMetadata.address) + } } for metadata in watchWallets {