Skip to content

Commit

Permalink
Add git-runic script (#122)
Browse files Browse the repository at this point in the history
* Add git-runic script based on git-clang-format.

* Add some docs about git-runic integration.

---------

Co-authored-by: Tim Besard <[email protected]>
  • Loading branch information
fredrikekre and maleadt authored Dec 16, 2024
1 parent 7a06393 commit 6625854
Show file tree
Hide file tree
Showing 2 changed files with 694 additions and 1 deletion.
28 changes: 27 additions & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -25,6 +25,7 @@ that is appreciated by most Go programmers, see for example the following
- [Usage](#usage)
- [CLI](#cli)
- [Editor integration](#editor-integration)
- [Git integration](#git-integration)
- [Adopting Runic formatting](#adopting-runic-formatting)
- [Ignore formatting commits in git blame](#ignore-formatting-commits-in-git-blame)
- [Badge](#badge)
Expand All @@ -44,6 +45,9 @@ julia --project=@runic -e 'using Pkg; Pkg.add("Runic")'
# Install the runic shell script
curl -fsSL -o ~/.local/bin/runic https://raw.githubusercontent.com/fredrikekre/Runic.jl/refs/heads/master/bin/runic
chmod +x ~/.local/bin/runic
# Install the git-runic shell script
curl -fsSL -o ~/.local/bin/runic https://raw.githubusercontent.com/fredrikekre/Runic.jl/refs/heads/master/bin/git-runic
chmod +x ~/.local/bin/git-runic
```

Assuming `~/.local/bin` is in your `PATH` you can now invoke `runic`, e.g.:
Expand Down Expand Up @@ -267,9 +271,28 @@ This assumes that Runic is installed in the `@runic` shared project as suggested
(push '(julia-mode . runic) apheleia-mode-alist)
```

### Git integration

The [`git-runic`](https://github.com/fredrikekre/Runic.jl/blob/master/bin/git-runic)
script (a modified version of
[`git-clang-format`](https://github.com/llvm/llvm-project/blob/main/clang/tools/clang-format/git-clang-format))
provides a convenient way to apply Runic formatting incrementally to a code
base by limiting formatting to lines that are added or modified in each commit.
The script can be installed with the following commands (replace the two
occurences of `~/.local/bin` if needed):

```sh
# Download the script into ~/.local/bin
curl -fsSL -o ~/.local/bin/git-runic https://raw.githubusercontent.com/fredrikekre/Runic.jl/refs/heads/master/bin/git-runic
# Make the script executable
chmod +x ~/.local/bin/git-runic
# Verify the installation
git runic -h
```

### Adopting Runic formatting

Here is a checklist for adopting Runic formatting in a project:
Here is a checklist for adopting Runic formatting wholesale in a project:

- Format all existing files with `runic -i <path>` and commit the changes in separate
commit. This commit can be ignored in `git blame` (see [Ignore formatting commits in git
Expand All @@ -278,6 +301,9 @@ Here is a checklist for adopting Runic formatting in a project:
future changes adhere to the formatting rules.
- Optionally add a badge to the repository README, see [Badge](#badge).

Alternatively Runic formatting can be adopted incrementally by using the
`git-runic` integration, see [Git integration](#git-integration) for details.

#### Ignore formatting commits in git blame

When setting up Runic formatting for a repository for the first time (or when upgrading to a
Expand Down
Loading

0 comments on commit 6625854

Please sign in to comment.