diff src/luan_editor/editor.luan @ 59:824f6d74b1d4

use launcher
author Franklin Schmidt <fschmidt@gmail.com>
date Wed, 04 Jun 2025 18:21:45 -0600
parents 6059b4e22d47
children
line wrap: on
line diff
--- a/src/luan_editor/editor.luan	Fri May 30 13:17:51 2025 -0600
+++ b/src/luan_editor/editor.luan	Wed Jun 04 18:21:45 2025 -0600
@@ -1,56 +1,21 @@
 local Luan = require "luan:Luan.luan"
 local error = Luan.error
 local ipairs = Luan.ipairs or error()
+local stringify = Luan.stringify or error()
 local String = require "luan:String.luan"
-local contains = String.contains or error()
 local to_number = String.to_number or error()
 local Io = require "luan:Io.luan"
 local new_file = Io.schemes.file or error()
-local Rpc = require "luan:Rpc.luan"
-local Swing = require "luan:swing/Swing.luan"
-local swing_run = Swing.run or error()
-local swing_run_later = Swing.run_later or error()
-local Window = require "classpath:luan_editor/Window.luan"
-local new_window = Window.new_window or error()
-local open_windows = Window.open_windows or error()
+local Launcher = require "luan:swing/Launcher.luan"
 local Java = require "classpath:luan_editor/Java.luan"
 local Logging = require "luan:logging/Logging.luan"
 local logger = Logging.logger "editor/editor"
 
 
-local port = Java.port
-if port == nil then
-	port = 56587
-else
-	port = to_number(port) or error("bad port: "..port)
-end
+local function open(args)
+	local Window = require "classpath:luan_editor/Window.luan"
+	local new_window = Window.new_window or error()
 
-Rpc.cipher_suites = nil
-local server_socket
-try
-	server_socket = Rpc.new_server_socket(port)
-catch e
-	--logger.info(e.get_message())
-	if not contains( e.get_message(), "java.net.BindException" ) then
-		e.throw()
-	end
-	local host = Rpc.remote("localhost",port)
-	local args = Luan.arg
-	local file_paths = {}
-	for _, arg in ipairs(args) do
-		local file = new_file(arg)
-		file = file.canonical().to_string()
-		file_paths[#file_paths+1] = file
-	end
-	host.open_windows(file_paths)
-	host.close()
-	return
-end
-
-Rpc.functions.open_windows = open_windows
-
-swing_run(function()
-	local args = Luan.arg
 	if #args == 0 then
 		new_window()
 	else
@@ -59,8 +24,25 @@
 			new_window(file)
 		end
 	end
-end)
+end
+
+local function reopen(args)
+	local Window = require "classpath:luan_editor/Window.luan"
+	local open_windows = Window.open_windows or error()
+
+	open_windows(args)
+end
 
-Rpc.serve_socket(server_socket,nil,function(socket,fns)
-	swing_run_later(Rpc.new_server_fn(socket,fns))
-end)
+local port = Java.port
+if port ~= nil then
+	Launcher.port = to_number(port) or error("bad port: "..port)
+end
+
+local args = {nil}
+for _, arg in ipairs(Luan.arg) do
+	local file = new_file(arg)
+	file = file.canonical().to_string()
+	args[#args+1] = file
+end
+
+Launcher.launch(open,reopen,args)