moved cd out of the shell and into the os library as os.chdir
This commit is contained in:
parent
c3347fa188
commit
ff321804ee
@ -1,12 +1,12 @@
|
||||
xpcall(function()
|
||||
os.setenv("PWD","/boot")
|
||||
os.spawnfile("/boot/service/getty.lua")
|
||||
coroutine.yield()
|
||||
for k,v in pairs(fs.list("/dev/")) do
|
||||
if v:sub(1,3) == "tty" then
|
||||
dprint(tostring(io.input("/dev/"..v)))
|
||||
dprint(tostring(io.output("/dev/"..v)))
|
||||
io.write("PsychOS v2.0a1 - ")
|
||||
print(tostring(math.floor(computer.totalMemory()/1024)).."K RAM")
|
||||
io.write(_OSVERSION.." - "..tostring(math.floor(computer.totalMemory()/1024)).."K RAM")
|
||||
os.spawnfile("/boot/exec/shell.lua")
|
||||
end
|
||||
end
|
||||
|
@ -3,25 +3,7 @@ local shenv = {}
|
||||
function shenv.quit()
|
||||
os.setenv("run",nil)
|
||||
end
|
||||
function shenv.cd(p)
|
||||
if p:sub(1,1) == "/" then
|
||||
if fs.list(p) then
|
||||
os.setenv("PWD",p)
|
||||
else
|
||||
print("no such directory: "..p)
|
||||
end
|
||||
else
|
||||
local np = {}
|
||||
for k,v in pairs(fs.segments(os.getenv("PWD").."/"..p)) do
|
||||
if v == ".." then
|
||||
np[#np] = nil
|
||||
else
|
||||
np[#np+1] = v
|
||||
end
|
||||
end
|
||||
os.setenv("PWD","/"..table.concat(np,"/"))
|
||||
end
|
||||
end
|
||||
shenv.cd = os.chdir
|
||||
setmetatable(shenv,{__index=function(_,k)
|
||||
if _G[k] then
|
||||
return _G[k]
|
||||
|
@ -1,6 +1,7 @@
|
||||
--#include "module/chatbox-dprint.lua"
|
||||
--#include "module/syslog.lua"
|
||||
--#include "module/sched.lua"
|
||||
--#include "module/osutil.lua"
|
||||
--#include "module/fs.lua"
|
||||
--#include "module/newio.lua"
|
||||
--#include "module/devfs.lua"
|
||||
|
18
module/osutil.lua
Normal file
18
module/osutil.lua
Normal file
@ -0,0 +1,18 @@
|
||||
function os.chdir(p) -- changes the current working directory of the calling process to the directory specified in *p*, returning true or false, error
|
||||
if not (p:sub(1,1) == "/") then
|
||||
local np = {}
|
||||
for k,v in pairs(fs.segments(os.getenv("PWD").."/"..p)) do
|
||||
if v == ".." then
|
||||
np[#np] = nil
|
||||
else
|
||||
np[#np+1] = v
|
||||
end
|
||||
end
|
||||
p = "/"..table.concat(np,"/")
|
||||
end
|
||||
if fs.exists(p) and fs.list(p) then
|
||||
os.setenv("PWD",p)
|
||||
else
|
||||
return false, "no such directory"
|
||||
end
|
||||
end
|
Loading…
Reference in New Issue
Block a user