/* * Copyright (c) 1990 The Regents of the University of California. * All rights reserved. * * Redistribution and use in source and binary forms are permitted * provided that the above copyright notice and this paragraph are * duplicated in all such forms and that any documentation, * and/or other materials related to such * distribution and use acknowledge that the software was developed * by the University of California, Berkeley. The name of the * University may not be used to endorse or promote products derived * from this software without specific prior written permission. * THIS SOFTWARE IS PROVIDED ``AS IS'' AND WITHOUT ANY EXPRESS OR * IMPLIED WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. */ /* FUNCTION <>---close all files INDEX fcloseall INDEX _fcloseall_r SYNOPSIS #include int fcloseall(void); int _fcloseall_r (struct _reent *<[ptr]>); DESCRIPTION <> closes all files in the current reentrancy struct's domain. The function <<_fcloseall_r>> is the same function, except the reentrancy struct is passed in as the <[ptr]> argument. This function is not recommended as it closes all streams, including the std streams. RETURNS <> returns <<0>> if all closes are successful. Otherwise, EOF is returned. PORTABILITY <> is a glibc extension. Required OS subroutines: <>, <>, <>, <>, <>, <>, <>. */ /* This file based upon fwalk.c. */ #include <_ansi.h> #include #include #include #include #include "local.h" int _fcloseall_r (struct _reent *ptr) { #ifdef _REENT_GLOBAL_STDIO_STREAMS /* There are no thread-specific FILE objects */ return 0; #else return _fwalk_sglue (ptr, _fclose_r, &ptr->__sglue); #endif } #ifndef _REENT_ONLY int fcloseall (void) { return _fwalk_sglue (_GLOBAL_REENT, _fclose_r, &__sglue); } #endif