blob: c29a31582d813e6a0bef8301d3bc479f8c27e89d [file] [log] [blame]
// 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]);
}