Index: webrtc/base/base64.cc |
diff --git a/webrtc/base/base64.cc b/webrtc/base/base64.cc |
deleted file mode 100644 |
index 43b63257a663f2abfae3da29483e7625b46b1b39..0000000000000000000000000000000000000000 |
--- a/webrtc/base/base64.cc |
+++ /dev/null |
@@ -1,278 +0,0 @@ |
- |
-//********************************************************************* |
-//* Base64 - a simple base64 encoder and decoder. |
-//* |
-//* Copyright (c) 1999, Bob Withers - bwit@pobox.com |
-//* |
-//* This code may be freely used for any purpose, either personal |
-//* or commercial, provided the authors copyright notice remains |
-//* intact. |
-//* |
-//* Enhancements by Stanley Yamane: |
-//* o reverse lookup table for the decode function |
-//* o reserve string buffer space in advance |
-//* |
-//********************************************************************* |
- |
-#include "webrtc/base/base64.h" |
- |
-#include <string.h> |
- |
-#include "webrtc/base/checks.h" |
- |
-using std::vector; |
- |
-namespace rtc { |
- |
-static const char kPad = '='; |
-static const unsigned char pd = 0xFD; // Padding |
-static const unsigned char sp = 0xFE; // Whitespace |
-static const unsigned char il = 0xFF; // Illegal base64 character |
- |
-const char Base64::Base64Table[] = |
- // 0000000000111111111122222222223333333333444444444455555555556666 |
- // 0123456789012345678901234567890123456789012345678901234567890123 |
- "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/"; |
- |
-// Decode Table gives the index of any valid base64 character in the |
-// Base64 table |
-// 65 == A, 97 == a, 48 == 0, 43 == +, 47 == / |
- |
-const unsigned char Base64::DecodeTable[] = { |
- // 0 1 2 3 4 5 6 7 8 9 |
- il, il, il, il, il, il, il, il, il, sp, // 0 - 9 |
- sp, sp, sp, sp, il, il, il, il, il, il, // 10 - 19 |
- il, il, il, il, il, il, il, il, il, il, // 20 - 29 |
- il, il, sp, il, il, il, il, il, il, il, // 30 - 39 |
- il, il, il, 62, il, il, il, 63, 52, 53, // 40 - 49 |
- 54, 55, 56, 57, 58, 59, 60, 61, il, il, // 50 - 59 |
- il, pd, il, il, il, 0, 1, 2, 3, 4, // 60 - 69 |
- 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, // 70 - 79 |
- 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, // 80 - 89 |
- 25, il, il, il, il, il, il, 26, 27, 28, // 90 - 99 |
- 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, // 100 - 109 |
- 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, // 110 - 119 |
- 49, 50, 51, il, il, il, il, il, il, il, // 120 - 129 |
- il, il, il, il, il, il, il, il, il, il, // 130 - 139 |
- il, il, il, il, il, il, il, il, il, il, // 140 - 149 |
- il, il, il, il, il, il, il, il, il, il, // 150 - 159 |
- il, il, il, il, il, il, il, il, il, il, // 160 - 169 |
- il, il, il, il, il, il, il, il, il, il, // 170 - 179 |
- il, il, il, il, il, il, il, il, il, il, // 180 - 189 |
- il, il, il, il, il, il, il, il, il, il, // 190 - 199 |
- il, il, il, il, il, il, il, il, il, il, // 200 - 209 |
- il, il, il, il, il, il, il, il, il, il, // 210 - 219 |
- il, il, il, il, il, il, il, il, il, il, // 220 - 229 |
- il, il, il, il, il, il, il, il, il, il, // 230 - 239 |
- il, il, il, il, il, il, il, il, il, il, // 240 - 249 |
- il, il, il, il, il, il // 250 - 255 |
-}; |
- |
-bool Base64::IsBase64Char(char ch) { |
- return (('A' <= ch) && (ch <= 'Z')) || (('a' <= ch) && (ch <= 'z')) || |
- (('0' <= ch) && (ch <= '9')) || (ch == '+') || (ch == '/'); |
-} |
- |
-bool Base64::GetNextBase64Char(char ch, char* next_ch) { |
- if (next_ch == nullptr) { |
- return false; |
- } |
- const char* p = strchr(Base64Table, ch); |
- if (!p) |
- return false; |
- ++p; |
- *next_ch = (*p) ? *p : Base64Table[0]; |
- return true; |
-} |
- |
-bool Base64::IsBase64Encoded(const std::string& str) { |
- for (size_t i = 0; i < str.size(); ++i) { |
- if (!IsBase64Char(str.at(i))) |
- return false; |
- } |
- return true; |
-} |
- |
-void Base64::EncodeFromArray(const void* data, |
- size_t len, |
- std::string* result) { |
- RTC_DCHECK(nullptr != result); |
- result->clear(); |
- result->resize(((len + 2) / 3) * 4); |
- const unsigned char* byte_data = static_cast<const unsigned char*>(data); |
- |
- unsigned char c; |
- size_t i = 0; |
- size_t dest_ix = 0; |
- while (i < len) { |
- c = (byte_data[i] >> 2) & 0x3f; |
- (*result)[dest_ix++] = Base64Table[c]; |
- |
- c = (byte_data[i] << 4) & 0x3f; |
- if (++i < len) { |
- c |= (byte_data[i] >> 4) & 0x0f; |
- } |
- (*result)[dest_ix++] = Base64Table[c]; |
- |
- if (i < len) { |
- c = (byte_data[i] << 2) & 0x3f; |
- if (++i < len) { |
- c |= (byte_data[i] >> 6) & 0x03; |
- } |
- (*result)[dest_ix++] = Base64Table[c]; |
- } else { |
- (*result)[dest_ix++] = kPad; |
- } |
- |
- if (i < len) { |
- c = byte_data[i] & 0x3f; |
- (*result)[dest_ix++] = Base64Table[c]; |
- ++i; |
- } else { |
- (*result)[dest_ix++] = kPad; |
- } |
- } |
-} |
- |
-size_t Base64::GetNextQuantum(DecodeFlags parse_flags, |
- bool illegal_pads, |
- const char* data, |
- size_t len, |
- size_t* dpos, |
- unsigned char qbuf[4], |
- bool* padded) { |
- size_t byte_len = 0, pad_len = 0, pad_start = 0; |
- for (; (byte_len < 4) && (*dpos < len); ++*dpos) { |
- qbuf[byte_len] = DecodeTable[static_cast<unsigned char>(data[*dpos])]; |
- if ((il == qbuf[byte_len]) || (illegal_pads && (pd == qbuf[byte_len]))) { |
- if (parse_flags != DO_PARSE_ANY) |
- break; |
- // Ignore illegal characters |
- } else if (sp == qbuf[byte_len]) { |
- if (parse_flags == DO_PARSE_STRICT) |
- break; |
- // Ignore spaces |
- } else if (pd == qbuf[byte_len]) { |
- if (byte_len < 2) { |
- if (parse_flags != DO_PARSE_ANY) |
- break; |
- // Ignore unexpected padding |
- } else if (byte_len + pad_len >= 4) { |
- if (parse_flags != DO_PARSE_ANY) |
- break; |
- // Ignore extra pads |
- } else { |
- if (1 == ++pad_len) { |
- pad_start = *dpos; |
- } |
- } |
- } else { |
- if (pad_len > 0) { |
- if (parse_flags != DO_PARSE_ANY) |
- break; |
- // Ignore pads which are followed by data |
- pad_len = 0; |
- } |
- ++byte_len; |
- } |
- } |
- for (size_t i = byte_len; i < 4; ++i) { |
- qbuf[i] = 0; |
- } |
- if (4 == byte_len + pad_len) { |
- *padded = true; |
- } else { |
- *padded = false; |
- if (pad_len) { |
- // Roll back illegal padding |
- *dpos = pad_start; |
- } |
- } |
- return byte_len; |
-} |
- |
-bool Base64::DecodeFromArray(const char* data, |
- size_t len, |
- DecodeFlags flags, |
- std::string* result, |
- size_t* data_used) { |
- return DecodeFromArrayTemplate<std::string>(data, len, flags, result, |
- data_used); |
-} |
- |
-bool Base64::DecodeFromArray(const char* data, |
- size_t len, |
- DecodeFlags flags, |
- vector<char>* result, |
- size_t* data_used) { |
- return DecodeFromArrayTemplate<vector<char>>(data, len, flags, result, |
- data_used); |
-} |
- |
-bool Base64::DecodeFromArray(const char* data, |
- size_t len, |
- DecodeFlags flags, |
- vector<uint8_t>* result, |
- size_t* data_used) { |
- return DecodeFromArrayTemplate<vector<uint8_t>>(data, len, flags, result, |
- data_used); |
-} |
- |
-template <typename T> |
-bool Base64::DecodeFromArrayTemplate(const char* data, |
- size_t len, |
- DecodeFlags flags, |
- T* result, |
- size_t* data_used) { |
- RTC_DCHECK(nullptr != result); |
- RTC_DCHECK(flags <= (DO_PARSE_MASK | DO_PAD_MASK | DO_TERM_MASK)); |
- |
- const DecodeFlags parse_flags = flags & DO_PARSE_MASK; |
- const DecodeFlags pad_flags = flags & DO_PAD_MASK; |
- const DecodeFlags term_flags = flags & DO_TERM_MASK; |
- RTC_DCHECK(0 != parse_flags); |
- RTC_DCHECK(0 != pad_flags); |
- RTC_DCHECK(0 != term_flags); |
- |
- result->clear(); |
- result->reserve(len); |
- |
- size_t dpos = 0; |
- bool success = true, padded; |
- unsigned char c, qbuf[4]; |
- while (dpos < len) { |
- size_t qlen = GetNextQuantum(parse_flags, (DO_PAD_NO == pad_flags), data, |
- len, &dpos, qbuf, &padded); |
- c = (qbuf[0] << 2) | ((qbuf[1] >> 4) & 0x3); |
- if (qlen >= 2) { |
- result->push_back(c); |
- c = ((qbuf[1] << 4) & 0xf0) | ((qbuf[2] >> 2) & 0xf); |
- if (qlen >= 3) { |
- result->push_back(c); |
- c = ((qbuf[2] << 6) & 0xc0) | qbuf[3]; |
- if (qlen >= 4) { |
- result->push_back(c); |
- c = 0; |
- } |
- } |
- } |
- if (qlen < 4) { |
- if ((DO_TERM_ANY != term_flags) && (0 != c)) { |
- success = false; // unused bits |
- } |
- if ((DO_PAD_YES == pad_flags) && !padded) { |
- success = false; // expected padding |
- } |
- break; |
- } |
- } |
- if ((DO_TERM_BUFFER == term_flags) && (dpos != len)) { |
- success = false; // unused chars |
- } |
- if (data_used) { |
- *data_used = dpos; |
- } |
- return success; |
-} |
- |
-} // namespace rtc |