Index: components/base32/base32.h |
diff --git a/components/base32/base32.h b/components/base32/base32.h |
new file mode 100644 |
index 0000000000000000000000000000000000000000..048c6dcc599c2a0358a5ffc3ae812b81d0f61366 |
--- /dev/null |
+++ b/components/base32/base32.h |
@@ -0,0 +1,32 @@ |
+// Copyright 2016 The Chromium Authors. All rights reserved. |
+// Use of this source code is governed by a BSD-style license that can be |
+// found in the LICENSE file. |
+ |
+#ifndef COMPONENTS_BASE32_BASE32_H_ |
+#define COMPONENTS_BASE32_BASE32_H_ |
+ |
+#include <string> |
+ |
+#include "base/strings/string_piece.h" |
+ |
+namespace base32 { |
+ |
+enum class Base32EncodePolicy { |
+ // Include the trailing padding in the output, when necessary. |
+ INCLUDE_PADDING, |
+ // Remove the trailing padding from the output. |
gab
2016/06/03 18:46:11
// Omit trailing padding to the output. Such an ou
Rob Percival
2016/06/04 06:20:25
That isn't quite accurate. It is decodable, if you
gab
2016/06/07 01:24:10
Your latest version lg to me.
|
+ OMIT_PADDING |
+}; |
+ |
+// Encodes the |input| string in base32, defined in RFC 4648: |
+// https://tools.ietf.org/html/rfc4648#section-5 |
+// |
+// The |policy| defines whether padding should be included or omitted from the |
+// encoded output. |
+std::string Base32Encode( |
+ base::StringPiece input, |
+ Base32EncodePolicy policy = Base32EncodePolicy::INCLUDE_PADDING); |
+ |
+} // namespace base32 |
+ |
+#endif // COMPONENTS_BASE32_BASE32_H_ |