gArgs.AddArg("-addresstype",strprintf("What type of addresses to use (\"legacy\", \"p2sh-segwit\", or \"bech32\", default: \"%s\")",FormatOutputType(DEFAULT_ADDRESS_TYPE)),ArgsManager::ALLOW_ANY,OptionsCategory::WALLET);
gArgs.AddArg("-avoidpartialspends",strprintf("Group outputs by address, selecting all or none, instead of selecting on a per-output basis. Privacy is improved as an address is only used once (unless someone sends to it after spending from it), but may result in slightly higher fees as suboptimal coin selection may result due to the added limitation (default: %u (always enabled for wallets with \"avoid_reuse\" enabled))",DEFAULT_AVOIDPARTIALSPENDS),ArgsManager::ALLOW_ANY,OptionsCategory::WALLET);
gArgs.AddArg("-changetype","What type of change to use (\"legacy\", \"p2sh-segwit\", or \"bech32\"). Default is same as -addresstype, except when -addresstype=p2sh-segwit a native segwit output is used when sending to a native segwit address)",ArgsManager::ALLOW_ANY,OptionsCategory::WALLET);
gArgs.AddArg("-disablewallet","Do not load the wallet and disable wallet RPC calls",ArgsManager::ALLOW_ANY,OptionsCategory::WALLET);
gArgs.AddArg("-discardfee=<amt>",strprintf("The fee rate (in %s/kB) that indicates your tolerance for discarding change by adding it to the fee (default: %s). "
"Note: An output is discarded if it is dust at this rate, but we will always discard up to the dust relay fee and a discard fee above that is limited by the fee estimate for the longest target",
gArgs.AddArg("-fallbackfee=<amt>",strprintf("A fee rate (in %s/kB) that will be used when fee estimation has insufficient data. 0 to entirely disable the fallbackfee feature. (default: %s)",
gArgs.AddArg("-keypool=<n>",strprintf("Set key pool size to <n> (default: %u). Warning: Smaller sizes may increase the risk of losing funds when restoring from an old backup, if none of the addresses in the original keypool have been used.",DEFAULT_KEYPOOL_SIZE),ArgsManager::ALLOW_ANY,OptionsCategory::WALLET);
gArgs.AddArg("-maxtxfee=<amt>",strprintf("Maximum total fees (in %s) to use in a single wallet transaction; setting this too low may abort large transactions (default: %s)",
gArgs.AddArg("-rescan","Rescan the block chain for missing wallet transactions on startup",ArgsManager::ALLOW_ANY,OptionsCategory::WALLET);
gArgs.AddArg("-salvagewallet","Attempt to recover private keys from a corrupt wallet on startup",ArgsManager::ALLOW_ANY,OptionsCategory::WALLET);
gArgs.AddArg("-spendzeroconfchange",strprintf("Spend unconfirmed change when sending transactions (default: %u)",DEFAULT_SPEND_ZEROCONF_CHANGE),ArgsManager::ALLOW_ANY,OptionsCategory::WALLET);
gArgs.AddArg("-txconfirmtarget=<n>",strprintf("If paytxfee is not set, include enough fee so transactions begin confirmation on average within n blocks (default: %u)",DEFAULT_TX_CONFIRM_TARGET),ArgsManager::ALLOW_ANY,OptionsCategory::WALLET);
gArgs.AddArg("-wallet=<path>","Specify wallet database path. Can be specified multiple times to load multiple wallets. Path is interpreted relative to <walletdir> if it is not absolute, and will be created if it does not exist (as a directory containing a wallet.dat file and log files). For backwards compatibility this will also accept names of existing data files in <walletdir>.)",ArgsManager::ALLOW_ANY|ArgsManager::NETWORK_ONLY,OptionsCategory::WALLET);
gArgs.AddArg("-walletdir=<dir>","Specify directory to hold wallets (default: <datadir>/wallets if it exists, otherwise <datadir>)",ArgsManager::ALLOW_ANY|ArgsManager::NETWORK_ONLY,OptionsCategory::WALLET);
gArgs.AddArg("-walletnotify=<cmd>","Execute command when a wallet transaction changes. %s in cmd is replaced by TxID and %w is replaced by wallet name. %w is not currently implemented on windows. On systems where %w is supported, it should NOT be quoted because this would break shell escaping used to invoke the command.",ArgsManager::ALLOW_ANY,OptionsCategory::WALLET);
gArgs.AddArg("-dblogsize=<n>",strprintf("Flush wallet database activity from memory to disk log every <n> megabytes (default: %u)",DEFAULT_WALLET_DBLOGSIZE),ArgsManager::ALLOW_ANY|ArgsManager::DEBUG_ONLY,OptionsCategory::WALLET_DEBUG_TEST);
gArgs.AddArg("-flushwallet",strprintf("Run a thread to flush wallet periodically (default: %u)",DEFAULT_FLUSHWALLET),ArgsManager::ALLOW_ANY|ArgsManager::DEBUG_ONLY,OptionsCategory::WALLET_DEBUG_TEST);
gArgs.AddArg("-privdb",strprintf("Sets the DB_PRIVATE flag in the wallet db environment (default: %u)",DEFAULT_WALLET_PRIVDB),ArgsManager::ALLOW_ANY|ArgsManager::DEBUG_ONLY,OptionsCategory::WALLET_DEBUG_TEST);
gArgs.AddArg("-walletrejectlongchains",strprintf("Wallet will not create transactions that violate mempool chain limits (default: %u)",DEFAULT_WALLET_REJECT_LONG_CHAINS),ArgsManager::ALLOW_ANY|ArgsManager::DEBUG_ONLY,OptionsCategory::WALLET_DEBUG_TEST);