Hi all! Thanks for chiming in. I'm sorry I wasn't able to participate in a timely manner, and unfortunately (once again..), I will be out of the office (returning 27 Apr, PDT) and my colleagues will be keeping tabs on the discussion in my stead (once again..). Nevertheless, I think the conversation has been pretty fruitful, so I'm optimistic about next steps. Here's my understanding of the conversation thus far - do chime in if you feel I'm off base or if I've missed something: * We all agree that something needs to be done about embedded bare repos. This is a pretty good starting point IMO, because we agree that 'do nothing' isn't a good response. * There are use cases for embedded bare repos that don't have great alternatives (e.g. libgit2 uses bare repos in its tests). Even if this workflow is frowned upon (I personally don't think we should support it), I don't think we're ready to categorically declare that Git should ban embedded bare repos altogether (e.g. the way we ban .GiT). * We want additional protection on the client besides `git fsck`; there are a few ways to do this: 1. Prevent checking out an embedded bare repo. 2. Detect if the bare repo is embedded and refuse to work with it. 3. Detect if the bare repo is embedded and do not read its config/hooks, but everything else still 'works'. 4. Don't detect bare repos. 5. Only detect bare repos that are named `.git` [1]. (I've responded with my thoughts on each of these approaches in-thread). With that in mind, here's what I propose we do next: * Merge the `git fsck` patch [2] if we think that it is useful despite the potentially huge number of false positives. That patch needs some fixing; I'll make the changes when I'm back. * I'll experiment with (5), and if it seems promising, I'll propose this as an opt-in feature, with the intent of making it opt-out in the future. We'll opt-into this at Google to help figure out if this is a good default or not. * If that direction turns out not to be promising, I'll pursue (1), since that is the only option that can be configured per-repo, which should hopefully minimize the fallout. Given that this embedded bare repo problem has been known for a long time, I don't think we need to rush out a fix, but (especially since I'll be OOO) I'm more than happy for someone to take my ideas (or any ideas) and run with them. [1] https://lore.kernel.org/git/kl6l5yn99ahv.fsf@xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx/ [2] https://lore.kernel.org/git/20220406232231.47714-1-chooglen@xxxxxxxxxx