mirror of
https://github.com/roc-lang/roc.git
synced 2025-09-28 22:34:45 +00:00
Implement List.sublist
This commit is contained in:
parent
d4a741d483
commit
9f5d3f521b
5 changed files with 118 additions and 0 deletions
|
@ -93,6 +93,7 @@ pub fn builtin_defs_map(symbol: Symbol, var_store: &mut VarStore) -> Option<Def>
|
|||
LIST_MAP4 => list_map4,
|
||||
LIST_TAKE_FIRST => list_take_first,
|
||||
LIST_TAKE_LAST => list_take_last,
|
||||
LIST_SUBLIST => list_sublist,
|
||||
LIST_DROP => list_drop,
|
||||
LIST_DROP_AT => list_drop_at,
|
||||
LIST_DROP_FIRST => list_drop_first,
|
||||
|
@ -2054,6 +2055,54 @@ fn list_take_last(symbol: Symbol, var_store: &mut VarStore) -> Def {
|
|||
)
|
||||
}
|
||||
|
||||
/// List.sublist : List elem, { start : Nat, len : Nat } -> List elem
|
||||
fn list_sublist(symbol: Symbol, var_store: &mut VarStore) -> Def {
|
||||
let list_var = var_store.fresh();
|
||||
let rec_var = var_store.fresh();
|
||||
|
||||
let sym_list = Symbol::ARG_1;
|
||||
let sym_rec = Symbol::ARG_2;
|
||||
|
||||
let start_var = var_store.fresh();
|
||||
let len_var = var_store.fresh();
|
||||
|
||||
let get_start = Access {
|
||||
record_var: rec_var,
|
||||
ext_var: var_store.fresh(),
|
||||
field_var: var_store.fresh(),
|
||||
loc_expr: Box::new(no_region(Var(sym_rec))),
|
||||
field: "start".into(),
|
||||
};
|
||||
|
||||
let get_len = Access {
|
||||
record_var: rec_var,
|
||||
ext_var: var_store.fresh(),
|
||||
field_var: var_store.fresh(),
|
||||
loc_expr: Box::new(no_region(Var(sym_rec))),
|
||||
field: "len".into(),
|
||||
};
|
||||
|
||||
let body_drop = RunLowLevel {
|
||||
op: LowLevel::ListDrop,
|
||||
args: vec![(list_var, Var(sym_list)), (start_var, get_start)],
|
||||
ret_var: list_var,
|
||||
};
|
||||
|
||||
let body_take = RunLowLevel {
|
||||
op: LowLevel::ListTakeFirst,
|
||||
args: vec![(list_var, body_drop), (len_var, get_len)],
|
||||
ret_var: list_var,
|
||||
};
|
||||
|
||||
defn(
|
||||
symbol,
|
||||
vec![(list_var, sym_list), (rec_var, sym_rec)],
|
||||
var_store,
|
||||
body_take,
|
||||
list_var,
|
||||
)
|
||||
}
|
||||
|
||||
/// List.drop : List elem, Nat -> List elem
|
||||
fn list_drop(symbol: Symbol, var_store: &mut VarStore) -> Def {
|
||||
let list_var = var_store.fresh();
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue