this post was submitted on 14 Dec 2024
8 points (100.0% liked)

Rust Programming

8228 readers
20 users here now

founded 5 years ago
MODERATORS
 

I am trying to understand the std::process::Termination trait.

As I'm not really used to read libraries, I took this as a challenge to try understanding a bit more about how to read them as well.

I think trying to build a library would give me better understanding, but for now...

Termination is quite easy, from the trait page I can see that this trait has single method: report, which returns an ExitCode.

pub trait Termination {
    fn report(self) -> ExitCode;
}

But when I try to dig in further and i read the page related to ExitCode, it confuses me a bit.

ExitCode is a struct, therefore it behaves like a type with many fields which define the types contained in the struct.

I cannot really understand what's the point of this type.. I don't see any fields defined in the struct and this part confuses me a lot:

The standard library provides the canonical SUCCESS and FAILURE exit codes as well as From for ExitCode for constructing other arbitrary exit codes.

I even thought this meant it was an enum which had the SUCCESS, FAILURE etc as variants, but this does not seem the case.

Can you help me to understand how this specific structs work, what exactly does it do and how I should read library pages like this one?

you are viewing a single comment's thread
view the rest of the comments
[–] [email protected] 2 points 4 days ago* (last edited 4 days ago) (1 children)

Here's the source of the ExitCode implementation for Unix: https://doc.rust-lang.org/src/std/sys/pal/unix/process/process_common.rs.html#622

I'm a seasoned Rust dev and this wasn't easy for me to find. The std lib can be somewhat complex, because it needs to cover all possible use-cases...

[–] [email protected] 3 points 4 days ago (1 children)

this wasn’t easy for me to find

Huh! This is the internal ExitCode, and it's two jump-to-definition calls away. The first to get to the public type definition, and the second from the public type's struct field to the private type.

[–] [email protected] 3 points 4 days ago (1 children)

If I had downloaded the source code and opened it in my editor, then it probably would've lead me there pretty easily, yeah. But you won't normally download the source code for libraries you're looking to use. Trying to navigate there via the imports and module structure is certainly a lot more difficult, because they seem to do various re-exports, in particular for the different implementations for different operating systems...

[–] [email protected] 1 points 4 days ago (1 children)

Another huh from me. Or maybe I'm missing something, because this should all be obvious.

The source of the standard library is a rustup component that everyone should have installed. As for crates, you don't have to manually download any sources. Just add the crate as a dependency, and jump around definitions as much as you like. You can remove the dependency later if you decide to not use it.

[–] [email protected] 2 points 4 days ago

Alright, yeah, I guess, I could've opened one of my Rust projects, written down use std::process::Termination; and jumped in that way. Admittedly, I didn't think of that, but it also sounded like OP wants to learn how to read the webpage documentation...