As we all know, file copying on Linux has long relied on the classic cp command, which remains reliable but offers little feedback and limited control over long or complex operations.

To address this, a promising new Rust-based command-line tool called cpx emerge, designed as an alternative rather than a replacement, that approaches the same task with a focus on performance, visibility, and configurability.

It targets scenarios where large directory trees, interrupted transfers, or the need for detailed progress reporting make standard tools less convenient to use. The project is currently Linux-only and leverages modern kernel features to improve copy throughput and reliability.

  • tomenzgg@midwest.social
    link
    fedilink
    English
    arrow-up
    51
    arrow-down
    1
    ·
    20 hours ago

    New Linux util.

    looks inside

    Non-copyleft license

    I appreciate that it’s not trying to replace cp but the lack of copyleft is always disconcerting.

    • The_Decryptor@aussie.zone
      link
      fedilink
      English
      arrow-up
      7
      ·
      12 hours ago

      What’s the risk here though, a company like Amazon makes a closed source version of it?

      If it was a file format library, or something like a web server I’d get it. But stuff like cp are effectively just userspace wrappers around kernel APIs.

    • Badabinski@kbin.earth
      link
      fedilink
      arrow-up
      11
      ·
      18 hours ago

      yeah, like, supposedly it can be hard to use GPL with some rust dependencies, but the MPL is right there as a decent compromise.

      • HappyFrog@lemmy.blahaj.zone
        link
        fedilink
        arrow-up
        1
        ·
        9 hours ago

        I like and use rust, and I actively try to use permissive licenses for libraries and copy left for binaries. Just makes sense in my head.

        • Badabinski@kbin.earth
          link
          fedilink
          arrow-up
          4
          ·
          14 hours ago

          Static linking makes things difficult. I’m not sure what the details are, that’s just what I’ve heard from Rust developers.

          • The_Decryptor@aussie.zone
            link
            fedilink
            English
            arrow-up
            2
            ·
            12 hours ago

            Because of static linking, a single GPL dependency turns the entire resulting binary into a GPL licensed one, so yeah just use something like the MPL in that case (Or EUPL, which I hear is similar)

            LGPL has the same issue, since it only provides an exception for dynamic linking. But honestly that’s all an issue for lawyers and judges to sort out (I bet you could win in court with an argument that dynamically linking to GPL is actually fine).