Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright (c) 2017, the Dart project authors. Please see the AUTHORS file | 1 // Copyright (c) 2017, the Dart project authors. Please see the AUTHORS file |
| 2 // for details. All rights reserved. Use of this source code is governed by a | 2 // for details. All rights reserved. Use of this source code is governed by a |
| 3 // BSD-style license that can be found in the LICENSE file. | 3 // BSD-style license that can be found in the LICENSE file. |
| 4 | 4 |
| 5 /// Implements support for Dart VM native method bodies of this form: | 5 /// Implements support for two variants of the native syntax extension. |
|
ahe
2017/07/05 13:29:40
I'd say that we should rename this file, but as I
Siggi Cherem (dart-lang)
2017/07/05 18:42:10
Done.
| |
| 6 /// | 6 /// |
| 7 /// native STRING | 7 /// * The Dart VM variant, where native method bodies have this form: |
| 8 /// | |
| 9 /// methodDeclaration() native STRING; | |
| 10 /// | |
| 11 /// * The Dart2js and DDC variant, where native method bodies have this form: | |
| 12 /// | |
| 13 /// methodDeclaration() native; | |
| 8 /// | 14 /// |
| 9 /// This support is kept separate from parser.dart as this isn't specified in | 15 /// This support is kept separate from parser.dart as this isn't specified in |
| 10 /// the Dart Language Specification, also we hope to remove this syntax long | 16 /// the Dart Language Specification, also we hope to remove this syntax long |
| 11 /// term and replace it with annotations as in `dart2js`. | 17 /// term and replace it with annotations and external declarations. |
| 12 library fasta.parser.dart_vm_native; | 18 library fasta.parser.dart_vm_native; |
| 13 | 19 |
| 20 /// CODE REVIEW COMMENT: I was going to also rename this file to native.dart or | |
| 21 /// native_support.dart. Peter - if that will conflict with changes you were | |
| 22 /// planning to do in this area, I can avoid it, if not I'll do it on the next | |
| 23 /// patch set. | |
|
ahe
2017/07/05 13:29:39
This comment was 15 lines to late for my thought p
Siggi Cherem (dart-lang)
2017/07/05 18:42:10
:)
| |
| 24 | |
| 14 import '../../scanner/token.dart' show Token; | 25 import '../../scanner/token.dart' show Token; |
| 15 | 26 |
| 16 import '../scanner/token_constants.dart' show STRING_TOKEN; | 27 import '../scanner/token_constants.dart' show STRING_TOKEN; |
| 17 | 28 |
| 18 import '../util/link.dart' show Link; | 29 import '../util/link.dart' show Link; |
| 19 | 30 |
| 20 import 'parser.dart' show optional; | 31 import 'parser.dart' show optional; |
| 21 | 32 |
| 22 /// When parsing a Dart VM library file, we may encounter a native clause | 33 import '../quote.dart' show unescapeString; |
| 23 /// instead of a function body. This method skips such a clause. | 34 |
| 35 /// When parsing a library file, we may encounter a native clause | |
| 36 /// instead of a function body. This method skips such a clause. The | |
| 37 /// [expectString] argument is used to choose which variant of the native clause | |
| 38 /// we expect to parse. | |
| 24 /// | 39 /// |
| 25 /// This method is designed to be called when encountering | 40 /// This method is designed to be called when encountering |
| 26 /// [ErrorKind.ExpectedBlockToSkip] in [Listener.handleUnrecoverableError]. | 41 /// [ErrorKind.ExpectedBlockToSkip] in [Listener.handleUnrecoverableError]. |
| 27 Token skipNativeClause(Token token) { | 42 Token skipNativeClause(Token token, bool expectString) { |
| 28 if (!optional("native", token)) return null; | 43 if (!optional("native", token)) return null; |
| 29 token = token.next; | 44 if (expectString) { |
| 30 if (token.kind != STRING_TOKEN) return null; | 45 token = token.next; |
| 46 if (token.kind != STRING_TOKEN) return null; | |
| 47 } | |
| 31 if (!optional(";", token.next)) return null; | 48 if (!optional(";", token.next)) return null; |
| 32 return token; | 49 return token; |
| 33 } | 50 } |
| 34 | 51 |
| 35 /// When parsing a Dart VM library file, we may encounter native getters like | 52 /// When parsing a library file, we may encounter native getters like |
| 36 /// | 53 /// |
| 37 /// int get length native "List_getLength"; | 54 /// int get length native "List_getLength"; |
| 38 /// | 55 /// |
| 39 /// This will result in [identifiers] being | 56 /// This will result in [identifiers] being |
| 40 /// | 57 /// |
| 41 /// [";", '"List_getLength"', "native", "length", "get"] | 58 /// [";", '"List_getLength"', "native", "length", "get"] |
| 42 /// | 59 /// |
| 43 /// We need to remove '"List_getLength"' and "native" from that list. | 60 /// Similarly if [expectString] is false, we expect a getter like: |
| 44 /// | 61 /// |
| 45 /// This method designed to be called from [Listener.handleMemberName]. | 62 /// int get length native; |
| 46 Link<Token> removeNativeClause(Link<Token> identifiers) { | 63 /// |
| 64 /// And [identifiers] being | |
| 65 /// | |
| 66 /// [";", "native", "length", "get"] | |
| 67 /// | |
| 68 /// This method returns a new list where '"List_getLength"' and "native" are | |
| 69 /// removed. | |
| 70 /// | |
| 71 /// This method is designed to be called from [Listener.handleMemberName]. | |
| 72 Link<Token> removeNativeClause(Link<Token> identifiers, bool expectString) { | |
| 47 Link<Token> result = identifiers.tail; | 73 Link<Token> result = identifiers.tail; |
| 48 if (result.isEmpty) return identifiers; | 74 if (result.isEmpty) return identifiers; |
| 49 if (result.head.kind != STRING_TOKEN) return identifiers; | 75 if (expectString) { |
| 50 result = result.tail; | 76 if (result.head.kind != STRING_TOKEN) return identifiers; |
| 77 result = result.tail; | |
| 78 } | |
| 51 if (result.isEmpty) return identifiers; | 79 if (result.isEmpty) return identifiers; |
| 52 if (optional('native', result.head)) { | 80 if (optional('native', result.head)) { |
| 53 return result.tail.prepend(identifiers.head); | 81 return result.tail.prepend(identifiers.head); |
| 54 } | 82 } |
| 55 return identifiers; | 83 return identifiers; |
| 56 } | 84 } |
| 85 | |
| 86 /// When the parser encounters a native clause and expects a string (like in VM | |
| 87 /// and flutter patch files), this method extracts the native name in that | |
| 88 /// string. | |
| 89 String extractNativeMethodName(Token token) { | |
| 90 return unescapeString(token.next.lexeme); | |
| 91 } | |
| OLD | NEW |