Added 'reversed' method for lists.

This commit is contained in:
Bruce Hill 2019-01-30 15:19:38 -08:00
parent bc41cc3a24
commit b714a55ec0
2 changed files with 14 additions and 0 deletions

View File

@ -225,6 +225,17 @@ local _list_mt = {
end
return _accum_0
end)())
end,
reversed = function(self)
return List((function()
local _accum_0 = { }
local _len_0 = 1
for i = #self, 1, -1 do
_accum_0[_len_0] = self[i]
_len_0 = _len_0 + 1
end
return _accum_0
end)())
end
},
__newindex = function(self, k, v)

View File

@ -88,6 +88,9 @@ _list_mt =
start = (n+1-start) if start < 0
stop = (n+1-stop) if stop < 0
return List[@[i] for i=start,stop]
reversed: => List[@[i] for i=#@,1,-1]
-- TODO: remove this safety check to get better performance?
__newindex: (k,v)=>
assert type(k) == 'number', "List indices must be numbers"