Format with unstable rustfmt options

- Format with nightly rustfmt
- Enable unstable options in rustfmt.toml
- Turn off git text file detection, so newlines are always unix newlines

type: reform
This commit is contained in:
Casey Rodarmor 2020-03-05 22:51:00 -08:00
parent d71bdffda1
commit f2a5f13729
No known key found for this signature in database
GPG Key ID: 556186B153EC6FE0
10 changed files with 111 additions and 44 deletions

1
.gitattributes vendored Normal file
View File

@ -0,0 +1 @@
* -text

View File

@ -21,7 +21,7 @@ jobs:
runs-on: ${{matrix.os}} runs-on: ${{matrix.os}}
steps: steps:
- uses: actions/checkout@v2 - uses: actions/checkout@v2
- name: Install - name: Install Stable
uses: actions-rs/toolchain@v1 uses: actions-rs/toolchain@v1
with: with:
toolchain: stable toolchain: stable
@ -43,8 +43,15 @@ jobs:
- name: Lint - name: Lint
if: matrix.os != 'windows-latest' if: matrix.os != 'windows-latest'
run: ./bin/lint run: ./bin/lint
- name: Install Nightly
uses: actions-rs/toolchain@v1
with:
toolchain: nightly
target: ${{matrix.target}}
profile: minimal
components: rustfmt
- name: Format - name: Format
run: cargo fmt --all -- --check run: cargo +nightly fmt --all -- --check
- name: Readme - name: Readme
if: matrix.os != 'windows-latest' if: matrix.os != 'windows-latest'
run: | run: |

View File

@ -33,6 +33,9 @@ test:
clippy: clippy:
cargo clippy --all cargo clippy --all
fmt:
cargo +nightly fmt --all
lint: lint:
./bin/lint ./bin/lint
@ -59,7 +62,7 @@ check-minimal-versions:
check: test clippy lint check-minimal-versions check: test clippy lint check-minimal-versions
git diff --no-ext-diff --quiet --exit-code git diff --no-ext-diff --quiet --exit-code
cargo fmt --all -- --check cargo +nightly fmt --all -- --check
cargo run --package update-readme toc cargo run --package update-readme toc
git diff --no-ext-diff --quiet --exit-code git diff --no-ext-diff --quiet --exit-code

View File

@ -1,2 +1,18 @@
tab_spaces = 2 comment_width = 80
edition = "2018"
error_on_line_overflow = true
error_on_unformatted = true
format_code_in_doc_comments = true
format_macro_bodies = true
format_strings = true
max_width = 100 max_width = 100
merge_imports = true
newline_style = "Unix"
normalize_comments = true
reorder_impl_items = true
required_version = "1.4.12"
tab_spaces = 2
unstable_features = true
use_field_init_shorthand = true
use_try_shorthand = true
wrap_comments = true

View File

@ -51,7 +51,8 @@ pub(crate) enum Error {
#[snafu(display("Failed to find opener utility, please install one of {}", tried.join(",")))] #[snafu(display("Failed to find opener utility, please install one of {}", tried.join(",")))]
OpenerMissing { tried: &'static [&'static str] }, OpenerMissing { tried: &'static [&'static str] },
#[snafu(display( #[snafu(display(
"Interal error, this may indicate a bug in intermodal: {}\nConsider filing an issue: https://github.com/casey/imdl/issues/new", "Interal error, this may indicate a bug in intermodal: {}\n\
Consider filing an issue: https://github.com/casey/imdl/issues/new",
message, message,
))] ))]
Internal { message: String }, Internal { message: String },
@ -104,7 +105,8 @@ pub(crate) enum Error {
#[snafu(display("Failed to write to standard output: {}", source))] #[snafu(display("Failed to write to standard output: {}", source))]
Stdout { source: io::Error }, Stdout { source: io::Error },
#[snafu(display( #[snafu(display(
"Attempted to create torrent from symlink `{}`. To override, pass the `--follow-symlinks` flag.", "Attempted to create torrent from symlink `{}`. To override, pass the \
`--follow-symlinks` flag.",
root.display() root.display()
))] ))]
SymlinkRoot { root: PathBuf }, SymlinkRoot { root: PathBuf },

View File

@ -17,7 +17,10 @@ pub(crate) struct Opt {
long = "unstable", long = "unstable",
short = "u", short = "u",
help = "Enable unstable features.", help = "Enable unstable features.",
long_help = "Enable unstable features. To avoid premature stabilization and excessive version churn, unstable features are unavailable unless this flag is set. Unstable features are not bound by semantic versioning stability guarantees, and may be changed or removed at any time." long_help = "Enable unstable features. To avoid premature stabilization and excessive version \
churn, unstable features are unavailable unless this flag is set. Unstable \
features are not bound by semantic versioning stability guarantees, and may be \
changed or removed at any time."
)] )]
unstable: bool, unstable: bool,
#[structopt( #[structopt(
@ -26,7 +29,10 @@ pub(crate) struct Opt {
set = ArgSettings::CaseInsensitive, set = ArgSettings::CaseInsensitive,
possible_values = use_color::VALUES, possible_values = use_color::VALUES,
help = "Print colorful output.", help = "Print colorful output.",
long_help = "Print colorful output. When `auto`, the default, colored output is only enabled if imdl detects that it is connected to a terminal, the `NO_COLOR` environment variable is not set, and the `TERM` environment variable is not set with a value of `dumb`.", long_help = "Print colorful output. When `auto`, the default, colored output is only enabled \
if imdl detects that it is connected to a terminal, the `NO_COLOR` environment \
variable is not set, and the `TERM` environment variable is not set with a \
value of `dumb`.",
)] )]
pub(crate) use_color: UseColor, pub(crate) use_color: UseColor,
#[structopt(subcommand)] #[structopt(subcommand)]

View File

@ -12,42 +12,53 @@ pub(crate) struct Create {
long = "announce", long = "announce",
required(true), required(true),
help = "Use `ANNOUNCE` as the primary tracker announce URL.", help = "Use `ANNOUNCE` as the primary tracker announce URL.",
long_help = "Use `ANNOUNCE` as the primary tracker announce URL. To supply multiple announce URLs, also use `--announce-tier`." long_help = "Use `ANNOUNCE` as the primary tracker announce URL. To supply multiple announce \
URLs, also use `--announce-tier`."
)] )]
announce: Url, announce: Url,
#[structopt( #[structopt(
name = "ALLOW", name = "ALLOW",
long = "allow", long = "allow",
help = "Use `ANNOUNCE` as the primary tracker announce URL.", help = "Use `ANNOUNCE` as the primary tracker announce URL.",
long_help = "Use `ANNOUNCE` as the primary tracker announce URL. To supply multiple announce URLs, also use `--announce-tier`." long_help = "Use `ANNOUNCE` as the primary tracker announce URL. To supply multiple announce \
URLs, also use `--announce-tier`."
)] )]
allowed_lints: Vec<Lint>, allowed_lints: Vec<Lint>,
#[structopt( #[structopt(
long = "announce-tier", long = "announce-tier",
name = "ANNOUNCE-TIER", name = "ANNOUNCE-TIER",
help = "Add `ANNOUNCE-TIER` to list of tracker announce tiers.", help = "Add `ANNOUNCE-TIER` to list of tracker announce tiers.",
long_help = "\ long_help = "Add `ANNOUNCE-TIER` to list of tracker announce tiers. Each instance adds a new \
Add `ANNOUNCE-TIER` to list of tracker announce tiers. Each instance adds a new tier. To add multiple trackers to a given tier, separate their announce URLs with commas: tier. To add multiple trackers to a given tier, separate their announce URLs \
with commas:\n\
`--announce-tier udp://example.com:80/announce,https://example.net:443/announce` \n\
`--announce-tier udp://example.com:80/announce,https://example.net:443/announce`
Announce tiers are stored in the `announce-list` key of the top-level metainfo dictionary as a list of lists of strings, as defined by BEP 12: Multitracker Metadata Extension. \n\
Announce tiers are stored in the `announce-list` key of the top-level metainfo \
Note: Many BitTorrent clients do not implement the behavior described in BEP 12. See the discussion here for more details: https://github.com/bittorrent/bittorrent.org/issues/82" dictionary as a list of lists of strings, as defined by BEP 12: Multitracker \
Metadata Extension.
\n\
Note: Many BitTorrent clients do not implement the behavior described in BEP \
12. See the discussion here for more details: \
https://github.com/bittorrent/bittorrent.org/issues/82"
)] )]
announce_tiers: Vec<String>, announce_tiers: Vec<String>,
#[structopt( #[structopt(
name = "COMMENT", name = "COMMENT",
long = "comment", long = "comment",
help = "Include `COMMENT` in generated `.torrent` file.", help = "Include `COMMENT` in generated `.torrent` file.",
long_help = "Include `COMMENT` in generated `.torrent` file. Stored under `comment` key of top-level metainfo dictionary." long_help = "Include `COMMENT` in generated `.torrent` file. Stored under `comment` key of \
top-level metainfo dictionary."
)] )]
comment: Option<String>, comment: Option<String>,
#[structopt( #[structopt(
name = "NODE", name = "NODE",
long = "dht-node", long = "dht-node",
help = "Add DHT bootstrap node `NODE` to torrent. `NODE` should be in the form `HOST:PORT`.", help = "Add DHT bootstrap node `NODE` to torrent. `NODE` should be in the form `HOST:PORT`.",
long_help = "Add DHT bootstrap node `NODE` to torrent. `NODE` should be in the form `HOST:PORT`, where `HOST` is a domain name, an IPv4 address, or an IPv6 address surrounded by brackets. May be given more than once to add multiple bootstrap nodes. Examples: long_help = "Add DHT bootstrap node `NODE` to torrent. `NODE` should be in the form \
`HOST:PORT`, where `HOST` is a domain name, an IPv4 address, or an IPv6 address \
surrounded by brackets. May be given more than once to add multiple bootstrap \
nodes. Examples:
`--dht-node router.example.com:1337` `--dht-node router.example.com:1337`
`--dht-node 203.0.113.0:2290` `--dht-node 203.0.113.0:2290`
`--dht-node [2001:db8:4275:7920:6269:7463:6f69:6e21]:8832`" `--dht-node [2001:db8:4275:7920:6269:7463:6f69:6e21]:8832`"
@ -56,7 +67,8 @@ Note: Many BitTorrent clients do not implement the behavior described in BEP 12.
#[structopt( #[structopt(
name = "FOLLOW-SYMLINKS", name = "FOLLOW-SYMLINKS",
long = "follow-symlinks", long = "follow-symlinks",
help = "Follow symlinks in torrent input. By default, symlinks to files and directories are not included in torrent contents." help = "Follow symlinks in torrent input. By default, symlinks to files and directories are \
not included in torrent contents."
)] )]
follow_symlinks: bool, follow_symlinks: bool,
#[structopt( #[structopt(
@ -68,13 +80,15 @@ Note: Many BitTorrent clients do not implement the behavior described in BEP 12.
#[structopt( #[structopt(
name = "GLOB", name = "GLOB",
long = "glob", long = "glob",
help = "Include or exclude files that match `GLOB`. Multiple glob may be provided, with the last one taking precedence. Precede a glob with a ! to exclude it." help = "Include or exclude files that match `GLOB`. Multiple glob may be provided, with the \
last one taking precedence. Precede a glob with a ! to exclude it."
)] )]
globs: Vec<String>, globs: Vec<String>,
#[structopt( #[structopt(
name = "INCLUDE-HIDDEN", name = "INCLUDE-HIDDEN",
long = "include-hidden", long = "include-hidden",
help = "Include hidden files that would otherwise be skipped, such as files that start with a `.`, and files hidden by file attributes on macOS and Windows." help = "Include hidden files that would otherwise be skipped, such as files that start with a \
`.`, and files hidden by file attributes on macOS and Windows."
)] )]
include_hidden: bool, include_hidden: bool,
#[structopt( #[structopt(
@ -87,15 +101,19 @@ Note: Many BitTorrent clients do not implement the behavior described in BEP 12.
name = "INPUT", name = "INPUT",
long = "input", long = "input",
help = "Read torrent contents from `INPUT`.", help = "Read torrent contents from `INPUT`.",
long_help = "Read torrent contents from `INPUT`. If `INPUT` is a file, torrent will be a single-file torrent, otherwise if `INPUT` is a directory, torrent will be a multi-file torrent.", long_help = "Read torrent contents from `INPUT`. If `INPUT` is a file, torrent will be a \
single-file torrent, otherwise if `INPUT` is a directory, torrent will be a \
multi-file torrent.",
parse(from_os_str) parse(from_os_str)
)] )]
input: PathBuf, input: PathBuf,
#[structopt( #[structopt(
name = "MD5SUM", name = "MD5SUM",
long = "md5sum", long = "md5sum",
help = "Include MD5 checksum of each file in the torrent. N.B. MD5 is cryptographically broken and only suitable for safeguarding against accidental corruption.", help = "Include MD5 checksum of each file in the torrent. N.B. MD5 is cryptographically \
long_help = "Include MD5 checksum of each file in the torrent. N.B. MD5 is cryptographically broken and only suitable for checking for accidental corruption." broken and only suitable for safeguarding against accidental corruption.",
long_help = "Include MD5 checksum of each file in the torrent. N.B. MD5 is cryptographically \
broken and only suitable for checking for accidental corruption."
)] )]
md5sum: bool, md5sum: bool,
#[structopt( #[structopt(
@ -120,13 +138,15 @@ Note: Many BitTorrent clients do not implement the behavior described in BEP 12.
name = "OPEN", name = "OPEN",
long = "open", long = "open",
help = "Open `.torrent` file after creation", help = "Open `.torrent` file after creation",
long_help = "Open `.torrent` file after creation. Uses `xdg-open`, `gnome-open`, or `kde-open` on Linux; `open` on macOS; and `cmd /C start on Windows" long_help = "Open `.torrent` file after creation. Uses `xdg-open`, `gnome-open`, or \
`kde-open` on Linux; `open` on macOS; and `cmd /C start on Windows"
)] )]
open: bool, open: bool,
#[structopt( #[structopt(
name = "OUTPUT", name = "OUTPUT",
long = "output", long = "output",
help = "Save `.torrent` file to `OUTPUT`, or `-` for standard output. Defaults to `$INPUT.torrent`.", help = "Save `.torrent` file to `OUTPUT`, or `-` for standard output. Defaults to \
`$INPUT.torrent`.",
parse(from_os_str) parse(from_os_str)
)] )]
output: Option<Target>, output: Option<Target>,
@ -134,21 +154,27 @@ Note: Many BitTorrent clients do not implement the behavior described in BEP 12.
name = "PIECE-LENGTH", name = "PIECE-LENGTH",
long = "piece-length", long = "piece-length",
help = "Set piece length to `PIECE-LENGTH` bytes.", help = "Set piece length to `PIECE-LENGTH` bytes.",
long_help = "Set piece length to `PIECE-LENGTH` bytes. Accepts SI units, e.g. kib, mib, and gib." long_help = "Set piece length to `PIECE-LENGTH` bytes. Accepts SI units, e.g. kib, mib, and \
gib."
)] )]
piece_length: Option<Bytes>, piece_length: Option<Bytes>,
#[structopt( #[structopt(
name = "PRIVATE", name = "PRIVATE",
long = "private", long = "private",
help = "Set the `private` flag.", help = "Set the `private` flag.",
long_help = "Set the `private` flag. Torrent clients that understand the flag and participate in the swarm of a torrent with the flag set will only announce themselves to the announce URLs included in the torrent, and will not use other peer discovery mechanisms, such as the DHT or local peer discovery. See BEP 27: Private Torrents for more information." long_help = "Set the `private` flag. Torrent clients that understand the flag and participate \
in the swarm of a torrent with the flag set will only announce themselves to the \
announce URLs included in the torrent, and will not use other peer discovery \
mechanisms, such as the DHT or local peer discovery. See BEP 27: Private \
Torrents for more information."
)] )]
private: bool, private: bool,
#[structopt( #[structopt(
name = "SOURCE", name = "SOURCE",
long = "source", long = "source",
help = "Include `SOURCE` in generated `.torrent` file.", help = "Include `SOURCE` in generated `.torrent` file.",
long_help = "Include `SOURCe` in generated `.torrent` file. Stored under `info.source` key of metainfo dictionary." long_help = "Include `SOURCe` in generated `.torrent` file. Stored under `info.source` key of \
metainfo dictionary."
)] )]
source: Option<String>, source: Option<String>,
} }
@ -1230,6 +1256,7 @@ mod tests {
fs::write(dir.join("h"), "hij").unwrap(); fs::write(dir.join("h"), "hij").unwrap();
env.run().unwrap(); env.run().unwrap();
let have = env.out(); let have = env.out();
#[rustfmt::skip]
let want = format!( let want = format!(
" Name foo " Name foo
Created By {} Created By {}

View File

@ -12,7 +12,8 @@ pub(crate) struct Stats {
long = "limit", long = "limit",
short = "l", short = "l",
help = "Stop after processing the first `COUNT` torrents.", help = "Stop after processing the first `COUNT` torrents.",
long_help = "Stop after processing the first `COUNT` torrents. Useful when processing large collections of `.torrent` files." long_help = "Stop after processing the first `COUNT` torrents. Useful when processing large \
collections of `.torrent` files."
)] )]
limit: Option<u64>, limit: Option<u64>,
#[structopt( #[structopt(
@ -20,8 +21,12 @@ pub(crate) struct Stats {
long = "extract-pattern", long = "extract-pattern",
short = "e", short = "e",
help = "Extract and display values from key paths that match `REGEX`.", help = "Extract and display values from key paths that match `REGEX`.",
long_help = "\ long_help = "Extract and display values under key paths that match `REGEX`. Subkeys of a \
Extract and display values under key paths that match `REGEX`. Subkeys of a bencodeded dictionary are delimited by `/`, and values of a bencoded list are delmited by `*`. For example, given the following bencoded dictionary `{\"foo\": [{\"bar\": {\"baz\": 2}}]}`, the value `2`'s key path will be `foo*bar/baz`. The value `2` would be displayed if any of `bar`, `foo[*]bar/baz`, or `foo.*baz` were passed to `--extract-pattern." bencodeded dictionary are delimited by `/`, and values of a bencoded list are \
delmited by `*`. For example, given the following bencoded dictionary `{\"foo\": \
[{\"bar\": {\"baz\": 2}}]}`, the value `2`'s key path will be `foo*bar/baz`. The \
value `2` would be displayed if any of `bar`, `foo[*]bar/baz`, or `foo.*baz` \
were passed to `--extract-pattern."
)] )]
extract_patterns: Vec<Regex>, extract_patterns: Vec<Regex>,
#[structopt( #[structopt(
@ -29,7 +34,8 @@ Extract and display values under key paths that match `REGEX`. Subkeys of a benc
long = "input", long = "input",
short = "i", short = "i",
help = "Search `INPUT` for torrents.", help = "Search `INPUT` for torrents.",
long_help = "Search `INPUT` for torrents. May be a directory to search or a single torrent file.", long_help = "Search `INPUT` for torrents. May be a directory to search or a single torrent \
file.",
parse(from_os_str) parse(from_os_str)
)] )]
input: PathBuf, input: PathBuf,

View File

@ -4,14 +4,14 @@
// Constraints: // Constraints:
// - Decreasing piece length increases protocol overhead. // - Decreasing piece length increases protocol overhead.
// - Decreasing piece length increases torrent metainfo size. // - Decreasing piece length increases torrent metainfo size.
// - Increasing piece length increases the amount of data that must be // - Increasing piece length increases the amount of data that must be thrown
// thrown away in case of corruption. // away in case of corruption.
// - Increasing piece length increases the amount of data that must be // - Increasing piece length increases the amount of data that must be
// downloaded before it can be verified and uploaded to other peers. // downloaded before it can be verified and uploaded to other peers.
// - Decreasing piece length increases the proportion of disk seeks to // - Decreasing piece length increases the proportion of disk seeks to disk
// disk reads. This can be an issue for spinning disks. // reads. This can be an issue for spinning disks.
// - The BitTorrent v2 specification requires that piece sizes be // - The BitTorrent v2 specification requires that piece sizes be larger than 16
// larger than 16 KiB. // KiB.
// //
// These constraints could probably be exactly defined and optimized // These constraints could probably be exactly defined and optimized
// using an integer programming solver, but instead we just copy what // using an integer programming solver, but instead we just copy what

View File

@ -30,8 +30,7 @@ impl PlatformInterface for Platform {
} }
fn hidden(path: &Path) -> Result<bool, Error> { fn hidden(path: &Path) -> Result<bool, Error> {
use std::os::unix::ffi::OsStrExt; use std::{ffi::CString, mem, os::unix::ffi::OsStrExt};
use std::{ffi::CString, mem};
const HIDDEN_MASK_MAC: u32 = 0x0000_8000; const HIDDEN_MASK_MAC: u32 = 0x0000_8000;