From 77380fb27b22a0a61a4636a7ef33a27043972015 Mon Sep 17 00:00:00 2001 From: Ben Adams Date: Fri, 5 Apr 2019 20:12:08 +0100 Subject: [PATCH] React to "Shrink StringValues" (#8864) --- .../Core/src/BadHttpRequestException.cs | 2 +- .../src/Internal/Http/Http1MessageBody.cs | 2 +- .../Internal/Http/HttpHeaders.Generated.cs | 20 +++++++++---------- .../Core/src/Internal/Http/HttpHeaders.cs | 12 +++++------ .../src/Internal/Http/HttpRequestHeaders.cs | 2 +- .../src/Internal/Http/HttpResponseHeaders.cs | 2 +- .../src/Internal/Http/HttpResponseTrailers.cs | 2 +- .../tools/CodeGenerator/KnownHeaders.cs | 6 +++--- 8 files changed, 24 insertions(+), 24 deletions(-) diff --git a/src/Servers/Kestrel/Core/src/BadHttpRequestException.cs b/src/Servers/Kestrel/Core/src/BadHttpRequestException.cs index 9501fe7e08c3..929a4087786f 100644 --- a/src/Servers/Kestrel/Core/src/BadHttpRequestException.cs +++ b/src/Servers/Kestrel/Core/src/BadHttpRequestException.cs @@ -128,7 +128,7 @@ internal static void Throw(RequestRejectionReason reason, string detail) } [StackTraceHidden] - internal static void Throw(RequestRejectionReason reason, in StringValues detail) + internal static void Throw(RequestRejectionReason reason, StringValues detail) { throw GetException(reason, detail.ToString()); } diff --git a/src/Servers/Kestrel/Core/src/Internal/Http/Http1MessageBody.cs b/src/Servers/Kestrel/Core/src/Internal/Http/Http1MessageBody.cs index 702b4f3b98f7..743306c9b329 100644 --- a/src/Servers/Kestrel/Core/src/Internal/Http/Http1MessageBody.cs +++ b/src/Servers/Kestrel/Core/src/Internal/Http/Http1MessageBody.cs @@ -145,7 +145,7 @@ public static MessageBody For( // status code and then close the connection. if (transferCoding != TransferCoding.Chunked) { - BadHttpRequestException.Throw(RequestRejectionReason.FinalTransferCodingNotChunked, in transferEncoding); + BadHttpRequestException.Throw(RequestRejectionReason.FinalTransferCodingNotChunked, transferEncoding); } // TODO may push more into the wrapper rather than just calling into the message body diff --git a/src/Servers/Kestrel/Core/src/Internal/Http/HttpHeaders.Generated.cs b/src/Servers/Kestrel/Core/src/Internal/Http/HttpHeaders.Generated.cs index dc7244b43cc5..a69e738048a1 100644 --- a/src/Servers/Kestrel/Core/src/Internal/Http/HttpHeaders.Generated.cs +++ b/src/Servers/Kestrel/Core/src/Internal/Http/HttpHeaders.Generated.cs @@ -1258,7 +1258,7 @@ protected override bool TryGetValueFast(string key, out StringValues value) return MaybeUnknown?.TryGetValue(key, out value) ?? false; } - protected override void SetValueFast(string key, in StringValues value) + protected override void SetValueFast(string key, StringValues value) { switch (key.Length) { @@ -1606,7 +1606,7 @@ protected override void SetValueFast(string key, in StringValues value) SetValueUnknown(key, value); } - protected override bool AddValueFast(string key, in StringValues value) + protected override bool AddValueFast(string key, StringValues value) { switch (key.Length) { @@ -5337,25 +5337,25 @@ public StringValues HeaderContentLength } } - public void SetRawConnection(in StringValues value, byte[] raw) + public void SetRawConnection(StringValues value, byte[] raw) { _bits |= 0x2L; _headers._Connection = value; _headers._rawConnection = raw; } - public void SetRawDate(in StringValues value, byte[] raw) + public void SetRawDate(StringValues value, byte[] raw) { _bits |= 0x4L; _headers._Date = value; _headers._rawDate = raw; } - public void SetRawTransferEncoding(in StringValues value, byte[] raw) + public void SetRawTransferEncoding(StringValues value, byte[] raw) { _bits |= 0x40L; _headers._TransferEncoding = value; _headers._rawTransferEncoding = raw; } - public void SetRawServer(in StringValues value, byte[] raw) + public void SetRawServer(StringValues value, byte[] raw) { _bits |= 0x2000000L; _headers._Server = value; @@ -5776,7 +5776,7 @@ protected override bool TryGetValueFast(string key, out StringValues value) return MaybeUnknown?.TryGetValue(key, out value) ?? false; } - protected override void SetValueFast(string key, in StringValues value) + protected override void SetValueFast(string key, StringValues value) { ValidateHeaderValueCharacters(value); switch (key.Length) @@ -6081,7 +6081,7 @@ protected override void SetValueFast(string key, in StringValues value) SetValueUnknown(key, value); } - protected override bool AddValueFast(string key, in StringValues value) + protected override bool AddValueFast(string key, StringValues value) { ValidateHeaderValueCharacters(value); switch (key.Length) @@ -8589,7 +8589,7 @@ protected override bool TryGetValueFast(string key, out StringValues value) return MaybeUnknown?.TryGetValue(key, out value) ?? false; } - protected override void SetValueFast(string key, in StringValues value) + protected override void SetValueFast(string key, StringValues value) { ValidateHeaderValueCharacters(value); switch (key.Length) @@ -8609,7 +8609,7 @@ protected override void SetValueFast(string key, in StringValues value) SetValueUnknown(key, value); } - protected override bool AddValueFast(string key, in StringValues value) + protected override bool AddValueFast(string key, StringValues value) { ValidateHeaderValueCharacters(value); switch (key.Length) diff --git a/src/Servers/Kestrel/Core/src/Internal/Http/HttpHeaders.cs b/src/Servers/Kestrel/Core/src/Internal/Http/HttpHeaders.cs index 3b9b281dde8d..f907c81d8810 100644 --- a/src/Servers/Kestrel/Core/src/Internal/Http/HttpHeaders.cs +++ b/src/Servers/Kestrel/Core/src/Internal/Http/HttpHeaders.cs @@ -121,7 +121,7 @@ public void Reset() } [MethodImpl(MethodImplOptions.NoInlining)] - protected static StringValues AppendValue(in StringValues existing, string append) + protected static StringValues AppendValue(StringValues existing, string append) { return StringValues.Concat(existing, append); } @@ -157,10 +157,10 @@ protected virtual int GetCountFast() protected virtual bool TryGetValueFast(string key, out StringValues value) { throw new NotImplementedException(); } - protected virtual void SetValueFast(string key, in StringValues value) + protected virtual void SetValueFast(string key, StringValues value) { throw new NotImplementedException(); } - protected virtual bool AddValueFast(string key, in StringValues value) + protected virtual bool AddValueFast(string key, StringValues value) { throw new NotImplementedException(); } protected virtual bool RemoveFast(string key) @@ -259,7 +259,7 @@ bool IDictionary.TryGetValue(string key, out StringValues return TryGetValueFast(key, out value); } - public static void ValidateHeaderValueCharacters(in StringValues headerValues) + public static void ValidateHeaderValueCharacters(StringValues headerValues) { var count = headerValues.Count; for (var i = 0; i < count; i++) @@ -290,7 +290,7 @@ public static void ValidateHeaderNameCharacters(string headerCharacters) } } - public static unsafe ConnectionOptions ParseConnection(in StringValues connection) + public static unsafe ConnectionOptions ParseConnection(StringValues connection) { var connectionOptions = ConnectionOptions.None; @@ -392,7 +392,7 @@ public static unsafe ConnectionOptions ParseConnection(in StringValues connectio return connectionOptions; } - public static unsafe TransferCoding GetFinalTransferCoding(in StringValues transferEncoding) + public static unsafe TransferCoding GetFinalTransferCoding(StringValues transferEncoding) { var transferEncodingOptions = TransferCoding.None; diff --git a/src/Servers/Kestrel/Core/src/Internal/Http/HttpRequestHeaders.cs b/src/Servers/Kestrel/Core/src/Internal/Http/HttpRequestHeaders.cs index 8691f7ef67e5..823cf6d126a8 100644 --- a/src/Servers/Kestrel/Core/src/Internal/Http/HttpRequestHeaders.cs +++ b/src/Servers/Kestrel/Core/src/Internal/Http/HttpRequestHeaders.cs @@ -24,7 +24,7 @@ private static long ParseContentLength(string value) } [MethodImpl(MethodImplOptions.NoInlining)] - private void SetValueUnknown(string key, in StringValues value) + private void SetValueUnknown(string key, StringValues value) { Unknown[key] = value; } diff --git a/src/Servers/Kestrel/Core/src/Internal/Http/HttpResponseHeaders.cs b/src/Servers/Kestrel/Core/src/Internal/Http/HttpResponseHeaders.cs index c613524a5716..02d8a36cd250 100644 --- a/src/Servers/Kestrel/Core/src/Internal/Http/HttpResponseHeaders.cs +++ b/src/Servers/Kestrel/Core/src/Internal/Http/HttpResponseHeaders.cs @@ -64,7 +64,7 @@ private static void ThrowInvalidContentLengthException(string value) } [MethodImpl(MethodImplOptions.NoInlining)] - private void SetValueUnknown(string key, in StringValues value) + private void SetValueUnknown(string key, StringValues value) { ValidateHeaderNameCharacters(key); Unknown[key] = value; diff --git a/src/Servers/Kestrel/Core/src/Internal/Http/HttpResponseTrailers.cs b/src/Servers/Kestrel/Core/src/Internal/Http/HttpResponseTrailers.cs index 61b6646c8c79..0a6e78bfea33 100644 --- a/src/Servers/Kestrel/Core/src/Internal/Http/HttpResponseTrailers.cs +++ b/src/Servers/Kestrel/Core/src/Internal/Http/HttpResponseTrailers.cs @@ -22,7 +22,7 @@ protected override IEnumerator> GetEnumerator } [MethodImpl(MethodImplOptions.NoInlining)] - private void SetValueUnknown(string key, in StringValues value) + private void SetValueUnknown(string key, StringValues value) { ValidateHeaderNameCharacters(key); Unknown[key] = value; diff --git a/src/Servers/Kestrel/tools/CodeGenerator/KnownHeaders.cs b/src/Servers/Kestrel/tools/CodeGenerator/KnownHeaders.cs index 7530800e836b..7dd1500cca4d 100644 --- a/src/Servers/Kestrel/tools/CodeGenerator/KnownHeaders.cs +++ b/src/Servers/Kestrel/tools/CodeGenerator/KnownHeaders.cs @@ -385,7 +385,7 @@ public StringValues Header{header.Identifier} }}")} }}")} {Each(loop.Headers.Where(header => header.EnhancedSetter), header => $@" - public void SetRaw{header.Identifier}(in StringValues value, byte[] raw) + public void SetRaw{header.Identifier}(StringValues value, byte[] raw) {{ {header.SetBit()}; _headers._{header.Identifier} = value; @@ -425,7 +425,7 @@ protected override bool TryGetValueFast(string key, out StringValues value) return MaybeUnknown?.TryGetValue(key, out value) ?? false; }} - protected override void SetValueFast(string key, in StringValues value) + protected override void SetValueFast(string key, StringValues value) {{{(loop.ClassName != "HttpRequestHeaders" ? @" ValidateHeaderValueCharacters(value);" : "")} switch (key.Length) @@ -447,7 +447,7 @@ protected override void SetValueFast(string key, in StringValues value) SetValueUnknown(key, value); }} - protected override bool AddValueFast(string key, in StringValues value) + protected override bool AddValueFast(string key, StringValues value) {{{(loop.ClassName != "HttpRequestHeaders" ? @" ValidateHeaderValueCharacters(value);" : "")} switch (key.Length)