| // Copyright (c) 2014, the Dart project authors. Please see the AUTHORS file |
| // for details. All rights reserved. Use of this source code is governed by a |
| // BSD-style license that can be found in the LICENSE file. |
| |
| /// Base functionality which code generated summary classes are built upon. |
| library analyzer.src.summary.base; |
| |
| /// Annotation used in the summary IDL to indicate the id of a field. The set |
| /// of ids used by a class must cover the contiguous range from 0 to N-1, where |
| /// N is the number of fields. |
| /// |
| /// In order to preserve forwards and backwards compatibility, id numbers must |
| /// be stable between releases. So when new fields are added they should take |
| /// the next available id without renumbering other fields. |
| class Id { |
| final int value; |
| |
| const Id(this.value); |
| } |
| |
| /// Instances of this class represent data that has been read from a summary. |
| abstract class SummaryClass { |
| /// Translate the data in this class into a JSON map, whose keys are the names |
| /// of fields and whose values are the data stored in those fields, |
| /// recursively converted into JSON. |
| /// |
| /// Fields containing their default value are elided. |
| /// |
| /// Intended for testing and debugging only. |
| Map<String, Object> toJson(); |
| |
| /// Translate the data in this class into a map whose keys are the names of |
| /// fields and whose values are the data stored in those fields. |
| /// |
| /// Intended for testing and debugging only. |
| Map<String, Object?> toMap(); |
| } |
| |
| /// Annotation used in the summary IDL to indicate that a summary class can be |
| /// the top level object in an encoded summary. |
| class TopLevel { |
| /// If non-null, identifier that will be stored in bytes 4-7 of the file, |
| /// prior all other file data. Must be exactly 4 Latin1 characters. |
| final String? fileIdentifier; |
| |
| const TopLevel([this.fileIdentifier]); |
| } |