cd now works.
git-svn-id: https://spexeah.com:8443/svn/Asuro@1440 6dbc8c32-bb84-406f-8558-d1cf31a0ab0c
This commit is contained in:
		| @@ -8,7 +8,7 @@ uses | |||||||
| type | type | ||||||
|     TOpenMode       = (omReadOnly, omWriteOnly, omReadWrite); |     TOpenMode       = (omReadOnly, omWriteOnly, omReadWrite); | ||||||
|     TWriteMode      = (wmRewrite, wmAppend, wmNew); |     TWriteMode      = (wmRewrite, wmAppend, wmNew); | ||||||
|     TError          = (eNone, eUnknown, eFileInUse, eWriteOnly, eReadOnly, eFileDoesNotExist, eDirectoryDoesNotExist, eDirectoryAlreadyExists, eNotADirectory); |     TError          = (eNone, eUnknown, eFileInUse, eWriteOnly, eReadOnly, eFileDoesNotExist, eDirectoryDoesNotExist, eDirectoryAlreadyExists, eNotADirectory, eDiskFull, eFilenameTooLong, eDirectoryFull); | ||||||
|     PError          = ^TError; |     PError          = ^TError; | ||||||
|     TIsPathValid    = (pvInvalid, pvFile, pvDirectory); |     TIsPathValid    = (pvInvalid, pvFile, pvDirectory); | ||||||
|  |  | ||||||
| @@ -80,8 +80,8 @@ function CloseFile(Filehandle : TFileHandle) : boolean; | |||||||
| function FileSize(Filename : pchar; error : puint8) : uint32; | function FileSize(Filename : pchar; error : puint8) : uint32; | ||||||
| function CreateDirectory(Handle : uint32; Path : pchar) : TError; | function CreateDirectory(Handle : uint32; Path : pchar) : TError; | ||||||
| function GetDirectories(Handle : uint32; Path : pchar) : PHashMap; | function GetDirectories(Handle : uint32; Path : pchar) : PHashMap; | ||||||
| function PathValid(Handle : uint32; Path : pchar) : TPathValid; | function PathValid(Path : pchar) : TIsPathValid; | ||||||
| function changeDirectory(Path : pchar) : TPathValid; | function changeDirectory(Path : pchar) : TIsPathValid; | ||||||
| function getWorkingDirectory : pchar; | function getWorkingDirectory : pchar; | ||||||
|  |  | ||||||
| //VFS Functions | //VFS Functions | ||||||
| @@ -165,6 +165,29 @@ begin | |||||||
|     tracer.push_trace('vfs.CombineToAbsolutePath.exit'); |     tracer.push_trace('vfs.CombineToAbsolutePath.exit'); | ||||||
| end; | end; | ||||||
|  |  | ||||||
|  | function evaluatePath(Path : pchar) : pchar; | ||||||
|  | var | ||||||
|  |     List : PLinkedListBase; | ||||||
|  |     i : uint32; | ||||||
|  |     elm : pchar; | ||||||
|  |  | ||||||
|  | begin | ||||||
|  |     List:= STRLL_FromString(Path, '/'); | ||||||
|  |     if STRLL_Size(List) > 0 then begin | ||||||
|  |         for i:=STRLL_Size(List)-1 downto 0 do begin | ||||||
|  |             elm:= STRLL_Get(List, i); | ||||||
|  |             if elm <> nil then begin | ||||||
|  |                 if StringEquals(elm,'..') then begin | ||||||
|  |                     STRLL_Delete(List, i); | ||||||
|  |                     if (i > 0) then STRLL_Delete(List, i-1); | ||||||
|  |                 end; | ||||||
|  |             end; | ||||||
|  |         end; | ||||||
|  |     end; | ||||||
|  |     evaluatePath:= CombineToAbsolutePath(List, STRLL_Size(List)); | ||||||
|  |     STRLL_Free(List); | ||||||
|  | end; | ||||||
|  |  | ||||||
| function getAbsolutePath(Obj : PVFSObject) : pchar; | function getAbsolutePath(Obj : PVFSObject) : pchar; | ||||||
| var | var | ||||||
|     buf, new, delim : pchar; |     buf, new, delim : pchar; | ||||||
| @@ -196,6 +219,23 @@ begin | |||||||
|     tracer.push_trace('vfs.getAbsolutePath.exit'); |     tracer.push_trace('vfs.getAbsolutePath.exit'); | ||||||
| end; | end; | ||||||
|  |  | ||||||
|  | function MakeAbsolutePath(Path : PChar) : pchar; | ||||||
|  | var | ||||||
|  |     AbsPath : pchar; | ||||||
|  |     TempPath : pchar; | ||||||
|  |  | ||||||
|  | begin | ||||||
|  |     if Path[0] = '/' then AbsPath:= stringCopy(Path) else begin | ||||||
|  |         if CurrentDirectory[StringSize(CurrentDirectory)-1] <> '/' then | ||||||
|  |             TempPath:= StringConcat(CurrentDirectory, '/') | ||||||
|  |         else | ||||||
|  |             TempPath:= stringCopy(CurrentDirectory); | ||||||
|  |         AbsPath:= StringConcat(TempPath, Path); | ||||||
|  |         kfree(void(TempPath)); | ||||||
|  |     end; | ||||||
|  |     MakeAbsolutePath:= AbsPath; | ||||||
|  | end; | ||||||
|  |  | ||||||
| function GetObjectFromPath(path : pchar) : PVFSObject; | function GetObjectFromPath(path : pchar) : PVFSObject; | ||||||
| var | var | ||||||
|     Obj         : PVFSObject; |     Obj         : PVFSObject; | ||||||
| @@ -216,7 +256,7 @@ begin | |||||||
|             NewObj:= PVFSObject(hashmap.get(ht, item));                                             |             NewObj:= PVFSObject(hashmap.get(ht, item));                                             | ||||||
|             if NewObj = nil then begin                                                               |             if NewObj = nil then begin                                                               | ||||||
|                 GetObjectFromPath:= nil; |                 GetObjectFromPath:= nil; | ||||||
|                 tracer.push_trace('vfs.GetObjectFromPath.shortexit'); |                 tracer.push_trace('vfs.GetObjectFromPath.shortexit_1'); | ||||||
|                 exit; |                 exit; | ||||||
|             end;                                                                                     |             end;                                                                                     | ||||||
|             Case NewObj^.ObjectType of |             Case NewObj^.ObjectType of | ||||||
| @@ -225,7 +265,7 @@ begin | |||||||
|                 end; |                 end; | ||||||
|                 else begin                                                                          |                 else begin                                                                          | ||||||
|                     Obj:= NewObj; |                     Obj:= NewObj; | ||||||
|                     tracer.push_trace('vfs.GetObjectFromPath.shortexit'); |                     tracer.push_trace('vfs.GetObjectFromPath.shortexit_2'); | ||||||
|                     Break; |                     Break; | ||||||
|                 end; |                 end; | ||||||
|             end; |             end; | ||||||
| @@ -322,20 +362,67 @@ begin | |||||||
|  |  | ||||||
| end; | end; | ||||||
|  |  | ||||||
| function PathValid(Handle : uint32; Path : pchar) : TPathValid; | function PathValid(Path : pchar) : TIsPathValid; | ||||||
| begin | var | ||||||
|  |     Obj : PVFSObject; | ||||||
|  |     ObjPath : pchar; | ||||||
|  |     RelPath : pchar; | ||||||
|  |  | ||||||
|  | begin | ||||||
|  |     PathValid:= pvInvalid; | ||||||
|  |     Obj:= GetObjectFromPath(Path); | ||||||
|  |     if Obj <> nil then begin | ||||||
|  |         Case Obj^.ObjectType of | ||||||
|  |             otVDIRECTORY:begin | ||||||
|  |                 PathValid:= pvDirectory; | ||||||
|  |             end; | ||||||
|  |             otDRIVE:begin | ||||||
|  |                 ObjPath:= getAbsolutePath(Obj); | ||||||
|  |                 RelPath:= makeRelative(Path, ObjPath); | ||||||
|  |                 PathValid:= PVFSDrive(Obj^.Reference)^.PathValid(PVFSDrive(Obj^.Reference)^.DriveHandle, RelPath); //Fix this to be relative path!!! | ||||||
|  |                 kfree(void(ObjPath)); | ||||||
|  |                 kfree(void(RelPath)); | ||||||
|  |             end;  | ||||||
|  |             otDEVICE:begin | ||||||
|  |                 ObjPath:= getAbsolutePath(Obj); | ||||||
|  |                 RelPath:= makeRelative(Path, ObjPath); | ||||||
|  |                 PathValid:= PVFSDevice(Obj^.Reference)^.PathValid(PVFSDevice(Obj^.Reference)^.DeviceHandle, RelPath); //Fix this to be the relative path | ||||||
|  |                 kfree(void(ObjPath)); | ||||||
|  |                 kfree(void(RelPath)); | ||||||
|  |             end; | ||||||
|  |             otFILE, otVFILE:begin | ||||||
|  |                 PathValid:= pvFile; | ||||||
|  |             end;  | ||||||
|  |             otMOUNT:begin | ||||||
|  |                 PathValid:= PathValid(PVFSMount(Obj^.Reference)^.Path); | ||||||
|  |             end; | ||||||
|  |         end; | ||||||
|  |     end; | ||||||
| end; | end; | ||||||
|  |  | ||||||
| function changeDirectory(Path : pchar) : TPathValid; | function changeDirectory(Path : pchar) : TIsPathValid; | ||||||
| begin | var | ||||||
|  |     TempPath : pchar; | ||||||
|  |     AbsPath : pchar; | ||||||
|  |     Validity : TIsPathValid; | ||||||
|  |  | ||||||
|  | begin | ||||||
|  |     TempPath:= MakeAbsolutePath(Path); | ||||||
|  |     AbsPath:= evaluatePath(TempPath); | ||||||
|  |     kfree(void(TempPath)); | ||||||
|  |     Validity:= PathValid(AbsPath); | ||||||
|  |     if (Validity = pvDirectory) then begin | ||||||
|  |         ChangeCurrentDirectoryValue(AbsPath); | ||||||
|  |     end; | ||||||
|  |     changeDirectory:= Validity; | ||||||
|  |     kfree(void(AbsPath)); | ||||||
| end; | end; | ||||||
|  |  | ||||||
| { VFS Functions } | { VFS Functions } | ||||||
|  |  | ||||||
| function newVirtualDirectory(Path : pchar) : TError; | function newVirtualDirectory(Path : pchar) : TError; | ||||||
| var | var | ||||||
|  |     TempPath              : pchar; | ||||||
|     AbsPath               : pchar;    |     AbsPath               : pchar;    | ||||||
|     SplitPath             : PLinkedListBase; |     SplitPath             : PLinkedListBase; | ||||||
|     SplitParentPath       : PLinkedListBase; |     SplitParentPath       : PLinkedListBase; | ||||||
| @@ -350,9 +437,7 @@ var | |||||||
| begin | begin | ||||||
|     tracer.push_trace('vfs.newVirtualDirectory.enter'); |     tracer.push_trace('vfs.newVirtualDirectory.enter'); | ||||||
|     newVirtualDirectory:= eUnknown; |     newVirtualDirectory:= eUnknown; | ||||||
|     if Path[0] = '/' then AbsPath:= stringCopy(Path) else begin |     AbsPath:= MakeAbsolutePath(Path); | ||||||
|         AbsPath:= StringConcat(CurrentDirectory, Path); |  | ||||||
|     end; |  | ||||||
|     SplitPath:= STRLL_FromString(AbsPath, '/'); |     SplitPath:= STRLL_FromString(AbsPath, '/'); | ||||||
|     ObjectName:= STRLL_Get(SplitPath, STRLL_Size(SplitPath)-1); |     ObjectName:= STRLL_Get(SplitPath, STRLL_Size(SplitPath)-1); | ||||||
|     ParentDirectoryPath:= CombineToAbsolutePath(SplitPath, STRLL_Size(SplitPath)-1); |     ParentDirectoryPath:= CombineToAbsolutePath(SplitPath, STRLL_Size(SplitPath)-1); | ||||||
| @@ -429,13 +514,41 @@ end; | |||||||
|  |  | ||||||
| procedure VFS_COMMAND_CD(params : PParamList); | procedure VFS_COMMAND_CD(params : PParamList); | ||||||
| var | var | ||||||
|     obj : PVFSObject; |     Path : pchar; | ||||||
|  |     Temp1, Temp2 : pchar; | ||||||
|  |     Result : TIsPathValid; | ||||||
|  |     i : uint32; | ||||||
|  |  | ||||||
| begin | begin | ||||||
|     tracer.push_trace('vfs.VFS_COMMAND_CD.enter'); |     if ParamCount(Params) > 0 then begin | ||||||
|     obj:= GetObjectFromPath('/disk/test/myfolder'); |         for i:=0 to ParamCount(Params)-1 do begin | ||||||
|     if obj <> nil then writestringlnWND(getAbsolutePath(obj),getTerminalHWND); |             if i = 0 then begin | ||||||
|     tracer.push_trace('vfs.VFS_COMMAND_CD.exit'); |                 Temp1:= StringCopy(GetParam(i, params)); | ||||||
|  |                 Path:= StringCopy(Temp1); | ||||||
|  |                 kfree(void(Temp1)); | ||||||
|  |             end else begin | ||||||
|  |                 Temp1:= StringConcat(' ', GetParam(i, Params)); | ||||||
|  |                 Temp2:= StringConcat(Path, Temp1); | ||||||
|  |                 kfree(void(Temp1)); | ||||||
|  |                 kfree(void(Path)); | ||||||
|  |                 Path:= Temp2; | ||||||
|  |             end; | ||||||
|  |         end; | ||||||
|  |         Result:= changeDirectory(Path); | ||||||
|  |         case Result of | ||||||
|  |             pvInvalid:begin | ||||||
|  |                 writestringWND('"', getTerminalHWND); | ||||||
|  |                 writestringWND(Path, getTerminalHWND); | ||||||
|  |                 writestringlnWND('" is not a valid path.', getTerminalHWND); | ||||||
|  |             end; | ||||||
|  |             pvFile:begin | ||||||
|  |                 writestringWND('"', getTerminalHWND); | ||||||
|  |                 writestringWND(Path, getTerminalHWND); | ||||||
|  |                 writestringlnWND('" is not a directory.', getTerminalHWND); | ||||||
|  |             end; | ||||||
|  |         end; | ||||||
|  |         kfree(void(Path)); | ||||||
|  |     end; | ||||||
| end; | end; | ||||||
|  |  | ||||||
| { Init } | { Init } | ||||||
| @@ -458,8 +571,8 @@ begin | |||||||
|     newVirtualDirectory('/dev'); |     newVirtualDirectory('/dev'); | ||||||
|     newVirtualDirectory('/home'); |     newVirtualDirectory('/home'); | ||||||
|     newVirtualDirectory('/disk'); |     newVirtualDirectory('/disk'); | ||||||
|     // newVirtualDirectory('/disk/test'); |     newVirtualDirectory('/disk/test'); | ||||||
|     // newVirtualDirectory('/disk/test/myfolder'); |     newVirtualDirectory('/disk/test/myfolder'); | ||||||
|  |  | ||||||
|     // rel:= makeRelative('/disk/SDA/mydirectory/myfile', '/disk/SDA'); |     // rel:= makeRelative('/disk/SDA/mydirectory/myfile', '/disk/SDA'); | ||||||
|     // if rel <> nil then outputln('VFS', rel) else outputln('VFS', 'REL IS NULL!'); |     // if rel <> nil then outputln('VFS', rel) else outputln('VFS', 'REL IS NULL!'); | ||||||
| @@ -469,14 +582,14 @@ begin | |||||||
|     terminal.registerCommand('LS', @VFS_COMMAND_LS, 'List directory contents.'); |     terminal.registerCommand('LS', @VFS_COMMAND_LS, 'List directory contents.'); | ||||||
|     terminal.registerCommand('CD', @VFS_COMMAND_CD, 'Set working directory'); |     terminal.registerCommand('CD', @VFS_COMMAND_CD, 'Set working directory'); | ||||||
|  |  | ||||||
|     {ht:= PHashMap(Root^.Reference); |     ht:= PHashMap(Root^.Reference); | ||||||
|     hashmap.add(ht, 'VDirectory', void(newDummyObject(otVDIRECTORY))); |     //hashmap.add(ht, 'VDirectory', void(newDummyObject(otVDIRECTORY))); | ||||||
|     hashmap.add(ht, 'Drive', void(newDummyObject(otDRIVE))); |     //hashmap.add(ht, 'Drive', void(newDummyObject(otDRIVE))); | ||||||
|     hashmap.add(ht, 'Device', void(newDummyObject(otDEVICE))); |     //hashmap.add(ht, 'Device', void(newDummyObject(otDEVICE))); | ||||||
|     hashmap.add(ht, 'VFile', void(newDummyObject(otVFILE))); |     hashmap.add(ht, 'virtualFile', void(createDummyObject(otVFILE))); | ||||||
|     hashmap.add(ht, 'Mount', void(newDummyObject(otMOUNT))); |     //hashmap.add(ht, 'Mount', void(newDummyObject(otMOUNT))); | ||||||
|     hashmap.add(ht, 'Directory', void(newDummyObject(otDIRECTORY))); |     //hashmap.add(ht, 'Directory', void(newDummyObject(otDIRECTORY))); | ||||||
|     hashmap.add(ht, 'File', void(newDummyObject(otFILE)));} |     //hashmap.add(ht, 'File', void(newDummyObject(otFILE)));} | ||||||
|     //otVDIRECTORY, otDRIVE, otDEVICE, otVFILE, otMOUNT, otDIRECTORY, otFILE) |     //otVDIRECTORY, otDRIVE, otDEVICE, otVFILE, otMOUNT, otDIRECTORY, otFILE) | ||||||
|     tracer.push_trace('vfs.init.exit'); |     tracer.push_trace('vfs.init.exit'); | ||||||
| end; | end; | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 kieron
					kieron