- 
                Notifications
    You must be signed in to change notification settings 
- Fork 557
Add: orphan rule rationale. #1755
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
Changes from 2 commits
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
| Original file line number | Diff line number | Diff line change | 
|---|---|---|
|  | @@ -174,6 +174,15 @@ be instantiable with the same set of types for the input type parameters. --> | |
| r[items.impl.trait.orphan-rule] | ||
| #### Orphan rules | ||
|  | ||
| r[items.impl.trait.orphan-rule.rationale] | ||
| The orphan rule helps ensure that other people's code can't break your code, and vice versa. | ||
| If an external crate implements an external trait for an external type, and your crate also | ||
| implements the same trait for the same type, the compiler wouldn't know which implementation | ||
| to use.\ | ||
| The orphan rule prevents this by requiring that either the trait or some type in the | ||
| implementation is local to your crate, ensuring only one crate defines the implementation and | ||
| thereby maintaining coherence. | ||
|          | ||
|  | ||
| r[items.impl.trait.orphan-rule.general] | ||
| Given `impl<P1..=Pn> Trait<T1..=Tn> for T0`, an `impl` is valid only if at | ||
| least one of the following is true: | ||
|  | ||
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.
I would personally put a “that” here: