# Libs-API Meeting 2024-09-17
###### tags: `Libs Meetings` `Minutes`
**Meeting Link**: https://meet.jit.si/rust-libs-meeting-crxoz2at8hiccp7b3ixf89qgxfymlbwr
**Attendees**: Amanieu, David, Mara, The 8472, Chris Denton, Jubilee, Urgau, theemathas
## Agenda
- Triage
- Anything else?
## Triage
### FCPs
20 rust-lang/rust T-libs-api FCPs
- merge rust.tf/80437 *Tracking Issue for \`box\_into\_inner\`* - (1 checkboxes left)
- merge rust.tf/106418 *Implement \`PartialOrd\` and \`Ord\` for \`Discriminant\`* - (2 checkboxes left)
- merge rust.tf/123723 *Make \`std::os::darwin\` public* - (3 checkboxes left)
- merge rust.tf/86918 *Tracking Issue for \`pin\_deref\_mut\`* - (3 checkboxes left)
- merge rust.tf/120141 *Tracking Issue for enum access in offset\_of* - (6 checkboxes left)
- merge rust.tf/129238 *Stabilize \`Ipv6Addr::is\_unique\_local\` and \`Ipv6Addr::is\_unicast\_link\_local\`* - (3 checkboxes left)
- merge rust.tf/130086 *Tracking Issue for const\_str\_as\_mut* - (3 checkboxes left)
- merge rust.tf/111735 *Tracking Issue for \`BufRead::skip\_until\`* - (3 checkboxes left)
- merge rust.tf/130350 *stabilize Strict Provenance and Exposed Provenance APIs* - (4 checkboxes left)
- merge rust.tf/86302 *Tracking Issue for const\_ptr\_write* - (4 checkboxes left)
- merge rust.tf/111774 *Tracking Issue for \`slice\_first\_last\_chunk\` feature (\`slice::{split\_,}{first,last}\_chunk{,\_mut}\`)* - (3 checkboxes left)
- merge rust.tf/111645 *Tracking Issue for \`UnsafeCell::from\_mut\`* - (3 checkboxes left)
- merge rust.tf/83570 *Tracking Issue for \`#!\[feature(const\_slice\_first\_last)\]\`* - (3 checkboxes left)
- merge rust.tf/101804 *Tracking Issue for \`feature(const\_slice\_split\_at\_mut)\`* - (3 checkboxes left)
- merge rust.tf/83164 *Tracking Issue for const\_replace* - (4 checkboxes left)
- merge rust.tf/91822 *Tracking Issue for \`const\_ptr\_as\_ref\`* - (3 checkboxes left)
- merge rust.tf/72440 *Tracking Issue for constify\-ing non\-trait \`Duration\` methods* - (3 checkboxes left)
- merge rust.tf/130191 *\[discussion\] \`ErrorKind::CrossesDevices\` from \`io\_error\_more\`* - (4 checkboxes left)
- merge rust.tf/130190 *\[discussion\] \`ErrorKind::FilesystemQuotaExceeded\` from \`io\_error\_more\`* - (4 checkboxes left)
- merge rust.tf/72505 *Tracking issue for \`#!\[feature(const\_float\_classify)\]\`* - (3 checkboxes left)
[tmandry (1)](https://rfcbot.rs/fcp/tmandry), [scottmcm (2)](https://rfcbot.rs/fcp/scottmcm), [m-ou-se (17)](https://rfcbot.rs/fcp/m-ou-se), [Amanieu (16)](https://rfcbot.rs/fcp/Amanieu), [dtolnay (1)](https://rfcbot.rs/fcp/dtolnay), [pnkfelix (1)](https://rfcbot.rs/fcp/pnkfelix), [BurntSushi (7)](https://rfcbot.rs/fcp/BurntSushi), [nikomatsakis (2)](https://rfcbot.rs/fcp/nikomatsakis), [joshtriplett (18)](https://rfcbot.rs/fcp/joshtriplett)
### (nominated) rust.tf/75251 *Tracking Issue for const MaybeUninit::as(\_mut)\_ptr (feature: const\_maybe\_uninit\_as\_ptr)*
FCP finished. Should be merged?
Previous FCP still applies, okay to stabilize
### (nominated) rust.tf/130188 *\[discussion\] \`ErrorKind::FilesystemLoop\` from \`io\_error\_more\`*
The 8472: [epoll_ctl](https://man7.org/linux/man-pages/man2/epoll_ctl.2.html#ERRORS) says
```
ELOOP fd refers to an epoll instance and this EPOLL_CTL_ADD
operation would result in a circular loop of epoll
instances monitoring one another or a nesting depth of
epoll instances greater than 5.
```
Mara: ERROR_CANT_RESOLVE_FILENAME on Windows is translated to this error too.
Amanieu: I don't care much about the name.
Mara: I feel like we should wait for people with stronger opinions to show up on the issue.
### (nominated) rust.tf/130229 *ptr::add/sub: fix docs (do not claim equivalence with \`offset\`), and fix gap in Miri UB checks*
FCP + relnotes
### (waiting on team) rust.tf/119550 *Rename \`AsyncIterator\` back to \`Stream\`, introduce an AFIT\-based \`AsyncIterator\` trait*
-
### (new change proposal) rust.tf/libs443 *ACP: Generic \`Atomic\<T\>\`*
AtomicU128 is still unstable
we cannot add AtomicU256 in the future if it is a trait impl, but that's probably fine.
seems fine to go ahead as unstable, as long as this doesn't break anything.
Accepted
### (new change proposal) rust.tf/libs440 *\`Vec::as\_non\_null()\` method*
Accepted
### (new change proposal) rust.tf/libs439 *add \`impl From\<Box\<str\>\> for Box\<Path\>\` and friends*
Accepted
### (new change proposal) rust.tf/libs438 *ACP: \`ForwardInit\<'a, T\>\` to complement \`MaybeUninit\<T\>\`*
Mara: It still won't guarantee that you initialized the memory you were expected too. Doesn't give much guarantees over just &mut MaybeUninit. Don't think this is worth it.
The 8472: Can it live in a crate?
Amanieu: It already does.
Amanieu: Did we stabilize the buffer api?
Mara: Nope.
Amanieu: I think it's only worth it if it can replace the buffer api.
The 8472: It cannot replace it. It can be part of it..
Amanieu: I want to see how this is used in APIs. Ask for feedback. Also how it relates to the buffer/cursor interface.
Amanieu to reply.
### (new change proposal) rust.tf/libs437 *Path::force\_relative*
Close in favor of 396 `normalize_lexically`
### rust.tf/libs396 *Add normalize_lexically to Path*
Accepted
### (new change proposal) rust.tf/libs435 *Adding position to Enumerate*
Accept with name `next_index`
### (new change proposal) rust.tf/libs420 *Add basic tempfile API to stdlib*
Defer for now
### (new change proposal) rust.tf/libs406 *Make \`proc\_macro\` available outside procedural macro generation*
Exclude from agenda -- waiting-on-author
### (new change proposal) rust.tf/libs403 *Add \`RawStatusCode\`*
Waiting on author
### (stalled change proposal) rust.tf/libs67 *Replace \`feature(layout\_for\_ptr)\` with \`feature(layout\_for\_meta)\`*
Defer until next week so we can review pointer metadata ACPs together with someone who knows about the design.
### (stalled change proposal) rust.tf/libs205 *Expose the internal \`SimpleMessage\` struct and allow creating \`std::io::Error\`s with them*
Amanieu: Don't like macro, SimpleMessage exposes too much internal detail
The8472: Prefer the macro solution
Defer for now, need more input from team.
### (stalled change proposal) rust.tf/libs186 *Implementing flatten for \`Option\<&Option\<T\>\>\` and \`Option\<&mut Option\<T\>\>\`*
The 8472: would like more details on alterantives / motivation. "unintuitive" doesn't seem obvious without further details.
The 8472 to reply
### (stalled change proposal) rust.tf/libs257 *Implement \`From\<&'a &'static str\>\` for \`Arguments\<'a\>\`*
Nominated for Mara
### (stalled change proposal) rust.tf/libs271 *Unix Domain Sockets on Windows*
Accept under `std::os::windows::net`
### (stalled change proposal) rust.tf/libs92 *Add \`InProgress\` variant to \`io::ErrorKind\`*
Nominate for Josh
### (stalled change proposal) rust.tf/libs122 *Revamp unstable MaybeUninit APIs*
Ask for an update with regards to what's already been changed on nightly.
Amanieu to reply.
### (stalled change proposal) rust.tf/libs296 *ACP: Designing an alternative \`FromStr\`*
### (stalled change proposal) rust.tf/libs184 *Add \`setsid\` method to \`CommandExt\` trait*
### (stalled change proposal) rust.tf/libs264 *Ability to stop child process from Inheriting Handles*
_Generated by [fully-automatic-rust-libs-team-triage-meeting-agenda-generator](https://github.com/rust-lang/libs-team/tree/main/tools/agenda-generator)_