mirror of
https://gitlab.com/bztsrc/posix-uefi.git
synced 2025-01-16 13:50:55 +01:00
Fix issue #23
This commit is contained in:
parent
e4644a7c4d
commit
5a71f6ae11
1 changed files with 6 additions and 4 deletions
10
uefi/stdio.c
10
uefi/stdio.c
|
@ -153,7 +153,8 @@ int __remove (const char_t *__filename, int isdir)
|
||||||
efi_guid_t infGuid = EFI_FILE_INFO_GUID;
|
efi_guid_t infGuid = EFI_FILE_INFO_GUID;
|
||||||
efi_file_info_t info;
|
efi_file_info_t info;
|
||||||
uintn_t fsiz = (uintn_t)sizeof(efi_file_info_t), i;
|
uintn_t fsiz = (uintn_t)sizeof(efi_file_info_t), i;
|
||||||
FILE *f = fopen(__filename, CL("r"));
|
/* little hack to support read and write mode for Delete() without create mode */
|
||||||
|
FILE *f = fopen(__filename, CL("@"));
|
||||||
if(!f || f == stdin || f == stdout || f == stderr || (__ser && f == (FILE*)__ser)) {
|
if(!f || f == stdin || f == stdout || f == stderr || (__ser && f == (FILE*)__ser)) {
|
||||||
errno = EBADF;
|
errno = EBADF;
|
||||||
return 1;
|
return 1;
|
||||||
|
@ -271,6 +272,7 @@ FILE *fopen (const char_t *__filename, const char_t *__modes)
|
||||||
errno = 0;
|
errno = 0;
|
||||||
ret = (FILE*)malloc(sizeof(FILE));
|
ret = (FILE*)malloc(sizeof(FILE));
|
||||||
if(!ret) return NULL;
|
if(!ret) return NULL;
|
||||||
|
/* normally write means read,write,create. But for remove (internal '@' mode), we need read,write without create */
|
||||||
#ifndef UEFI_NO_UTF8
|
#ifndef UEFI_NO_UTF8
|
||||||
mbstowcs((wchar_t*)&wcname, __filename, BUFSIZ - 1);
|
mbstowcs((wchar_t*)&wcname, __filename, BUFSIZ - 1);
|
||||||
status = __root_dir->Open(__root_dir, &ret, (wchar_t*)&wcname,
|
status = __root_dir->Open(__root_dir, &ret, (wchar_t*)&wcname,
|
||||||
|
@ -278,7 +280,7 @@ FILE *fopen (const char_t *__filename, const char_t *__modes)
|
||||||
status = __root_dir->Open(__root_dir, &ret, (wchar_t*)__filename,
|
status = __root_dir->Open(__root_dir, &ret, (wchar_t*)__filename,
|
||||||
#endif
|
#endif
|
||||||
__modes[0] == CL('w') || __modes[0] == CL('a') ? (EFI_FILE_MODE_WRITE | EFI_FILE_MODE_READ | EFI_FILE_MODE_CREATE) :
|
__modes[0] == CL('w') || __modes[0] == CL('a') ? (EFI_FILE_MODE_WRITE | EFI_FILE_MODE_READ | EFI_FILE_MODE_CREATE) :
|
||||||
EFI_FILE_MODE_READ,
|
EFI_FILE_MODE_READ | (__modes[0] == CL('@') ? EFI_FILE_MODE_WRITE : 0),
|
||||||
__modes[1] == CL('d') ? EFI_FILE_DIRECTORY : 0);
|
__modes[1] == CL('d') ? EFI_FILE_DIRECTORY : 0);
|
||||||
if(EFI_ERROR(status)) {
|
if(EFI_ERROR(status)) {
|
||||||
err: __stdio_seterrno(status);
|
err: __stdio_seterrno(status);
|
||||||
|
@ -287,10 +289,10 @@ err: __stdio_seterrno(status);
|
||||||
status = ret->GetInfo(ret, &infGuid, &fsiz, &info);
|
status = ret->GetInfo(ret, &infGuid, &fsiz, &info);
|
||||||
if(EFI_ERROR(status)) goto err;
|
if(EFI_ERROR(status)) goto err;
|
||||||
if(__modes[1] == CL('d') && !(info.Attribute & EFI_FILE_DIRECTORY)) {
|
if(__modes[1] == CL('d') && !(info.Attribute & EFI_FILE_DIRECTORY)) {
|
||||||
free(ret); errno = ENOTDIR; return NULL;
|
ret->Close(ret); free(ret); errno = ENOTDIR; return NULL;
|
||||||
}
|
}
|
||||||
if(__modes[1] != CL('d') && (info.Attribute & EFI_FILE_DIRECTORY)) {
|
if(__modes[1] != CL('d') && (info.Attribute & EFI_FILE_DIRECTORY)) {
|
||||||
free(ret); errno = EISDIR; return NULL;
|
ret->Close(ret); free(ret); errno = EISDIR; return NULL;
|
||||||
}
|
}
|
||||||
if(__modes[0] == CL('a')) fseek(ret, 0, SEEK_END);
|
if(__modes[0] == CL('a')) fseek(ret, 0, SEEK_END);
|
||||||
return ret;
|
return ret;
|
||||||
|
|
Loading…
Reference in a new issue