use crate::functions::clone_clone_alt_b::with_clone_maps;
use crate::records::binding::Binding;
use crate::records::clone_state::CloneState;
use crate::records::fragment_autocomplete_type_cloner::FragmentAutocompleteTypeCloner;
use crate::records::scope::Scope;
use crate::records::type_arena::TypeArena;
use crate::type_aliases::type_id::TypeId;
use crate::type_aliases::type_pack_id::TypePackId;
use std::collections::HashMap;
pub fn clone_incremental(
binding: &Binding,
dest: &mut TypeArena,
clone_state: &mut CloneState,
fresh_scope_for_free_types: *mut Scope,
) -> Binding {
let builtin_types = clone_state.builtin_types;
with_clone_maps(
&mut clone_state.seen_types,
&mut clone_state.seen_type_packs,
|tys, tps| {
let mut cloner = FragmentAutocompleteTypeCloner::fragment_autocomplete_type_cloner(
dest as *mut TypeArena,
builtin_types,
tys as *mut HashMap<TypeId, TypeId>,
tps as *mut HashMap<TypePackId, TypePackId>,
core::ptr::null(),
core::ptr::null(),
fresh_scope_for_free_types,
);
Binding {
deprecated: binding.deprecated,
deprecated_suggestion: binding.deprecated_suggestion.clone(),
documentation_symbol: binding.documentation_symbol.clone(),
location: binding.location,
type_id: if unsafe { (*binding.type_id).persistent } {
binding.type_id
} else {
cloner.base.clone_type_id(binding.type_id)
},
}
},
)
}