Git repos have lots of write protected files in the .git directory, sometimes hundreds, and the default rm my_project_managed_by_git will prompt before deleting each write protected file. So, to actually delete my project I have to do rm -rf my_project_managed_by_git.

Using rm -rf scares me. Is there a reasonable way to delete git repos without it?

  • biribiri11@lemmy.ml
    link
    fedilink
    arrow-up
    0
    ·
    edit-2
    18 days ago

    If you’re nervous about rm, there’s many alternatives that work by moving a file to your recycling bin instead of deleting it outright. I think the current fun one is trash-rs, but some distros package trash-cli.

  • flux@lemmy.ml
    link
    fedilink
    arrow-up
    0
    ·
    18 days ago

    You should have backups. Preferably also snapshots. Then rm will feel less scary.

  • krnl386@lemmy.ca
    link
    fedilink
    arrow-up
    0
    ·
    edit-2
    18 days ago

    If you’re that worried, why not run chmod -R u+w .git inside the project dir to “un write-protect” the files, then just ascend to the directory containing the project dir (cd …) and use rm -r without -f?

    The force flag (-f) is the scary one, I presume?

  • davel@lemmy.ml
    link
    fedilink
    English
    arrow-up
    0
    ·
    edit-2
    19 days ago

    I’ve shot myself in the foot enough times over the years with rm -rf. Now I use trash-cli. I don’t know what package manager(s) you use, but I install it via Homebrew.

    • Buttons@programming.devOP
      link
      fedilink
      English
      arrow-up
      0
      ·
      edit-2
      19 days ago

      More like, I’m afraid of the command doing more than I’m trying to do.

      What I want to do is ignore prompts about write-protected files in the .git directory, what it does is ignore all prompts for all files.

          • Buttons@programming.devOP
            link
            fedilink
            English
            arrow-up
            0
            ·
            18 days ago

            That’s a good example. If I’m regularly running a command that is a single whitespace character away from disaster, that’s a problem.

            Imagine a fighter aircraft that had an eject button on the side of the flight stick. The pilot complains “I’m afraid I might accidentally hit the eject button when I don’t need to”, but everyone responds “why would you push the eject button if you don’t want to eject?”, or “so your concern is that the eject button will cause you to eject…?” – That’s how I feel right now.

            • OneCardboardBox@lemmy.sdf.org
              link
              fedilink
              English
              arrow-up
              0
              ·
              edit-2
              18 days ago

              How about writing a script to automate the deletion, thus minimizing the chance of human error being a factor? It could include checks like “Is this a folder with .git contents? Am I being invoked from /home/username/my_dev_workspace?”

              In a real aviation design scenario, they want to minimize the bullshit tasks that take up cognitive load on a pilot so they can focus on actually flying. Your ejector seat example would probably be replaced with an automatic ejection system that’s managed by the flight computer.

            • IsoKiero@sopuli.xyz
              link
              fedilink
              English
              arrow-up
              0
              ·
              18 days ago

              I understand the mindset you have, but trust me, you’ll learn (sooner or later) a habit to pause and check your command before hitting enter. For some it takes a bit longer and it’ll bite you in the butt for few times (so have backups), but everyone has gone down that path and everyone has fixed their mistakes now and then. If you want hard (and fast) way to learn to confirm your commands, use dd a lot ;)

              One way to make it a bit less scary is to ‘mv <thing you want removed> /tmp’ and when you confirmed that nothing extra got removed you can ‘cd /tmp; rm -rf <thing>’, but that still includes the ‘rm -rf’ part.

          • CarrotsHaveEars@lemmy.ml
            link
            fedilink
            arrow-up
            0
            ·
            17 days ago

            Generally that is not a concern because regular users won’t be able to rm anything else other than those in his own $HOME.

            Another thing I want to say is, command line is for careful users. If someone is careless, they should create a wrapper around rm, or just use a FM.

      • Butt Pirate@reddthat.com
        link
        fedilink
        arrow-up
        0
        ·
        19 days ago

        You just need to do this then

        cd git-project
        rm -rf .git
        cd ..
        rm -r git-project
        

        With rm -r is for ®ecursion and -f is for F(force) disabled the prompting. So, use -f on the .git directory which has the files you want to obliterate, and leave it off for the safety prompts.

  • bloodfart@lemmy.ml
    link
    fedilink
    arrow-up
    0
    ·
    19 days ago

    Cd into the directory first, then run rm -rf, then cd back out and rm -r just the directory.

  • ssm@lemmy.sdf.org
    link
    fedilink
    arrow-up
    0
    ·
    17 days ago

    use relative paths (cd into the directory below your repository) and use tab completion, and you won’t have problems.

  • Kekin@lemy.lol
    link
    fedilink
    arrow-up
    0
    ·
    edit-2
    19 days ago

    A tip I saw some time ago is to do:

    rm folder -rf

    Additionally you could move the git folder to the trash folder. I think it’s usually located at $HOME/.local/share/trash/files/

    Then you can delete it from the trash once you’re certain you got the right folder

    • d_k_bo@feddit.de
      link
      fedilink
      arrow-up
      0
      ·
      edit-2
      18 days ago

      Additionally you could move the git folder to the trash folder. I think it’s usually located at $HOME/.local/share/trash/files/

      Moving something to the trash files folder isn’t the correct way to trash it, since the Trash specification requires storing some metadata for each trash item.

      You should use eg. trash-cli instead.

  • gomp@lemmy.ml
    link
    fedilink
    arrow-up
    0
    ·
    18 days ago

    The problem is that rm -rf shouldn’t scare you?

    What are the chances something like

    ~/projects/some-project $ cd ..
    ~/projects $ rm -fr some-project
    

    may delete unexpected stuff? (especially if you get into the habit of tab-completing the directory argument)

  • qaz@lemmy.world
    link
    fedilink
    arrow-up
    0
    ·
    edit-2
    17 days ago

    You can use ls <PATH> first to check you are deleting the right files. I do this and I’ve never accidentally deleted the wrong files (using rm).