jj/demos/demo_juggle_conflicts.sh
Martin von Zweigbergk f86455a452 demos: allow running without ui.allow-init-native = true
We need to use the native backend here because of #27, but we
shouldn't require the user running the script to have it in their
config.
2022-11-14 00:25:24 -08:00

46 lines
1.3 KiB
Bash
Executable file

#!/bin/bash
set -euo pipefail
. "$(dirname "$0")"/demo_helpers.sh
new_tmp_dir
jj init --config-toml ui.allow-init-native=true
echo "first" > file
jj branch create first
jj commit -m 'first'
echo "second" > file
jj branch create second
jj commit -m 'second'
echo "third" > file
jj branch create third
jj commit -m 'third'
comment "We are in a repo with three commits, all
editing the same line:"
run_command "jj log"
run_command "jj diff -r first"
run_command "jj diff -r second"
run_command "jj diff -r third"
comment "Let's reorder the second and third commits:"
run_command "jj rebase -s third -d first"
run_command "jj rebase -s second -d third"
run_command "jj log"
comment "The commit labeled \"third\" has a conflict,
as expected. What's more interesting is
that the top commit has no conflict! That's
because it has the changes from all three
commits applied to it."
comment "Let's verify that by looking at its contents:"
run_command "jj co second"
run_command "cat file"
comment "Let's now instead make \"second\" and \"third\"
sibling and merge them:"
run_command "jj rebase -s second -d first"
run_command "jj merge second third -m merged"
run_command "jj log"
comment "Again, because the merge commit has the
changes from all three commits, it has no
conflict."