blob: 5354155ba987bde81d515e3fae24e9454b27f4ab [file] [log] [blame]
// Copyright (c) 2015, 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.
/**
* This file contains a set of concrete classes representing an in-memory
* semantic model of the IDL used to code generate summary serialization and
* deserialization code.
*/
import 'package:meta/meta.dart';
/**
* Information about a single class defined in the IDL.
*/
class ClassDeclaration extends Declaration {
/**
* All fields defined in the class, including deprecated ones.
*/
final List<FieldDeclaration> allFields = <FieldDeclaration>[];
/**
* Indicates whether the class has the `topLevel` annotation.
*/
final bool isTopLevel;
/**
* If [isTopLevel] is `true` and a file identifier was specified for this
* class, the file identifier string. Otherwise `null`.
*/
final String fileIdentifier;
/**
* Indicates whether the class has the `deprecated` annotation.
*/
final bool isDeprecated;
final String variantField;
ClassDeclaration({
@required String documentation,
@required this.fileIdentifier,
@required String name,
@required this.isDeprecated,
@required this.isTopLevel,
@required this.variantField,
}) : super(documentation, name);
/**
* Get the non-deprecated fields defined in the class.
*/
Iterable<FieldDeclaration> get fields =>
allFields.where((FieldDeclaration field) => !field.isDeprecated);
}
/**
* Information about a declaration in the IDL.
*/
class Declaration {
/**
* The optional documentation, may be `null`.
*/
final String documentation;
/**
* The name of the declaration.
*/
final String name;
Declaration(this.documentation, this.name);
}
/**
* Information about a single enum defined in the IDL.
*/
class EnumDeclaration extends Declaration {
/**
* List of enumerated values.
*/
final List<EnumValueDeclaration> values = <EnumValueDeclaration>[];
EnumDeclaration(String documentation, String name)
: super(documentation, name);
}
/**
* Information about a single enum value defined in the IDL.
*/
class EnumValueDeclaration extends Declaration {
EnumValueDeclaration(String documentation, String name)
: super(documentation, name);
}
/**
* Information about a single class field defined in the IDL.
*/
class FieldDeclaration extends Declaration {
/**
* The file of the field.
*/
final FieldType type;
/**
* The id of the field.
*/
final int id;
/**
* Indicates whether the field is deprecated.
*/
final bool isDeprecated;
/**
* Indicates whether the field is informative.
*/
final bool isInformative;
/**
* Maps logical property names to logical property.
*/
final Map<String, LogicalProperty> logicalProperties;
FieldDeclaration({
@required String documentation,
@required String name,
@required this.type,
@required this.id,
@required this.isDeprecated,
@required this.isInformative,
@required this.logicalProperties,
}) : super(documentation, name);
}
/**
* Information about the type of a class field defined in the IDL.
*/
class FieldType {
/**
* Type of the field (e.g. 'int').
*/
final String typeName;
/**
* Indicates whether this field contains a list of the type specified in
* [typeName].
*/
final bool isList;
FieldType(this.typeName, this.isList);
@override
int get hashCode {
var hash = 0x3fffffff & typeName.hashCode;
hash = 0x3fffffff & (hash * 31 + (hash ^ isList.hashCode));
return hash;
}
bool operator ==(Object other) {
if (other is FieldType) {
return other.typeName == typeName && other.isList == isList;
}
return false;
}
@override
String toString() => isList ? 'List<$typeName>' : typeName;
}
/**
* Top level representation of the summary IDL.
*/
class Idl {
/**
* Classes defined in the IDL.
*/
final Map<String, ClassDeclaration> classes = <String, ClassDeclaration>{};
/**
* Enums defined in the IDL.
*/
final Map<String, EnumDeclaration> enums = <String, EnumDeclaration>{};
}
/**
* Information about a logical property mapped to a single data fields.
*/
class LogicalProperty {
/**
* Indicates whether the property is deprecated.
*/
final bool isDeprecated;
/**
* Indicates whether the property is informative.
*/
final bool isInformative;
/**
* Names of variants in which this property is available.
*/
final List<String> variants;
LogicalProperty({
@required this.isDeprecated,
@required this.isInformative,
@required this.variants,
});
}