Compare commits

...

1 Commits

Author SHA1 Message Date
Micha Reiser
56a3978479 [ty] Use OrderedSet/Map in more places 2026-01-04 19:54:22 +01:00
3 changed files with 12 additions and 11 deletions

View File

@@ -8,6 +8,7 @@ use super::{
SubclassOfType, Truthiness, Type, TypeQualifiers, class_base::ClassBase,
function::FunctionType,
};
use crate::FxOrderMap;
use crate::place::TypeOrigin;
use crate::semantic_index::definition::{Definition, DefinitionState};
use crate::semantic_index::scope::{NodeWithScopeKind, Scope, ScopeKind};
@@ -161,8 +162,8 @@ fn fields_cycle_initial<'db>(
_self: ClassLiteral<'db>,
_specialization: Option<Specialization<'db>>,
_field_policy: CodeGeneratorKind<'db>,
) -> FxIndexMap<Name, Field<'db>> {
FxIndexMap::default()
) -> FxOrderMap<Name, Field<'db>> {
FxOrderMap::default()
}
/// A category of classes with code generation capabilities (with synthesized methods).
@@ -3147,7 +3148,7 @@ impl<'db> ClassLiteral<'db> {
db: &'db dyn Db,
specialization: Option<Specialization<'db>>,
field_policy: CodeGeneratorKind<'db>,
) -> FxIndexMap<Name, Field<'db>> {
) -> FxOrderMap<Name, Field<'db>> {
if field_policy == CodeGeneratorKind::NamedTuple {
// NamedTuples do not allow multiple inheritance, so it is sufficient to enumerate the
// fields of this class only.
@@ -3195,8 +3196,8 @@ impl<'db> ClassLiteral<'db> {
db: &'db dyn Db,
specialization: Option<Specialization<'db>>,
field_policy: CodeGeneratorKind,
) -> FxIndexMap<Name, Field<'db>> {
let mut attributes = FxIndexMap::default();
) -> FxOrderMap<Name, Field<'db>> {
let mut attributes = FxOrderMap::default();
let class_body_scope = self.body_scope(db);
let table = place_table(db, class_body_scope);

View File

@@ -31,7 +31,7 @@ use crate::types::{
protocol_class::ProtocolClass,
};
use crate::types::{DataclassFlags, KnownInstanceType, MemberLookupPolicy, TypeVarInstance};
use crate::{Db, DisplaySettings, FxIndexMap, Program, declare_lint};
use crate::{Db, DisplaySettings, FxOrderMap, Program, declare_lint};
use itertools::Itertools;
use ruff_db::{
diagnostic::{Annotation, Diagnostic, Span, SubDiagnostic, SubDiagnosticSeverity},
@@ -3001,7 +3001,7 @@ pub(crate) fn report_instance_layout_conflict(
/// The inner data is an `IndexMap` to ensure that diagnostics regarding conflicting disjoint bases
/// are reported in a stable order.
#[derive(Debug, Default)]
pub(super) struct IncompatibleBases<'db>(FxIndexMap<DisjointBase<'db>, IncompatibleBaseInfo<'db>>);
pub(super) struct IncompatibleBases<'db>(FxOrderMap<DisjointBase<'db>, IncompatibleBaseInfo<'db>>);
impl<'db> IncompatibleBases<'db> {
pub(super) fn insert(

View File

@@ -2,7 +2,7 @@ use ruff_python_ast::name::Name;
use rustc_hash::FxHashMap;
use crate::{
Db, FxIndexMap,
Db, FxOrderMap,
place::{Place, PlaceAndQualifiers, place_from_bindings, place_from_declarations},
semantic_index::{place_table, use_def_map},
types::{
@@ -13,7 +13,7 @@ use crate::{
#[derive(Debug, PartialEq, Eq, salsa::Update)]
pub(crate) struct EnumMetadata<'db> {
pub(crate) members: FxIndexMap<Name, Type<'db>>,
pub(crate) members: FxOrderMap<Name, Type<'db>>,
pub(crate) aliases: FxHashMap<Name, Name>,
}
@@ -22,7 +22,7 @@ impl get_size2::GetSize for EnumMetadata<'_> {}
impl EnumMetadata<'_> {
fn empty() -> Self {
EnumMetadata {
members: FxIndexMap::default(),
members: FxOrderMap::default(),
aliases: FxHashMap::default(),
}
}
@@ -253,7 +253,7 @@ pub(crate) fn enum_metadata<'db>(
Some((name.clone(), value_ty))
})
.collect::<FxIndexMap<_, _>>();
.collect::<FxOrderMap<_, _>>();
if members.is_empty() {
// Enum subclasses without members are not considered enums.