mirror of
				https://github.com/rust-lang/rust.git
				synced 2025-10-31 13:04:42 +00:00 
			
		
		
		
	 5b54286640
			
		
	
	
		5b54286640
		
	
	
	
	
		
			
			Remove the "which is required by `{root_obligation}`" post-script in
"the trait `X` is not implemented for `Y`" explanation in E0277. This
information is already conveyed in the notes explaining requirements,
making it redundant while making the text (particularly in labels)
harder to read.
```
error[E0277]: the trait bound `NotCopy: Copy` is not satisfied
  --> $DIR/wf-static-type.rs:10:13
   |
LL | static FOO: IsCopy<Option<NotCopy>> = IsCopy { t: None };
   |             ^^^^^^^^^^^^^^^^^^^^^^^ the trait `Copy` is not implemented for `NotCopy`
   |
   = note: required for `Option<NotCopy>` to implement `Copy`
note: required by a bound in `IsCopy`
  --> $DIR/wf-static-type.rs:7:17
   |
LL | struct IsCopy<T:Copy> { t: T }
   |                 ^^^^ required by this bound in `IsCopy`
```
vs the prior
```
error[E0277]: the trait bound `NotCopy: Copy` is not satisfied
  --> $DIR/wf-static-type.rs:10:13
   |
LL | static FOO: IsCopy<Option<NotCopy>> = IsCopy { t: None };
   |             ^^^^^^^^^^^^^^^^^^^^^^^ the trait `Copy` is not implemented for `NotCopy`, which is required by `Option<NotCopy>: Copy`
   |
   = note: required for `Option<NotCopy>` to implement `Copy`
note: required by a bound in `IsCopy`
  --> $DIR/wf-static-type.rs:7:17
   |
LL | struct IsCopy<T:Copy> { t: T }
   |                 ^^^^ required by this bound in `IsCopy`
```
		
	
			
		
			
				
	
	
		
			26 lines
		
	
	
		
			1021 B
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			26 lines
		
	
	
		
			1021 B
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| error: future cannot be sent between threads safely
 | |
|   --> $DIR/missing-send-bound.rs:13:20
 | |
|    |
 | |
| LL |     assert_is_send(test::<T>());
 | |
|    |                    ^^^^^^^^^^^ future returned by `test` is not `Send`
 | |
|    |
 | |
|    = help: within `impl Future<Output = ()>`, the trait `Send` is not implemented for `impl Future<Output = ()>`
 | |
| note: future is not `Send` as it awaits another future which is not `Send`
 | |
|   --> $DIR/missing-send-bound.rs:9:5
 | |
|    |
 | |
| LL |     T::bar().await;
 | |
|    |     ^^^^^^^^ await occurs here on type `impl Future<Output = ()>`, which is not `Send`
 | |
| note: required by a bound in `assert_is_send`
 | |
|   --> $DIR/missing-send-bound.rs:17:27
 | |
|    |
 | |
| LL | fn assert_is_send(_: impl Send) {}
 | |
|    |                           ^^^^ required by this bound in `assert_is_send`
 | |
| help: `Send` can be made part of the associated future's guarantees for all implementations of `Foo::bar`
 | |
|    |
 | |
| LL -     async fn bar();
 | |
| LL +     fn bar() -> impl std::future::Future<Output = ()> + Send;
 | |
|    |
 | |
| 
 | |
| error: aborting due to 1 previous error
 | |
| 
 |