Intermediate step in upgrading to 3.6. Fixed a bug with upgrading
methods.
This commit is contained in:
parent
e64632be1a
commit
23b52bc22d
@ -505,6 +505,12 @@ do
|
|||||||
end
|
end
|
||||||
NomsuCode = _class_0
|
NomsuCode = _class_0
|
||||||
end
|
end
|
||||||
|
Code.__base.append_1 = Code.__base.append
|
||||||
|
Code.__base.append_1_joined_by_2 = Code.__base.concat_append
|
||||||
|
Code.__base.prepend_1 = Code.__base.prepend
|
||||||
|
Code.__base.declare_locals_1 = Code.__base.declare_locals
|
||||||
|
Code.__base.remove_free_vars_1 = Code.__base.remove_free_vars
|
||||||
|
Code.__base.add_free_vars_1 = Code.__base.add_free_vars
|
||||||
return {
|
return {
|
||||||
Code = Code,
|
Code = Code,
|
||||||
NomsuCode = NomsuCode,
|
NomsuCode = NomsuCode,
|
||||||
|
@ -256,4 +256,11 @@ class NomsuCode extends Code
|
|||||||
__repr: Code.__repr
|
__repr: Code.__repr
|
||||||
__len: Code.__len
|
__len: Code.__len
|
||||||
|
|
||||||
|
Code.__base.append_1 = Code.__base.append
|
||||||
|
Code.__base.append_1_joined_by_2 = Code.__base.concat_append
|
||||||
|
Code.__base.prepend_1 = Code.__base.prepend
|
||||||
|
Code.__base.declare_locals_1 = Code.__base.declare_locals
|
||||||
|
Code.__base.remove_free_vars_1 = Code.__base.remove_free_vars
|
||||||
|
Code.__base.add_free_vars_1 = Code.__base.add_free_vars
|
||||||
|
|
||||||
return {:Code, :NomsuCode, :LuaCode, :Source}
|
return {:Code, :NomsuCode, :LuaCode, :Source}
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
#!/usr/bin/env nomsu -V3.5.5.6
|
#!/usr/bin/env nomsu -V3.6.5.6
|
||||||
#
|
#
|
||||||
This file defines upgrades from Nomsu <2.3 to Nomsu 2.3
|
This file defines upgrades from Nomsu <2.3 to Nomsu 2.3
|
||||||
|
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
#!/usr/bin/env nomsu -V3.5.5.6
|
#!/usr/bin/env nomsu -V3.6.5.6
|
||||||
#
|
#
|
||||||
This file defines upgrades from Nomsu <2.4 to Nomsu 2.4
|
This file defines upgrades from Nomsu <2.4 to Nomsu 2.4
|
||||||
|
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
#!/usr/bin/env nomsu -V3.5.5.6
|
#!/usr/bin/env nomsu -V3.6.5.6
|
||||||
#
|
#
|
||||||
This file defines upgrades from Nomsu <2.5.5.5 to Nomsu 2.5.5.5
|
This file defines upgrades from Nomsu <2.5.5.5 to Nomsu 2.5.5.5
|
||||||
|
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
#!/usr/bin/env nomsu -V3.5.5.6
|
#!/usr/bin/env nomsu -V3.6.5.6
|
||||||
#
|
#
|
||||||
This file defines upgrades from Nomsu <2.5 to Nomsu 2.5
|
This file defines upgrades from Nomsu <2.5 to Nomsu 2.5
|
||||||
|
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
#!/usr/bin/env nomsu -V3.5.5.6
|
#!/usr/bin/env nomsu -V3.6.5.6
|
||||||
#
|
#
|
||||||
This file defines upgrades from Nomsu 1 to Nomsu 2
|
This file defines upgrades from Nomsu 1 to Nomsu 2
|
||||||
|
|
||||||
|
@ -1,8 +1,11 @@
|
|||||||
#!/usr/bin/env nomsu -V3.5.5.6
|
#!/usr/bin/env nomsu -V3.6.5.6
|
||||||
#
|
#
|
||||||
This file defines upgrades from Nomsu <3.5.5.6 to Nomsu 3.5.5.6
|
This file defines upgrades from Nomsu <3.5.5.6 to Nomsu 3.5.5.6
|
||||||
|
|
||||||
use "compatibility/compatibility.nom"
|
use "compatibility/compatibility.nom"
|
||||||
|
|
||||||
upgrade action "traceback" to "3.5.5.6" via ([%] -> (barf "'traceback' has been deprecated"))
|
upgrade action "traceback" to "3.5.5.6" via (..)
|
||||||
upgrade action "traceback 1" to "3.5.5.6" via ([%] -> (barf "'traceback 1' has been deprecated"))
|
[%] -> (barf "'traceback' has been deprecated")
|
||||||
|
|
||||||
|
upgrade action "traceback 1" to "3.5.5.6" via (..)
|
||||||
|
[%] -> (barf "'traceback 1' has been deprecated")
|
||||||
|
21
compatibility/3.6.nom
Normal file
21
compatibility/3.6.nom
Normal file
@ -0,0 +1,21 @@
|
|||||||
|
#!/usr/bin/env nomsu -V3
|
||||||
|
#
|
||||||
|
This file defines upgrades from Nomsu <3.6 to 3.6
|
||||||
|
|
||||||
|
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 (..)
|
||||||
|
%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 (..)
|
||||||
|
%lua::declare locals %locs
|
||||||
|
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 (..)
|
||||||
|
%lua::remove free vars %vars
|
||||||
|
|
@ -1,4 +1,4 @@
|
|||||||
#!/usr/bin/env nomsu -V3.5.5.6
|
#!/usr/bin/env nomsu -V3.6.5.6
|
||||||
#
|
#
|
||||||
This file defines upgrades from Nomsu <=2 to Nomsu 3
|
This file defines upgrades from Nomsu <=2 to Nomsu 3
|
||||||
|
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
#!/usr/bin/env nomsu -V3.5.5.6
|
#!/usr/bin/env nomsu -V3.6.5.6
|
||||||
#
|
#
|
||||||
This file contains code for defining ways to upgrade code between different versions
|
This file contains code for defining ways to upgrade code between different versions
|
||||||
of Nomsu.
|
of Nomsu.
|
||||||
@ -33,20 +33,22 @@ compile [upgrade action %actions to %version as %body] to:
|
|||||||
return %replacements.(%t.1)
|
return %replacements.(%t.1)
|
||||||
..else:
|
..else:
|
||||||
return ".."
|
return ".."
|
||||||
\(%t.type)(\(quote "\(%t.source)"), \(..)
|
\(%t.type){source=\(quote "\(%t.source)"), \(..)
|
||||||
quote "\(%t.1) \000\(=lua "string.format('%X', __MANGLE_INDEX)")"
|
quote "\(%t.1) \000\(=lua "string.format('%X', __MANGLE_INDEX)")"
|
||||||
..)
|
..}
|
||||||
|
|
||||||
(%t is syntax tree):
|
(%t is syntax tree):
|
||||||
%args = ((make tree %) for % in %t)
|
%args = ((make tree %) for % in %t)
|
||||||
add "\(\%tree as lua id).source" to %args at index 1
|
add "source=\(\%tree as lua id).source" to %args at index 1
|
||||||
return "\(%t.type)(\(%args joined with ", "))"
|
if %t.target:
|
||||||
|
add "target=\(make tree %t.target)" to %args at index 1
|
||||||
|
return "\(%t.type){\(%args joined with ", ")}"
|
||||||
|
|
||||||
else:
|
else:
|
||||||
return (quote "\%t")
|
return (quote "\%t")
|
||||||
|
|
||||||
unless ("\%lua" == ""): to %lua write "\n"
|
unless ("\%lua" == ""): %lua::append "\n"
|
||||||
to %lua write (..)
|
%lua::append (..)
|
||||||
Lua ".."
|
Lua ".."
|
||||||
A_upgrade_action_1_to_2_via_3(\(quote %action.stub), \(%version as lua expr), function(\(..)
|
A_upgrade_action_1_to_2_via_3(\(quote %action.stub), \(%version as lua expr), function(\(..)
|
||||||
\%tree as lua id
|
\%tree as lua id
|
||||||
|
@ -1,9 +1,9 @@
|
|||||||
#!/usr/bin/env nomsu -V3.5.5.6
|
#!/usr/bin/env nomsu -V3.6.5.6
|
||||||
#
|
#
|
||||||
This File contains actions for making actions and compile-time actions and some helper
|
This File contains actions for making actions and compile-time actions and some helper
|
||||||
functions to make that easier.
|
functions to make that easier.
|
||||||
|
|
||||||
lua> "NOMSU_CORE_VERSION = 5"
|
lua> "NOMSU_CORE_VERSION = 6"
|
||||||
lua> ".."
|
lua> ".."
|
||||||
COMPILE_ACTIONS["1 -> 2"] = function(nomsu, tree, \%args, \%body)
|
COMPILE_ACTIONS["1 -> 2"] = function(nomsu, tree, \%args, \%body)
|
||||||
local lua = LuaCode.Value(tree.source, "(function(")
|
local lua = LuaCode.Value(tree.source, "(function(")
|
||||||
|
@ -5,7 +5,7 @@ file:
|
|||||||
/ file_chunks / empty_block)
|
/ file_chunks / empty_block)
|
||||||
%ws* (!! .+ -> "Parse error" !!)?
|
%ws* (!! .+ -> "Parse error" !!)?
|
||||||
|
|
||||||
shebang: {:shebang: "#!" (!"nomsu" [^%nl])* "nomsu" %ws+ "-V" %ws* {:version: [0-9.]+ :} [^%nl]* :}
|
shebang: "#!" (!"nomsu" [^%nl])* "nomsu" %ws+ "-V" %ws* {:version: [0-9.]+ :} [^%nl]*
|
||||||
|
|
||||||
file_chunks (FileChunks):
|
file_chunks (FileChunks):
|
||||||
{:curr_indent: ' '* :}
|
{:curr_indent: ' '* :}
|
||||||
|
@ -5,7 +5,7 @@ file:
|
|||||||
/ file_chunks / empty_block)
|
/ file_chunks / empty_block)
|
||||||
%ws* (!! .+ -> "Parse error" !!)?
|
%ws* (!! .+ -> "Parse error" !!)?
|
||||||
|
|
||||||
shebang: {:shebang: "#!" (!"nomsu" [^%nl])* "nomsu" %ws+ "-V" %ws* {:version: [0-9.]+ :} [^%nl]* :}
|
shebang: "#!" (!"nomsu" [^%nl])* "nomsu" %ws+ "-V" %ws* {:version: [0-9.]+ :} [^%nl]*
|
||||||
|
|
||||||
file_chunks (FileChunks):
|
file_chunks (FileChunks):
|
||||||
{:curr_indent: ' '* :}
|
{:curr_indent: ' '* :}
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
#!/usr/bin/env nomsu -V3.5.5.6
|
#!/usr/bin/env nomsu -V3.6.5.6
|
||||||
#
|
#
|
||||||
Auto-format Nomsu code. Usage:
|
Auto-format Nomsu code. Usage:
|
||||||
nomsu tools/autoformat.nom [-i] file1 file2 directory1 ...
|
nomsu tools/autoformat.nom [-i] file1 file2 directory1 ...
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
#!/usr/bin/env nomsu -V3.5.5.6
|
#!/usr/bin/env nomsu -V3.6.5.6
|
||||||
#
|
#
|
||||||
Find an action by its stub. Usage:
|
Find an action by its stub. Usage:
|
||||||
nomsu tools/find_action.nom "foo %" file1 file2 directory1 ...
|
nomsu tools/find_action.nom "foo %" file1 file2 directory1 ...
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
#!/usr/bin/env nomsu -V3.5.5.6
|
#!/usr/bin/env nomsu -V3.6.5.6
|
||||||
#
|
#
|
||||||
Tool to print out a parse tree of files in an easy-to-read format. Usage:
|
Tool to print out a parse tree of files in an easy-to-read format. Usage:
|
||||||
nomsu tools/parse.nom file1 file2 directory1 ...
|
nomsu tools/parse.nom file1 file2 directory1 ...
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
#!/usr/bin/env nomsu -V3.5.5.6
|
#!/usr/bin/env nomsu -V3.6.5.6
|
||||||
#
|
#
|
||||||
Tool to run all tests in a file (i.e. the code block inside a call to 'test %'). Usage:
|
Tool to run all tests in a file (i.e. the code block inside a call to 'test %'). Usage:
|
||||||
nomsu tools/test.nom file1 file2 directory1 ...
|
nomsu tools/test.nom file1 file2 directory1 ...
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
#!/usr/bin/env nomsu -V3.5.5.6
|
#!/usr/bin/env nomsu -V3.6.5.6
|
||||||
#
|
#
|
||||||
Tool to automatically update code from old versions of Nomsu. Usage:
|
Tool to automatically update code from old versions of Nomsu. Usage:
|
||||||
nomsu tools/upgrade.nom [-i] file1 file2 directory1 ...
|
nomsu tools/upgrade.nom [-i] file1 file2 directory1 ...
|
||||||
|
Loading…
Reference in New Issue
Block a user