# Libs-API Meeting 2023-08-29 ###### tags: `Libs Meetings` `Minutes` **Meeting Link**: https://meet.jit.si/rust-libs-meeting-crxoz2at8hiccp7b3ixf89qgxfymlbwr **Attendees**: Amanieu, David, Mara, The 8472, Urgau, wayne ## Agenda - Triage - Anything else? ## Triage ### FCPs 1 rust-lang/rfcs T-libs-api FCPs - merge rust.tf/rfc3453 *Add \`f16\` and \`f128\` float types* - (5 checkboxes left) 13 rust-lang/rust T-libs-api FCPs - merge rust.tf/80437 *Tracking Issue for \`box\_into\_inner\`* - (1 checkboxes left) - merge rust.tf/52331 *Correcting Path::components on Redox* - (5 checkboxes left) - merge rust.tf/82901 *Tracking Issue for \`Option::get\_or\_insert\_default\`* - (2 checkboxes left) - merge rust.tf/83871 *Tracking Issue for CharIndices::offset function* - (3 checkboxes left) - merge rust.tf/99262 *Tracking Issue for \`io\_error\_downcast\`* - (4 checkboxes left) - merge rust.tf/106655 *Tracking Issue for \`#!\[feature(offset\_of)\]\`* - (0 checkboxes left) - merge rust.tf/107587 *Mark \`std\` integral modules as deprecated (\`std::u32\`, \`std::i16\`, etc.)* - (3 checkboxes left) - merge rust.tf/62726 *Tracking issue for io\_slice\_advance* - (3 checkboxes left) - merge rust.tf/80552 *Tracking Issue for the GroupBy and GroupByMut iterators* - (3 checkboxes left) - merge rust.tf/85528 *Implement iterator specialization traits on more adapters* - (4 checkboxes left) - merge rust.tf/114986 *FCP process: Require 2/3 majority for FCP* - (5 checkboxes left) - merge rust.tf/106418 *Implement \`PartialOrd\` and \`Ord\` for \`Discriminant\`* - (1 checkboxes left) - merge rust.tf/115108 *Fix exit status / wait status on non\-Unix cfg(unix) platforms* - (3 checkboxes left) [joshtriplett (4)](https://rfcbot.rs/fcp/joshtriplett), [Amanieu (5)](https://rfcbot.rs/fcp/Amanieu), [m-ou-se (9)](https://rfcbot.rs/fcp/m-ou-se), [BurntSushi (7)](https://rfcbot.rs/fcp/BurntSushi), [dtolnay (5)](https://rfcbot.rs/fcp/dtolnay) ### (nominated) rust.tf/85122 *Tracking Issue for inherent unchecked integer methods* Waiting on Mara to reply from last meeting. ### (nominated) rust.tf/91345 *Tracking Issue for \`result\_option\_inspect\`* Waiting on Mara to reply from last meeting. ### (nominated) rust.tf/111090 *Tracking Issue for const \`\[u8\]::is\_ascii\` (\`const\_slice\_is\_ascii\`)* FCP ongoing. Nominated label removed. ### (nominated) rust.tf/114564 *Attempt to describe the intent behind the \`From\` trait further* Waiting on author. Removed nominated label. Seems fine after applying Josh's suggestion. Amanieu to comment. ### (nominated) rust.tf/114737 *\`std::process::Command::env\_clear\` is unusable on Windows* Pinged windows ping group with the question. ### (nominated) rust.tf/114780 *add more explicit I/O safety documentation* Amanieu: We should make clear that uniquely owning a fd does not mean uniquely owning the underlying file. Mara: text already says underlying "file description" is not unique. Mara: https://github.com/nix-rust/nix/issues/1421 is relevant. close(123) is no longer safe under these rules. Mara: nix::unistd::close is still a safe function today.. but it's nearly impossible to write a safe library if you have to assume another library can randomly close (and reopen) your file descriptors.. Amanieu: I'll read through it. It's on Josh's review queue. ### (waiting on team) rust.tf/87920 *Tracking Issue for \`Saturating\` type* Waiting for FCP to complete ### (waiting on team) rust.tf/114149 *\`read\_dir\` has unexpected behavior for \`""\`* Discussed before, but didn't reach consensus. (Some of us wanted "" to work for the CWD, others didn't want "" to work.) Mara left a comment a few weeks ago with her perspective. The 8472 to write up the opposing perspective. David: Either way, *a* change is necessary. (Either fix on Windows or make "" work on Unix.) ### (new change proposal) rust.tf/libs256 *Add a \`CStr::len()\` method* Discussed last time. Mara replied earlier today. ### (new change proposal) rust.tf/libs257 *Implement \`From\<&'a &'static str\>\` for \`Arguments\<'a\>\`* Mara: I implemented a new fmt::Arguments that supports Arguments::from_str(&str). Still tweaking perf. Can merge that soon. David: When would we stabilize that? Mara: We should leave it unstable for a few months, while I try out a few more fmt::Arguments implementations. But I'm pretty confident we should always support Arguments::from_str. ### (new change proposal) rust.tf/libs259 *Add openat/unlinkat/etc. abstractions to ReadDir/DirEntry/OpenOptions* ### (new change proposal) rust.tf/libs260 *Include MappedRwLocKWriteGuard from lock\_api or parking\_lot* [Discussion about use cases] Amanieu: I've used it twice David: I just write a wrapper struct. The API of a guard is very very small. Amanieu: I'm in favor of adding it. It's not obvious how to write it yourself. Mara: You can't write it safely yourself. Amanieu: right Mara: lock_api has `map` and `try_map`. Do we need both? Amanieu: probably. Mara: Not convinced we need this. What's wrong with writing your own wrapper, keeping the original guard? Amanieu: Then you might have to expose generic args that you don't want to expose. Mara: Right. Mara: Not fully convinced, but adding as unstable is fine with me. Amanieu to reply. ### (new change proposal) rust.tf/libs261 *add \`write\_fmt\` method to String, to make \`write!\` macro work without imports* ### (stalled change proposal) rust.tf/libs152 *Feature item\_find\_many* ### (stalled change proposal) rust.tf/libs156 *&mut \[MaybeUninit\<T\>\]: Fill with value or with closure.* ### (stalled change proposal) rust.tf/libs155 *Arbitrary alternate flags in \`std::fmt::Formatter\`* ### (stalled change proposal) rust.tf/libs124 *Integrate \`Error\` trait with panic interfaces* ### (stalled change proposal) rust.tf/libs111 *Restructure ptr\_metadata to minimal support* _Generated by [fully-automatic-rust-libs-team-triage-meeting-agenda-generator](https://github.com/rust-lang/libs-team/tree/main/tools/agenda-generator)_