OLD | NEW |
1 #region Copyright notice and license | 1 #region Copyright notice and license |
2 // Protocol Buffers - Google's data interchange format | 2 // Copyright 2015, Google Inc. |
3 // Copyright 2008 Google Inc. All rights reserved. | 3 // All rights reserved. |
4 // https://developers.google.com/protocol-buffers/ | |
5 // | 4 // |
6 // Redistribution and use in source and binary forms, with or without | 5 // Redistribution and use in source and binary forms, with or without |
7 // modification, are permitted provided that the following conditions are | 6 // modification, are permitted provided that the following conditions are |
8 // met: | 7 // met: |
9 // | 8 // |
10 // * Redistributions of source code must retain the above copyright | 9 // * Redistributions of source code must retain the above copyright |
11 // notice, this list of conditions and the following disclaimer. | 10 // notice, this list of conditions and the following disclaimer. |
12 // * Redistributions in binary form must reproduce the above | 11 // * Redistributions in binary form must reproduce the above |
13 // copyright notice, this list of conditions and the following disclaimer | 12 // copyright notice, this list of conditions and the following disclaimer |
14 // in the documentation and/or other materials provided with the | 13 // in the documentation and/or other materials provided with the |
15 // distribution. | 14 // distribution. |
16 // * Neither the name of Google Inc. nor the names of its | 15 // * Neither the name of Google Inc. nor the names of its |
17 // contributors may be used to endorse or promote products derived from | 16 // contributors may be used to endorse or promote products derived from |
18 // this software without specific prior written permission. | 17 // this software without specific prior written permission. |
19 // | 18 // |
20 // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS | 19 // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS |
21 // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT | 20 // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT |
22 // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR | 21 // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR |
23 // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT | 22 // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT |
24 // OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | 23 // OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, |
25 // SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | 24 // SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT |
26 // LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | 25 // LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, |
27 // DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | 26 // DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY |
28 // THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | 27 // THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT |
29 // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | 28 // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE |
30 // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | 29 // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
31 #endregion | 30 #endregion |
32 | 31 |
33 using System; | 32 using Grpc.Core.Utils; |
34 | 33 |
35 namespace Google.Protobuf | 34 namespace Grpc.Core |
36 { | 35 { |
37 /// <summary> | 36 /// <summary> |
38 /// Provides a utility routine to copy small arrays much more quickly than B
uffer.BlockCopy | 37 /// Represents RPC result, which consists of <see cref="StatusCode"/> and an
optional detail string. |
39 /// </summary> | 38 /// </summary> |
40 internal static class ByteArray | 39 public struct Status |
41 { | 40 { |
42 /// <summary> | 41 /// <summary> |
43 /// The threshold above which you should use Buffer.BlockCopy rather tha
n ByteArray.Copy | 42 /// Default result of a successful RPC. StatusCode=OK, empty details mes
sage. |
44 /// </summary> | 43 /// </summary> |
45 private const int CopyThreshold = 12; | 44 public static readonly Status DefaultSuccess = new Status(StatusCode.OK,
""); |
46 | 45 |
47 /// <summary> | 46 /// <summary> |
48 /// Determines which copy routine to use based on the number of bytes to
be copied. | 47 /// Default result of a cancelled RPC. StatusCode=Cancelled, empty detai
ls message. |
49 /// </summary> | 48 /// </summary> |
50 internal static void Copy(byte[] src, int srcOffset, byte[] dst, int dst
Offset, int count) | 49 public static readonly Status DefaultCancelled = new Status(StatusCode.C
ancelled, ""); |
| 50 |
| 51 readonly StatusCode statusCode; |
| 52 readonly string detail; |
| 53 |
| 54 /// <summary> |
| 55 /// Creates a new instance of <c>Status</c>. |
| 56 /// </summary> |
| 57 /// <param name="statusCode">Status code.</param> |
| 58 /// <param name="detail">Detail.</param> |
| 59 public Status(StatusCode statusCode, string detail) |
51 { | 60 { |
52 if (count > CopyThreshold) | 61 this.statusCode = statusCode; |
| 62 this.detail = detail; |
| 63 } |
| 64 |
| 65 /// <summary> |
| 66 /// Gets the gRPC status code. OK indicates success, all other values in
dicate an error. |
| 67 /// </summary> |
| 68 public StatusCode StatusCode |
| 69 { |
| 70 get |
53 { | 71 { |
54 Buffer.BlockCopy(src, srcOffset, dst, dstOffset, count); | 72 return statusCode; |
55 } | |
56 else | |
57 { | |
58 int stop = srcOffset + count; | |
59 for (int i = srcOffset; i < stop; i++) | |
60 { | |
61 dst[dstOffset++] = src[i]; | |
62 } | |
63 } | 73 } |
64 } | 74 } |
65 | 75 |
66 /// <summary> | 76 /// <summary> |
67 /// Reverses the order of bytes in the array | 77 /// Gets the detail. |
68 /// </summary> | 78 /// </summary> |
69 internal static void Reverse(byte[] bytes) | 79 public string Detail |
70 { | 80 { |
71 for (int first = 0, last = bytes.Length - 1; first < last; first++,
last--) | 81 get |
72 { | 82 { |
73 byte temp = bytes[first]; | 83 return detail; |
74 bytes[first] = bytes[last]; | |
75 bytes[last] = temp; | |
76 } | 84 } |
77 } | 85 } |
| 86 |
| 87 /// <summary> |
| 88 /// Returns a <see cref="System.String"/> that represents the current <s
ee cref="Grpc.Core.Status"/>. |
| 89 /// </summary> |
| 90 public override string ToString() |
| 91 { |
| 92 return string.Format("Status(StatusCode={0}, Detail=\"{1}\")", statu
sCode, detail); |
| 93 } |
78 } | 94 } |
79 } | 95 } |
OLD | NEW |