I made a small utility for listing the file names inside an archive file, e.g. tar, zip, etc. This comes in handy when you download some software package using the command line but you aren’t sure whether to extract it in its own folder because you don’t know what the file structure inside is.

  • Huh. tar tf and unzip -l. I’m not sure I’d even bother to write a shell function to combine them, much less install software.

    Zips just exploding to files is so common, if you just mkdir unzpd ; unzip -d unzpd file.zip it’s going to be right nearly all of the time. Same with tarballs always containing a directory; it’s just so common it’s barely worth checking.

    You write the tools you need, don’t get me wrong. This seems like, at most, a 10-line bash function, and even that seems excessive.

    function pear() {
    case $1 in
      *.zip)
        unzip -l "$1"
        ;;
      *.tar.*)
        tar tf "$1"
        ;;
    esac
    }
    
  • RedSnt 👓♂️🖥️@feddit.dk
    link
    fedilink
    arrow-up
    2
    ·
    3 days ago

    Nifty! I’ve recently begun using archivemount-ng, which allows mounting an archive of the formats you mention (not rar though, but I have rar2fs for that), and in theory one can easily mount an archive using those methods and just do a tree in the mount folder, but it seems that pear saves a few steps and makes that a lot easier.

  • Lembot_0004@discuss.online
    link
    fedilink
    arrow-up
    2
    arrow-down
    3
    ·
    edit-2
    3 days ago

    Haven’t used archivers from the command line for the last few decades already, so I have a question: is it faster than using the appropriate tools? When using GUIs, some archive listings are opened almost instantly, others, like *.tar.zst, could take dozens of minutes…

    P.S. There is actually no need to commit “.gitignore”

    • BrianTheeBiscuiteer@lemmy.world
      link
      fedilink
      arrow-up
      2
      ·
      2 days ago

      Disagree on the .gitignore file. If you’re the only developer and you only work off of one machine then it doesn’t need to be committed. In a team setting it’s absolutely imperative to commit it.

          • Lembot_0004@discuss.online
            link
            fedilink
            arrow-up
            1
            arrow-down
            1
            ·
            2 days ago

            It just isn’t. It has nothing to do neither with code nor with compiling. The same tier of “partness” as /etc/fstab or something.

            • vala@lemmy.dbzer0.com
              link
              fedilink
              arrow-up
              2
              ·
              2 days ago

              So everyone who contributes to the project should make their own gitignore on every development machine they use to prevent committing build files, secrets ect?

              I don’t understand why you say it has nothing to do with the code when it literally has nothing to do with anything BUT the code.

              What is the downside you see to committing the gitignore?

        • BrianTheeBiscuiteer@lemmy.world
          link
          fedilink
          arrow-up
          1
          ·
          2 days ago

          How do you ensure your teammates don’t start committing their own IDE settings or committing “secrets.json” files or helper scripts or log files?

        • nous@programming.dev
          link
          fedilink
          English
          arrow-up
          1
          ·
          edit-2
          2 days ago

          You never want build artifacts to be committed. You don’t want to have everyone working on your project to need to setup their own gitignore for every project. So it makes sense to have a common commited gitignore for files the project produces that should never be tracked by git.

          I dislike when people put in editor files in the gitignore though. People should setup global ones for their local tooling.

    • pipe01@programming.devOP
      link
      fedilink
      arrow-up
      2
      ·
      3 days ago

      It only parses as little data as possible to get just file names, on some files like ZIPs it’ll be just the header but on others like tar it’ll have to walk through and seek to the start of each file. It should be pretty fast even on big files though