Index | index by Group | index by Distribution | index by Vendor | index by creation date | index by Name | Mirrors | Help | Search |
Name: rx-ranges-devel | Distribution: Fedora Project |
Version: 2.0.0 | Vendor: Fedora Project |
Release: 1.fc43 | Build date: Mon Apr 7 19:25:19 2025 |
Group: Unspecified | Build host: buildvm-x86-21.iad2.fedoraproject.org |
Size: 106950 | Source RPM: rx-ranges-2.0.0-1.fc43.src.rpm |
Packager: Fedora Project | |
Url: https://github.com/simonask/rx-ranges | |
Summary: Simpler ranges for C++17 |
This is a ranges-like library for C++17 that provides zero-overhead list comprehensions with a pipe-like syntax. Standard containers can be filtered, transformed, passed through various algorithms, optimizing to loops that would not be more efficient if written by hand. The goal is to provide the tools to write more readable loops, where the intent of the programmer is clearly communicated to the reader. Mentally simulating loops is a common but error-prone part of reading other people's code, and indeed your own code from 3 months ago. The library makes heavy use of modern C++17 features, so a compliant C++17 compiler is required. Features: - Arbitrary composability. - Constexpr-friendly. - No unnecessary temporary heap allocations (`foo | sort() | to_vector()` only allocates into the resulting container). - Heap allocation minimization: `reserve()` is used on resulting containers, when possible. - Open-ended generators (non-terminating, infinite ranges). - Re-entrancy: A non-rvalue range can be used multiple times in a function. - Compatible with standard containers (anything that supports `std::begin()` and `std::end()`). - Compatible with standard algorithms (implicit conversion to iterator-like objects). - Simple extensibility with custom range adapters. Just implement the `InputRange` faux-concept. - Non-intrusive `operator|`. The ranges `foo | bar | baz` can be expressed as `baz(bar(foo))`, if using `operator|` would introduce ambiguous overloads. - No dependencies beyond the standard library. - Integration with foreign codebases (override hooks for `std::optional`, `std::remove_cvref_t`, assertions, etc.). Can easily be used as a submodule. - Compiler support for all major compilers (GCC, Clang, MSVC). - Zero-overhead, compared to manually written loops in optimized builds. - Header-only, and single-header. Other than usability concerns, these are the main differences from C++20 ranges: - Bidirectional ranges. Ranges can only be consumed linearly in the forward direction. - Random-access ranges. Ranges can only be consumed linearly in the forward direction. - Internally using iterators. The internal iteration objects are modeled with an "enumerator" concept instead (objects that provide `next()`, `get()`, `at_end()`, etc.), which simplifies custom extensions. Implicit, zero-overhead conversion to iterators is provided for compatibility with standard algorithms and the range-based for loop syntax. - Direct access to the data of underlying contiguous ranges (`data()` etc.).
MIT
* Mon Apr 07 2025 Jerry James <loganjerry@gmail.com> - 2.0.0-1 - Initial RPM
/usr/include/rx /usr/include/rx/ranges.hpp /usr/share/doc/rx-ranges-devel /usr/share/doc/rx-ranges-devel/AUTHORS.md /usr/share/doc/rx-ranges-devel/CHANGELOG.md /usr/share/doc/rx-ranges-devel/README.md /usr/share/licenses/rx-ranges-devel /usr/share/licenses/rx-ranges-devel/LICENSE
Generated by rpm2html 1.8.1
Fabrice Bellet, Sun Apr 27 03:01:23 2025