Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/StardustDL/Linq-in-Rust
Language Integrated Query in Rust.
https://github.com/StardustDL/Linq-in-Rust
iterator iterator-functions linq linq-methods rust
Last synced: 2 months ago
JSON representation
Language Integrated Query in Rust.
- Host: GitHub
- URL: https://github.com/StardustDL/Linq-in-Rust
- Owner: StardustDL
- License: apache-2.0
- Created: 2019-02-11T06:40:25.000Z (almost 6 years ago)
- Default Branch: master
- Last Pushed: 2023-11-16T12:33:38.000Z (about 1 year ago)
- Last Synced: 2024-10-06T00:48:21.264Z (3 months ago)
- Topics: iterator, iterator-functions, linq, linq-methods, rust
- Language: Rust
- Homepage:
- Size: 33.2 KB
- Stars: 127
- Watchers: 3
- Forks: 7
- Open Issues: 4
-
Metadata Files:
- Readme: README.md
- License: LICENSE.txt
Awesome Lists containing this project
- awesome-rust - Linq-in-Rust - Macro and methods for C#-LINQ-like expressions. [![CI](https://github.com/StardustDL/Linq-in-Rust/workflows/CI/badge.svg?branch=master)](https://github.com/StardustDL/Linq-in-Rust/actions?query=workflow%3ACI) (Libraries / Macro)
- awesome-rust-cn - Linq-in-Rust - (库 Libraries / Macro Macro)
README
# Linq in Rust
![CI](https://github.com/StardustDL/Linq-in-Rust/workflows/CI/badge.svg)
[![](https://img.shields.io/librariesio/github/StardustDL/Linq-in-Rust.svg)](https://libraries.io/cargo/linq)
[![](https://img.shields.io/crates/v/linq.svg)](https://crates.io/crates/linq)
[![](https://img.shields.io/crates/v/linq.svg?label=docs&&colorA=blue)](https://docs.rs/linq/)
![](https://img.shields.io/crates/d/linq.svg)
![](https://img.shields.io/crates/l/linq.svg)
[![Average time to resolve an issue](http://isitmaintained.com/badge/resolution/StardustDL/Linq-in-Rust.svg)](http://isitmaintained.com/project/StardustDL/Linq-in-Rust "Average time to resolve an issue")
[![Percentage of issues still open](http://isitmaintained.com/badge/open/StardustDL/Linq-in-Rust.svg)](http://isitmaintained.com/project/StardustDL/Linq-in-Rust "Percentage of issues still open")Language Integrated Query in Rust (created by declarative macros).
- Inspired by [LINQ in .NET](https://docs.microsoft.com/en-us/dotnet/csharp/linq/).
- [What's LINQ](https://en.wikipedia.org/wiki/Language_Integrated_Query)**This project is under development!** API might be **changed**.
## Quick Start
This is an example:
```rust
use linq::linq;
use linq::Queryable;fn try_linq_methods() {
let x = 1..100;
let mut y: Vec = x.clone().filter(|p| p <= &5).collect();
y.sort_by_key(|t| -t);
let y: Vec = y.into_iter().map(|t| t * 2).collect();
let e: Vec = x
.clone()
.where_by(|p| p <= &5)
.order_by(|p| -p)
.select(|p| p * 2)
.collect();
assert_eq!(e, y);
}fn try_linq_expr() {
let x = 1..100;
let mut y: Vec = x.clone().filter(|p| p <= &5).collect();
y.sort_by_key(|t| -t);
let y: Vec = y.into_iter().map(|t| t * 2).collect();
let e: Vec =
linq!(from p in x.clone(), where p <= &5, orderby -p, select p * 2).collect();
assert_eq!(e, y);
}
```If you are familier with LINQ in C#, you will find this is easy to use.
## Usage
The two imports is necessary:
```rust
use linq::linq; // for `linq!` macro
use linq::iter::Enumerable; // for LINQ methods and `linq!` macro
```### Methods
The trait `linq::Queryable` supports LINQ methods on `Iterator`. You can find the correspondences below.
- Normal items mean they are builtin methods of `Iterator` in std.
- **Bold** items mean they are implemented in this project. You can find them in module `linq::iter` (but they are private so that you can't import them).
- *Italic* items mean they are not in roadmap. Happy for your suggestions.-----
- [x] where => **where_by** => filter
- [x] **select** => map
- [x] select_many => **select_many_single, select_many**
- [x] skip
- [x] skip_while
- [x] take
- [x] take_while
- [ ] join
- [ ] *group_join*
- [x] **concate** => chain
- [x] **order_by**
- [x] **order_by_descending**
- [ ] *then_by*
- [ ] *then_by_descending*
- [x] **reverse** => rev
- [ ] *group_by*
- [x] distinct
- [x] union
- [ ] *intersect*
- [ ] *except*
- [x] **first** => next
- [x] **single**
- [x] **element_at** => nth
- [x] all
- [x] any
- [x] **contains**
- [x] count
- [x] sum
- [x] product
- [x] min
- [x] max
- [ ] *average*
- [ ] **aggregate** => fold### Expressions
The query expression begins with `from` clause and ends with `select` clause. Use `,` to seperate every clause.
```rust
linq!(from x in coll, select x)
```Now we supports these keywords:
- [x] from
- [x] from (`select_many_single`)
- [x] zfrom (`select_many`)
- [x] in
- [x] select
- [x] where
- [x] orderby
- [x] descending
- [ ] group_by
- [ ] more...### From
```rust
from in ,
```Also you can enumerate elements of each set in the collection (Attention: for this type, you can't access the value that is in the first `from` clause in `select` clause):
```rust
let x = 1..5;
let y = vec![0, 0, 1, 0, 1, 2, 0, 1, 2, 3];
let e: Vec = linq!(from p in x.clone(), from t in 0..p, select t).collect();assert_eq!(e, y);
```If you want to zip or enumerate value-pairs of two sets, use `zfrom` for the second `from`:
```rust
let x = 1..5;
let y = vec![
(1, 0),
(2, 0),
(2, 1),
(3, 0),
(3, 1),
(3, 2),
(4, 0),
(4, 1),
(4, 2),
(4, 3),
];
let e: Vec<_> = linq!(from p in x.clone(), zfrom t in 0..p, select (p,t)).collect();assert_eq!(e, y);
```The expression in `zfrom` recieve the cloned value in the first `from`,
and the elements in two sets will be cloned for `select` clause.### Where
```rust
while ,
```You can use `where` clause in single-from query, and the expression will recieve a variable named the `id` in `from` clause. The expression need to return a boolean value.
### Orderby
```rust
orderby ,
orderby , descending,
```You can use `orderby` clause in single-from query. This query will collect the iterator, and sort them by the expression, then return the new iterator.
## Development
We need more unit-test samples. If you have any ideas, open issues to tell us.
Since the expression procedural macros is not stable, I only create macros by declarative macros.
```sh
$ cargo test
```