-
Notifications
You must be signed in to change notification settings - Fork 558
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Introduced default plugin suites to the RootDatabaseBuilder #6852
base: spr/main/5dc187d6
Are you sure you want to change the base?
Conversation
d7c12d5
to
fc37389
Compare
bf4655b
to
79ec121
Compare
fc37389
to
d0e9571
Compare
d0e9571
to
46919f1
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Reviewed 12 of 12 files at r1, all commit messages.
Reviewable status: all files reviewed, 2 unresolved discussions (waiting on @integraledelebesgue, @orizi, and @piotmag769)
crates/cairo-lang-semantic/src/db.rs
line 1881 at r1 (raw file):
/// Sets macro, inline macro and analyzer plugins specified in the [`PluginSuite`] as default /// for all crates. /// ***
this hr was not idiomatic
Suggestion:
///
crates/cairo-lang-semantic/src/db.rs
line 1917 at r1 (raw file):
/// Sets macro, inline macro and analyzer plugins present in the [`PluginSuite`] for a crate /// pointed to by the [`CrateId`], overriding the defaults for that crate. /// ***
Suggestion:
///
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Reviewable status: all files reviewed, 3 unresolved discussions (waiting on @integraledelebesgue, @orizi, and @piotmag769)
crates/cairo-lang-semantic/src/db.rs
line 1939 at r1 (raw file):
.into_iter() .map(|plugin| self.intern_analyzer_plugin(AnalyzerPluginLongId(plugin))) .collect();
Can we deduplicate this logic? Also, make it a public api; it will be useful in LS, too.
Code quote:
let PluginSuite { plugins, inline_macro_plugins, analyzer_plugins } = suite;
let macro_plugins = plugins
.into_iter()
.map(|plugin| self.intern_macro_plugin(MacroPluginLongId(plugin)))
.collect();
let inline_macro_plugins = inline_macro_plugins
.into_iter()
.map(|(name, plugin)| {
(name, self.intern_inline_macro_plugin(InlineMacroExprPluginLongId(plugin)))
})
.collect();
let analyzer_plugins = analyzer_plugins
.into_iter()
.map(|plugin| self.intern_analyzer_plugin(AnalyzerPluginLongId(plugin)))
.collect();
46919f1
to
629a86e
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Reviewable status: 11 of 12 files reviewed, 3 unresolved discussions (waiting on @Draggu, @mkaput, @orizi, and @piotmag769)
crates/cairo-lang-semantic/src/db.rs
line 1939 at r1 (raw file):
Previously, Draggu (Piotr Figiela) wrote…
Can we deduplicate this logic? Also, make it a public api; it will be useful in LS, too.
I extracted it as another helper.
These helpers should already be public since they belong to a pub trait, mutually implemented on every type that is a SemanticGroup
.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Reviewable status: 11 of 12 files reviewed, 3 unresolved discussions (waiting on @integraledelebesgue, @mkaput, @orizi, and @piotmag769)
crates/cairo-lang-semantic/src/db.rs
line 1883 at r2 (raw file):
&mut self, suite: PluginSuite, ) -> (Vec<MacroPluginId>, OrderedHashMap<String, InlineMacroExprPluginId>, Vec<AnalyzerPluginId>)
Make struct for these.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Reviewed 1 of 1 files at r2, all commit messages.
Reviewable status: all files reviewed, 1 unresolved discussion (waiting on @integraledelebesgue, @orizi, and @piotmag769)
5d50783
to
69ac9d9
Compare
629a86e
to
98416ed
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Reviewable status: 11 of 13 files reviewed, 1 unresolved discussion (waiting on @Draggu, @mkaput, @orizi, and @piotmag769)
crates/cairo-lang-semantic/src/db.rs
line 1883 at r2 (raw file):
Previously, Draggu (Piotr Figiela) wrote…
Make struct for these.
Done
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Reviewed 11 of 12 files at r1, 2 of 2 files at r3, all commit messages.
Reviewable status: all files reviewed, 2 unresolved discussions (waiting on @integraledelebesgue, @orizi, and @piotmag769)
crates/cairo-lang-semantic/src/db.rs
line 1916 at r3 (raw file):
/// [`DefsGroup::default_inline_macro_plugins`], and /// [`SemanticGroup::default_analyzer_plugins`]. fn set_default_plugins_from_suite(&mut self, suite: PluginSuite) {
Maybe inverse this? up to you
Suggestion:
InternedPluginSuite
crates/cairo-lang-semantic/src/db.rs
line 1931 at r3 (raw file):
/// [`DefsGroup::override_crate_inline_macro_plugins`], and /// [`SemanticGroup::override_crate_analyzer_plugins`]. fn set_override_crate_plugins_from_suite(&mut self, crate_id: CrateId, suite: PluginSuite) {
vide supra
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Reviewed 2 of 2 files at r3, all commit messages.
Reviewable status: all files reviewed, 2 unresolved discussions (waiting on @integraledelebesgue, @orizi, and @piotmag769)
4b6a57f
to
8b84cb3
Compare
15418f8
to
0318f63
Compare
2a0cd52
to
5438ec5
Compare
0318f63
to
3a72155
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Reviewed 1 of 1 files at r4, all commit messages.
Reviewable status: all files reviewed, 2 unresolved discussions (waiting on @integraledelebesgue, @orizi, and @piotmag769)
5438ec5
to
c49be77
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Reviewable status: 11 of 13 files reviewed, all discussions resolved (waiting on @Draggu, @mkaput, @orizi, and @piotmag769)
crates/cairo-lang-semantic/src/db.rs
line 1916 at r3 (raw file):
Previously, Draggu (Piotr Figiela) wrote…
Maybe inverse this? up to you
Done
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Reviewed 2 of 2 files at r5, all commit messages.
Reviewable status: all files reviewed, 2 unresolved discussions (waiting on @integraledelebesgue and @piotmag769)
crates/cairo-lang-semantic/src/db.rs
line 1963 at r5 (raw file):
self.set_inline_macro_plugins(Arc::new(raw_inline_macro_plugins)); self.set_analyzer_plugins(raw_analyzer_plugins); // ---
?
Code quote:
// ---
crates/cairo-lang-semantic/src/plugin.rs
line 84 at r5 (raw file):
pub inline_macro_plugins: Arc<OrderedHashMap<String, InlineMacroExprPluginId>>, pub analyzer_plugins: Arc<[AnalyzerPluginId]>, }
maybe just have these as the original PluginSuite and having the creator responsible for interning?
Code quote:
#[derive(Clone, Debug)]
pub struct InternedPluginSuite {
pub macro_plugins: Arc<[MacroPluginId]>,
pub inline_macro_plugins: Arc<OrderedHashMap<String, InlineMacroExprPluginId>>,
pub analyzer_plugins: Arc<[AnalyzerPluginId]>,
}
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Reviewable status: all files reviewed, 2 unresolved discussions (waiting on @orizi and @piotmag769)
crates/cairo-lang-semantic/src/db.rs
line 1963 at r5 (raw file):
Previously, orizi wrote…
?
Invoking these old setters is required to keep the compiler working while shifting to the new logic with default plugins. In this PR, queries related to the default and crate-specific plugins are not introduced to the compiler yet.
crates/cairo-lang-semantic/src/plugin.rs
line 84 at r5 (raw file):
Previously, orizi wrote…
maybe just have these as the original PluginSuite and having the creator responsible for interning?
It's just a helper, plain-data struct reducing the boilerplate in the methods responsible for setting per-crate plugins by wrapping those Arc
s. I think that the current logic is nicer and more flexible - we first set up the suite, modify its contents depending on our needs and eventually intern its contents all at once before setting them as a default or for a crate.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Reviewable status: all files reviewed, 1 unresolved discussion (waiting on @integraledelebesgue and @piotmag769)
crates/cairo-lang-semantic/src/plugin.rs
line 84 at r5 (raw file):
Previously, integraledelebesgue (Jan Smółka) wrote…
It's just a helper, plain-data struct reducing the boilerplate in the methods responsible for setting per-crate plugins by wrapping those
Arc
s. I think that the current logic is nicer and more flexible - we first set up the suite, modify its contents depending on our needs and eventually intern its contents all at once before setting them as a default or for a crate.
this sounds like something for a testing framework - for the general purpose - i don't like this hiding of behaviour - you're going to have this interning in any case, so you should probably not have the un-interned data here.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Reviewed 11 of 12 files at r1, 2 of 2 files at r3, 2 of 2 files at r5, all commit messages.
Reviewable status: all files reviewed, 1 unresolved discussion (waiting on @orizi)
crates/cairo-lang-semantic/src/plugin.rs
line 84 at r5 (raw file):
Previously, orizi wrote…
this sounds like something for a testing framework - for the general purpose - i don't like this hiding of behaviour - you're going to have this interning in any case, so you should probably not have the un-interned data here.
Agree with @orizi here
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Reviewed 5 of 12 files at r1.
Reviewable status: all files reviewed, 1 unresolved discussion (waiting on @integraledelebesgue)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Reviewable status: all files reviewed, 1 unresolved discussion (waiting on @orizi)
crates/cairo-lang-semantic/src/plugin.rs
line 84 at r5 (raw file):
Previously, piotmag769 (Piotr Magiera) wrote…
Agree with @orizi here
I think it's no use merging those two structures and getting rid of a raw PluginSuite
. Although we usually don't want to use the raw data that eventually gets interned, plugins are an exception, since Scarb and LS rely on the manipulation of PluginSuite
s with raw plugins. It's essential for proc macro server logic and would require a huge effort to change
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Reviewable status: all files reviewed, 1 unresolved discussion (waiting on @orizi)
crates/cairo-lang-semantic/src/plugin.rs
line 84 at r5 (raw file):
Previously, integraledelebesgue (Jan Smółka) wrote…
I think it's no use merging those two structures and getting rid of a raw
PluginSuite
. Although we usually don't want to use the raw data that eventually gets interned, plugins are an exception, since Scarb and LS rely on the manipulation ofPluginSuite
s with raw plugins. It's essential for proc macro server logic and would require a huge effort to change
I feel convinced, if @orizi wants to have it uninterned here than I am fine with it too I guess
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Reviewed 2 of 2 files at r5, all commit messages.
Reviewable status: all files reviewed, 1 unresolved discussion (waiting on @orizi)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Reviewable status: all files reviewed, 1 unresolved discussion (waiting on @integraledelebesgue)
crates/cairo-lang-semantic/src/plugin.rs
line 84 at r5 (raw file):
Previously, piotmag769 (Piotr Magiera) wrote…
I feel convinced, if @orizi wants to have it uninterned here than I am fine with it too I guess
i didn't want to have any uninterened structure.
i'm getting more confused.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Reviewable status: all files reviewed, 1 unresolved discussion (waiting on @integraledelebesgue)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Reviewable status: all files reviewed, 1 unresolved discussion (waiting on @orizi)
crates/cairo-lang-semantic/src/plugin.rs
line 84 at r5 (raw file):
Previously, orizi wrote…
i didn't want to have any uninterened structure.
i'm getting more confused.
Yea, missed one message. Anyways I think changing PluginSuite
requires a lot of changes in both Scarb and LS
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Reviewable status: all files reviewed, 1 unresolved discussion (waiting on @integraledelebesgue)
crates/cairo-lang-semantic/src/plugin.rs
line 84 at r5 (raw file):
Previously, piotmag769 (Piotr Magiera) wrote…
Yea, missed one message. Anyways I think changing
PluginSuite
requires a lot of changes in both Scarb and LS
tough luck - that is still the correct solution.
I don't see why you can't provide a pathway for this going towards the correct solution.
assuming the suite builder
still exists - the fix should be extremely easy.
3a72155
to
a90b920
Compare
c49be77
to
6802516
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Reviewed 5 of 5 files at r6, all commit messages.
Reviewable status: all files reviewed, 1 unresolved discussion (waiting on @integraledelebesgue)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Reviewable status: all files reviewed, 1 unresolved discussion (waiting on @orizi)
crates/cairo-lang-semantic/src/plugin.rs
line 84 at r5 (raw file):
Previously, orizi wrote…
tough luck - that is still the correct solution.
I don't see why you can't provide a pathway for this going towards the correct solution.assuming the
suite builder
still exists - the fix should be extremely easy.
How would we rework, for example, the get_default_plugin_suite
and similar functions if we want to hold the interned data in the PluginSuite
instead of raw plugins? That's a significant breakage, both in the compiler and our tools.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Reviewable status: all files reviewed, 1 unresolved discussion (waiting on @integraledelebesgue)
crates/cairo-lang-semantic/src/plugin.rs
line 84 at r5 (raw file):
Previously, integraledelebesgue (Jan Smółka) wrote…
How would we rework, for example, the
get_default_plugin_suite
and similar functions if we want to hold the interned data in thePluginSuite
instead of raw plugins? That's a significant breakage, both in the compiler and our tools.
yes - they should hold that exactly - that is definitely a very minor change.
commit-id:ffce04df
a90b920
to
7383bca
Compare
6802516
to
a8f1876
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Reviewed 4 of 12 files at r1, 2 of 2 files at r7, all commit messages.
Reviewable status: all files reviewed, 1 unresolved discussion (waiting on @integraledelebesgue)
Stack:
DefsGroup
andSemanticGroup
#6840