1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
|
+++
title = "mkhint"
tagline = "Manage slackrepo hint files: bump versions, recompute checksums, track upstream releases."
status = "active"
repo_url = "https://git.danix.xyz/mkhintfile"
tags = ["bash", "slackware", "slackrepo", "packaging"]
[menus.main]
name = "hintfiles helper"
parent = "slackware"
weight = 10
+++
**mkhint** is a single Bash script that takes the tedium out of maintaining
[slackrepo](https://idlemoor.github.io/slackrepo/) *hint files*. A hint file
overrides build details for an SBo package: which version to build, where to
download the source, and the checksums to verify it. Keeping those in sync by
hand, across dozens of packages, is exactly the kind of repetitive work a
script should own.
## What it does
- **Update a hint** `-f package -v 2.0.1`: bump the version everywhere in the
file, re-download the source from `DOWNLOAD` / `DOWNLOAD_x86_64`, and recompute
`MD5SUM` / `MD5SUM_x86_64`. The old file is backed up to `.bak` first.
- **Create a hint** `-n package`: generate a new hint from the matching
repository `.info` file, stripping the fields slackrepo does not want and
defaulting `ARCH` to `x86_64`. With no `.info`, it writes an empty skeleton.
- **List** `-l`: print every hint with its `HintVer` (version in the hint) next
to the `SBOVer` (version in the repo `.info`), highlighting the rows where the
two are byte-equal so you can spot hints that have become redundant with
upstream.
- **Review** `-R`: walk only those matched hints, showing each hint side by
side with its `.info` (`git diff --no-index`, falling back to `diff -y`), and
prompt to keep, delete, or skip.
- **Check** `-C [package...]`: query
[nvchecker](https://github.com/lilydjwg/nvchecker) for the latest upstream
version of one, several, or all hints; report what is outdated; update accepted
packages with `nvtake`; and finish with a single `slackrepo update` prompt for
everything that changed.
- **Housekeeping** `-d package` / `-c`: delete a hint and its backup, or clean
every `.bak` from the hint directory in one go.
## Command reference
```text
mkhint - Manage hint files for slackrepo scripts
Usage:
./mkhint --version VERSION --hintfile FILE Update existing hint file
./mkhint --version VERSION --new FILE Create new hint file
./mkhint --new FILE Create new hint file (no version)
./mkhint --hintfile FILE Update hint, suggest latest version via nvchecker
./mkhint --check [FILE...] Check all (or named) hints for upstream updates
./mkhint --list List hint files
./mkhint --review Review hints matching SBo version, keep/delete each
./mkhint --clean Remove .bak files from HINT_DIR
./mkhint --no-dl --hintfile FILE Update hint, skip downloads, add NODOWNLOAD=yes
./mkhint --no-dl --new FILE Create hint with NODOWNLOAD=yes
./mkhint --help Show this help
Options:
--version, -v VERSION New version string (required for --hintfile)
--hintfile, -f FILE Path to existing hint file (required with --version)
--new, -n FILE Create new hint file (required with --version or standalone)
--list, -l List all hint files in the default directory
--review, -R Review hints whose version matches the SBo .info; diff + keep/delete
--clean, -c Remove all .bak files from HINT_DIR
--check, -C [FILE...] Check hints for upstream updates via nvchecker, update interactively
--delete, -d FILE Delete a hint file (and .bak if present)
--no-dl, -N Skip downloads; add NODOWNLOAD=yes to hint file (use with -f or -n)
--help, -h Show this help message
```
## How it works
mkhint is plain Bash with three small dependencies, each doing one job:
- `wget` downloads archives so their MD5 can be computed,
- `nvchecker` (and its companion `nvtake`) tracks upstream versions,
- `jq` parses nvchecker's JSON output.
Everything else is shell. Paths to the repository and the hint directory are
two variables at the top of the script. The bash-completion file mirrors them,
so `-f`, `-n`, `-d`, and `-C` autocomplete package names from the right
directory, and `-v` even suggests the current version pulled straight from the
named hint file.
Multiline `DOWNLOAD` entries (a package with several source URLs) are handled
carefully: the first URL is always re-fetched because the version changed,
while each continuation URL is offered interactively so unchanged sources keep
their existing checksum instead of being downloaded again for nothing.
## Why it exists
Maintaining a personal SBo overlay means a steady trickle of version bumps.
Each one is the same dance: edit the version string, fetch the new tarball,
recompute the checksum, hope you did not fat-finger a digit. mkhint turns that
dance into one command, and the `--check` / `--list` / `--review` trio turns
"which of my hints are now stale or pointless?" from a manual audit into a
glance. It is the kind of small, sharp tool Slackware encourages: no daemon,
no database, no framework, just a script that does one annoying job well.
## Quick start
```bash
sudo cp mkhint /usr/local/bin/mkhint
sudo cp mkhint.bash-completion /etc/bash-completion.d/mkhint
# update an existing hint to a known version
mkhint -f mypackage -v 2.0.1
# create a new hint from the repo .info
mkhint -n mypackage
# see what upstream has moved on
mkhint --check
```
Edit the `REPO_DIR` and `HINT_DIR` paths at the top of the script (and in the
completion file) to match your setup before first use.
{{< actions use="repo" url="https://git.danix.xyz/mkhintfile/" desc="Browse the source" caption="I hope you find it useful. If you maintain your own slackrepo overlay, mkhint might save you the same tedium it saves me. Patches and ideas are welcome." >}}
|