-
Notifications
You must be signed in to change notification settings - Fork 129
/
Copy pathclearLMOD_cmd.in.lua
273 lines (235 loc) · 7.03 KB
/
clearLMOD_cmd.in.lua
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
#!@path_to_lua@
-- -*- lua -*-
--------------------------------------------------------------------------
-- Fixme
-- @script clearLMOD_cmd
--------------------------------------------------------------------------
-- Lmod License
--------------------------------------------------------------------------
--
-- Lmod is licensed under the terms of the MIT license reproduced below.
-- This means that Lmod is free software and can be used for both academic
-- and commercial purposes at absolutely no cost.
--
-- ----------------------------------------------------------------------
--
-- Copyright (C) 2008-2018 Robert McLay
--
-- Permission is hereby granted, free of charge, to any person obtaining
-- a copy of this software and associated documentation files (the
-- "Software"), to deal in the Software without restriction, including
-- without limitation the rights to use, copy, modify, merge, publish,
-- distribute, sublicense, and/or sell copies of the Software, and to
-- permit persons to whom the Software is furnished to do so, subject
-- to the following conditions:
--
-- The above copyright notice and this permission notice shall be
-- included in all copies or substantial portions of the Software.
--
-- THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
-- EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES
-- OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
-- NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
-- BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
-- ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
-- CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
-- THE SOFTWARE.
--
--------------------------------------------------------------------------
local sys_lua_path = "@sys_lua_path@"
if (sys_lua_path:sub(1,1) == "@") then
sys_lua_path = package.path
end
local sys_lua_cpath = "@sys_lua_cpath@"
if (sys_lua_cpath:sub(1,1) == "@") then
sys_lua_cpath = package.cpath
end
package.path = sys_lua_path
package.cpath = sys_lua_cpath
local arg_0 = arg[0]
_G._DEBUG = false
local posix = require("posix")
local readlink = posix.readlink
local stat = posix.stat
local getenv = posix.getenv
local st = stat(arg_0)
while (st.type == "link") do
local lnk = readlink(arg_0)
if (arg_0:find("/") and (lnk:find("^/") == nil)) then
local dir = arg_0:gsub("/[^/]*$","")
lnk = dir .. "/" .. lnk
end
arg_0 = lnk
st = stat(arg_0)
end
local ia,ja = arg_0:find(".*/")
local cmd_dir = "./"
if (ia) then
cmd_dir = arg_0:sub(1,ja)
end
package.path = cmd_dir .. "../tools/?.lua;" ..
cmd_dir .. "../tools/?/init.lua;" ..
cmd_dir .. "?.lua;" ..
sys_lua_path
package.cpath = cmd_dir .. "../lib/?.so;"..
sys_lua_cpath
require("strict")
require("fileOps")
local concatTbl = table.concat
local strfmt = string.format
local huge = math.huge
local s_optionTbl = {}
local Optiks = require("Optiks")
function optionTbl()
return s_optionTbl
end
function cmdDir()
return cmd_dir
end
function bash_unset(name)
io.stdout:write("unset -f ",name," 2> /dev/null || true;\n")
end
function csh_unset(name)
io.stdout:write("unalias ",name,";\n")
end
function python_unset(name)
end
function bash_export(name, value)
local a = {}
if (value == "") then
a[#a+1] = "unset "
a[#a+1] = name
a[#a+1] = ";\n"
else
a[#a+1] = name
a[#a+1] = "=\""
a[#a+1] = value
a[#a+1] = "\"; export "
a[#a+1] = name
a[#a+1] = ";\n"
end
io.stdout:write(concatTbl(a,""))
end
function csh_setenv(name, value)
local a = {}
if (value == "") then
a[#a+1] = "unsetenv "
a[#a+1] = name
a[#a+1] = ";\n"
else
a[#a+1] = "setenv "
a[#a+1] = name
a[#a+1] = " \""
a[#a+1] = value
a[#a+1] = "\";\n"
end
io.stdout:write(concatTbl(a,""))
end
function python_setenv(name, value)
local a = {}
if (value == "") then
a[#a + 1] = "os.environ['"
a[#a + 1] = name
a[#a + 1] = "'] = ''\n"
a[#a + 1] = "del os.environ['"
a[#a + 1] = name
a[#a + 1] = "']\n"
else
a[#a + 1] = "os.environ['"
a[#a + 1] = name
a[#a + 1] = "'] = '"
a[#a + 1] = value
a[#a + 1] = "';\n"
end
io.stdout:write(concatTbl(a,""))
end
function options()
local optionTbl = optionTbl()
local usage = "Usage: "
local cmdlineParser = Optiks:new{usage=usage, version="1.0"}
cmdlineParser:add_option{
name = {'-q','--quiet'},
dest = 'quiet',
action = 'store_true',
}
cmdlineParser:add_option{
name = {'--simple'},
dest = 'simple',
action = 'store_true',
}
cmdlineParser:add_option{
name = {'--full'},
dest = 'full',
action = 'store_true',
}
cmdlineParser:add_option{
name = {'-s','--shell'},
dest = 'shell',
action = 'store',
default = 'bash',
}
local optTbl, pargs = cmdlineParser:parse(arg)
for v in pairs(optTbl) do
optionTbl[v] = optTbl[v]
end
optionTbl.pargs = pargs
end
function main()
local optionTbl = optionTbl()
options()
local setenv = bash_export
local unset = bash_unset
if ( optionTbl.shell == "csh" ) then
setenv = csh_setenv
unset = csh_unset
end
if ( optionTbl.shell == "python" ) then
setenv = python_setenv
unset = python_unset
end
setenv("_ModuleTable_Sz_", "")
setenv("LOADEDMODULES", "")
setenv("_LMFILES_", "")
if (not optionTbl.full) then
for k = 1, huge do
local name = strfmt("_ModuleTable%03d_",k)
local v = getenv(name)
if (v == nil) then break end
setenv(name,"")
end
for key, value in pairs(getenv()) do
if ( key:find("^__LMOD_REF_COUNT_")) then
setenv(key,"")
end
end
return
end
if (not optionTbl.quiet) then
io.stderr:write("Executing a module purge and removing all Lmod environment variables, aliases and shell functions\n")
io.stderr:write("This includes the module and ml commands!\n")
end
--------------------------------------------------------------
-- If here then remove LMOD completely from the environment
setenv("SETTARG_TAG1", "")
setenv("SETTARG_TAG2", "")
setenv("MODULESHOME", "")
setenv("MODULEPATH", "")
setenv("MODULEPATH_ROOT", "")
setenv("LMOD_MODULERCFILE", "")
setenv("LMOD_MODULERC", "")
setenv("MODULERCFILE", "")
setenv("TARG_TITLE_BAR_PAREN", "")
setenv("__Init_Default_Modules", "")
unset("module")
unset("ml")
unset("clearMT")
unset("clearLmod")
unset("xSetTitleLmod")
for key, value in pairs(getenv()) do
if ( key:find("^LMOD") or
key:find("^_ModuleTable%d%d+_") ) then
setenv(key,"")
end
end
end
main()