aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/src/sledjchisl/sledjchisl.c
diff options
context:
space:
mode:
authoronefang2021-08-11 19:32:33 +1000
committeronefang2021-08-11 19:32:33 +1000
commite657b09bf9998c575138d4fb4a6ebf5463e3aebb (patch)
tree8dbebdd57ddc576bdba187856a6b8db025a5bb52 /src/sledjchisl/sledjchisl.c
parentMore betterer output. (diff)
downloadopensim-SC-e657b09bf9998c575138d4fb4a6ebf5463e3aebb.zip
opensim-SC-e657b09bf9998c575138d4fb4a6ebf5463e3aebb.tar.gz
opensim-SC-e657b09bf9998c575138d4fb4a6ebf5463e3aebb.tar.bz2
opensim-SC-e657b09bf9998c575138d4fb4a6ebf5463e3aebb.tar.xz
More shutdown clean ups.
Diffstat (limited to 'src/sledjchisl/sledjchisl.c')
-rw-r--r--src/sledjchisl/sledjchisl.c43
1 files changed, 39 insertions, 4 deletions
diff --git a/src/sledjchisl/sledjchisl.c b/src/sledjchisl/sledjchisl.c
index f04d5ff..b946f95 100644
--- a/src/sledjchisl/sledjchisl.c
+++ b/src/sledjchisl/sledjchisl.c
@@ -7306,6 +7306,17 @@ static void cleanup(void)
7306// TODO - not sure why, but this gets called twice on quitting sometimes. 7306// TODO - not sure why, but this gets called twice on quitting sometimes.
7307 C("Caught signal, or quitting, cleaning up."); 7307 C("Caught signal, or quitting, cleaning up.");
7308 7308
7309 char *cmd = xmprintf("%s/sledjchisl.socket", scRun);
7310
7311 if (qfile_exist(cmd))
7312 {
7313 free(cmd);
7314 cmd = xmprintf("rm %s/sledjchisl.socket", scRun);
7315 if (!WIFEXITED(system(cmd)))
7316 E("rm command failed!");
7317 free(cmd);
7318 }
7319
7309 if (accountPages) 7320 if (accountPages)
7310 { 7321 {
7311 qhashtbl_obj_t obj; 7322 qhashtbl_obj_t obj;
@@ -7367,6 +7378,18 @@ static void cleanup(void)
7367 } 7378 }
7368 if (configs) configs->free(configs); 7379 if (configs) configs->free(configs);
7369 configs = NULL; 7380 configs = NULL;
7381
7382/* tmux should clean up it's own socket. Doesn't seem to care anyway.
7383 cmd = xmprintf("%s/%s", scRun, Tsocket);
7384 if (qfile_exist(cmd))
7385 {
7386 free(cmd);
7387 cmd = xmprintf("rm %s/%s", scRun, Tsocket);
7388 if (!WIFEXITED(system(cmd)))
7389 E("rm command failed!");
7390 free(cmd);
7391 }
7392*/
7370} 7393}
7371 7394
7372 7395
@@ -7902,6 +7925,17 @@ jit library is loaded or the JIT compiler will not be activated.
7902 { 7925 {
7903 // Stop all the sims. 7926 // Stop all the sims.
7904 forEachSim(NULL, stopSims, NULL); 7927 forEachSim(NULL, stopSims, NULL);
7928
7929 if (checkSimIsRunning("ROBUST"))
7930 {
7931 sendTmuxCmd("@0.%0", "quit");
7932 while (checkSimIsRunning("ROBUST"))
7933 usleep(100000);
7934 usleep(10000);
7935 sendTmuxCmd("@0.%0", "exit");
7936 I("ROBUST has stopped in tmux ID @0.%%0.");
7937 }
7938
7905 I("Closing all the other windows."); 7939 I("Closing all the other windows.");
7906 // First figure out what panes and windows are left. 7940 // First figure out what panes and windows are left.
7907 snprintf(toybuf, sizeof(toybuf), "echo 'IDs={' >%s/IDs_ALL.lua", scTemp); 7941 snprintf(toybuf, sizeof(toybuf), "echo 'IDs={' >%s/IDs_ALL.lua", scTemp);
@@ -7912,6 +7946,11 @@ jit library is loaded or the JIT compiler will not be activated.
7912 snprintf(toybuf, sizeof(toybuf), "%s/IDs_ALL.lua", scTemp); 7946 snprintf(toybuf, sizeof(toybuf), "%s/IDs_ALL.lua", scTemp);
7913 qtreetbl_t *IDs = Lua2tree(toybuf, "IDs"); 7947 qtreetbl_t *IDs = Lua2tree(toybuf, "IDs");
7914 7948
7949 char *c = xmprintf("rm -fr %s/*", scTemp);
7950 if (!WIFEXITED(system(c)))
7951 E("rm command failed! %s", c);
7952 free(c);
7953
7915 qtreetbl_obj_t obj0; 7954 qtreetbl_obj_t obj0;
7916 memset((void*)&obj0, 0, sizeof(obj0)); 7955 memset((void*)&obj0, 0, sizeof(obj0));
7917 IDs->lock(IDs); 7956 IDs->lock(IDs);
@@ -7925,10 +7964,6 @@ jit library is loaded or the JIT compiler will not be activated.
7925 IDs->unlock(IDs); 7964 IDs->unlock(IDs);
7926 freeLuaTree(IDs); 7965 freeLuaTree(IDs);
7927 7966
7928 char *c = xmprintf("rm -fr %s/*", scTemp);
7929 if (!WIFEXITED(system(c)))
7930 E("rm command failed! %s", c);
7931 free(c);
7932 } 7967 }
7933 else if (START == currentMode) 7968 else if (START == currentMode)
7934 { 7969 {