made in gimp, with <3

Context for actual rust programmers

I was having massive beef with the rust compiler yesterday, every cargo check takes 20 seconds.

And then look at the three functions below, only one of them are Send, if you know why, please let me know.

(Note: value that is not Send cannot be held across an await point, and Box<dyn Error> is not Send)

async fn one() {
    let res: Result<(), Box<dyn Error>> = do_stuff();
    if let Err(err) = res {
        let content = err.to_string();
        let _ = do_stuff(content).await;
    }
}

async fn two() {
    let res: Result<(), Box<dyn Error>> = do_stuff();
    let content = if let Err(err) = res {
        Some(err.to_string())
    } else {
        None
    };
    drop(res);
    if let Some(content) = content {
        let _ = do_stuff(content).await;
    }
}

async fn three() {
    let content = {
        let res: Result<(), Box<dyn Error>> = do_stuff();
        if let Err(err) = res {
            Some(err.to_string())
        } else {
            None
        }
    };
    if let Some(content) = content {
        let _ = do_stuff(content).await;
    }
}
  • wisha@lemmy.ml
    link
    fedilink
    arrow-up
    10
    ·
    edit-2
    14 hours ago

    You are running into the Send Approximation being too conservative. The compiler does not like to see a let binding for a non-Send type and an .await statement in the same scope. It is not (yet) smart enough to know that the non-Send type is already consumed by the time of the .await.

    You’ve already discovered the workaround in your three(). To make it more concise

    async fn four() {
        let content = do_stuff().err().map(|err| err.to_string());
        if let Some(content) = content {
            let _ = do_stuff_2(content).await;
        }
    }
    
  • [object Object]@sh.itjust.works
    link
    fedilink
    English
    arrow-up
    94
    arrow-down
    2
    ·
    edit-2
    23 hours ago

    Rust output is bad? I feel like it’s one of the best in terms of telling you where you got things wrong. Nix output when you accidentally get infinite recursion is so bad.

    Come to think of it, Nix fits all three better than Rust.

      • Ethan@programming.dev
        link
        fedilink
        English
        arrow-up
        1
        arrow-down
        5
        ·
        16 hours ago

        Yes, preferring a language that’s easy to read and therefore easy to maintain over a language like Rust is definitely coping 🙄

        • WhyJiffie@sh.itjust.works
          link
          fedilink
          English
          arrow-up
          15
          arrow-down
          1
          ·
          14 hours ago

          preferring Rust over Rust? what do you mean?

          do you think loosely typed python is easy to read and maintain?

            • edinbruh@feddit.it
              link
              fedilink
              English
              arrow-up
              2
              ·
              edit-2
              3 hours ago

              Yeah, like, who would ever want to

              stuff1()?.map(stuff2);
              

              It’s much better to just:

              err, value = stuff1();
              if err == nil 
                  return err, nil;
              if value != nil
                  stuff2(value);
              
              

              And you might even:

              for a in vec {
                  vec[a]
              }
              
    • First_Thunder@lemmy.zip
      link
      fedilink
      arrow-up
      11
      ·
      20 hours ago

      Ah yes, the good old random pile of unclear errors because you forgot to add the file in git thanks nix

      • bobo@lemmy.ml
        link
        fedilink
        arrow-up
        5
        ·
        11 hours ago

        random pile of unclear errors

        warning: Git tree ‘/path/to/repo’ is dirty

        • Ephera@lemmy.ml
          link
          fedilink
          English
          arrow-up
          1
          ·
          2 hours ago

          Unfortunately, that shows up even when you’ve just modified an existing file, which is not a problem for it.

          And which also happens to be the state my repo is in basically all the time, because I’ll change some setting, then see if it works like I want it to before making a commit…

          • bobo@lemmy.ml
            link
            fedilink
            arrow-up
            1
            ·
            edit-2
            46 minutes ago

            Fortunately, your comment is not relevant at all since I incorrectly posted the warning instead of the explicit error:

            error: Path 'path/to/file' in the repository "/path/to/repo" is not tracked by Git.
            

            It even gives you

            To make it visible to Nix, run:
            
            git -C "/path/to/repo" add "path/to/file"
            
  • anyhow2503@lemmy.world
    link
    fedilink
    arrow-up
    70
    arrow-down
    1
    ·
    22 hours ago

    I get that it’s supposed to be a meme, but aside from the first one these aren’t even rust stereotypes. Is this a meme specifically for people who haven’t used rust, know nothing about rust but have maybe heard that it’s a programming language?

    • nightlily@leminal.space
      link
      fedilink
      English
      arrow-up
      22
      ·
      19 hours ago

      Yeah, part of the point of Rust is that it does exactly what you tell it - sometimes to the point of absurdity. No implicit casting for instance.

      • MoffKalast@lemmy.world
        link
        fedilink
        arrow-up
        7
        ·
        edit-2
        18 hours ago

        And here I was thinking most of our programming problems come from the thing doing exactly what we told it to, but didn’t quite think the process through enough. Or at all.

    • Fontasia@feddit.nl
      link
      fedilink
      arrow-up
      13
      ·
      19 hours ago

      This is for people who learnt C++ in 2008 and refuse to believe that they’ve never fucked up a malloc in their lives

    • communism@lemmy.ml
      link
      fedilink
      arrow-up
      9
      ·
      20 hours ago

      I mean Rust is definitely known for long compilation times but yeah otherwise I am not sure how any of this is Rust-specific. Maybe by “doesn’t do what you tell it to do” they mean the borrow checker and strict compile time checks…?

        • anyhow2503@lemmy.world
          link
          fedilink
          arrow-up
          2
          ·
          8 hours ago

          I was actually wondering if this was supposed to be about a specific problem someone has with rust (not like I haven’t gotten stuck on some weird corner with rust before), but looking at the meme, that seemed unlikely to me. Thanks for the context.

    • Ephera@lemmy.ml
      link
      fedilink
      English
      arrow-up
      3
      ·
      13 hours ago

      Yeah, I was gonna say, that might be the root cause.

      In the vast majority of cases, you want Box<dyn Error + Send + Sync>, but folks tend to leave out the Send + Sync, because it looks like additional complexity to them, and because it doesn’t cause problems when they’re not doing async/await.
      It’s better to define a type alias, if you don’t want that long type name everywhere.