fixred is a command line utility to fix outdated links in files with redirect URLs.
fixred is installed via cargo package manager. libcurl is necessary as dependency.
sh
cargo install fixred
fixred --help
If you don't have Rust toolchain, a Docker image is also available.
sh
docker run -it --rm rhysd/fixred:latest --help
fixred checks redirects of URLs in text files. When a URL is redirected, fixred replaces it with the redirected one. fixred ignores invalid URLs or broken links (e.g. 404) to avoid false positives in extracted URLs.
See the help output for each flags, options, and arguments.
sh
fixred --help
Most basic usage is fixing files by passing them to command line arguments.
```sh
fixred ./docs/usage.md
fixred ./docs
fixred ./README.md ./CONTRIBUTING.md ./docs ```
When no argument is given, fixred reads stdin and outputs result to stdout.
sh
cat ./docs/usage.md | fixred
Mount local directories with -v
and pass an environment variable (if necessary) with -e
. Running
the Docker image executes fixred
executable by default.
```sh
docker run -it --rm -v $(pwd):/app -e FIXRED_LOG=info rhysd/fixred:latest /app/docs ```
Passing the input via stdin is also possible. The result is output to stdout.
```sh
cat ./docs/usage.md | docker run -i --rm rhysd/fixred:latest ```
By default, fixred follows redirects repeatedly and uses the last URL to replace. However, sometimes redirecting only
once would be more useful. --shallow
flag is available for it.
For example, link to raw README file in rhysd/vim-crystal
repository (moved to vim-crystal/vim-crystal
later) is
redirected as follows.
When you want to fix 1. to 2. but don't want to fix 1. to 3., --shallow
is useful.
sh
fixred --shallow ./README.md
When you want to fix only specific links in a file, filtering URLs with regular expressions is available. The following
example fixes URLs which starts with https://github.com/
using --extract
option.
sh
fixred --extract '^https://github\.com/' ./docs
--ignore
option is an invert version of --extract
. URLs matched to the pattern are ignored. The following example
avoids to resolve URLs which contain hashes.
sh
fixred --ignore '#' ./docs
By default, fixred outputs nothing when it runs successfully. For verbose log outputs, --verbose
flag or $FIXRED_LOG
i
environment variable is available.
```sh
fixred --verbose
FIXRED_LOG=info fixred ./docs
FIXRED_LOG=debug fixred ./docs ```
Here is an example of usage in actionlint project.
Please see the API document. And for the real world example, please see src directory.
To install as dependency, add fixred
to your Cargo.toml
file.
toml
[dependencies]
fixred = "1"
Here is a small example code
```rust use fixred::resolve::CurlResolver; use fixred::redirect::Redirector;
fn main() {
let red = Redirector::
Distributed under the MIT license.