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

[WIP] Add support for custom allocator for String #101551

Draft
wants to merge 19 commits into
base: master
Choose a base branch
from

Conversation

zachs18
Copy link
Contributor

@zachs18 zachs18 commented Sep 7, 2022

Roadmap for allocator support.

API Change Proposal: rust-lang/libs-team#101 [ Accepted ]

A subset/bring-to-current of #79500 utilizing a workaround(?) to the issue (#79499) that was blocking it.
(Note: I previously tried rebasing that (2 year old) PR onto current master, which was not my best idea).


Blocked on:

Todo/Unresolved Questions:

  • Fix UI tests. Done? (see my question below) (see Apparent duplicated diagnostic note for type mismatch involving type with defaulted type parameter. #101992)
  • Gdb/Lldb pretty-printing of String<A>.
  • Should From<String<A>> for Rc<str>/Arc be removed from this PR? (Corresponding impl does not exist for Vec/Rc<[T]>, and also it may preclude a future From<String<A>> for Rc<str, A>) removed
  • Should impl StructuralEq for String<_> be re-added? This PR removes it (because it no longer derive(Eq)), but it may not be observable because String: !StructuralPartialEq
    • Also for FromUtf8Error<_>, but that derived both PartialEq and Eq so it had both StructuralPartialEq and StructuralEq.
    • (Future: This will also will apply to CString, which derives PartialEq and Eq.)
  • impl<A: Allocator> From<String<A>> to Box<str, A> breaks orphan rules? (because Box and str are fundamental?)
  • Add better ways to make a new non-empty String<A>?
    • fn String<A>::from_str_in(s: &str, alloc: A) -> String<A>?
    • Likewise fn str::to_string_in(alloc: A) -> String<A> (parallels slice::to_vec_in)
    • Or maybe add to_string_in to ToString? (Probably a non-starter, since that would make ToString not object-safe, unless we put a where Self: Sized, which would preclude str)
  • [ ] Other FIXMEs (implement or remove comments) (removed FIXME comments, APIs moved to future work)

Possible Future work

  • How to handle from_utf8_lossy, which returns a non-allocator-aware Cow<str>?
  • How to handle from_utf16(_lossy), which return String and Result<String, _>?
  • (If specialization like this is sound), From<Cow<str>> for String<A> where A: Default could be implemented as from_str_in(&*cow, A::default()) , and specialized for A = Global to the current implementation cow.into_owned().
  • From<&String<A>> for String<A> where A: Clone or From<&String<A>> for String<B> where B: Default (I don't think both can exist).
  • FromIterator<_> for String, FromStr for String, and From<&str-like> for String could be for String<A> where A: Default.
  • impl const Default for String could be impl<A: _ + ~const Default> Default for String<A>, except that Global doesn't implement const Default currently (but I don't see any reason it couldn't).

@rustbot rustbot added the T-libs Relevant to the library team, which will review and decide on the PR/issue. label Sep 7, 2022
@rust-highfive
Copy link
Collaborator

r? @Mark-Simulacrum

(rust-highfive has picked a reviewer for you, use r? to override)

@rust-highfive rust-highfive added the S-waiting-on-review Status: Awaiting review from the assignee but also interested parties. label Sep 7, 2022
@rust-log-analyzer

This comment has been minimized.

Comment on lines 7 to 11
| | expected struct `String`, found `&String`
| arguments to this function are incorrect
|
= note: expected struct `String`
found reference `&String`
Copy link
Contributor Author

@zachs18 zachs18 Sep 8, 2022

Choose a reason for hiding this comment

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

This PR changed a lot of the UI tests/diagnostics to have duplicated-ish note messages. I don't know enough about the diagnostics system to really understand why. Are these changes acceptable?

(Several similar changes, e.g. expected struct String, found type str in src/test/ui/issues/issue-53348.stderr, expected struct String, found unit type () in src/test/ui/block-result/consider-removing-last-semi.stderr)

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Note that #79500 had the same kind of duplicated-ish note messages, e.g..

Copy link
Member

Choose a reason for hiding this comment

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

I also don't know the cause here, but it feels like it might be a larger bug -- maybe worth trying to reproduce on stable/nightly outside of the String type (e.g., have a struct and add a generic parameter to it) and see if that causes similar behavior on regular rustc compilers? If so, then you could file an issue for that.

If this is something specific to String that's probably worth poking at too.

Copy link
Contributor Author

Choose a reason for hiding this comment

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

It does not appear to be specific to String; I have opened #101992 about it.

@rust-log-analyzer

This comment has been minimized.

@rust-log-analyzer

This comment has been minimized.

@zachs18
Copy link
Contributor Author

zachs18 commented Sep 10, 2022

Things that are the same as 79500:

The following were made allocator-aware (or added) in the same way as in 79500:

  • alloc::str::from_boxed_utf8_unchecked
  • alloc::string::String<A>
    • from_utf8(_unchecked), alloc::string::FromUtf8Error and all impls.
    • add from_raw_parts_in/into_raw_parts_with_alloc (from_raw_parts/into_raw_parts stay in String<Global>, unlike for Vec::into_raw_parts currently)
    • add new_in/with_capacity_in
    • into_bytes/as_mut_vec
    • split_off where A: Clone
    • drain, alloc::string::Drain and all impls,
    • Display/Debug/Hash
    • Clone where A: Clone
    • Extend<.*>/fmt::Write
    • Pattern
    • PartialEq to other string-like types (Cow<str>, str, &str)
    • Add(Assign)<&str>
    • Index(Mut)/Deref(Mut)
    • From<Box<str, A>> for String<A>
    • From<String<A>> for Vec<u8, A>

DIfferences from 79500 :

  • This does not add String::from_utf16_in.
  • This implements PartialEq and PartialOrd between Strings of different allocators.
  • This manually implements PartialOrd, Eq, Ord (where 79500 derived these) to avoid an A: Eq (etc) bound.
    • This does not implement StructuralEq anymore.
    • (79500 made deriving work by implementing (Partial){Eq,Ord} for Global. This does not add or require those implementations.)
  • This does not currently implement From<&String<A>> for String<A> where A: Clone in case we would want From<&String<A2>> for String<A1> where A1: Default.
  • This does not currently implement From<String<A>> for Box<str, A> (because of orphan rules? A is an uncovered type parameter, because Box is fundamental?).

Additions from 79500:

  • This adds String::allocator à la Vec::allocator
  • This makes AsRef<str>/AsMut<str>/AsRef<[u8]> for String allocator-generic.
  • This implements ToString for String<A> (using <str as ToOwned>::to_owned instead of the current <String as ToOwned>::to_owned, which clones the String)

@zachs18 zachs18 marked this pull request as ready for review September 10, 2022 20:26
@rustbot
Copy link
Collaborator

rustbot commented Sep 10, 2022

Hey! It looks like you've submitted a new PR for the library teams!

If this PR contains changes to any rust-lang/rust public library APIs then please comment with @rustbot label +T-libs-api -T-libs to tag it appropriately. If this PR contains changes to any unstable APIs please edit the PR description to add a link to the relevant API Change Proposal or create one if you haven't already. If you're unsure where your change falls no worries, just leave it as is and the reviewer will take a look and make a decision to forward on if necessary.

Examples of T-libs-api changes:

  • Stabilizing library features
  • Introducing insta-stable changes such as new implementations of existing stable traits on existing stable types
  • Introducing new or changing existing unstable library APIs (excluding permanently unstable features / features without a tracking issue)
  • Changing public documentation in ways that create new stability guarantees
  • Changing observable runtime behavior of library APIs

@zachs18
Copy link
Contributor Author

zachs18 commented Sep 10, 2022

It passes the checks now, so I'm marking this as ready for review. Feedback is appreciated! (especially on the unresolved questions in the Todos).

(CC'ing people from 79500)
cc @Amanieu , @TimDiekmann

@zachs18
Copy link
Contributor Author

zachs18 commented Sep 10, 2022

(I think this is right?)
@rustbot label +T-libs-api -T-libs
(I don't know if this needs an API change proposal since it has a tracking issue?) ACP: rust-lang/libs-team#101

@rustbot rustbot added T-libs-api Relevant to the library API team, which will review and decide on the PR/issue. and removed T-libs Relevant to the library team, which will review and decide on the PR/issue. labels Sep 10, 2022
#[inline]
#[unstable(feature = "allocator_api", issue = "32838")]
#[must_use]
pub fn with_capacity_in(capacity: usize, alloc: A) -> String<A> {
Copy link
Member

Choose a reason for hiding this comment

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

I sort of feel like we shouldn't provide these APIs and instead encourage String::from(Vec::with_capacity_in(....)), since they do add noise to documentation and most users aren't using them. But that can be handled at stabilization time, I suppose, and is a broader question about everything being allocator-generic.


#[cfg(not(no_global_oom_handling))]
#[stable(feature = "from_char_for_string", since = "1.46.0")]
impl From<char> for String {
// FIXME(zachs18): A: Allocator + Default?
Copy link
Member

Choose a reason for hiding this comment

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

I don't think we should add this comment; there's many APIs which could do this (even on Vec) and it doesn't seem worth leaving comments strewn around std for that future possibility.

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Yeah, I had intended to remove or implement most of the FIXMEs based on feedback before the PR gets merged. I'll just remove the ones that don't currently exist for Vec for this PR.

@Mark-Simulacrum
Copy link
Member

A few notes:

String no longer implementing StructuralEq

I think this is not observable on stable, though I'm not entirely confident. The primary area where it matters that I know of is pattern matching with a const value, but that requires StructuralPartialEq too.

FromUtf8Error<_>, but that derived both PartialEq and Eq so it had both StructuralPartialEq and StructuralEq.

In order to check whether this is a breaking change we need to know whether any const context on stable can get the value -- I think the answer may be no, but I'm not confident.


Also left some comments inline, going to @rustbot author for now but please mark it as ready for review if the ACP goes through and you have addressed comments (or posted back with questions).

@rustbot rustbot added S-waiting-on-author Status: This is awaiting some action (such as code changes or more information) from the author. and removed S-waiting-on-review Status: Awaiting review from the assignee but also interested parties. labels Sep 17, 2022
library/alloc/src/rc.rs Outdated Show resolved Hide resolved
library/alloc/src/sync.rs Outdated Show resolved Hide resolved
@rust-log-analyzer

This comment has been minimized.

@brunogouveia
Copy link

Hello, I would like to take a shot on this, since @zachs18 doesn't seem to have time for this atm.

I have a few (probably dumb) questions regarding this:

This is still (somewhat) blocked on the duplicate diagnostic issue (#101992).

Also, unless the semantics around how generic defaults affect inference are changed (e.g. to allow String to default to String::<Global> in paths), it may be a problem that things like this (playground link) with let _ = String::ASSOC_CONST_FROM_TRAIT; or let _ = String::assoc_fn_nonmethod(); don't compile. I don't think this can actually break any existing code, because it would only break if the trait(/associated function) is implemented for String<A> for multiple allocators A (not just A = Global), but I think there are no such impls (String::new/Default/FromStr/FromIterator/From/etc should still only be implemented for String<Global> in this PR). (I vaguely remember some UI test failing because of this, but it's not happening locally in my rebase; maybe it'll pop up in CI). (related: #101319 and #98931)

Edit: Yup, the test failure i half-remembered was library/core/src/mem/mod.rs:1271. Anything like this, with a blanket implementation that applies to String<A> for multiple A will cause problems.

trait MySized { const SIZE: usize; }
impl<T: Sized> MySized for T {
  const SIZE: usize = std::mem::size_of::<Self>();
}
fn main() {
  dbg!(String::SIZE); // Fails under this PR
}

So this PR is a breaking change unless the default generic parameter issue is resolved.

I just rebased today, and there are some UI test changes that I have questions about: (see later inline comments).

Maybe I'm missing something but isn't this a problem on other containers as well (e.g., Vec)?

I did checkout the changes on the PR and reverted the "moving the String struct into alloc::string::string module" and the only test failing is the library/core/src/mem/mod.rs:1271 which as far as I understand is also an unstable feature (sized_type_properties). And as you mentioned, this is unlikely to break any existing crates since crate-defined traits will likely only be implemented for String<Global>. So is this a real problem?

Also, wouldn't moving string to the module alloc::string::string cause a runtime breaking change, since std::any::type_name::<String>() would return a different name now? Sure, maybe one should not rely on that API for anything in production (?) but it's certainly useful for tooling.

@zachs18
Copy link
Contributor Author

zachs18 commented Jan 4, 2025

Maybe I'm missing something but isn't this a problem on other containers as well (e.g., Vec)?

I don't know exactly which issue you're referring to. If you mean specifically that Vec::ASSOC_CONST doesn't work, that is expected since Vec has a generic parameter for the element type. As to why adding the allocator parameter to Vec and other containers didn't break existing code, I don't recall all of the reasoning at the moment, but IIRC this issue doesn't affect Vec or other stdlib containers (as much) because String is the only one that doesn't already have any generics, so the other containers already have to rely on either explicit annotations or type inference for their element type(s), so adding the allocator type doesn't change much for them.

Also, wouldn't moving string to the module alloc::string::string cause a runtime breaking change, since std::any::type_name::<String>() would return a different name now? Sure, maybe one should not rely on that API for anything in production (?) but it's certainly useful for tooling.

type_name's output is explicitly not guaranteed, so I don't think that's a significant issue. Other types have been moved around like this before also, and IIUC it is not considered a breaking change as long as the type is still reachable through an alias at the original path.

And as you mentioned, this is unlikely to break any existing crates since crate-defined traits will likely only be implemented for String<Global>. So is this a real problem?

Any trait with a blanket impl for (e.g.) T: Sized or T: Clone would cover String<A>, not just String<Global>, as I show in the code snippet.


In a later comment than the one you quoted, I explained my reasoning for the new module. I (or someone) should probably consult with T-libs-api to see if this strategy with the new module would have any chance of actually being merged before working on this further (mainly just fixing clippy and debuginfo tests IIUC?). I'm not sure if T-libs-api has a process for "amending" and ACP vs making a new one, or if the new module is a small enough change to not need to amend the ACP?

@brunogouveia
Copy link

Hey @zachs18, thanks for the quick reply and providing all the context I was missing.

I don't recall all of the reasoning at the moment, but IIRC this issue doesn't affect Vec or other stdlib containers (as much) because String is the only one that doesn't already have any generics, so the other containers already have to rely on either explicit annotations or type inference for their element type(s), so adding the allocator type doesn't change much for them.

I see, somehow I missed the actual example (🤦) and it's interesting that if I specify the first template argument type inference works.

type_name's output is explicitly not guaranteed, so I don't think that's a significant issue. Other types have been moved around like this before also, and IIUC it is not considered a breaking change as long as the type is still reachable through an alias at the original path.

Ok, fair enough.

I (or someone) should probably consult with T-libs-api to see if this strategy with the new module would have any chance of actually being merged before working on this further (mainly just fixing clippy and debuginfo tests IIUC?). I'm not sure if T-libs-api has a process for "amending" and ACP vs making a new one, or if the new module is a small enough change to not need to amend the ACP?

Can I help here in moving this discussion forward in any way? (I'm also happy in fixing clippy, etc if you don't have time and provided there is an agreement with T-libs-api)

@Amanieu Amanieu added the I-libs-api-nominated Nominated for discussion during a libs-api team meeting. label Jan 20, 2025
@Amanieu
Copy link
Member

Amanieu commented Jan 21, 2025

In a later comment than the one you quoted, I explained my reasoning for the new module. I (or someone) should probably consult with T-libs-api to see if this strategy with the new module would have any chance of actually being merged before working on this further (mainly just fixing clippy and debuginfo tests IIUC?). I'm not sure if T-libs-api has a process for "amending" and ACP vs making a new one, or if the new module is a small enough change to not need to amend the ACP?

We discussed this in the libs-api meeting today. We're OK with using the module approach to land this as unstable for now, but longer term we may want to look at ways we can avoid this issue at the language level.

@Amanieu Amanieu removed the I-libs-api-nominated Nominated for discussion during a libs-api team meeting. label Jan 21, 2025
… even if there are multiple inherent impls to check.
More `allocator_api`-aware `String` implementations (Most allocator-irrelevant associated functions, Drain, and FromUtf8Error).

More `allocator_api`-aware `String` implementations, including added `new_in` etc inherent impls.

tidy, new_in etc, raw_parts_in etc, allocator(&self), FromUtf8Error impls, Extend, Pattern, PartialEq &str etc with String<A>, Display, Debug, Hash, Add(Assign), ToString, AsRef/AsMut, conversions Box<str, A> -> String<A>, &String -> Cow<str>, String<A> -> Vec<u8, A>; fmt::Write.

Fix gdb/lldb integration for String<A>.

Add some simple trait impls I missed.

Borrow(Mut)<str> for String, From<String<A>> for Rc<str>/Arc<str>, Clone for Box<str, A>.

Remove FIXMEs for String<A> APIs that don't already exist for Vec<T,A>.

Rewrite `Clone for Box<str, A>` to avoid extra capacity/length checks converting from Vec.

Also implement `clone_from` to re-use the allocation when the lengths are the same.

Remove `From<String<A>> for Rc<str>`/`Arc` impls to allow for future alloc-ification of `Rc`/`Arc`

Note: find out how to make "the full type name has been written to" errors be deterministic (./x.py test alone didn't do it).

AsRef<OsStr> and AsRef<Path> for String<A: Allocator>
…o the new path.

Also reverts some UI test changes that were due to on_unimplemented path being wrong.
@zachs18
Copy link
Contributor Author

zachs18 commented Jan 22, 2025

Okay, if the team's OK with using the module approach to land this as unstable, then I'll rebase and work on fixing the tests etc.

Leaving as draft for now while I finish fixing tests etc. Current push includes #135865 for diagnostics changes.

Also will need to squash some commits 😄.

@rust-log-analyzer

This comment has been minimized.

@rust-log-analyzer
Copy link
Collaborator

The job x86_64-gnu-llvm-18 failed! Check out the build log: (web) (plain)

Click to see the possible cause of the failure (guessed by this bot)
#21 exporting to docker image format
#21 sending tarball 27.9s done
#21 DONE 41.6s
##[endgroup]
Setting extra environment values for docker:  --env ENABLE_GCC_CODEGEN=1 --env GCC_EXEC_PREFIX=/usr/lib/gcc/
[CI_JOB_NAME=x86_64-gnu-llvm-18]
debug: `DISABLE_CI_RUSTC_IF_INCOMPATIBLE` configured.
---
sccache: Starting the server...
##[group]Configure the build
configure: processing command line
configure: 
configure: build.configure-args := ['--build=x86_64-unknown-linux-gnu', '--llvm-root=/usr/lib/llvm-18', '--enable-llvm-link-shared', '--set', 'rust.randomize-layout=true', '--set', 'rust.thin-lto-import-instr-limit=10', '--enable-verbose-configure', '--enable-sccache', '--disable-manage-submodules', '--enable-locked-deps', '--enable-cargo-native-static', '--set', 'rust.codegen-units-std=1', '--set', 'dist.compression-profile=balanced', '--dist-compression-formats=xz', '--set', 'rust.lld=false', '--disable-dist-src', '--release-channel=nightly', '--enable-debug-assertions', '--enable-overflow-checks', '--enable-llvm-assertions', '--set', 'rust.verify-llvm-ir', '--set', 'rust.codegen-backends=llvm,cranelift,gcc', '--set', 'llvm.static-libstdcpp', '--enable-new-symbol-mangling']
configure: target.x86_64-unknown-linux-gnu.llvm-config := /usr/lib/llvm-18/bin/llvm-config
configure: llvm.link-shared     := True
configure: rust.randomize-layout := True
configure: rust.thin-lto-import-instr-limit := 10
---
failures:

---- [ui] tests/ui/consts/miri_unleashed/assoc_const_2.rs stdout ----

error: /checkout/tests/ui/consts/miri_unleashed/assoc_const_2.rs:10: unexpected error: '10:20: 10:30: evaluation of `<std::string::string::String as Bar<std::string::string::String>>::F` failed [E0080]'

error: /checkout/tests/ui/consts/miri_unleashed/assoc_const_2.rs:10: expected error not found: evaluation of `<std::string::String as Bar<std::string::String>>::F` failed
error: 1 unexpected errors found, 1 expected errors not found
status: exit status: 1
status: exit status: 1
command: env -u RUSTC_LOG_COLOR RUSTC_ICE="0" RUST_BACKTRACE="short" "/checkout/obj/build/x86_64-unknown-linux-gnu/stage2/bin/rustc" "/checkout/tests/ui/consts/miri_unleashed/assoc_const_2.rs" "-Zthreads=1" "-Zsimulate-remapped-rust-src-base=/rustc/FAKE_PREFIX" "-Ztranslate-remapped-path-to-local-path=no" "-Z" "ignore-directory-in-diagnostics-source-blocks=/cargo" "-Z" "ignore-directory-in-diagnostics-source-blocks=/checkout/vendor" "--sysroot" "/checkout/obj/build/x86_64-unknown-linux-gnu/stage2" "--target=x86_64-unknown-linux-gnu" "--check-cfg" "cfg(test,FALSE)" "--error-format" "json" "--json" "future-incompat" "-Ccodegen-units=1" "-Zui-testing" "-Zdeduplicate-diagnostics=no" "-Zwrite-long-types-to-disk=no" "-Cstrip=debuginfo" "-C" "prefer-dynamic" "--out-dir" "/checkout/obj/build/x86_64-unknown-linux-gnu/test/ui/consts/miri_unleashed/assoc_const_2" "-A" "unused" "-A" "internal_features" "-Crpath" "-Cdebuginfo=0" "-Lnative=/checkout/obj/build/x86_64-unknown-linux-gnu/native/rust-test-helpers"
--- unexpected errors (from JSON output) ---
--- unexpected errors (from JSON output) ---
ERROR     line  10: 10:20: 10:30: evaluation of `<std::string::string::String as Bar<std::string::string::String>>::F` failed [E0080]
--- not found errors (from test file) ---
--- not found errors (from test file) ---
ERROR     line  10: evaluation of `<std::string::String as Bar<std::string::String>>::F` failed


thread '[ui] tests/ui/consts/miri_unleashed/assoc_const_2.rs' panicked at src/tools/compiletest/src/runtest.rs:797:13:
errors differ from expected
---
2   --> $DIR/string.rs:2:14
3    |
4 LL |     for _ in "".to_owned() {}
-    |              ^^^^^^^^^^^^^ `String` is not an iterator
+    |              ^^^^^^^^^^^^^ `String` is not an iterator; try calling `.chars()` or `.bytes()`
7    = help: the trait `Iterator` is not implemented for `String`
8    = note: required for `String` to implement `IntoIterator`



The actual stderr differed from the expected stderr.
To update references, rerun the tests and pass the `--bless` flag
To only update this specific test, also pass `--test-args iterators/string.rs`

error: 1 errors occurred comparing output.
status: exit status: 1
command: env -u RUSTC_LOG_COLOR RUSTC_ICE="0" RUST_BACKTRACE="short" "/checkout/obj/build/x86_64-unknown-linux-gnu/stage2/bin/rustc" "/checkout/tests/ui/iterators/string.rs" "-Zthreads=1" "-Zsimulate-remapped-rust-src-base=/rustc/FAKE_PREFIX" "-Ztranslate-remapped-path-to-local-path=no" "-Z" "ignore-directory-in-diagnostics-source-blocks=/cargo" "-Z" "ignore-directory-in-diagnostics-source-blocks=/checkout/vendor" "--sysroot" "/checkout/obj/build/x86_64-unknown-linux-gnu/stage2" "--target=x86_64-unknown-linux-gnu" "--check-cfg" "cfg(test,FALSE)" "--error-format" "json" "--json" "future-incompat" "-Ccodegen-units=1" "-Zui-testing" "-Zdeduplicate-diagnostics=no" "-Zwrite-long-types-to-disk=no" "-Cstrip=debuginfo" "--emit" "metadata" "-C" "prefer-dynamic" "--out-dir" "/checkout/obj/build/x86_64-unknown-linux-gnu/test/ui/iterators/string" "-A" "unused" "-A" "internal_features" "-Crpath" "-Cdebuginfo=0" "-Lnative=/checkout/obj/build/x86_64-unknown-linux-gnu/native/rust-test-helpers"
--- stderr -------------------------------
error[E0277]: `String` is not an iterator
##[error]  --> /checkout/tests/ui/iterators/string.rs:2:14
   |
   |
LL |     for _ in "".to_owned() {}
   |              ^^^^^^^^^^^^^ `String` is not an iterator; try calling `.chars()` or `.bytes()`
   = help: the trait `Iterator` is not implemented for `String`
   = note: required for `String` to implement `IntoIterator`

error[E0277]: `&str` is not an iterator
error[E0277]: `&str` is not an iterator
##[error]  --> /checkout/tests/ui/iterators/string.rs:4:14
   |
LL |     for _ in "" {}
   |              ^^ `&str` is not an iterator; try calling `.chars()` or `.bytes()`
   = help: the trait `Iterator` is not implemented for `&str`
   = note: required for `&str` to implement `IntoIterator`

error: aborting due to 2 previous errors
---
error: /checkout/tests/ui/pattern/issue-115599.rs:5: expected error not found: constant of non-structural type `Vec<u8>` in a pattern

error: 1 unexpected errors found, 1 expected errors not found
status: exit status: 1
command: env -u RUSTC_LOG_COLOR RUSTC_ICE="0" RUST_BACKTRACE="short" "/checkout/obj/build/x86_64-unknown-linux-gnu/stage2/bin/rustc" "/checkout/tests/ui/pattern/issue-115599.rs" "-Zthreads=1" "-Zsimulate-remapped-rust-src-base=/rustc/FAKE_PREFIX" "-Ztranslate-remapped-path-to-local-path=no" "-Z" "ignore-directory-in-diagnostics-source-blocks=/cargo" "-Z" "ignore-directory-in-diagnostics-source-blocks=/checkout/vendor" "--sysroot" "/checkout/obj/build/x86_64-unknown-linux-gnu/stage2" "--target=x86_64-unknown-linux-gnu" "--check-cfg" "cfg(test,FALSE)" "--error-format" "json" "--json" "future-incompat" "-Ccodegen-units=1" "-Zui-testing" "-Zdeduplicate-diagnostics=no" "-Zwrite-long-types-to-disk=no" "-Cstrip=debuginfo" "--emit" "metadata" "-C" "prefer-dynamic" "--out-dir" "/checkout/obj/build/x86_64-unknown-linux-gnu/test/ui/pattern/issue-115599" "-A" "unused" "-A" "internal_features" "-Crpath" "-Cdebuginfo=0" "-Lnative=/checkout/obj/build/x86_64-unknown-linux-gnu/native/rust-test-helpers"
--- unexpected errors (from JSON output) ---
ERROR     line   5: 5:12: 5:24: constant of non-structural type `String` in a pattern
---
--- not found errors (from test file) ---
---
error: /checkout/tests/ui/resolve/issue-22692.rs:6: expected help message not found: use the path separator

error: 0 unexpected errors found, 2 expected errors not found
status: exit status: 1
command: env -u RUSTC_LOG_COLOR RUSTC_ICE="0" RUST_BACKTRACE="short" "/checkout/obj/build/x86_64-unknown-linux-gnu/stage2/bin/rustc" "/checkout/tests/ui/resolve/issue-22692.rs" "-Zthreads=1" "-Zsimulate-remapped-rust-src-base=/rustc/FAKE_PREFIX" "-Ztranslate-remapped-path-to-local-path=no" "-Z" "ignore-directory-in-diagnostics-source-blocks=/cargo" "-Z" "ignore-directory-in-diagnostics-source-blocks=/checkout/vendor" "--sysroot" "/checkout/obj/build/x86_64-unknown-linux-gnu/stage2" "--target=x86_64-unknown-linux-gnu" "--check-cfg" "cfg(test,FALSE)" "--error-format" "json" "--json" "future-incompat" "-Ccodegen-units=1" "-Zui-testing" "-Zdeduplicate-diagnostics=no" "-Zwrite-long-types-to-disk=no" "-Cstrip=debuginfo" "--emit" "metadata" "-C" "prefer-dynamic" "--out-dir" "/checkout/obj/build/x86_64-unknown-linux-gnu/test/ui/resolve/issue-22692" "-A" "unused" "-A" "internal_features" "-Crpath" "-Cdebuginfo=0" "-Lnative=/checkout/obj/build/x86_64-unknown-linux-gnu/native/rust-test-helpers"
--- not found errors (from test file) ---
HELP MESSAGEline   2: use the path separator
HELP MESSAGEline   6: use the path separator
---
---


thread '[ui] tests/ui/resolve/issue-22692.rs' panicked at src/tools/compiletest/src/runtest.rs:797:13:
errors differ from expected

---- [ui] tests/ui/resolve/unresolved-segments-visibility.rs stdout ----

error: /checkout/tests/ui/resolve/unresolved-segments-visibility.rs:8: unexpected error: '8:27: 8:33: failed to resolve: `String` is a type alias, not a module [E0433]'
error: /checkout/tests/ui/resolve/unresolved-segments-visibility.rs:8: expected error not found: failed to resolve: `String` is a struct, not a module [E0433]

error: 1 unexpected errors found, 1 expected errors not found
status: exit status: 1
status: exit status: 1
command: env -u RUSTC_LOG_COLOR RUSTC_ICE="0" RUST_BACKTRACE="short" "/checkout/obj/build/x86_64-unknown-linux-gnu/stage2/bin/rustc" "/checkout/tests/ui/resolve/unresolved-segments-visibility.rs" "-Zthreads=1" "-Zsimulate-remapped-rust-src-base=/rustc/FAKE_PREFIX" "-Ztranslate-remapped-path-to-local-path=no" "-Z" "ignore-directory-in-diagnostics-source-blocks=/cargo" "-Z" "ignore-directory-in-diagnostics-source-blocks=/checkout/vendor" "--sysroot" "/checkout/obj/build/x86_64-unknown-linux-gnu/stage2" "--target=x86_64-unknown-linux-gnu" "--check-cfg" "cfg(test,FALSE)" "--error-format" "json" "--json" "future-incompat" "-Ccodegen-units=1" "-Zui-testing" "-Zdeduplicate-diagnostics=no" "-Zwrite-long-types-to-disk=no" "-Cstrip=debuginfo" "--emit" "metadata" "-C" "prefer-dynamic" "--out-dir" "/checkout/obj/build/x86_64-unknown-linux-gnu/test/ui/resolve/unresolved-segments-visibility" "-A" "unused" "-A" "internal_features" "-Crpath" "-Cdebuginfo=0" "-Lnative=/checkout/obj/build/x86_64-unknown-linux-gnu/native/rust-test-helpers"
--- unexpected errors (from JSON output) ---
--- unexpected errors (from JSON output) ---
ERROR     line   8: 8:27: 8:33: failed to resolve: `String` is a type alias, not a module [E0433]
--- not found errors (from test file) ---
ERROR     line   8: failed to resolve: `String` is a struct, not a module [E0433]
---

---

6    |     |
7    |     required by a bound introduced by this call
8    |
+    = note: to coerce a `String` into a `&str`, use `&*` as a prefix
9    = help: the following other types implement trait `From<T>`:
10              `String` implements `From<&String>`
11              `String` implements `From<&mut str>`

The actual stderr differed from the expected stderr.
To update references, rerun the tests and pass the `--bless` flag
To only update this specific test, also pass `--test-args suggestions/into-str.rs`
To only update this specific test, also pass `--test-args suggestions/into-str.rs`

error: 1 errors occurred comparing output.
status: exit status: 1
command: env -u RUSTC_LOG_COLOR RUSTC_ICE="0" RUST_BACKTRACE="short" "/checkout/obj/build/x86_64-unknown-linux-gnu/stage2/bin/rustc" "/checkout/tests/ui/suggestions/into-str.rs" "-Zthreads=1" "-Zsimulate-remapped-rust-src-base=/rustc/FAKE_PREFIX" "-Ztranslate-remapped-path-to-local-path=no" "-Z" "ignore-directory-in-diagnostics-source-blocks=/cargo" "-Z" "ignore-directory-in-diagnostics-source-blocks=/checkout/vendor" "--sysroot" "/checkout/obj/build/x86_64-unknown-linux-gnu/stage2" "--target=x86_64-unknown-linux-gnu" "--check-cfg" "cfg(test,FALSE)" "--error-format" "json" "--json" "future-incompat" "-Ccodegen-units=1" "-Zui-testing" "-Zdeduplicate-diagnostics=no" "-Zwrite-long-types-to-disk=no" "-Cstrip=debuginfo" "--emit" "metadata" "-C" "prefer-dynamic" "--out-dir" "/checkout/obj/build/x86_64-unknown-linux-gnu/test/ui/suggestions/into-str" "-A" "unused" "-A" "internal_features" "-Crpath" "-Cdebuginfo=0" "-Lnative=/checkout/obj/build/x86_64-unknown-linux-gnu/native/rust-test-helpers"
--- stderr -------------------------------
--- stderr -------------------------------
error[E0277]: the trait bound `&str: From<String>` is not satisfied
   |
LL |     foo(String::new());
   |     --- ^^^^^^^^^^^^^ the trait `From<String>` is not implemented for `&str`
   |     |
   |     |
   |     required by a bound introduced by this call
   |
   = note: to coerce a `String` into a `&str`, use `&*` as a prefix
   = help: the following other types implement trait `From<T>`:
             `String` implements `From<&String>`
             `String` implements `From<&mut str>`
             `String` implements `From<&str>`
             `String` implements `From<Cow<'_, str>>`
             `String` implements `From<char>`
             `String<A>` implements `From<Box<str, A>>`
   = note: required for `String` to implement `Into<&str>`
  --> /checkout/tests/ui/suggestions/into-str.rs:1:31
   |
   |
LL | fn foo<'a, T>(_t: T) where T: Into<&'a str> {}

error: aborting due to 1 previous error

For more information about this error, try `rustc --explain E0277`.
---

4 LL |     String::from::utf8;
5    |     ^^^^^^^^^^^^
6    |
- help: if there were a trait named `Example` with associated type `from` implemented for `String`, you could use the fully-qualified path
+ help: there is an associated function with a similar name: `from_utf8`
- LL |     <String as Example>::from::utf8;
-    |     ~~~~~~~~~~~~~~~~~~~~~~~~~
+ LL |     String::from_utf8;
+    |             ~~~~~~~~~
+    |             ~~~~~~~~~
11 
12 error[E0223]: ambiguous associated type
13   --> $DIR/issue-109195.rs:15:5

15 LL |     String::from::utf8();
16    |     ^^^^^^^^^^^^
17    |
- help: if there were a trait named `Example` with associated type `from` implemented for `String`, you could use the fully-qualified path
+ help: there is an associated function with a similar name: `from_utf8`
- LL |     <String as Example>::from::utf8();
-    |     ~~~~~~~~~~~~~~~~~~~~~~~~~
+ LL |     String::from_utf8();
+    |             ~~~~~~~~~
+    |             ~~~~~~~~~
22 
23 error[E0223]: ambiguous associated type
24   --> $DIR/issue-109195.rs:18:5

26 LL |     String::from::utf16();
27    |     ^^^^^^^^^^^^
28    |
- help: if there were a trait named `Example` with associated type `from` implemented for `String`, you could use the fully-qualified path
+ help: there is an associated function with a similar name: `from_utf16`
- LL |     <String as Example>::from::utf16();
-    |     ~~~~~~~~~~~~~~~~~~~~~~~~~
+ LL |     String::from_utf16();
+    |             ~~~~~~~~~~
---
To only update this specific test, also pass `--test-args suggestions/issue-109195.rs`

error: 1 errors occurred comparing output.
status: exit status: 1
command: env -u RUSTC_LOG_COLOR RUSTC_ICE="0" RUST_BACKTRACE="short" "/checkout/obj/build/x86_64-unknown-linux-gnu/stage2/bin/rustc" "/checkout/tests/ui/suggestions/issue-109195.rs" "-Zthreads=1" "-Zsimulate-remapped-rust-src-base=/rustc/FAKE_PREFIX" "-Ztranslate-remapped-path-to-local-path=no" "-Z" "ignore-directory-in-diagnostics-source-blocks=/cargo" "-Z" "ignore-directory-in-diagnostics-source-blocks=/checkout/vendor" "--sysroot" "/checkout/obj/build/x86_64-unknown-linux-gnu/stage2" "--target=x86_64-unknown-linux-gnu" "--check-cfg" "cfg(test,FALSE)" "--error-format" "json" "--json" "future-incompat" "-Ccodegen-units=1" "-Zui-testing" "-Zdeduplicate-diagnostics=no" "-Zwrite-long-types-to-disk=no" "-Cstrip=debuginfo" "--emit" "metadata" "-C" "prefer-dynamic" "--out-dir" "/checkout/obj/build/x86_64-unknown-linux-gnu/test/ui/suggestions/issue-109195" "-A" "unused" "-A" "internal_features" "-Crpath" "-Cdebuginfo=0" "-Lnative=/checkout/obj/build/x86_64-unknown-linux-gnu/native/rust-test-helpers"
--- stderr -------------------------------
error[E0223]: ambiguous associated type
##[error]  --> /checkout/tests/ui/suggestions/issue-109195.rs:12:5
   |
---
   |
LL |     String::from::method_that_doesnt_exist();
   |     ^^^^^^^^^^^^
   |
help: if there were a trait named `Example` with associated type `from` implemented for `String`, you could use the fully-qualified path
LL |     <String as Example>::from::method_that_doesnt_exist();
   |     ~~~~~~~~~~~~~~~~~~~~~~~~~

error[E0223]: ambiguous associated type
error[E0223]: ambiguous associated type
##[error]  --> /checkout/tests/ui/suggestions/issue-109195.rs:24:5
   |
LL |     str::from::utf8();
   |     ^^^^^^^^^
   |
help: if there were a trait named `Example` with associated type `from` implemented for `str`, you could use the fully-qualified path
   |
LL |     <str as Example>::from::utf8();

error[E0223]: ambiguous associated type
##[error]  --> /checkout/tests/ui/suggestions/issue-109195.rs:27:5
   |
   |
LL |     str::from::utf8_mut();
   |     ^^^^^^^^^
   |
help: if there were a trait named `Example` with associated type `from` implemented for `str`, you could use the fully-qualified path
   |
LL |     <str as Example>::from::utf8_mut();

error[E0223]: ambiguous associated type
##[error]  --> /checkout/tests/ui/suggestions/issue-109195.rs:30:5
   |
---

error[E0223]: ambiguous associated type
##[error]  --> /checkout/tests/ui/suggestions/issue-109195.rs:33:5
   |
LL |     Foo::bar::quux;
   |
   |
help: there is an associated function with a similar name: `bar_quux`
   |
LL |     Foo::bar_quux;

error[E0223]: ambiguous associated type
##[error]  --> /checkout/tests/ui/suggestions/issue-109195.rs:36:5
   |
   |
LL |     Foo::bar::fizz;
   |     ^^^^^^^^
   |
help: if there were a trait named `Example` with associated type `bar` implemented for `Foo`, you could use the fully-qualified path
   |
LL |     <Foo as Example>::bar::fizz;

error: aborting due to 9 previous errors

For more information about this error, try `rustc --explain E0223`.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
S-blocked Status: Blocked on something else such as an RFC or other implementation work. T-libs-api Relevant to the library API team, which will review and decide on the PR/issue.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

10 participants