Permanently Deleted

  • Rustmilian
    link
    3
    edit-2
    1 year ago

    If you go to the uutils repo you can see that it’s making proper use of fuzzing, test, etc. and only makes use of unsafe in necessary areas. Uutils is also more consistent with modern standards thanks to clap & uniform design, has out of the box selinux support, etc.

    The unsafe keyword isn’t inherently “unsafe”, nore does it disable any checks contrary to what some believe.

    if you use a reference in unsafe code, it will still be checked.

    Also many distros are already packaging uutils do to it “growing into remarkably robust shape”, it’s just not ready to completely replace coreutils quite yet and so it’s not up for consideration by distros to ditch coreutils until it’s at least at parity. (That’s why I make use of hybrid and not outright replacing everything).

    The point is not the language, it’s how the project is making use of the language and uutils is doing a lot right.

    • folkrav
      link
      fedilink
      1
      edit-2
      1 year ago

      My point was intended to be more generic than just uutils though. Agreed that this specific project looks interesting.

      And yes, I know the unsafe keyword is not inherently unsafe to use, but it’s also, in practice, one of the few potential footguns of the language, and is easy to abuse and get wrong. It’ll raise a few eyebrows in PRs and you’ll be expected to have both good reasons and a good test coverage at the very minimum lol. It’s a good red flag, if you do end up with runtime memory issues, that it’s probably happening in that block, but past this, you’re still basically foregoing some safety for convenience. And people fail. Often.