Skip to content

Commit

Permalink
Merge pull request #49 from triarius/update-rust-actions
Browse files Browse the repository at this point in the history
Update rust actions
  • Loading branch information
triarius authored Jan 9, 2024
2 parents 061640c + f0c537b commit 216a0f4
Show file tree
Hide file tree
Showing 3 changed files with 42 additions and 30 deletions.
20 changes: 9 additions & 11 deletions .github/workflows/ci.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -5,35 +5,33 @@ jobs:
build:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
- uses: actions-rs/toolchain@v1
- uses: actions/checkout@v4
- uses: dtolnay/rust-toolchain@nightly
with:
toolchain: stable
- run: cargo build --verbose
fmt:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
- uses: actions-rs/toolchain@v1
- uses: actions/checkout@v4
- uses: dtolnay/rust-toolchain@nightly
with:
toolchain: stable
- run: cargo fmt --verbose --all --check
test:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
- uses: actions-rs/toolchain@v1
- uses: actions/checkout@v4
- uses: dtolnay/rust-toolchain@nightly
with:
toolchain: stable
- run: cargo test --verbose
clippy:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
- uses: actions-rs/toolchain@v1
- uses: actions/checkout@v4
- uses: dtolnay/rust-toolchain@nightly
with:
toolchain: stable
components: clippy
- uses: giraffate/clippy-action@v1
with:
clippy_flags: -- -D clippy::pedantic -D clippy::all
- run: cargo clippy -- -D clippy::pedantic -D clippy::all
6 changes: 3 additions & 3 deletions src/passphrase.rs
Original file line number Diff line number Diff line change
Expand Up @@ -12,16 +12,16 @@ pub fn new(
words.len(),
num_words
);
return "".to_string();
return String::new();
}

(0..num_words).for_each(|i| {
let j = rng.gen_range(i..words.len());
words.swap(i, j)
words.swap(i, j);
});

(0..num_words)
.map(|i| words[i].to_owned())
.map(|i| words[i].clone())
.collect::<Vec<String>>()
.join(separator)
}
Expand Down
46 changes: 30 additions & 16 deletions src/words.rs
Original file line number Diff line number Diff line change
Expand Up @@ -13,25 +13,39 @@ lazy_static! {

pub(crate) fn list(path: Option<impl AsRef<Path>>) -> Result<Vec<String>> {
match path {
Some(path) => words_from_file(path),
None => words_from_fixture(),
Some(path) => WordsFromFile { path }.words(),
None => WordsFromFixture {}.words(),
}
}

fn words_from_fixture() -> Result<Vec<String>> {
let bytes = include_bytes!("fixtures/words");
Ok(String::from_utf8_lossy(bytes)
.split('\n')
.filter(|w| RE.is_match(w))
.map(|l| l.to_owned())
.collect())
trait Words {
fn words(&self) -> Result<Vec<String>>;
}

fn words_from_file(path: impl AsRef<Path>) -> Result<Vec<String>> {
let file = File::open(path)?;
Ok(BufReader::new(file)
.lines()
.map_while(|l| l.ok())
.filter(|w| RE.is_match(w))
.collect())
struct WordsFromFixture;

impl Words for WordsFromFixture {
fn words(&self) -> Result<Vec<String>> {
let bytes = include_bytes!("fixtures/words");
Ok(String::from_utf8_lossy(bytes)
.split('\n')
.filter(|w| RE.is_match(w))
.map(std::borrow::ToOwned::to_owned)
.collect())
}
}

struct WordsFromFile<P: AsRef<Path>> {
path: P,
}

impl<P: AsRef<Path>> Words for WordsFromFile<P> {
fn words(&self) -> Result<Vec<String>> {
let file = File::open(&self.path)?;
Ok(BufReader::new(file)
.lines()
.map_while(std::result::Result::ok)
.filter(|w| RE.is_match(w))
.collect())
}
}

0 comments on commit 216a0f4

Please sign in to comment.