Skip to content

fetlife/distributing-iterator

Repository files navigation

distributing-iterator

Distributing iterator

Rust

Synopsis

Rust

use distributing_iterator::DistributingIterator;

#[derive(Debug, PartialEq)]
struct Item {
    id: u64,
}

let data = vec![
    Item { id: 1 },
    Item { id: 1 },
    Item { id: 1 },
    Item { id: 2 },
    Item { id: 2 },
    Item { id: 2 },
    Item { id: 3 },
    Item { id: 3 },
    Item { id: 3 },
];
let iterator = DistributingIterator::new(data.into(), 3, |item| item.id);
let result: Vec<Item> = iterator.collect();
assert_eq!(
    result,
    vec![
        Item { id: 1 }, Item { id: 2 }, Item { id: 3 },
        Item { id: 1 }, Item { id: 2 }, Item { id: 3 },
        Item { id: 1 }, Item { id: 2 }, Item { id: 3 },
    ]
);

As a ruby gem:

Gemfile:

gem 'distributing_iterator', git: 'fetlife/distributing-iterator'
require 'distributing_iterator'

csv = <<~CSV
id,name
1,foo
1,bar
1,baz
2,qux
3,quux
3,corge
2,grault
2,garply
3,waldo
3,fred
2,plugh
3,xyzzy
2,thud
3,plugh
3,xyzzy
CSV

output = DistributingIterator.distribute(csv, 'id', 3)

puts output
# id,name
# 1,foo
# 2,qux
# 3,quux
# 1,bar
# 2,grault
# 3,corge
# 1,baz
# 2,garply
# 3,waldo
# 2,plugh
# 3,fred
# 2,thud
# 3,xyzzy
# 3,plugh
# 3,xyzzy

Releasing a New Version

To release a new version of the gem:

  1. Update the version number in Cargo.toml and lib/distributing_iterator/version.rb
  2. Create and push a new git tag with the version number (e.g., v1.0.0):
    git tag 1.0.0
    git push origin 1.0.0

The release workflow will automatically:

  • Build the source gem
  • Compile native gems for multiple platforms:
    • x86_64 Linux
    • aarch64 Linux
    • arm64 macOS
  • Create a GitHub release with all compiled gems
  • Generate release notes based on the commits since the last release

The compiled gems will be available for download from the GitHub release page: https://github.com/fetlife/distributing-iterator/releases

About

Distributing iterator

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Contributors 3

  •  
  •  
  •