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

Unified Diff: src/core/SkRemote_protocol.h

Issue 1391023005: SkRemote (Closed) Base URL: https://skia.googlesource.com/skia.git@master
Patch Set: hal Created 5 years, 2 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
« no previous file with comments | « src/core/SkRemote.cpp ('k') | no next file » | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: src/core/SkRemote_protocol.h
diff --git a/src/core/SkRemote_protocol.h b/src/core/SkRemote_protocol.h
new file mode 100644
index 0000000000000000000000000000000000000000..997521356e2563875d46c7f74e13ab88127b9f90
--- /dev/null
+++ b/src/core/SkRemote_protocol.h
@@ -0,0 +1,53 @@
+/*
+ * Copyright 2015 Google Inc.
+ *
+ * Use of this source code is governed by a BSD-style license that can be
+ * found in the LICENSE file.
+ */
+
+#ifndef SkRemote_protocol_DEFINED
+#define SkRemote_protocol_DEFINED
+
+// ATTENTION! Changes to this file can break protocol compatibility. Tread carefully.
+
+namespace SkRemote {
+
+ // It is safe to append to this enum without breaking protocol compatibility.
+ // Resorting, deleting, or inserting anywhere but the end will break compatibility.
+ enum class Type : uint8_t {
+ kNone,
+
+ kMatrix,
+ kMisc,
+ kPath,
+ kStroke,
+ };
+
+ class ID {
+ public:
+ explicit ID(Type type = Type::kNone) : fVal((uint64_t)type << 56) {}
+ ID(Type type, uint64_t val) {
+ fVal = (uint64_t)type << 56 | val;
+ SkASSERT(this->type() == type && this->val() == val);
+ }
+
+ Type type() const { return (Type)(fVal >> 56); }
+ uint64_t val() const { return fVal & ~((uint64_t)0xFF << 56); }
+
+ bool operator==(ID o) const { return fVal == o.fVal; }
+ ID operator++(int) {
+ ID prev = *this;
+ fVal++;
+ SkASSERT(this->val() != 0); // Overflow is particularly bad as it'd change our Type.
+ return prev;
+ }
+
+ private:
+ // High 8 bits hold a Type. Low 56 bits are unique within that Type.
+ // Any change to this format will break protocol compatibility.
+ uint64_t fVal;
+ };
+
+} // namespace SkRemote
+
+#endif//SkRemote_protocol_DEFINED
« no previous file with comments | « src/core/SkRemote.cpp ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698