New Action List Sort

Created on 5 April 2023, almost 2 years ago

Problem/Motivation

This action should sort a list by given parameters like the order:

  • asc
  • desc

We could also include flags here:

SORT_REGULAR - compare items normally; the details are described in the comparison operators section
SORT_NUMERIC - compare items numerically
SORT_STRING - compare items as strings
SORT_LOCALE_STRING - compare items as strings, based on the current locale. It uses the locale, which can be changed using setlocale()
SORT_NATURAL - compare items as strings using "natural ordering" like natsort()

✨ Feature request
Status

Active

Version

1.2

Component

Code

Created by

πŸ‡©πŸ‡ͺGermany danielspeicher Steisslingen

Live updates comments and jobs are added and updated live.
Sign in to follow issues

Merge Requests

Comments & Activities

  • Issue created by @danielspeicher
  • πŸ‡©πŸ‡ͺGermany jurgenhaas Gottmadingen
  • πŸ‡©πŸ‡ͺGermany jurgenhaas Gottmadingen
  • πŸ‡ΊπŸ‡ΈUnited States luke.leber Pennsylvania

    luke.leber β†’ made their first commit to this issue’s fork.

  • πŸ‡ΊπŸ‡ΈUnited States luke.leber Pennsylvania

    I've taken a slightly different stab at this in the issue fork. Rather than providing various flags for the \sort function, the action operates at a slightly higher level by allowing users to pick different sorting functions.

    Jurgen also mentioned in a slack thread...

    I'd like to add that there should also be sorting based on either keys, values, or callbacks. The latter would allow sorting based on properties or other logic when values are complex data types.

    This might be a crazy idea, but I think that this could be feasible by linking to another ECA action that acts to compare two values with arbitrary steps!

    I know that the actual sorting implementation isn't correct -- but it at least allows the kernel tests to pass.

    I'll open a draft PR to get some feedback on this feature request.

    Thanks!

  • Merge request !484Add list sorting action β†’ (Open) created by luke.leber
  • Pipeline finished with Failed
    9 days ago
    Total: 463s
    #458937
  • Pipeline finished with Success
    9 days ago
    Total: 569s
    #458990
  • πŸ‡ΊπŸ‡ΈUnited States luke.leber Pennsylvania

    Added some example model configuration files to aid in review.

    I'll mark as NR for the concept check anyhow.

  • Pipeline finished with Success
    9 days ago
    Total: 586s
    #459020
  • πŸ‡ΊπŸ‡ΈUnited States luke.leber Pennsylvania

    Clean up I.S.

  • Pipeline finished with Success
    9 days ago
    Total: 767s
    #459054
  • πŸ‡©πŸ‡ͺGermany jurgenhaas Gottmadingen

    This looks great, thanks @luke.leber for your contribution. Just a minor suggestion in the MR, everything else is ready to be merged.

Production build 0.71.5 2024