add readme
- SHA
08b2c07a72d514e4bfdaeceffa60710cb1b8cdd1- Parents
-
3ceeb23 - Tree
0ba5b9e
08b2c07
08b2c07a72d514e4bfdaeceffa60710cb1b8cdd13ceeb23
0ba5b9e| Status | File | + | - |
|---|---|---|---|
| A |
README.md
|
59 | 0 |
README.mdadded@@ -0,0 +1,59 @@ | |||
| 1 | +# fit | ||
| 2 | +(noun) : something clever never | ||
| 3 | + | ||
| 4 | +A terminal-based merge conflict resolver with a three-pane TUI interface, written in Modern Fortran. | ||
| 5 | + | ||
| 6 | +## Features | ||
| 7 | + | ||
| 8 | +- **Three-Pane Layout**: Visual side-by-side comparison similar to VS Code's merge conflict UI | ||
| 9 | + - Left pane: Incoming changes (from remote/HEAD) | ||
| 10 | + - Right pane: Local changes (current branch) | ||
| 11 | + - Bottom pane: Live preview of your resolution choice | ||
| 12 | + | ||
| 13 | +- **Color-Coded Diffs**: | ||
| 14 | + - Green `+` for incoming additions | ||
| 15 | + - Red `-` for local changes | ||
| 16 | + - Clear visual distinction between versions | ||
| 17 | + | ||
| 18 | +- **Sequential Navigation**: Navigate through multiple conflicts with keyboard shortcuts | ||
| 19 | + | ||
| 20 | +- **Interactive Resolution**: Choose incoming, local, or both changes for each conflict | ||
| 21 | + | ||
| 22 | +## Installation | ||
| 23 | + | ||
| 24 | +### Prerequisites | ||
| 25 | +- [Fortran Package Manager (fpm)](https://fpm.fortran-lang.org/) | ||
| 26 | +- A modern Fortran compiler (gfortran, ifort, etc.) | ||
| 27 | + | ||
| 28 | +### Build | ||
| 29 | +```bash | ||
| 30 | +fpm build | ||
| 31 | +``` | ||
| 32 | + | ||
| 33 | +### Install | ||
| 34 | +```bash | ||
| 35 | +fpm install | ||
| 36 | +``` | ||
| 37 | + | ||
| 38 | +## Usage | ||
| 39 | + | ||
| 40 | +```bash | ||
| 41 | +fit <file-with-conflicts> | ||
| 42 | +``` | ||
| 43 | + | ||
| 44 | +Example: | ||
| 45 | +```bash | ||
| 46 | +fit myfile.txt | ||
| 47 | +``` | ||
| 48 | + | ||
| 49 | +## Keyboard Controls | ||
| 50 | + | ||
| 51 | +| Key | Action | | ||
| 52 | +|-----|--------| | ||
| 53 | +| `i` | Select **incoming** changes (from remote/HEAD) | | ||
| 54 | +| `l` | Select **local** changes (current branch) | | ||
| 55 | +| `b` | Select **both** changes (incoming then local) | | ||
| 56 | +| `n` / `→` / `↓` | Navigate to **next** conflict | | ||
| 57 | +| `p` / `←` / `↑` | Navigate to **previous** conflict | | ||
| 58 | +| `s` | **Save** resolved file and quit | | ||
| 59 | +| `q` / `ESC` | **Quit** without saving | | ||