FuelLabs/sway

refactor(fmt): use `drain_filter` during comment formatting when stabilized

Open

Aperta il 30 gen 2023

Vedi su GitHub
 (1 commento) (0 reazioni) (0 assegnatari)Rust (61.702 star) (5421 fork)batch import
P: lowgood first issue

Descrizione

BTreeMap does not have an equivalent for Range that also removes the yielded elements, however it does have a > drain_filter method.

A more efficient (performance and code-wise) alternative to this function using drain_filter might look like:

formatter.comment_map.drain_filter(|bs, _v| bs.start >= start && bs.end <= end)

Originally posted by @mitchmindtree in https://github.com/FuelLabs/sway/pull/3854#discussion_r1083691334

Currently, drain_filter is a a nightly-only API - I opted to use retain instead to filter out already formatted comments. We can perhaps consider doing this once drain_filter is stabilized.

Guida contributor