char *tmpStr;
int iPos = 0;
int iPos2 = 0;
+ char *chroot = CFGPTR(CFG_VFS_CHROOT);
+ int chrootLen;
char *cwd = CFGPTR(CFG_VFS_CWD);
int cwdLen;
-
ENTER("sPath", Path);
// Memory File
return ret;
}
+ // - Fetch ChRoot
+ if( chroot == NULL ) {
+ chroot = "";
+ chrootLen = 0;
+ } else {
+ chrootLen = strlen(chroot);
+ }
+
// Check if the path is already absolute
if(Path[0] == '/') {
ret = malloc(pathLen + 1);
strcpy(ret, cwd);
ret[cwdLen] = '/';
strcpy(&ret[cwdLen+1], Path);
+ //Log("ret = '%s'\n", ret);
}
// Parse Path
else
ret[iPos2] = 0;
+
+ // Prepend the chroot
+ tmpStr = malloc(chrootLen + strlen(ret) + 1);
+ strcpy( tmpStr, chroot );
+ strcpy( tmpStr+chrootLen, ret );
+ free(ret);
+ ret = tmpStr;
+
LEAVE('s', ret);
- Log("VFS_GetAbsPath: RETURN '%s'", ret);
+ //Log("VFS_GetAbsPath: RETURN '%s'", ret);
return ret;
}
// Sanity Check
/*if(!longestMount) {
- Log("VFS_GetTruePath - ERROR: No Root Node\n");
+ Log("VFS_ParsePath - ERROR: No Root Node\n");
return NULL;
}*/
free(*TruePath);
*TruePath = NULL;
}
- Log("Permissions fail on '%s'", Path);
+ //Log("Permissions fail on '%s'", Path);
LEAVE('n');
return NULL;
}
*TruePath = NULL;
}
Path[nextSlash] = '/';
- Log("FindDir fail on '%s'", Path);
+ //Log("FindDir fail on '%s'", Path);
LEAVE('n');
return NULL;
}
free(*TruePath);
*TruePath = NULL;
}
- Log("Child fail on '%s' ('%s)", Path, &Path[ofs]);
+ //Log("Child fail on '%s' ('%s)", Path, &Path[ofs]);
Path[nextSlash] = '/';
LEAVE('n');
return NULL;
// Check if file was found
if(!tmpNode) {
LOG("Node '%s' not found in dir '%s'", &Path[ofs], Path);
- Log("Child fail '%s' ('%s')", Path, &Path[ofs]);
+ //Log("Child fail '%s' ('%s')", Path, &Path[ofs]);
if(TruePath) free(*TruePath);
if(curNode->Close) curNode->Close(curNode);
LEAVE('n');
if( MM_GetPhysAddr( (Uint)gaUserHandles ) == 0 )
{
Uint addr, size;
- Log("Allocating %i user handles", CFGINT(CFG_VFS_MAXFILES));
size = CFGINT(CFG_VFS_MAXFILES) * sizeof(tVFS_Handle);
for(addr = 0; addr < size; addr += 0x1000)
MM_Allocate( (Uint)gaUserHandles + addr );
// Set new
CFGPTR(CFG_VFS_CWD) = buf;
- //Log("Updated CWD to '%s'", buf);
+ Log("Updated CWD to '%s'", buf);
+
+ return 1;
+}
+
+/**
+ * \fn int VFS_ChRoot(char *New)
+ * \brief Change current root directory
+ */
+int VFS_ChRoot(char *New)
+{
+ char *buf;
+ int fd;
+ tVFS_Handle *h;
+
+ if(New[0] == '/' && New[1] == '\0')
+ return 1; // What a useless thing to ask!
+
+ // Create Absolute
+ buf = VFS_GetAbsPath(New);
+ if(buf == NULL) {
+ LOG("Path expansion failed");
+ return -1;
+ }
+
+ // Check if path exists
+ fd = VFS_Open(buf, VFS_OPENFLAG_EXEC);
+ if(fd == -1) {
+ LOG("Path is invalid");
+ return -1;
+ }
+
+ // Get node so we can check for directory
+ h = VFS_GetHandle(fd);
+ if( !(h->Node->Flags & VFS_FFLAG_DIRECTORY) ) {
+ LOG("Path is not a directory");
+ VFS_Close(fd);
+ return -1;
+ }
+
+ // Close file
+ VFS_Close(fd);
+
+ // Free old working directory
+ if( CFGPTR(CFG_VFS_CHROOT) )
+ free( CFGPTR(CFG_VFS_CHROOT) );
+ // Set new
+ CFGPTR(CFG_VFS_CHROOT) = buf;
+
+ LOG("Updated Root to '%s'", buf);
return 1;
}
if(h->Node == NULL) return NULL;
return h;
}
+
+// === EXPORTS ===
+EXPORT(VFS_Open);
+EXPORT(VFS_Close);