diff options
Diffstat (limited to 'core/ustring.cpp')
| -rw-r--r-- | core/ustring.cpp | 66 | 
1 files changed, 64 insertions, 2 deletions
diff --git a/core/ustring.cpp b/core/ustring.cpp index d749146998..954f590218 100644 --- a/core/ustring.cpp +++ b/core/ustring.cpp @@ -3165,7 +3165,7 @@ String String::word_wrap(int p_chars_per_line) const {  	return ret;  } -String String::percent_encode() const { +String String::http_escape() const {  	const CharString temp = utf8();  	String res;  	for (int i = 0; i < temp.length(); ++i) { @@ -3189,7 +3189,7 @@ String String::percent_encode() const {  	return res;  } -String String::percent_decode() const { +String String::http_unescape() const {  	String res;  	for (int i = 0; i < length(); ++i) {  		if (ord_at(i) == '%' && i + 2 < length()) { @@ -3727,6 +3727,68 @@ String String::plus_file(const String &p_file) const {  	return *this + "/" + p_file;  } +String String::percent_encode() const { + +	CharString cs = utf8(); +	String encoded; +	for (int i = 0; i < cs.length(); i++) { +		uint8_t c = cs[i]; +		if ((c >= 'A' && c <= 'Z') || (c >= 'a' && c <= 'z') || (c >= '0' && c <= '9') || c == '-' || c == '_' || c == '~' || c == '.') { + +			char p[2] = { (char)c, 0 }; +			encoded += p; +		} else { +			char p[4] = { '%', 0, 0, 0 }; +			static const char hex[16] = { '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'a', 'b', 'c', 'd', 'e', 'f' }; + +			p[1] = hex[c >> 4]; +			p[2] = hex[c & 0xF]; +			encoded += p; +		} +	} + +	return encoded; +} +String String::percent_decode() const { + +	CharString pe; + +	CharString cs = utf8(); +	for (int i = 0; i < cs.length(); i++) { + +		uint8_t c = cs[i]; +		if (c == '%' && i < length() - 2) { + +			uint8_t a = LOWERCASE(cs[i + 1]); +			uint8_t b = LOWERCASE(cs[i + 2]); + +			c = 0; +			if (a >= '0' && a <= '9') +				c = (a - '0') << 4; +			else if (a >= 'a' && a <= 'f') +				c = (a - 'a' + 10) << 4; +			else +				continue; + +			uint8_t d = 0; + +			if (b >= '0' && b <= '9') +				d = (b - '0'); +			else if (b >= 'a' && b <= 'f') +				d = (b - 'a' + 10); +			else +				continue; +			c += d; +			i += 2; +		} +		pe.push_back(c); +	} + +	pe.push_back(0); + +	return String::utf8(pe.ptr()); +} +  String String::get_basename() const {  	int pos = find_last(".");  |