X-Git-Url: http://wien.tomnetworks.com/gitweb/?a=blobdiff_plain;f=mcs%2Fmcs%2Fcs-tokenizer.cs;h=1be3309b1bfdd611d404408e743e0414f81f2860;hb=522d0276630d843944e57522f96e2613913452cd;hp=02f6f3df77494ae11eec7fda3dd1b388fd94fc9b;hpb=12461baf50da00c5d30f757af0e1891d7ebbef3b;p=mono.git diff --git a/mcs/mcs/cs-tokenizer.cs b/mcs/mcs/cs-tokenizer.cs index 02f6f3df774..1be3309b1bf 100644 --- a/mcs/mcs/cs-tokenizer.cs +++ b/mcs/mcs/cs-tokenizer.cs @@ -893,6 +893,16 @@ namespace Mono.CSharp if (parsing_block == 0) res = -1; + break; + case Token.THROW: + switch (current_token) { + case Token.ARROW: + case Token.OP_COALESCING: + case Token.INTERR: + res = Token.THROW_EXPR; + break; + } + break; } @@ -1095,6 +1105,7 @@ namespace Mono.CSharp case Token.DECIMAL: case Token.BOOL: case Token.STRING: + case Token.SBYTE: return Token.OPEN_PARENS_CAST; } } @@ -1266,7 +1277,8 @@ namespace Mono.CSharp else if (the_token == Token.INTERR_NULLABLE || the_token == Token.STAR) goto again; else if (the_token == Token.OP_GENERICS_LT) { - if (!parse_less_than (ref genericDimension)) + int unused = 0; + if (!parse_less_than (ref unused)) return false; goto again; } else if (the_token == Token.OPEN_BRACKET) { @@ -1313,7 +1325,8 @@ namespace Mono.CSharp } if (d == '.') { - return Token.INTERR_OPERATOR; + d = reader.Peek (); + return d >= '0' && d <= '9' ? Token.INTERR : Token.INTERR_OPERATOR; } if (d != ' ') { @@ -1343,6 +1356,7 @@ namespace Mono.CSharp case Token.THIS: case Token.NEW: case Token.INTERPOLATED_STRING: + case Token.THROW: next_token = Token.INTERR; break; @@ -2464,6 +2478,12 @@ namespace Mono.CSharp case '\"': ++str_quote; break; + case '\\': + // Skip escaped " character + c = reader.Read (); + if (c == -1) + res = false; + break; case -1: res = false; break; @@ -2522,7 +2542,6 @@ namespace Mono.CSharp int TokenizePragmaWarningIdentifier (ref int c, ref bool identifier) { - if ((c >= '0' && c <= '9') || is_identifier_start_character (c)) { int number; @@ -2547,7 +2566,7 @@ namespace Mono.CSharp id_builder [pos] = (char)c; if (c >= '0' && c <= '9') { - if (pos == 6 && id_builder [0] == 'C' && id_builder [1] == 'S') { + if (pos == 5 && id_builder [0] == 'C' && id_builder [1] == 'S') { // Recognize CSXXXX as C# XXXX warning number = 0; int pow = 1000; @@ -2562,6 +2581,9 @@ namespace Mono.CSharp pow /= 10; } } + } else if (c == '\n' || c == UnicodeLS || c == UnicodePS) { + advance_line (); + break; } else if ((c < 'a' || c > 'z') && (c < 'A' || c > 'Z') && c != '_') { break; } @@ -4057,6 +4079,9 @@ namespace Mono.CSharp --braces; break; case '\\': + if (parsing_string_interpolation_quoted != null && parsing_string_interpolation_quoted.Peek ()) + break; + ++col; int surrogate; ch = escape (ch, out surrogate); @@ -4101,8 +4126,6 @@ namespace Mono.CSharp private void handle_one_line_xml_comment () { int c; - while ((c = peek_char ()) == ' ') - get_char (); // skip heading whitespaces. while ((c = peek_char ()) != -1 && c != '\n' && c != '\r') { xml_comment_buffer.Append ((char) get_char ()); }