aboutsummaryrefslogtreecommitdiff
path: root/launcher.py
diff options
context:
space:
mode:
authorTinWoodman92 <chrhodgden@gmail.com>2023-05-31 21:17:06 -0500
committerTinWoodman92 <chrhodgden@gmail.com>2023-05-31 21:17:06 -0500
commitd67f09fb2f5a1dd11ac445eccec5dfe3976a6ce9 (patch)
tree065f0bc2b0a6ace3b8dd6bf0da0ca831f43cd959 /launcher.py
parentb9244a0e12333f441947cb1f31ad07efe9c897af (diff)
clients now connect via sockets.
Diffstat (limited to 'launcher.py')
-rw-r--r--launcher.py52
1 files changed, 33 insertions, 19 deletions
diff --git a/launcher.py b/launcher.py
index 23e3000..32ec12b 100644
--- a/launcher.py
+++ b/launcher.py
@@ -2,6 +2,7 @@ import os
import subprocess
import threading
import socket
+import time
HEADER = 64
PORT = 6011
@@ -29,54 +30,67 @@ def recv_msg(conn):
msg = conn.recv(HEADER).strip()
return msg
-def terminate_connection(conn):
- conn.close()
-
def execute_source_file(file_name):
ext = file_name.split('.')
if ext[1] == 'py': cmd = 'Python'
- elif ext[1] == 'r': cmd = 'RScript'
+ elif ext[1] == 'r': cmd = 'Rscript'
subprocess.run(
f'{cmd} {file_name}',
cwd = os.getcwd(),
start_new_session = True
)
+ print(f'{file_name} executed')
def launch_and_connect(file_name, CONN):
- mutable = {}
- connect_ = threading.Thread(target=establish_connection, args=[mutable])
+ connect_ = threading.Thread(target=establish_connection, args=[CONN])
launch_ = threading.Thread(target=execute_source_file, args=[file_name])
connect_.start()
launch_.start()
connect_.join()
- conn = mutable['conn']
- addr = mutable['addr']
- CONN['conn'] = mutable['conn']
- CONN['addr'] = mutable['addr']
+ conn = CONN['conn']
+ addr = CONN['addr']
+ CONN['launch_'] = launch_
return conn, addr
-def disconnect_and_close(file_name):
- pass
+def disconnect_and_close(CONN):
+ conn = CONN['conn']
+ launch_ = CONN['launch_']
+ send_msg(conn, '!DISCONNECT')
+ print(f'closing {CONN["addr"]}')
+ launch_.join()
+ print(f'closed {CONN["addr"]}')
+ conn.close()
+CONN_R = {}
CONN_PY = {}
+src_fil_r = threading.Thread(target=launch_and_connect, args=['source_file.r', CONN_R])
src_fil_py = threading.Thread(target=launch_and_connect, args=['source_file.py', CONN_PY])
-#src_fil_r = threading.Thread(target=execute_source_file, args=['source_file.r'])
+disc_r = threading.Thread(target=disconnect_and_close, args=[CONN_R])
+disc_py = threading.Thread(target=disconnect_and_close, args=[CONN_PY])
-#src_fil_r.start()
-src_fil_py.start()
+src_fil_r.run()
+src_fil_py.run()
-#src_fil_r.join()
-src_fil_py.join()
+conn_r = CONN_R['conn']
conn_py = CONN_PY['conn']
+msg = recv_msg(conn_r)
+print(msg)
msg = recv_msg(conn_py)
print(msg)
-msg = "goodbye"
-send_msg(conn_py, msg)
+for i in range(255):
+ msg = f'message {i}'
+ send_msg(conn_r, msg)
+ send_msg(conn_py, msg)
+
+disc_r.start()
+disc_py.start()
+disc_r.join()
+disc_py.join()
print("end launcher")