[utils] Allow bitcoin-cli's -rpcconnect option to be used with square brackets #10812
Merged
Commits
Show all changes
2 commits
Select commit
Hold shift + click to select a range
Jump to file or symbol
Failed to load files and symbols.
| @@ -91,6 +91,25 @@ std::vector<unsigned char> ParseHex(const std::string& str) | ||
| return ParseHex(str.c_str()); | ||
| } | ||
| +void SplitHostPort(std::string in, int &portOut, std::string &hostOut) { | ||
jnewbery
Member
|
||
| + size_t colon = in.find_last_of(':'); | ||
| + // if a : is found, and it either follows a [...], or no other : is in the string, treat it as port separator | ||
| + bool fHaveColon = colon != in.npos; | ||
| + bool fBracketed = fHaveColon && (in[0]=='[' && in[colon-1]==']'); // if there is a colon, and in[0]=='[', colon is not 0, so in[colon-1] is safe | ||
| + bool fMultiColon = fHaveColon && (in.find_last_of(':',colon-1) != in.npos); | ||
| + if (fHaveColon && (colon==0 || fBracketed || !fMultiColon)) { | ||
| + int32_t n; | ||
| + if (ParseInt32(in.substr(colon + 1), &n) && n > 0 && n < 0x10000) { | ||
| + in = in.substr(0, colon); | ||
| + portOut = n; | ||
| + } | ||
| + } | ||
| + if (in.size()>0 && in[0] == '[' && in[in.size()-1] == ']') | ||
| + hostOut = in.substr(1, in.size()-2); | ||
| + else | ||
| + hostOut = in; | ||
| +} | ||
| + | ||
| std::string EncodeBase64(const unsigned char* pch, size_t len) | ||
| { | ||
| static const char *pbase64 = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/"; | ||
This really doesn't belong in strencodings.