Tweaked version 3.6 to include deprecating list append/removal functions

in favor of using a method call style.
This commit is contained in:
Bruce Hill 2018-08-29 15:59:30 -07:00
parent 22495c7d70
commit 811fdd6856
13 changed files with 92 additions and 62 deletions

View File

@ -17,20 +17,20 @@ upgrade %tree to "2.4" as:
(not (%line is syntax tree)):
compile error at %tree.source "WUT: %s"
(not (%line is "Action" syntax tree)):
add %line to %new_lines
%new_lines::add %line
(%line.stub is "* %"):
add %line.2 to %conditions
%conditions::add %line.2
(%line.stub == "* else %"):
add (\(else %block) with vars {block:%line.3}) to %new_lines
%new_lines::add (\(else %block) with vars {block:%line.3})
(%line.stub != "* % %"):
add %line to %new_lines
%new_lines::add %line
else:
add %line.2 to %conditions
%conditions::add %line.2
%action = %line.3
unless (%action is "Block" syntax tree):
%action = (=lua "Block(\%action.source, \%action)")
add %action to %conditions
add (=lua "Action(\%conditions[1].source, unpack(\%conditions))") to %new_lines
%conditions::add %action
%new_lines::add (=lua "Action(\%conditions[1].source, unpack(\%conditions))")
%conditions = []
return (..)
@ -44,20 +44,20 @@ upgrade %tree to "2.4" as:
for %line in %body:
if:
(not (%line is "Action" syntax tree)):
add %line to %new_lines
%new_lines::add %line
(%line.stub is "* %"):
add %line.2 to %values
%values::add %line.2
(%line.stub == "* else %"):
add (\(else %block) with vars {block:%line.3}) to %new_lines
%new_lines::add (\(else %block) with vars {block:%line.3})
(%line.stub != "* % %"):
add %line to %new_lines
%new_lines::add %line
else:
add %line.2 to %values
%values::add %line.2
%action = %line.3
unless (%action is "Block" syntax tree):
%action = \(: %action)
add %action to %values
add (=lua "Action(\%values[1].source, unpack(\%values))") to %new_lines
%values::add %action
%new_lines::add (=lua "Action(\%values[1].source, unpack(\%values))")
%values = []
return (..)

View File

@ -4,17 +4,27 @@
use "compatibility/compatibility.nom"
upgrade action (to %1 write %2) to "3.6" as (%1::append %2)
upgrade action (%1 <-write %2) to "3.6" as (%1::append %2)
upgrade action (to %1 write %2 joined by %3) to "3.6" as (..)
upgrade action [..]
append %item to %list, add %item to %list, to %list add %item, to %list append %item
..to "3.6" as (%list::add %item)
upgrade action [add %item to %list at index %i] to "3.6" as (..)
%list::at index %i add %item
upgrade action [pop from %list, remove last from %list] to "3.6" as (%list::pop)
upgrade action [remove index %index from %list] to "3.6" as (..)
%list::remove index %index
upgrade action [to %1 write %2, %1 <-write %2] to "3.6" as (%1::append %2)
upgrade action [to %1 write %2 joined by %3] to "3.6" as (..)
%1::append %2 joined by %3
upgrade action (declare locals in %lua) to "3.6" as (%lua::declare locals)
upgrade action (declare locals %locs in %lua) to "3.6" as (..)
upgrade action [declare locals in %lua] to "3.6" as (%lua::declare locals)
upgrade action [declare locals %locs in %lua] to "3.6" as (..)
%lua::declare locals %locs
upgrade action (add free vars %vars to %lua) to "3.6" as (..)
upgrade action [add free vars %vars to %lua] to "3.6" as (..)
%lua::add free vars %vars
upgrade action (remove free vars %vars from %lua) to "3.6" as (..)
upgrade action [remove free vars %vars from %lua] to "3.6" as (..)
%lua::remove free vars %vars

View File

@ -39,9 +39,9 @@ compile [upgrade action %actions to %version as %body] to:
(%t is syntax tree):
%args = ((make tree %) for % in %t)
add "source=\(\%tree as lua id).source" to %args at index 1
%args::add "source=\(\%tree as lua id).source"
if %t.target:
add "target=\(make tree %t.target)" to %args at index 1
%args::add "target=\(make tree %t.target)"
return "\(%t.type){\(%args joined with ", ")}"
else:

View File

@ -58,9 +58,9 @@ test:
%list = [1, 2, 3, 4, 5]
append 6 to %list
assume ((last in %list) is 6)
pop from %list
%list::pop
assume ((last in %list) is 5)
remove index 1 from %list
%list::remove index 1
assume ((first in %list) is 2)
compile [..]
append %item to %list, add %item to %list, to %list add %item, to %list append %item
@ -85,7 +85,7 @@ parse [%expression for %item in %iterable] as (..)
result of:
%comprehension = []
for %item in %iterable:
add %expression to %comprehension
%comprehension::add %expression
return %comprehension
parse [..]
@ -95,7 +95,7 @@ parse [..]
result of:
%comprehension = []
for %index in %start to %stop via %step:
add %expression to %comprehension
%comprehension::add %expression
return %comprehension
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
@ -114,7 +114,7 @@ parse [..]
result of:
%comprehension = []
for %key = %value in %iterable:
add %expression to %comprehension
%comprehension::add %expression
return %comprehension
# Dict comprehensions
@ -164,7 +164,7 @@ test:
action [%lists flattened]:
%flat = []
for %list in %lists:
for %item in %list: add %item to %flat
for %item in %list: %flat::add %item
return %flat
test:
@ -240,7 +240,7 @@ action [unique %items]:
%seen = {}
for % in %items:
unless %seen.%:
add % to %unique
%unique::add %
%seen.% = (yes)
return %unique

View File

@ -172,19 +172,19 @@ compile [===next %var ===, ---next %var ---, ***next %var ***] to (..)
test:
%nums = []
for %x in 1 to 5: add %x to %nums
for %x in 1 to 5: %nums::add %x
assume (%nums == [1, 2, 3, 4, 5])
%nums = []
for %x in 1 to 5 via 2: add %x to %nums
for %x in 1 to 5 via 2: %nums::add %x
assume (%nums == [1, 3, 5])
%nums = []
for %outer in 1 to 100:
for %inner in %outer to (%outer + 2):
if (%inner == 2):
add -2 to %nums
%nums::add -2
do next %inner
add %inner to %nums
%nums::add %inner
if (%inner == 5): stop %outer
assume (%nums == [1, -2, 3, -2, 3, 4, 3, 4, 5])
@ -227,13 +227,13 @@ parse [for %var in %start to %stop %body] as (..)
test:
%a = [10, 20, 30, 40, 50]
%b = []
for %x in %a: add %x to %b
for %x in %a: %b::add %x
assume (%a == %b)
%b = []
for %x in %a:
if (%x == 10): do next %x
if (%x == 50): stop %x
add %x to %b
%b::add %x
assume (%b == [20, 30, 40])
@ -268,7 +268,7 @@ test:
for %k = %v in %d:
if (%k == "a"): do next %k
if (%v == 20): do next %v
add "\%k = \%v" to %result
%result::add "\%k = \%v"
assume ((%result sorted) == ["c = 30", "d = 40", "e = 50"])
@ -486,7 +486,7 @@ test:
for % in recursive %t:
if ((type of %) is "table"):
for %2 in %: recurse % on %2
..else: add % to %flat
..else: %flat::add %
assume ((sorted %flat) == [1, 2, 3, 4, 5, 6])

View File

@ -12,7 +12,7 @@ test:
-> 5
repeat 3 times: -> 6
for % in coroutine %co: add % to %nums
for % in coroutine %co: %nums::add %
assume (%nums == [4, 5, 6, 6, 6]) or barf "Coroutine iteration failed"
compile [coroutine %body, generator %body] to (..)
Lua value ".."

View File

@ -21,22 +21,22 @@ action [base64 %str, base64 encode %str, %str base64]:
%chars = []
for %i in 1 to (length of %str) via 3:
%bytes = [=lua "\%str:byte(\%i, \(%i + 2))"]
add %b64_str.(((%bytes.1 & 252) >> 2) + 1) to %chars
%chars::add %b64_str.(((%bytes.1 & 252) >> 2) + 1)
if (length of %bytes) is:
3:
add %b64_str.(((%bytes.1 & 3) << 4) + ((%bytes.2 & 240) >> 4) + 1) to %chars
add %b64_str.(((%bytes.2 & 15) << 2) + ((%bytes.3 & 192) >> 6) + 1) to %chars
add %b64_str.((%bytes.3 & 63) + 1) to %chars
%chars::add %b64_str.(((%bytes.1 & 3) << 4) + ((%bytes.2 & 240) >> 4) + 1)
%chars::add %b64_str.(((%bytes.2 & 15) << 2) + ((%bytes.3 & 192) >> 6) + 1)
%chars::add %b64_str.((%bytes.3 & 63) + 1)
2:
add %b64_str.(((%bytes.1 & 3) << 4) + ((%bytes.2 & 240) >> 4) + 1) to %chars
add %b64_str.(((%bytes.2 & 15) << 2) + 1) to %chars
add "=" to %chars
%chars::add %b64_str.(((%bytes.1 & 3) << 4) + ((%bytes.2 & 240) >> 4) + 1)
%chars::add %b64_str.(((%bytes.2 & 15) << 2) + 1)
%chars::add "="
1:
add %b64_str.(((%bytes.1 & 3) << 4) + 1) to %chars
add "=" to %chars
add "=" to %chars
%chars::add %b64_str.(((%bytes.1 & 3) << 4) + 1)
%chars::add "="
%chars::add "="
return (%chars joined)
@ -45,10 +45,10 @@ action [decode base64 %str, %str base64 decoded, base64 decode %str]:
%chars = []
for %i in 1 to (length of %str) via 4:
%indices = (%reverse_b64.(%str.%) for % in %i to (%i + 3))
add (chr ((%indices.1 << 2) + ((%indices.2 & 48) >> 4))) to %chars
%chars::add (chr ((%indices.1 << 2) + ((%indices.2 & 48) >> 4)))
if (%str.(%i + 2) == "="): stop
add (chr (((%indices.2 & 15) << 4) + ((%indices.3 & 60) >> 2))) to %chars
%chars::add (chr (((%indices.2 & 15) << 4) + ((%indices.3 & 60) >> 2)))
if (%str.(%i + 3) == "="): stop
add (chr (((%indices.3 & 3) << 6) + %indices.4)) to %chars
%chars::add (chr (((%indices.3 & 3) << 6) + %indices.4))
return (%chars joined)

View File

@ -125,7 +125,18 @@ local _list_mt = {
end
end
return true
end
end,
__index = {
add_1 = insert,
append_1 = insert,
add_1_at_index_2 = function(t, x, i)
return insert(t, i, x)
end,
at_index_1_add_2 = insert,
pop = table.remove,
remove_last = table.remove,
remove_index_1 = table.remove
}
}
local list
list = function(t)

View File

@ -80,6 +80,14 @@ _list_mt =
elseif @[i] < other[i] then return true
elseif @[i] > other[i] then return false
return true
__index:
add_1: insert
append_1: insert
add_1_at_index_2: (t,x,i)-> insert(t,i,x)
at_index_1_add_2: insert
pop: table.remove
remove_last: table.remove
remove_index_1: table.remove
list = (t)-> setmetatable(t, _list_mt)

View File

@ -11,7 +11,7 @@ use "lib/os.nom"
%inplace = (no)
if (%args.1 is "-i"):
%inplace = (yes)
remove index 1 from %args
%args::remove index 1
for %path in %args:
for file %filename in %path:

View File

@ -11,14 +11,14 @@ use "lib/os.nom"
%inplace = (no)
if (%args.1 is "-i"):
%inplace = (yes)
remove index 1 from %args
%args::remove index 1
if ((length of %args) < 3):
say "Usage: nomsu tools/replace.nom [-i] tree_to_replace replacement files..."
lua> "os.exit(1)"
%pattern = (parse (remove index 1 from %args))
%replacement = (parse (remove index 1 from %args))
%pattern = (parse (%args::remove index 1))
%replacement = (parse (%args::remove index 1))
for %path in %args:
for file %filename in %path:
unless (any [%filename matches "%.nom$", %filename == "-", %filename == "stdin"]):
@ -37,4 +37,5 @@ for %path in %args:
%inplace:
say "Replaced in \%filename"
write %text to file %filename
else: say %text

View File

@ -8,7 +8,7 @@ use "lib/consolecolor.nom"
%args = (command line args)
if (%args.1 == "-v"):
remove index 1 from %args
%args::remove index 1
%verbose = (yes)
# Make sure all the files get run
@ -24,7 +24,7 @@ for %path in (command line args):
%file_tests = []
for %src = %test in %tests:
if (%src.filename == %filename):
add {test:%test, source:%src} to %file_tests
%file_tests::add {test:%test, source:%src}
unless (%file_tests is empty):
sort %file_tests by % -> %.source

View File

@ -12,12 +12,12 @@ use "lib/os.nom"
%inplace = (no)
if (%args.1 is "-i"):
%inplace = (yes)
remove index 1 from %args
%args::remove index 1
if (%args.1 is "-t"):
use "lib/consolecolor.nom"
%test = (yes)
remove index 1 from %args
%args::remove index 1
for %path in %args:
for file %filename in %path: