changeset 1261:198d6af7330a

rename Luan.to_table to Table.java_to_table_shallow and Luan.to_luan to Table.java_to_table_deep
author Franklin Schmidt <fschmidt@gmail.com>
date Mon, 24 Sep 2018 13:09:16 -0600 (2018-09-24)
parents 4b5b84853f6f
children 81d3a01fbd09
files src/luan/modules/Luan.luan src/luan/modules/Parsers.luan src/luan/modules/Rpc.luan src/luan/modules/Table.luan src/luan/modules/http/Http.luan src/luan/modules/http/tools/Luan_threads.luan
diffstat 6 files changed, 52 insertions(+), 38 deletions(-) [+]
line wrap: on
line diff
--- a/src/luan/modules/Luan.luan	Sun Sep 23 22:32:34 2018 -0600
+++ b/src/luan/modules/Luan.luan	Mon Sep 24 13:09:16 2018 -0600
@@ -1,6 +1,5 @@
 java()
 local BasicLuan = require "java:luan.modules.BasicLuan"
-local LuanJava = require "java:luan.Luan"
 
 local Luan = {}
 
@@ -38,30 +37,4 @@
 	return Luan.load( "return "..s, source_name or "eval" )()
 end
 
-
-local error = Luan.error
-local type = Luan.type or error()
-local pairs = Luan.pairs or error()
-
-Luan.to_table = LuanJava.toTable
-
-local function to_luan(obj,to_table)
-	if type(obj) ~= "java" then
-		return obj
-	end
-	obj = to_table(obj) or error("can't convert type "..obj.getClass().getName().." to luan")
-	local tbl = {}
-	for key, value in pairs(obj) do
-		key = to_luan(key,to_table)
-		value = to_luan(value,to_table)
-		tbl[key] = value
-	end
-	return tbl
-end
-
-function Luan.to_luan(obj,to_table)
-	to_table = to_table or Luan.to_table
-	return to_luan(obj,to_table)
-end
-
 return Luan
--- a/src/luan/modules/Parsers.luan	Sun Sep 23 22:32:34 2018 -0600
+++ b/src/luan/modules/Parsers.luan	Mon Sep 24 13:09:16 2018 -0600
@@ -12,13 +12,18 @@
 Parsers.theme_to_luan = Theme.toLuan
 
 local Luan = require "luan:Luan.luan"
+local error = Luan.error
+local type = Luan.type or error()
+local Table = require "luan:Table.luan"
+local java_to_table_deep = Table.java_to_table_deep or error()
 local LuanJava = require "java:luan.Luan"
 local JsonParser = require "java:luan.lib.json.JsonParser"
 local JsonToString = require "java:luan.lib.json.JsonToString"
 
 -- converts json string to luan object
 function Parsers.json_parse(s)
-	return Luan.to_luan(JsonParser.parse(s))
+	local obj = JsonParser.parse(s)
+	return type(obj)=="java" and java_to_table_deep(obj) or obj
 end
 
 -- converts luan object to json string
--- a/src/luan/modules/Rpc.luan	Sun Sep 23 22:32:34 2018 -0600
+++ b/src/luan/modules/Rpc.luan	Mon Sep 24 13:09:16 2018 -0600
@@ -19,10 +19,10 @@
 local try = Luan.try or error()
 local ipairs = Luan.ipairs or error()
 local type = Luan.type or error()
-local to_luan = Luan.to_luan or error()
 local Io = require "luan:Io.luan"
 local Thread = require "luan:Thread.luan"
 local Table = require "luan:Table.luan"
+local java_to_table_deep = Table.java_to_table_deep or error()
 local unpack = Table.unpack or error()
 local Logging = require "luan:logging/Logging.luan"
 local logger = Logging.logger "Rpc"
@@ -54,7 +54,7 @@
 end
 
 local function luan_args(list,binary_in)
-	list = to_luan(list)
+	list = java_to_table_deep(list)
 	if binary_in ~= nil then
 		local i_in = list[#list]
 		list[#list] = nil
--- a/src/luan/modules/Table.luan	Sun Sep 23 22:32:34 2018 -0600
+++ b/src/luan/modules/Table.luan	Mon Sep 24 13:09:16 2018 -0600
@@ -15,4 +15,38 @@
 Table.sort = TableLuan.sort
 Table.unpack = TableLuan.unpack
 
+
+local Luan = require "luan:Luan.luan"
+local error = Luan.error
+local type = Luan.type or error()
+local pairs = Luan.pairs or error()
+local LuanJava = require "java:luan.Luan"
+local toTable = LuanJava.toTable or error()
+
+function Table.java_to_table_shallow(obj)
+	return toTable(obj) or error("can't convert type "..obj.getClass().getName().." to table")
+end
+
+local to_luan, deepen
+
+function to_luan(obj,java_to_table_shallow)
+	return type(obj)=="java" and deepen(java_to_table_shallow(obj),java_to_table_shallow) or obj
+end
+
+function deepen(tbl,java_to_table_shallow)
+	local rtn = {}
+	for key, value in pairs(tbl) do
+		key = to_luan(key,java_to_table_shallow)
+		value = to_luan(value,java_to_table_shallow)
+		rtn[key] = value
+	end
+	return rtn
+end
+
+function Table.java_to_table_deep(obj,java_to_table_shallow)
+	java_to_table_shallow = java_to_table_shallow or Table.java_to_table_shallow
+	return deepen(java_to_table_shallow(obj),java_to_table_shallow)
+end
+
+
 return Table
--- a/src/luan/modules/http/Http.luan	Sun Sep 23 22:32:34 2018 -0600
+++ b/src/luan/modules/http/Http.luan	Mon Sep 24 13:09:16 2018 -0600
@@ -4,11 +4,11 @@
 local ipairs = Luan.ipairs or error()
 local pairs = Luan.pairs or error()
 local type = Luan.type or error()
-local to_luan = Luan.to_luan or error()
 local Io = require "luan:Io.luan"
 local Html = require "luan:Html.luan"
 local Table = require "luan:Table.luan"
 local clear = Table.clear or error()
+local java_to_table_deep = Table.java_to_table_deep or error()
 local Package = require "luan:Package.luan"
 local String = require "luan:String.luan"
 local lower = String.lower or error()
@@ -25,9 +25,9 @@
 
 local Http = {}
 
-local old_to_table = Luan.to_table or error()
+local old_java_to_table_shallow = Table.java_to_table_shallow or error()
 
-local function to_table(obj)
+local function java_to_table_shallow(obj)
 	if type(obj)=="java" and obj.instanceof(Request.MultipartFile) then
 		return {
 			filename = obj.filename
@@ -35,7 +35,7 @@
 			content = obj.content
 		}
 	end
-	return old_to_table(obj)
+	return old_java_to_table_shallow(obj)
 end
 
 function Http.new_request(java)
@@ -55,9 +55,9 @@
 		this.path = java.path or error()
 		this.protocol = java.protocol or error()
 		this.scheme = java.scheme or error()
-		this.headers = to_luan(java.headers)
-		this.parameters = to_luan(java.parameters,to_table)
-		this.cookies = to_luan(java.cookies)
+		this.headers = java_to_table_deep(java.headers)
+		this.parameters = java_to_table_deep(java.parameters,java_to_table_shallow)
+		this.cookies = java_to_table_deep(java.cookies)
 	end
 
 	function this.url()
--- a/src/luan/modules/http/tools/Luan_threads.luan	Sun Sep 23 22:32:34 2018 -0600
+++ b/src/luan/modules/http/tools/Luan_threads.luan	Mon Sep 24 13:09:16 2018 -0600
@@ -1,5 +1,7 @@
 local Luan = require "luan:Luan.luan"
 local error = Luan.error
+local Table = require "luan:Table.luan"
+local java_to_table_shallow = Table.java_to_table_shallow or error()
 local Io = require "luan:Io.luan"
 local Time = require "luan:Time.luan"
 local Http = require "luan:http/Http.luan"
@@ -31,7 +33,7 @@
 		<%
 		local count = 0
 		for _, thread in Luan.ipairs(threads) do
-			local luan_trace = Luan.to_table(LuanException.justLuan(thread.trace)) or error()
+			local luan_trace = java_to_table_shallow(LuanException.justLuan(thread.trace))
 			if #luan_trace > 0 then
 				%>
 				<p><%=thread.string%> <%=thread.state%>