17 breaking releases

new 0.17.0 Jan 13, 2025
0.16.0 Sep 26, 2024
0.15.0 Jul 18, 2024
0.9.0 Mar 18, 2024
0.0.0 May 13, 2023

#473 in Magic Beans

Download history 187/week @ 2024-09-25 40/week @ 2024-10-02 98/week @ 2024-10-09 100/week @ 2024-10-16 206/week @ 2024-10-23 260/week @ 2024-10-30 5489/week @ 2024-11-06 25357/week @ 2024-11-13 24338/week @ 2024-11-20 24634/week @ 2024-11-27 25585/week @ 2024-12-04 21936/week @ 2024-12-11 17604/week @ 2024-12-18 5838/week @ 2024-12-25 17747/week @ 2025-01-01 15895/week @ 2025-01-08

60,339 downloads per month
Used in 10 crates (via polkadot-sdk)

Apache-2.0

3MB
48K SLoC

Release

Polkadot SDK Stable 2412


lib.rs:

Made with Substrate, for DotSama.

github - polkadot

Paged List Pallet

A thin wrapper pallet around a paged_list::StoragePagedList. It provides an API for a single paginated list. It can be instantiated multiple times to provide multiple lists.

Overview

The pallet is quite unique since it does not expose any Calls, Errors or Events. All interaction goes through the implemented StorageList trait.

A fuzzer for testing is provided in crate pallet-paged-list-fuzzer.

Examples

  1. Appending some data to the list can happen either by Pallet::append_one:
  2. or by Pallet::append_many. This should always be preferred to repeated calls to Pallet::append_one:
  3. If you want to append many values (ie. in a loop), then best use the Pallet::appender:
  4. Iterating over the list can be done with Pallet::iter. It uses the standard Iterator trait:
  5. Draining elements happens through the Pallet::drain iterator. Note that even peeking a value will already remove it.

Pallet API

None. Only things to consider is the Config traits.

Low Level / Implementation Details

Implementation details are documented in paged_list::StoragePagedList. All storage entries are prefixed with a unique prefix that is generated by ListPrefix.

Dependencies

~18–33MB
~535K SLoC