-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
158894e
commit 7908de8
Showing
1 changed file
with
86 additions
and
14 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,24 +1,96 @@ | ||
# Buku Merger | ||
|
||
[![Package Version](https://img.shields.io/hexpm/v/buku_merger)](https://hex.pm/packages/buku_merger) | ||
[![Hex Docs](https://img.shields.io/badge/hex-docs-ffaff3)](https://hexdocs.pm/buku_merger/) | ||
Custom Git driver to handle merge conflicts of your [buku](buku) bookmarks. | ||
|
||
```sh | ||
gleam add buku_merger@1 | ||
I had the idea of using git to sync my bookmarks, _which are stored as a | ||
SQLite database_. The first merge conflict proved me that it was a bad idea. But | ||
I am lazy and I don't want to handle the sync service myself, so I made this | ||
tool to handle the conflicts automatically for me so that I can keep using git | ||
as a "cloud service" for my bookmarks. | ||
|
||
Feel free to use it for your own buku git repository! | ||
|
||
## Installation | ||
|
||
**From source:** | ||
|
||
1. Clone the repository. | ||
1. Install [Gleam](gleam) | ||
1. Run `gleam run -m gleescript`. | ||
1. Add the generated `buku_merger` to your `PATH`. | ||
|
||
**Using Nix:** | ||
|
||
This repository includes a flake which provides the package. You can test the | ||
package directly by running: | ||
|
||
```bash | ||
nix run "github:pierrot-lc/buku-merger" | ||
``` | ||
|
||
## How to Use | ||
|
||
The tool expects the following: | ||
|
||
```bash | ||
buku_merger <base> <current> <other> | ||
``` | ||
```gleam | ||
import buku_merger | ||
|
||
pub fn main() { | ||
// TODO: An example of the project in use | ||
} | ||
Where: | ||
|
||
- `<current>` is the local version of the bookmarks database, | ||
- `<other>` is the remote version conflicting with your `<current>` version, | ||
and | ||
- `<base>` is the latest common ancestor between the two conflicting databases. | ||
|
||
To use the tool automatically when there's a conflict, you need to add the driver | ||
to your Git configuration: | ||
|
||
```gitconfig | ||
# .gitconfig or config | ||
[merge "buku-driver"] | ||
name = "Custom buku merge driver, handling the bookmarks SQLite database" | ||
driver = buku_merger %O %A %B | ||
recursive = binary | ||
``` | ||
|
||
Further documentation can be found at <https://hexdocs.pm/buku_merger>. | ||
Add those lines either in your `~/.config/git/config` globally or in your buku | ||
repository at `.git/config`. | ||
|
||
## Development | ||
Then, specify in your buku repository that you want to use that driver for | ||
bookmark conflicts: | ||
|
||
```sh | ||
gleam run # Run the project | ||
gleam test # Run the tests | ||
```gitattributes | ||
# .gitattributes | ||
bookmarks.db merge=buku-driver | ||
``` | ||
|
||
Place this file at the root of your buku repository. | ||
|
||
## How it Works? | ||
|
||
The merge conflict is handled in two phases: | ||
|
||
1. Finds the modified rows from `<other>` w.r.t. `<current>` and apply those | ||
modifications to `<current>`. | ||
1. Finds the new rows from `<other>` that do not exist in `<current>` and them | ||
to it. | ||
1. ~~Finds the removed rows from `<other>` that are still present in `<base>` and | ||
remove them from `<current>`.~~ | ||
|
||
The final file `<current>` is what git uses as the merged version of the file. | ||
|
||
_I do not delete the bookmarks anymore as it is too easy to mess everything up._ | ||
|
||
## Shoutouts | ||
|
||
This tool is made using the awesome [Gleam](gleam) language and uses | ||
[sqlight](sqlight) to interface with SQLite. | ||
|
||
The flake uses [nix-gleam](nix-gleam) to generate the package derivation | ||
effortlessly. | ||
|
||
[buku]: https://github.com/jarun/buku | ||
[gleam]: https://gleam.run/ | ||
[nix-gleam]: https://github.com/arnarg/nix-gleam | ||
[sqlight]: https://github.com/lpil/sqlight |