Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(1641)

Unified Diff: content/renderer/webcrypto/crypto_data.h

Issue 155623005: Refactor to share more code between OpenSSL and NSS implementations. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Fix for openssl Created 6 years, 10 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: content/renderer/webcrypto/crypto_data.h
diff --git a/content/renderer/webcrypto/crypto_data.h b/content/renderer/webcrypto/crypto_data.h
new file mode 100644
index 0000000000000000000000000000000000000000..9008c812560ba8ee86e48cd24f743f8e30274192
--- /dev/null
+++ b/content/renderer/webcrypto/crypto_data.h
@@ -0,0 +1,54 @@
+// Copyright (c) 2014 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 CONTENT_RENDERER_WEBCRYPTO_CRYPTO_DATA_
+#define CONTENT_RENDERER_WEBCRYPTO_CRYPTO_DATA_
+
+#include <string>
+#include <vector>
+
+#include "base/basictypes.h"
+#include "content/common/content_export.h"
+
+namespace blink {
+class WebArrayBuffer;
+}
+
+namespace content {
+
+namespace webcrypto {
+
+// Helper to pass around a range of immutable bytes. This is conceptually
+// similar to StringPiece, but for crypto byte data.
Ryan Sleevi 2014/02/07 01:19:21 base::StringPiece
eroman 2014/02/07 21:15:57 Done.
+//
+// The data used at construction is NOT owned, and should remain valid as long
+// as the CryptoData is being used.
+class CONTENT_EXPORT CryptoData {
+ public:
+ // Constructs empty data.
+ CryptoData();
+
+ CryptoData(const unsigned char* bytes, unsigned int byte_length);
+
+ // Allow implicit conversions for convenience.
+ CryptoData(const std::vector<unsigned char>& bytes);
+ CryptoData(const std::string& bytes);
+ CryptoData(const blink::WebArrayBuffer& buffer);
Ryan Sleevi 2014/02/07 01:19:21 style guide says: boo http://google-styleguide.go
eroman 2014/02/07 21:15:57 I am aware of the style guide, however I was model
+
+ const unsigned char* bytes() const { return bytes_; }
+ unsigned int byte_length() const { return byte_length_; }
+
+ private:
+ const unsigned char* bytes_;
+ const unsigned int byte_length_;
+
+ // Copying would not be safe, since the data is not owned.
+ DISALLOW_COPY_AND_ASSIGN(CryptoData);
Ryan Sleevi 2014/02/07 01:19:21 This comment doesn't make any sense. Just because
eroman 2014/02/07 21:15:57 Copies are dangerous, since they encourage develop
Ryan Sleevi 2014/02/07 21:18:49 I still don't believe this does anything to reduce
+};
+
+} // namespace webcrypto
+
+} // namespace content
+
+#endif // CONTENT_RENDERER_WEBCRYPTO_CRYPTO_DATA_

Powered by Google App Engine
This is Rietveld 408576698