git.ucc.asn.au
/
tpg
/
acess2.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Made the KPanic routine switch back to 0xB8000 text mode
[tpg/acess2.git]
/
Kernel
/
vfs
/
dir.c
diff --git
a/Kernel/vfs/dir.c
b/Kernel/vfs/dir.c
index
ba2311e
..
fbfc3af
100644
(file)
--- a/
Kernel/vfs/dir.c
+++ b/
Kernel/vfs/dir.c
@@
-1,7
+1,11
@@
/*
/*
+ * Acess2 VFS
+ * - Directory Management Functions
*/
*/
-#include "vfs.h"
-#include "vfs_int.h"
+#define DEBUG 0
+#include <acess.h>
+#include <vfs.h>
+#include <vfs_int.h>
// === IMPORTS ===
extern tVFS_Mount *gRootMount;
// === IMPORTS ===
extern tVFS_Mount *gRootMount;
@@
-30,18
+34,27
@@
int VFS_MkDir(char *Path)
int VFS_MkNod(char *Path, Uint Flags)
{
char *absPath, *name;
int VFS_MkNod(char *Path, Uint Flags)
{
char *absPath, *name;
- int pos=0, oldpos = 0;
+ int pos = 0, oldpos = 0;
+ int next = 0;
tVFS_Node *parent;
int ret;
tVFS_Node *parent;
int ret;
-
Debug_Enter("VFS_MkNod",
"sPath xFlags", Path, Flags);
+
ENTER(
"sPath xFlags", Path, Flags);
absPath = VFS_GetAbsPath(Path);
absPath = VFS_GetAbsPath(Path);
+ LOG("absPath = '%s'", absPath);
- while( (pos = strpos8(&absPath[pos+1], '/')) != -1 ) oldpos = pos;
+ while( (next = strpos(&absPath[pos+1], '/')) != -1 ) {
+ LOG("next = %i", next);
+ pos += next+1;
+ LOG("pos = %i", pos);
+ oldpos = pos;
+ }
absPath[oldpos] = '\0'; // Mutilate path
name = &absPath[oldpos+1];
absPath[oldpos] = '\0'; // Mutilate path
name = &absPath[oldpos+1];
+ LOG("absPath = '%s', name = '%s'", absPath, name);
+
// Check for root
if(absPath[0] == '\0')
parent = VFS_ParsePath("/", NULL);
// Check for root
if(absPath[0] == '\0')
parent = VFS_ParsePath("/", NULL);
@@
-54,15
+67,15
@@
int VFS_MkNod(char *Path, Uint Flags)
if( !VFS_CheckACL(parent, VFS_PERM_EXECUTE|VFS_PERM_WRITE) ) {
if(parent->Close) parent->Close( parent );
free(absPath);
if( !VFS_CheckACL(parent, VFS_PERM_EXECUTE|VFS_PERM_WRITE) ) {
if(parent->Close) parent->Close( parent );
free(absPath);
-
Debug_Leave("VFS_MkNod",
'i', -1);
+
LEAVE(
'i', -1);
return -1;
}
return -1;
}
-
Debug_Log("VFS_MkNod", "parent = %p\n
", parent);
+
LOG("parent = %p
", parent);
if(parent->MkNod == NULL) {
Warning("VFS_MkNod - Directory has no MkNod method");
if(parent->MkNod == NULL) {
Warning("VFS_MkNod - Directory has no MkNod method");
-
Debug_Leave("VFS_MkNod",
'i', -1);
+
LEAVE(
'i', -1);
return -1;
}
return -1;
}
@@
-76,9
+89,12
@@
int VFS_MkNod(char *Path, Uint Flags)
if(parent->Close) parent->Close( parent );
// Error Check
if(parent->Close) parent->Close( parent );
// Error Check
- if(ret == 0) return -1;
+ if(ret == 0) {
+ LEAVE('i', -1);
+ return -1;
+ }
-
Debug_Leave("VFS_MkNod",
'i', 0);
+
LEAVE(
'i', 0);
return 0;
}
return 0;
}
@@
-94,7
+110,7
@@
int VFS_Symlink(char *Name, char *Link)
int fp;
tVFS_Node *destNode;
int fp;
tVFS_Node *destNode;
- //
LogF("vfs_symlink: (name='%s', link='%s')\n", name, l
ink);
+ //
ENTER("sName sLink", Name, L
ink);
// Get absolue path name
Link = VFS_GetAbsPath( Link );
// Get absolue path name
Link = VFS_GetAbsPath( Link );
@@
-141,15
+157,15
@@
int VFS_ReadDir(int FD, char *Dest)
tVFS_Handle *h = VFS_GetHandle(FD);
char *tmp;
tVFS_Handle *h = VFS_GetHandle(FD);
char *tmp;
- ENTER("ph pDest", h, Dest);
+
//
ENTER("ph pDest", h, Dest);
if(!h || h->Node->ReadDir == NULL) {
if(!h || h->Node->ReadDir == NULL) {
- LEAVE('i', 0);
+
//
LEAVE('i', 0);
return 0;
}
return 0;
}
- if(h->Position >= h->Node->Size) {
- LEAVE('i', 0);
+ if(h->
Node->Size != -1 && h->
Position >= h->Node->Size) {
+
//
LEAVE('i', 0);
return 0;
}
return 0;
}
@@
-160,17
+176,17
@@
int VFS_ReadDir(int FD, char *Dest)
else
h->Position ++;
} while(tmp != NULL && (Uint)tmp < (Uint)VFS_MAXSKIP);
else
h->Position ++;
} while(tmp != NULL && (Uint)tmp < (Uint)VFS_MAXSKIP);
- LOG("tmp = '%s'", tmp);
+
+ //LOG("tmp = '%s'", tmp);
if(!tmp) {
if(!tmp) {
- LEAVE('i', 0);
+
//
LEAVE('i', 0);
return 0;
}
strcpy(Dest, tmp);
return 0;
}
strcpy(Dest, tmp);
+ free(tmp);
- if(IsHeap(tmp)) free(tmp);
-
- LEAVE('i', 1);
+ //LEAVE('i', 1);
return 1;
}
return 1;
}
UCC
git Repository :: git.ucc.asn.au