mirror of
https://gitlab.com/sortix/sortix.git
synced 2023-02-13 20:55:38 -05:00
Remove dcloseall() and fcloseall().
This commit is contained in:
parent
b6b19c88fd
commit
5e60007904
10 changed files with 54 additions and 101 deletions
|
@ -37,7 +37,6 @@ dirent/alphasort.o \
|
||||||
dirent/alphasort_r.o \
|
dirent/alphasort_r.o \
|
||||||
dirent/closedir.o \
|
dirent/closedir.o \
|
||||||
dirent/dclearerr.o \
|
dirent/dclearerr.o \
|
||||||
dirent/dcloseall.o \
|
|
||||||
dirent/deof.o \
|
dirent/deof.o \
|
||||||
dirent/derror.o \
|
dirent/derror.o \
|
||||||
dirent/dirfd.o \
|
dirent/dirfd.o \
|
||||||
|
@ -129,6 +128,7 @@ stdio/ftello.o \
|
||||||
stdio/ftello_unlocked.o \
|
stdio/ftello_unlocked.o \
|
||||||
stdio/ftrylockfile.o \
|
stdio/ftrylockfile.o \
|
||||||
stdio/funlockfile.o \
|
stdio/funlockfile.o \
|
||||||
|
stdio/funregister.o \
|
||||||
stdio/fwritable.o \
|
stdio/fwritable.o \
|
||||||
stdio/fwritable_unlocked.o \
|
stdio/fwritable_unlocked.o \
|
||||||
stdio/fwrite.o \
|
stdio/fwrite.o \
|
||||||
|
@ -412,7 +412,6 @@ signal/signal.o \
|
||||||
signal/sigpending.o \
|
signal/sigpending.o \
|
||||||
signal/sigprocmask.o \
|
signal/sigprocmask.o \
|
||||||
signal/sigsuspend.o \
|
signal/sigsuspend.o \
|
||||||
stdio/fcloseall.o \
|
|
||||||
stdio/fdio_install_fd.o \
|
stdio/fdio_install_fd.o \
|
||||||
stdio/fdio_install_path.o \
|
stdio/fdio_install_path.o \
|
||||||
stdio/fdio.o \
|
stdio/fdio.o \
|
||||||
|
|
|
@ -23,17 +23,14 @@
|
||||||
*******************************************************************************/
|
*******************************************************************************/
|
||||||
|
|
||||||
#include <dirent.h>
|
#include <dirent.h>
|
||||||
#include <DIR.h>
|
|
||||||
#include <pthread.h>
|
#include <pthread.h>
|
||||||
|
|
||||||
extern "C" pthread_mutex_t __dirname_lock;
|
|
||||||
|
|
||||||
extern "C" void dregister(DIR* dir)
|
extern "C" void dregister(DIR* dir)
|
||||||
{
|
{
|
||||||
pthread_mutex_lock(&__dirname_lock);
|
pthread_mutex_lock(&__first_dir_lock);
|
||||||
dir->flags |= _DIR_REGISTERED;
|
dir->flags |= _DIR_REGISTERED;
|
||||||
if ( (dir->next = __firstdir) )
|
if ( (dir->next = __first_dir) )
|
||||||
dir->next->prev = dir;
|
dir->next->prev = dir;
|
||||||
__firstdir = dir;
|
__first_dir = dir;
|
||||||
pthread_mutex_unlock(&__dirname_lock);
|
pthread_mutex_unlock(&__first_dir_lock);
|
||||||
}
|
}
|
||||||
|
|
|
@ -23,22 +23,19 @@
|
||||||
*******************************************************************************/
|
*******************************************************************************/
|
||||||
|
|
||||||
#include <dirent.h>
|
#include <dirent.h>
|
||||||
#include <DIR.h>
|
|
||||||
#include <pthread.h>
|
#include <pthread.h>
|
||||||
|
|
||||||
extern "C" { pthread_mutex_t __dirname_lock = PTHREAD_MUTEX_INITIALIZER; }
|
|
||||||
|
|
||||||
extern "C" void dunregister(DIR* dir)
|
extern "C" void dunregister(DIR* dir)
|
||||||
{
|
{
|
||||||
if ( !(dir->flags & _DIR_REGISTERED) )
|
if ( !(dir->flags & _DIR_REGISTERED) )
|
||||||
return;
|
return;
|
||||||
pthread_mutex_lock(&__dirname_lock);
|
pthread_mutex_lock(&__first_dir_lock);
|
||||||
if ( !dir->prev )
|
if ( !dir->prev )
|
||||||
__firstdir = dir->next;
|
__first_dir = dir->next;
|
||||||
if ( dir->prev )
|
if ( dir->prev )
|
||||||
dir->prev->next = dir->next;
|
dir->prev->next = dir->next;
|
||||||
if ( dir->next )
|
if ( dir->next )
|
||||||
dir->next->prev = dir->prev;
|
dir->next->prev = dir->prev;
|
||||||
dir->flags &= ~_DIR_REGISTERED;
|
dir->flags &= ~_DIR_REGISTERED;
|
||||||
pthread_mutex_unlock(&__dirname_lock);
|
pthread_mutex_unlock(&__first_dir_lock);
|
||||||
}
|
}
|
||||||
|
|
|
@ -29,6 +29,8 @@
|
||||||
|
|
||||||
#include <sys/__/types.h>
|
#include <sys/__/types.h>
|
||||||
|
|
||||||
|
#include <pthread.h>
|
||||||
|
|
||||||
__BEGIN_DECLS
|
__BEGIN_DECLS
|
||||||
|
|
||||||
#ifndef __size_t_defined
|
#ifndef __size_t_defined
|
||||||
|
@ -64,6 +66,11 @@ struct DIR
|
||||||
int flags;
|
int flags;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
#if defined(__is_sortix_libc)
|
||||||
|
extern DIR* __first_dir;
|
||||||
|
extern __pthread_mutex_t __first_dir_lock;
|
||||||
|
#endif
|
||||||
|
|
||||||
__END_DECLS
|
__END_DECLS
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -31,6 +31,10 @@
|
||||||
|
|
||||||
#include <sortix/__/dirent.h>
|
#include <sortix/__/dirent.h>
|
||||||
|
|
||||||
|
#if defined(__is_sortix_libc)
|
||||||
|
#include <DIR.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
__BEGIN_DECLS
|
__BEGIN_DECLS
|
||||||
|
|
||||||
#ifndef __dev_t_defined
|
#ifndef __dev_t_defined
|
||||||
|
@ -111,16 +115,11 @@ int versionsort_r(const struct dirent**, const struct dirent**, void*);
|
||||||
void dregister(DIR* dir);
|
void dregister(DIR* dir);
|
||||||
void dunregister(DIR* dir);
|
void dunregister(DIR* dir);
|
||||||
DIR* dnewdir(void);
|
DIR* dnewdir(void);
|
||||||
int dcloseall(void);
|
|
||||||
void dclearerr(DIR* dir);
|
void dclearerr(DIR* dir);
|
||||||
int derror(DIR* dir);
|
int derror(DIR* dir);
|
||||||
int deof(DIR* dif);
|
int deof(DIR* dif);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(__is_sortix_libc)
|
|
||||||
extern DIR* __firstdir;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
__END_DECLS
|
__END_DECLS
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -247,7 +247,6 @@ int vdprintf(int fildes, const char* __restrict format, __gnuc_va_list ap)
|
||||||
int asprintf(char** __restrict, const char* __restrict, ...)
|
int asprintf(char** __restrict, const char* __restrict, ...)
|
||||||
__attribute__((__format__ (printf, 2, 3)));
|
__attribute__((__format__ (printf, 2, 3)));
|
||||||
void clearerr_unlocked(FILE* stream);
|
void clearerr_unlocked(FILE* stream);
|
||||||
int fcloseall(void);
|
|
||||||
int feof_unlocked(FILE* stream);
|
int feof_unlocked(FILE* stream);
|
||||||
int ferror_unlocked(FILE* stream);
|
int ferror_unlocked(FILE* stream);
|
||||||
int fflush_unlocked(FILE* stream);
|
int fflush_unlocked(FILE* stream);
|
||||||
|
|
|
@ -1,35 +0,0 @@
|
||||||
/*******************************************************************************
|
|
||||||
|
|
||||||
Copyright(C) Jonas 'Sortie' Termansen 2011, 2012, 2013.
|
|
||||||
|
|
||||||
This file is part of the Sortix C Library.
|
|
||||||
|
|
||||||
The Sortix C Library is free software: you can redistribute it and/or modify
|
|
||||||
it under the terms of the GNU Lesser General Public License as published by
|
|
||||||
the Free Software Foundation, either version 3 of the License, or (at your
|
|
||||||
option) any later version.
|
|
||||||
|
|
||||||
The Sortix C Library is distributed in the hope that it will be useful, but
|
|
||||||
WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
|
||||||
or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public
|
|
||||||
License for more details.
|
|
||||||
|
|
||||||
You should have received a copy of the GNU Lesser General Public License
|
|
||||||
along with the Sortix C Library. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
stdio/fcloseall.cpp
|
|
||||||
Closes and flushes all open registered files.
|
|
||||||
|
|
||||||
*******************************************************************************/
|
|
||||||
|
|
||||||
#include <stdio.h>
|
|
||||||
|
|
||||||
extern "C" int fcloseall(void)
|
|
||||||
{
|
|
||||||
int result = 0;
|
|
||||||
// We do not lock __first_file_lock here because this function is called on
|
|
||||||
// process termination and only one thread can call exit(3).
|
|
||||||
while ( __first_file )
|
|
||||||
result |= fclose(__first_file);
|
|
||||||
return result ? EOF : 0;
|
|
||||||
}
|
|
|
@ -1,6 +1,6 @@
|
||||||
/*******************************************************************************
|
/*******************************************************************************
|
||||||
|
|
||||||
Copyright(C) Jonas 'Sortie' Termansen 2011, 2012, 2013.
|
Copyright(C) Jonas 'Sortie' Termansen 2011, 2012, 2013, 2014.
|
||||||
|
|
||||||
This file is part of the Sortix C Library.
|
This file is part of the Sortix C Library.
|
||||||
|
|
||||||
|
@ -18,44 +18,19 @@
|
||||||
along with the Sortix C Library. If not, see <http://www.gnu.org/licenses/>.
|
along with the Sortix C Library. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
stdio/fregister.cpp
|
stdio/fregister.cpp
|
||||||
Registers a FILE in the global list of open FILES, which allows the standard
|
Registers a FILE in the global list of open FILEs.
|
||||||
library to close and flush all open files upon program exit.
|
|
||||||
|
|
||||||
*******************************************************************************/
|
*******************************************************************************/
|
||||||
|
|
||||||
#include <pthread.h>
|
#include <pthread.h>
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
|
|
||||||
extern "C"
|
|
||||||
{
|
|
||||||
FILE* __first_file = NULL;
|
|
||||||
pthread_mutex_t __first_file_lock = PTHREAD_MUTEX_INITIALIZER;
|
|
||||||
}
|
|
||||||
|
|
||||||
extern "C" void fregister(FILE* fp)
|
extern "C" void fregister(FILE* fp)
|
||||||
{
|
{
|
||||||
pthread_mutex_lock(&__first_file_lock);
|
pthread_mutex_lock(&__first_file_lock);
|
||||||
fp->flags |= _FILE_REGISTERED;
|
fp->flags |= _FILE_REGISTERED;
|
||||||
if ( __first_file )
|
if ( (fp->next = __first_file) )
|
||||||
{
|
|
||||||
fp->next = __first_file;
|
|
||||||
__first_file->prev = fp;
|
__first_file->prev = fp;
|
||||||
}
|
|
||||||
__first_file = fp;
|
__first_file = fp;
|
||||||
pthread_mutex_unlock(&__first_file_lock);
|
pthread_mutex_unlock(&__first_file_lock);
|
||||||
}
|
}
|
||||||
|
|
||||||
extern "C" void funregister(FILE* fp)
|
|
||||||
{
|
|
||||||
if ( !(fp->flags & _FILE_REGISTERED) )
|
|
||||||
return;
|
|
||||||
pthread_mutex_lock(&__first_file_lock);
|
|
||||||
if ( !fp->prev )
|
|
||||||
__first_file = fp->next;
|
|
||||||
if ( fp->prev )
|
|
||||||
fp->prev->next = fp->next;
|
|
||||||
if ( fp->next )
|
|
||||||
fp->next->prev = fp->prev;
|
|
||||||
fp->flags &= ~_FILE_REGISTERED;
|
|
||||||
pthread_mutex_unlock(&__first_file_lock);
|
|
||||||
}
|
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
/*******************************************************************************
|
/*******************************************************************************
|
||||||
|
|
||||||
Copyright(C) Jonas 'Sortie' Termansen 2011, 2014.
|
Copyright(C) Jonas 'Sortie' Termansen 2011, 2012, 2013, 2014.
|
||||||
|
|
||||||
This file is part of the Sortix C Library.
|
This file is part of the Sortix C Library.
|
||||||
|
|
||||||
|
@ -17,23 +17,25 @@
|
||||||
You should have received a copy of the GNU Lesser General Public License
|
You should have received a copy of the GNU Lesser General Public License
|
||||||
along with the Sortix C Library. If not, see <http://www.gnu.org/licenses/>.
|
along with the Sortix C Library. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
dirent/dcloseall.cpp
|
stdio/funregister.cpp
|
||||||
Closes all registered directory streams.
|
Unregisters a FILE in the global list of open FILEs.
|
||||||
|
|
||||||
*******************************************************************************/
|
*******************************************************************************/
|
||||||
|
|
||||||
#include <dirent.h>
|
#include <pthread.h>
|
||||||
#include <DIR.h>
|
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
|
|
||||||
extern "C" { DIR* __firstdir = NULL; }
|
extern "C" void funregister(FILE* fp)
|
||||||
|
|
||||||
extern "C" int dcloseall(void)
|
|
||||||
{
|
{
|
||||||
int result = 0;
|
if ( !(fp->flags & _FILE_REGISTERED) )
|
||||||
// We do not lock __firstdir_lock here because this function is called on
|
return;
|
||||||
// process termination and only one thread can call exit(3).
|
pthread_mutex_lock(&__first_file_lock);
|
||||||
while ( __firstdir )
|
if ( !fp->prev )
|
||||||
result |= closedir(__firstdir);
|
__first_file = fp->next;
|
||||||
return result ? EOF : 0;
|
if ( fp->prev )
|
||||||
|
fp->prev->next = fp->next;
|
||||||
|
if ( fp->next )
|
||||||
|
fp->next->prev = fp->prev;
|
||||||
|
fp->flags &= ~_FILE_REGISTERED;
|
||||||
|
pthread_mutex_unlock(&__first_file_lock);
|
||||||
}
|
}
|
|
@ -1,6 +1,6 @@
|
||||||
/*******************************************************************************
|
/*******************************************************************************
|
||||||
|
|
||||||
Copyright(C) Jonas 'Sortie' Termansen 2011, 2012.
|
Copyright(C) Jonas 'Sortie' Termansen 2011, 2012, 2014.
|
||||||
|
|
||||||
This file is part of the Sortix C Library.
|
This file is part of the Sortix C Library.
|
||||||
|
|
||||||
|
@ -23,6 +23,8 @@
|
||||||
*******************************************************************************/
|
*******************************************************************************/
|
||||||
|
|
||||||
#include <dirent.h>
|
#include <dirent.h>
|
||||||
|
#include <DIR.h>
|
||||||
|
#include <FILE.h>
|
||||||
#include <pthread.h>
|
#include <pthread.h>
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
|
@ -33,6 +35,11 @@ extern "C" { struct exit_handler* __exit_handler_stack = NULL; }
|
||||||
static pthread_mutex_t exit_lock = PTHREAD_RECURSIVE_MUTEX_INITIALIZER_NP;
|
static pthread_mutex_t exit_lock = PTHREAD_RECURSIVE_MUTEX_INITIALIZER_NP;
|
||||||
static bool currently_exiting = false;
|
static bool currently_exiting = false;
|
||||||
|
|
||||||
|
extern "C" { DIR* __first_dir = NULL; }
|
||||||
|
extern "C" { pthread_mutex_t __first_dir_lock = PTHREAD_RECURSIVE_MUTEX_INITIALIZER_NP; }
|
||||||
|
extern "C" { FILE* __first_file = NULL; }
|
||||||
|
extern "C" { pthread_mutex_t __first_file_lock = PTHREAD_RECURSIVE_MUTEX_INITIALIZER_NP; }
|
||||||
|
|
||||||
extern "C" void exit(int status)
|
extern "C" void exit(int status)
|
||||||
{
|
{
|
||||||
// It's undefined behavior to call this function more than once: If more
|
// It's undefined behavior to call this function more than once: If more
|
||||||
|
@ -51,7 +58,13 @@ extern "C" void exit(int status)
|
||||||
__exit_handler_stack = __exit_handler_stack->next;
|
__exit_handler_stack = __exit_handler_stack->next;
|
||||||
}
|
}
|
||||||
|
|
||||||
dcloseall();
|
pthread_mutex_lock(&__first_dir_lock);
|
||||||
fcloseall();
|
pthread_mutex_lock(&__first_file_lock);
|
||||||
|
|
||||||
|
while ( __first_dir )
|
||||||
|
closedir(__first_dir);
|
||||||
|
while ( __first_file )
|
||||||
|
fclose(__first_file);
|
||||||
|
|
||||||
_Exit(status);
|
_Exit(status);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue