//! Settings for tweaking assists. //! //! The fun thing here is `SnippetCap` -- this type can only be created in this //! module, and we use to statically check that we only produce snippet //! assists if we are allowed to. use hir::FindPathConfig; use ide_db::{ SnippetCap, assists::ExprFillDefaultMode, imports::{import_assets::ImportPathConfig, insert_use::InsertUseConfig}, rename::RenameConfig, }; use crate::AssistKind; #[derive(Clone, Debug, PartialEq, Eq)] pub struct AssistConfig { pub snippet_cap: Option, pub allowed: Option>, pub insert_use: InsertUseConfig, pub prefer_no_std: bool, pub prefer_prelude: bool, pub prefer_absolute: bool, pub assist_emit_must_use: bool, pub term_search_fuel: u64, pub term_search_borrowck: bool, pub code_action_grouping: bool, pub expr_fill_default: ExprFillDefaultMode, pub prefer_self_ty: bool, pub show_rename_conflicts: bool, } impl AssistConfig { pub fn import_path_config(&self) -> ImportPathConfig { ImportPathConfig { prefer_no_std: self.prefer_no_std, prefer_prelude: self.prefer_prelude, prefer_absolute: self.prefer_absolute, } } pub fn find_path_config(&self, allow_unstable: bool) -> FindPathConfig { FindPathConfig { prefer_no_std: self.prefer_no_std, prefer_prelude: self.prefer_prelude, prefer_absolute: self.prefer_absolute, allow_unstable, } } pub fn rename_config(&self) -> RenameConfig { RenameConfig { show_conflicts: self.show_rename_conflicts } } }