| ▲ | Okkef 14 hours ago |
| I worked with JJ for half a year, and it was great. However, I've since decided to go back to GIT because of compatibility with existing workflows and AI tools. Pre-commit hooks are not possible [yet?], which is a minor inconvenience. Worse, workspaces/worktrees use a different mechanism. This causes like Claude Desktop (which uses worktrees) to break. Also Claude and other agents are always confused about JJ and fall back to git too often. |
|
| ▲ | Yeroc 14 hours ago | parent | next [-] |
| Seeing similar comments across different articles and technologies and it makes me wonder how much AI is going to hold back the adoption of new technologies going forward. |
| |
| ▲ | j1elo 10 hours ago | parent | next [-] | | I find it a bit ridiculous to see that people or whole teams don't want to use JJ (or any tool, for that matter) because in essence they hired a "support intern" (read: AI assistant) who doesn't know or want to use it. | | |
| ▲ | knallfrosch 9 hours ago | parent [-] | | Why would I learn the abstraction of JJ on top of git when I've got a butler who's happy to deal with git directly? You're right in principle, but it just seems JJ is a solution in search of a problem. | | |
| ▲ | Zambyte 9 hours ago | parent [-] | | How does your AI agent deal with large merge conflict resolution? | | |
| ▲ | avarun 8 hours ago | parent [-] | | It just reads through the merge conflict and intelligently resolves it. This is not a problem. |
|
|
| |
| ▲ | surajrmal 11 hours ago | parent | prev | next [-] | | Even breaking changes in a library can cause massive pain. AI constantly wants to the use the old pattern it was trained on. Up until a few months ago it would always prefer using the 2021 edition of rust rather than 2024 for instance. Overall though I don't think this is insurmountable, but it definitely adds an impediment which will overall motivate people to do things non optimally for the foreseeable future. Luckily, not everyone is bound by AI today. I just write my own commits messages instead of letting the AI do it. jj is popular enough that I'm sure it'll learn how to use it in the next year (especially Gemini because Google is using jj internally and would probably train it on it as a result) | |
| ▲ | stouset 10 hours ago | parent | prev | next [-] | | Claude Code has zero issue using jj, for what it’s worth. | | |
| ▲ | SatvikBeri 8 hours ago | parent [-] | | I noticed it get a lot better with the 4.5 models specifically. Before then, I would have to tell Claude "do a web search for the docs for jj, then do XYZ." Now I just tell it to "do XYZ using jj" |
| |
| ▲ | ithkuil 13 hours ago | parent | prev | next [-] | | Innovation budget is a finite resource | |
| ▲ | hippo22 13 hours ago | parent | prev [-] | | I agree it will hold back new technologies, but, at the same time, I'm not sure what the value add of new technologies will be going forward. Often, as is the case with git vs. jj, the value add of a new technology is mostly ergonomic. As AI becomes more ingrained in the development flow, engineers won't engage with the underlying tech directly, and so ergonomic benefits will be diminished. New technologies that emerge will need to provide benefits to AI-agents, not to engineers. Should such a technology emerge, agent developers will likely adopt it. For this reason, programming languages, at least how we understand them today, have reached a terminal state. I could easily make a new language now, especially with the help of Claude Code et al, but there would never be any reason for any other engineer to use it. | | |
| ▲ | desmondwillow 5 hours ago | parent | next [-] | | I'm quite surprised to hear that "programming languages have reached a terminal state": there are (imo) at least four in-progress movements in the industry right now: 1. Memory safety
2. Better metaprogramming capabilities
3. Algebraic effects
4. Solver/prover awareness Even if LLMs become capable of writing all code, I think there's a good chance that we'd want those LLMs writing code in a language with memory safety and one amenable to some sort of verification. | |
| ▲ | wenc 7 hours ago | parent | prev | next [-] | | > For this reason, programming languages, at least how we understand them today, have reached a terminal state. I could easily make a new language now, especially with the help of Claude Code et al, but there would never be any reason for any other engineer to use it. This is an interesting opinion. I feel we are nowhere near the terminal state for programming languages. Just as we didn't stop inventing math after arithmetic, we will always need to invent higher abstractions to help us reason beyond what is concrete (for example, imaginary numbers). A lot of electrical engineering wouldn't be possible to reason about without imaginary numbers. So new higher abstractions -- always necessary, in my opinion. That said, I feel your finer point resonates -- about how new languages might not need to be constrained to the limitations of human ergonomics. In fact, this opens up new space of languages that can transcend human intuition because they are not written for humans to comprehend (yet are provably "correct"). As engineers, we care about human intuition because we are concerned about failure modes. But what if we could evolve along a more theoretical direction, similar to the one Haskell took? Haskell is basically "executable category theory" with some allowances for humans. Even with those tradeoffs, Haskell remains hard for most humans to write, but what if we could create a better Haskell? Then farther along, what if we created a LEAN-adjacent language, not for mathematical proofs, but for writing programs? We could throw in formal methods (TLA+) type thinking. Today formal methods give you a correctness proof, but are disconnected to implementation (AWS uses TLA+ for modeling distributed systems, but the final code was not generated from TLA+, so there's disconnect). What if one day we can write a spec, and it generates a TLA+ proof, which we can then use to generate code? In this world, the code generator is simply a compiler -- from mathematically rigorous spec to machine code. (that said, I have to check myself. I wonder what this would look like in a world full of exceptions, corner cases, and ambiguities that cannot be modeled well? Tukey's warning comes to mind: "Far better an approximate answer to the right question, than an exact answer to the wrong question") | |
| ▲ | surajrmal 11 hours ago | parent | prev | next [-] | | Even if you're not authoring changes as much, change management is likely still to be a very useful activity for a long while. Also note that not everyone is using AI today, and many that do only use it as glorified auto complete. It will take many more years for it's adoption to put us in a situation like your describing, why halt progress in the meantime? My personal productivity increased greatly by switching to jj, perhaps more than adding Gemini CLI to my workflow. I can more confidently work on several changes in parallel while waiting on things like code review. This was possible before but rebasing it and dealing with merge conflicts tended to limit me from doing it beyond a handful of commits. Now I can have 20+ outstanding commits (largely with no interdependencies) and not feel like I'm paying much management overhead while doing so. I can also get them reviewed in parallel more easily. | |
| ▲ | sunshowers 9 hours ago | parent | prev [-] | | Ah yes, the inevitable future where the only way we'll know to interact with the machine is through persuading a capricious LLM. We'll spend our days reciting litanies to the machine spirits like in 40k. | | |
| ▲ | aniforprez 8 hours ago | parent [-] | | Praise and glory be to the Agentic gods. Accept this markdown file and bless this wretched body of flesh and bone with the light of working code. Long live the OpenssAIah |
|
|
|
|
| ▲ | steveklabnik 10 hours ago | parent | prev | next [-] |
| Pre commit hooks are complicated because jj just has a fundamentally different lifecycle than git does. Tools that integrate with git specifically can be tough though, yeah. Some do Just Work, and some very much do not. I’ve found a “we use jj not git for this project” in Claude.md makes falling back to git rare, but I also tend to incorporate version control into slash commands or skills directly rather than let Claude decide what to do. |
| |
| ▲ | zamalek 2 hours ago | parent | next [-] | | Yeah, in an ideal world we'd have "save hooks" but that would probably be much too computationally expensive in some cases. | |
| ▲ | rtaylorgarlock 10 hours ago | parent | prev [-] | | I also prefer to manage version management myself directly, even with llm-gen'd CICD elements, so preferring jj hasn't been nearly as costly for me specifically :D |
|
|
| ▲ | dwattttt 4 hours ago | parent | prev | next [-] |
| I wonder if you could replace the git commands exposed to an agent. A 'commit' 'happens' when you leave a change in jj, i.e. by moving to a new or existing change; that's when you'd run pre-commit hooks. |
| |
| ▲ | steveklabnik 4 hours ago | parent [-] | | The problem with this is that at the limit, this means "run the precommit on every save of a file," which is not really usually how people think of precommit hooks. | | |
| ▲ | rtpg 3 hours ago | parent [-] | | Given jj's rebasing tooling, rewiring precommit into "prepush" feels like the right way forward. There's a bit of a phase transition between commits on your machine and commits that are out in the wild, after all. | | |
| ▲ | steveklabnik 2 hours ago | parent [-] | | Maybe! I agree that it feels kinda better. I’m not a huge hook user personally though. |
|
|
|
|
| ▲ | olup 14 hours ago | parent | prev | next [-] |
| My team is asking the same. We are using jj with great success but tools like auto claude are designed around git and git worktrees. It's a shame - at least with git backend we can sort of make things work together. |
|
| ▲ | KingMob 10 hours ago | parent | prev [-] |
| I agree about hooks and workspaces, but I'm surprised your Claude is having issues with jj itself. jj is definitely in the training data now, so it might be a matter of guiding it with CLAUDE.md. |
| |
| ▲ | Okkef 10 hours ago | parent [-] | | It usually works, but sometimes it'll try to use git instead of jj at random and needs a reminder. As JJ is not completely stable it tries some old commandline versions as well. This improved after I put in some lines in my agents file, but still it's much better at complex changes with git than jj. | | |
| ▲ | KingMob 9 hours ago | parent [-] | | If it helps, this was all I needed in my CLAUDE.md to make it use jj perfectly: # Version Control
- IMPORTANT: YOU MUST assume we use Jujutsu ("jj") for version control. Check by running `jj root` (or look for a `.jj/` directory) to confirm.
- If I say "commit", "branch", "squash", etc., assume jj equivalents first.
- You can ignore any `git add` command, since jj always auto-adds.
- Use `jj` commands instead of `git`. Never run `git` in a jj repository.
- ALWAYS prefer jj change IDs over commit SHAs. jj change IDs are stable.
- jj doesn't usually require named branches
- If you need named branches, use `jj bookmark`, but you must manually update the bookmark after making new commits, since they won't automatically get updated
- When reading data from jj, always use `--ignore-working-copy` to avoid snapshotting the working copy (which is slow and unnecessary for read operations). But when writing (commit, squash, rebase, etc.), you MUST NOT use `--ignore-working-copy`.
- If you get "Error: The working copy is stale", run `jj workspace update-stale` first
| | |
|
|