|
|
|
|
|
by nextaccountic
950 days ago
|
|
> Rust currently cannot reliably panic on allocation failures because the error object is inside a Box, which itself requires allocation. This means that if memory is tight, panicking itself might fail. This seems like something that should be allocated at program startup, just like other things like the program's environment (I think it's copied to Rust's own data structures at startup to avoid using the non-threadsafe C API), and other things allocated at startup .. but of course, not at Linux, such error allocation would be unneeded there.. .. except of you disable overcommit, which can and do happen, so in the general case you don't know if this error object can ever appear |
|
It should be possible to add a third arm to that Result type, returning some &'static reference, but I'm not sure how to do it in a backwards-compatibile way.