LCOV - code coverage report
Current view: top level - src/common - messages.cpp (source / functions) Coverage Total Hit
Test: test_bitcoin_coverage.info Lines: 45.4 % 97 44
Test Date: 2025-10-25 04:38:23 Functions: 46.2 % 13 6
Branches: 28.9 % 135 39

             Branch data     Line data    Source code
       1                 :             : // Copyright (c) 2009-2010 Satoshi Nakamoto
       2                 :             : // Copyright (c) 2009-2022 The Bitcoin Core developers
       3                 :             : // Distributed under the MIT software license, see the accompanying
       4                 :             : // file COPYING or http://www.opensource.org/licenses/mit-license.php.
       5                 :             : 
       6                 :             : #include <common/messages.h>
       7                 :             : 
       8                 :             : #include <common/types.h>
       9                 :             : #include <policy/fees.h>
      10                 :             : #include <node/types.h>
      11                 :             : #include <tinyformat.h>
      12                 :             : #include <util/strencodings.h>
      13                 :             : #include <util/string.h>
      14                 :             : #include <util/translation.h>
      15                 :             : 
      16                 :             : #include <cassert>
      17                 :             : #include <map>
      18                 :             : #include <string>
      19                 :             : #include <string_view>
      20                 :             : #include <utility>
      21                 :             : #include <vector>
      22                 :             : 
      23                 :             : using node::TransactionError;
      24                 :             : using util::Join;
      25                 :             : 
      26                 :             : namespace common {
      27                 :          13 : std::string StringForFeeReason(FeeReason reason)
      28                 :             : {
      29                 :          13 :     static const std::map<FeeReason, std::string> fee_reason_strings = {
      30         [ +  - ]:           2 :         {FeeReason::NONE, "None"},
      31                 :           2 :         {FeeReason::HALF_ESTIMATE, "Half Target 60% Threshold"},
      32                 :           2 :         {FeeReason::FULL_ESTIMATE, "Target 85% Threshold"},
      33                 :           2 :         {FeeReason::DOUBLE_ESTIMATE, "Double Target 95% Threshold"},
      34                 :           2 :         {FeeReason::CONSERVATIVE, "Conservative Double Target longer horizon"},
      35                 :           2 :         {FeeReason::MEMPOOL_MIN, "Mempool Min Fee"},
      36                 :           2 :         {FeeReason::PAYTXFEE, "PayTxFee set"},
      37                 :           2 :         {FeeReason::FALLBACK, "Fallback fee"},
      38                 :           2 :         {FeeReason::REQUIRED, "Minimum Required Fee"},
      39   [ +  +  +  -  :          77 :     };
             +  +  -  - ]
      40                 :          13 :     auto reason_string = fee_reason_strings.find(reason);
      41                 :             : 
      42         [ -  + ]:          13 :     if (reason_string == fee_reason_strings.end()) return "Unknown";
      43                 :             : 
      44         [ -  + ]:          13 :     return reason_string->second;
      45   [ +  -  +  -  :          18 : }
          +  -  +  -  +  
          -  +  -  +  -  
          +  -  -  +  -  
                      - ]
      46                 :             : 
      47                 :         416 : const std::vector<std::pair<std::string, FeeEstimateMode>>& FeeModeMap()
      48                 :             : {
      49                 :         416 :     static const std::vector<std::pair<std::string, FeeEstimateMode>> FEE_MODES = {
      50         [ +  - ]:          44 :         {"unset", FeeEstimateMode::UNSET},
      51                 :          44 :         {"economical", FeeEstimateMode::ECONOMICAL},
      52                 :          44 :         {"conservative", FeeEstimateMode::CONSERVATIVE},
      53   [ +  +  +  -  :         592 :     };
             +  +  -  - ]
      54                 :         416 :     return FEE_MODES;
      55   [ +  -  +  -  :          44 : }
             -  +  -  - ]
      56                 :             : 
      57                 :         624 : std::string FeeModeInfo(const std::pair<std::string, FeeEstimateMode>& mode, std::string& default_info)
      58                 :             : {
      59   [ +  +  +  - ]:         624 :     switch (mode.second) {
      60                 :         208 :         case FeeEstimateMode::UNSET:
      61                 :         208 :             return strprintf("%s means no mode set (%s). \n", mode.first, default_info);
      62                 :         208 :         case FeeEstimateMode::ECONOMICAL:
      63                 :         208 :             return strprintf("%s estimates use a shorter time horizon, making them more\n"
      64                 :             :                    "responsive to short-term drops in the prevailing fee market. This mode\n"
      65                 :         208 :                    "potentially returns a lower fee rate estimate.\n", mode.first);
      66                 :         208 :         case FeeEstimateMode::CONSERVATIVE:
      67                 :         208 :             return strprintf("%s estimates use a longer time horizon, making them\n"
      68                 :             :                    "less responsive to short-term drops in the prevailing fee market. This mode\n"
      69                 :         208 :                    "potentially returns a higher fee rate estimate.\n", mode.first);
      70                 :           0 :         default:
      71                 :             :             // Other modes apart from the ones handled are fee rate units; they should not be clarified.
      72                 :           0 :             assert(false);
      73                 :             :     }
      74                 :             : }
      75                 :             : 
      76                 :         208 : std::string FeeModesDetail(std::string default_info)
      77                 :             : {
      78         [ +  - ]:         208 :     std::string info;
      79   [ +  -  +  + ]:         832 :     for (const auto& fee_mode : FeeModeMap()) {
      80         [ +  - ]:        1248 :         info += FeeModeInfo(fee_mode, default_info);
      81                 :             :     }
      82   [ +  -  +  -  :         416 :     return strprintf("%s \n%s", FeeModes(", "), info);
                   +  - ]
      83                 :         208 : }
      84                 :             : 
      85                 :         208 : std::string FeeModes(const std::string& delimiter)
      86                 :             : {
      87   [ -  +  -  + ]:        1456 :     return Join(FeeModeMap(), delimiter, [&](const std::pair<std::string, FeeEstimateMode>& i) { return i.first; });
      88                 :             : }
      89                 :             : 
      90                 :           0 : std::string InvalidEstimateModeErrorMessage()
      91                 :             : {
      92   [ #  #  #  # ]:           0 :     return "Invalid estimate_mode parameter, must be one of: \"" + FeeModes("\", \"") + "\"";
      93                 :             : }
      94                 :             : 
      95                 :           0 : bool FeeModeFromString(std::string_view mode_string, FeeEstimateMode& fee_estimate_mode)
      96                 :             : {
      97                 :           0 :     auto searchkey = ToUpper(mode_string);
      98   [ #  #  #  # ]:           0 :     for (const auto& pair : FeeModeMap()) {
      99   [ #  #  #  #  :           0 :         if (ToUpper(pair.first) == searchkey) {
                   #  # ]
     100                 :           0 :             fee_estimate_mode = pair.second;
     101                 :           0 :             return true;
     102                 :             :         }
     103                 :             :     }
     104                 :             :     return false;
     105                 :           0 : }
     106                 :             : 
     107                 :           0 : bilingual_str PSBTErrorString(PSBTError err)
     108                 :             : {
     109   [ #  #  #  #  :           0 :     switch (err) {
             #  #  #  # ]
     110                 :           0 :         case PSBTError::MISSING_INPUTS:
     111         [ #  # ]:           0 :             return Untranslated("Inputs missing or spent");
     112                 :           0 :         case PSBTError::SIGHASH_MISMATCH:
     113         [ #  # ]:           0 :             return Untranslated("Specified sighash value does not match value stored in PSBT");
     114                 :           0 :         case PSBTError::EXTERNAL_SIGNER_NOT_FOUND:
     115         [ #  # ]:           0 :             return Untranslated("External signer not found");
     116                 :           0 :         case PSBTError::EXTERNAL_SIGNER_FAILED:
     117         [ #  # ]:           0 :             return Untranslated("External signer failed to sign");
     118                 :           0 :         case PSBTError::UNSUPPORTED:
     119         [ #  # ]:           0 :             return Untranslated("Signer does not support PSBT");
     120                 :           0 :         case PSBTError::INCOMPLETE:
     121         [ #  # ]:           0 :             return Untranslated("Input needs additional signatures or other data");
     122                 :           0 :         case PSBTError::OK:
     123         [ #  # ]:           0 :             return Untranslated("No errors");
     124                 :             :         // no default case, so the compiler can warn about missing cases
     125                 :             :     }
     126                 :           0 :     assert(false);
     127                 :             : }
     128                 :             : 
     129                 :           0 : bilingual_str TransactionErrorString(const TransactionError err)
     130                 :             : {
     131   [ #  #  #  #  :           0 :     switch (err) {
             #  #  #  #  
                      # ]
     132                 :           0 :         case TransactionError::OK:
     133         [ #  # ]:           0 :             return Untranslated("No error");
     134                 :           0 :         case TransactionError::MISSING_INPUTS:
     135         [ #  # ]:           0 :             return Untranslated("Inputs missing or spent");
     136                 :           0 :         case TransactionError::ALREADY_IN_UTXO_SET:
     137         [ #  # ]:           0 :             return Untranslated("Transaction outputs already in utxo set");
     138                 :           0 :         case TransactionError::MEMPOOL_REJECTED:
     139         [ #  # ]:           0 :             return Untranslated("Transaction rejected by mempool");
     140                 :           0 :         case TransactionError::MEMPOOL_ERROR:
     141         [ #  # ]:           0 :             return Untranslated("Mempool internal error");
     142                 :           0 :         case TransactionError::MAX_FEE_EXCEEDED:
     143         [ #  # ]:           0 :             return Untranslated("Fee exceeds maximum configured by user (e.g. -maxtxfee, maxfeerate)");
     144                 :           0 :         case TransactionError::MAX_BURN_EXCEEDED:
     145         [ #  # ]:           0 :             return Untranslated("Unspendable output exceeds maximum configured by user (maxburnamount)");
     146                 :           0 :         case TransactionError::INVALID_PACKAGE:
     147         [ #  # ]:           0 :             return Untranslated("Transaction rejected due to invalid package");
     148                 :             :         // no default case, so the compiler can warn about missing cases
     149                 :             :     }
     150                 :           0 :     assert(false);
     151                 :             : }
     152                 :             : 
     153                 :           2 : bilingual_str ResolveErrMsg(const std::string& optname, const std::string& strBind)
     154                 :             : {
     155                 :           2 :     return strprintf(_("Cannot resolve -%s address: '%s'"), optname, strBind);
     156                 :             : }
     157                 :             : 
     158                 :           0 : bilingual_str InvalidPortErrMsg(const std::string& optname, const std::string& invalid_value)
     159                 :             : {
     160                 :           0 :     return strprintf(_("Invalid port specified in %s: '%s'"), optname, invalid_value);
     161                 :             : }
     162                 :             : 
     163                 :           0 : bilingual_str AmountHighWarn(const std::string& optname)
     164                 :             : {
     165                 :           0 :     return strprintf(_("%s is set very high!"), optname);
     166                 :             : }
     167                 :             : 
     168                 :           0 : bilingual_str AmountErrMsg(const std::string& optname, const std::string& strValue)
     169                 :             : {
     170                 :           0 :     return strprintf(_("Invalid amount for -%s=<amount>: '%s'"), optname, strValue);
     171                 :             : }
     172                 :             : } // namespace common
        

Generated by: LCOV version 2.0-1