Skip to content
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

[DO NOT LAND] unify packages in ptb logic #20827

Draft
wants to merge 3 commits into
base: main
Choose a base branch
from

Conversation

tzakian
Copy link
Contributor

@tzakian tzakian commented Jan 9, 2025

Description

Describe the changes or additions included in this PR.

Test plan

How did you test the new or updated feature?


Release notes

Check each box that your changes affect. If none of the boxes relate to your changes, release notes aren't required.

For each box you select, include information after the relevant heading that describes the impact of your changes that a user might notice and any actions they must take to implement updates.

  • Protocol:
  • Nodes (Validators and Full nodes):
  • gRPC:
  • JSON-RPC:
  • GraphQL:
  • CLI:
  • Rust SDK:

@tzakian tzakian requested a review from a team January 9, 2025 00:30
@tzakian tzakian temporarily deployed to sui-typescript-aws-kms-test-env January 9, 2025 00:30 — with GitHub Actions Inactive
Copy link

vercel bot commented Jan 9, 2025

The latest updates on your projects. Learn more about Vercel for Git ↗︎

Name Status Preview Comments Updated (UTC)
sui-docs ✅ Ready (Inspect) Visit Preview 💬 Add feedback Jan 21, 2025 8:26pm
2 Skipped Deployments
Name Status Preview Comments Updated (UTC)
multisig-toolkit ⬜️ Ignored (Inspect) Visit Preview Jan 21, 2025 8:26pm
sui-kiosk ⬜️ Ignored (Inspect) Visit Preview Jan 21, 2025 8:26pm

}

impl ConflictResolution {
pub fn unify(&mut self, other: &ConflictResolution) -> anyhow::Result<()> {
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Nit, I'd prefer

Suggested change
pub fn unify(&mut self, other: &ConflictResolution) -> anyhow::Result<()> {
pub fn unify(&self, other: &ConflictResolution) -> anyhow::Result<ConflictResolution> {

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I always find these sort of mutable unifications harder to follow (but maybe thats just me)

Copy link
Contributor

@cgswords cgswords Jan 13, 2025

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

FWIW I significantly prefer them due to their efficiency improvements. In this instance, switching to return the value would require us to update the BTreeMap every time we do unification (or at least call std::mem::replace at each call), whereas this does it directly.

}
// If we have two exact resolutions, they must be the same.
(ConflictResolution::Exact(sv, self_id), ConflictResolution::Exact(ov, other_id)) => {
if self_id != other_id {
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I'm confused. Why aren't we checking the sv and ov?

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Is it because if the ids are the same, the sequence number should also be the same?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Correct. But it doesn't hurt to double-check.

Comment on lines 85 to 90
ConflictResolution::Exact(exact_version, self_id),
ConflictResolution::AtLeast(at_least_version, oid),
)
| (
ConflictResolution::AtLeast(at_least_version, oid),
ConflictResolution::Exact(exact_version, self_id),
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

nit

Suggested change
ConflictResolution::Exact(exact_version, self_id),
ConflictResolution::AtLeast(at_least_version, oid),
)
| (
ConflictResolution::AtLeast(at_least_version, oid),
ConflictResolution::Exact(exact_version, self_id),
ConflictResolution::Exact(exact_version, exact_id),
ConflictResolution::AtLeast(at_least_version, at_least_id),
)
| (
ConflictResolution::AtLeast(at_least_version, exact_id),
ConflictResolution::Exact(exact_version, at_least_id),

Comment on lines 368 to 503
if unification_table.contains_key(&package.original_package_id()) {
let existing_unifier = unification_table
.get_mut(&package.original_package_id())
.expect("Guaranteed to exist");
existing_unifier.unify(&resolution)?;
} else {
unification_table.insert(package.original_package_id(), resolution);
}
Copy link
Contributor

@cgswords cgswords Jan 13, 2025

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

unification_table
    .entry(&package.original_package_id())
    .and_modify(|existing_unifier| { existing_unifier.unify(&resolution)?; })
    .or_insert(resolution);

Comment on lines 329 to 342
for object_id in self.non_entry_functions.iter() {
Self::add_and_unify(
&mut unification_table,
&self.all_packages,
object_id,
|pkg| {
if linking_config.fix_top_level_functions {
ConflictResolution::Exact(pkg.version(), pkg.id())
} else {
ConflictResolution::AtLeast(pkg.version(), *object_id)
}
},
)?;
}
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

A small nit for logic like this: consider moving it onto the linking_config, as:

        for object_id in self.non_entry_functions.iter() {
            Self::add_and_unify(
                &mut unification_table,
                &self.all_packages,
                object_id,
                |pkg| linking_config.generate_top_level_function_constraint(pkg.version(), pkg.id(), object_id)
            )?;
        }

That way as the flags grow, we do not need to update their usage across the file; we can just ask the config what it should be.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants