diff options
author | Jo Shields <directhex@apebox.org> | 2014-02-19 22:12:43 +0000 |
---|---|---|
committer | Jo Shields <directhex@apebox.org> | 2014-02-19 22:12:43 +0000 |
commit | 9972bf87b4f27d9c8f358ef8414ac1ab957a2f0f (patch) | |
tree | 5bb230c1d698659115f918e243c1d4b0aa4c7f51 /mcs/class/System.Net.Http/System.Net.Http.Headers/NameValueWithParametersHeaderValue.cs | |
parent | d0a215f5626219ff7927f576588a777e5331c7be (diff) | |
download | mono-upstream/3.2.8+dfsg.tar.gz |
Imported Upstream version 3.2.8+dfsgupstream/3.2.8+dfsg
Diffstat (limited to 'mcs/class/System.Net.Http/System.Net.Http.Headers/NameValueWithParametersHeaderValue.cs')
-rw-r--r-- | mcs/class/System.Net.Http/System.Net.Http.Headers/NameValueWithParametersHeaderValue.cs | 53 |
1 files changed, 45 insertions, 8 deletions
diff --git a/mcs/class/System.Net.Http/System.Net.Http.Headers/NameValueWithParametersHeaderValue.cs b/mcs/class/System.Net.Http/System.Net.Http.Headers/NameValueWithParametersHeaderValue.cs index 81d7bb089c..3d32834184 100644 --- a/mcs/class/System.Net.Http/System.Net.Http.Headers/NameValueWithParametersHeaderValue.cs +++ b/mcs/class/System.Net.Http/System.Net.Http.Headers/NameValueWithParametersHeaderValue.cs @@ -53,8 +53,8 @@ namespace System.Net.Http.Headers } } - private NameValueWithParametersHeaderValue (NameValueHeaderValue source) - : base (source) + private NameValueWithParametersHeaderValue () + : base () { } @@ -102,15 +102,52 @@ namespace System.Net.Http.Headers public static bool TryParse (string input, out NameValueWithParametersHeaderValue parsedValue) { - List<NameValueHeaderValue> values; - if (!TryParseParameters (new Lexer (input), out values)) { - parsedValue = null; + var lexer = new Lexer (input); + Token token; + if (TryParseElement (lexer, out parsedValue, out token) && token == Token.Type.End) + return true; + + parsedValue = null; + return false; + } + + internal static bool TryParse (string input, int minimalCount, out List<NameValueWithParametersHeaderValue> result) + { + return CollectionParser.TryParse (input, minimalCount, TryParseElement, out result); + } + + static bool TryParseElement (Lexer lexer, out NameValueWithParametersHeaderValue parsedValue, out Token t) + { + parsedValue = null; + + t = lexer.Scan (); + if (t != Token.Type.Token) return false; + + parsedValue = new NameValueWithParametersHeaderValue () { + Name = lexer.GetStringValue (t), + }; + + t = lexer.Scan (); + if (t == Token.Type.SeparatorEqual) { + t = lexer.Scan (); + + if (t == Token.Type.Token || t == Token.Type.QuotedString) { + parsedValue.value = lexer.GetStringValue (t); + t = lexer.Scan (); + } else { + return false; + } + } + + if (t == Token.Type.SeparatorSemicolon) { + List<NameValueHeaderValue> result; + if (!TryParseParameters (lexer, out result, out t)) + return false; + + parsedValue.parameters = result; } - parsedValue = new NameValueWithParametersHeaderValue (values[0]); - values.RemoveAt (0); - parsedValue.parameters = values; return true; } } |