* WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
*/
-/* $Id: rndc.c,v 1.62 2001/05/31 10:42:49 tale Exp $ */
+/* $Id: rndc.c,v 1.63 2001/06/08 21:53:47 tale Exp $ */
/*
* Principal Author: DCL
isc_result_t result;
const char *conffile = admin_conffile;
- if (! isc_file_test(conffile, ISC_FILE_EXISTS)) {
+ if (! isc_file_exists(conffile)) {
conffile = auto_conffile;
- if (! isc_file_test(conffile, ISC_FILE_EXISTS))
+ if (! isc_file_exists(conffile))
fatal("neither %s nor %s was found",
admin_conffile, auto_conffile);
}
* WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
*/
-/* $Id: file.h,v 1.19 2001/05/31 10:53:13 tale Exp $ */
+/* $Id: file.h,v 1.20 2001/06/08 21:53:48 tale Exp $ */
#ifndef ISC_FILE_H
#define ISC_FILE_H 1
#include <isc/lang.h>
#include <isc/types.h>
-/*
- * Definitions for the isc_file_test() 'what' argument.
- *
- * Notes:
- * ISC_FILE_EXISTS tests for existence, but not type. It can fail
- * if the user does not have sufficient permissions to explore the
- * full path of the file.
- *
- * ISC_FILE_ABSOLUTE tests for pathnames that start from the root
- * of a filesystem hierarchy.
- *
- * ISC_FILE_CURRENTDIR is an extremely simplistic test. On Unix systems,
- * it only returns true if the pathname is ".". It will return false
- * for "subdir/..", for example.
- *
- * Unimplemented, perhaps desirable:
- * ISC_FILE_REGULAR
- * ISC_FILE_DIRECTORY
- * ISC_FILE_SYMLINK
- * ISC_FILE_SPECIAL
- * ISC_FILE_BLOCK ?
- * ISC_FILE_CHARACTER ?
- * ISC_FILE_PIPE ?
- * ISC_FILE_SOCKET ?
- * ISC_FILE_READABLE
- * ISC_FILE_WRITABLE
- * ISC_FILE_RUNABLE
- * ISC_FILE_EMPTY
- */
-#define ISC_FILE_EXISTS 0x00000001
-#define ISC_FILE_ABSOLUTE 0x00000002
-#define ISC_FILE_CURRENTDIR 0x00000004
-
ISC_LANG_BEGINDECLS
isc_result_t
*/
isc_boolean_t
-isc_file_test(const char *filename, isc_uint32_t what);
+isc_file_exists(const char *pathname);
/*
- * Test for various file attributes, such as existence or writability.
- *
- * Notes:
- * This is like the Unix shell test(1) command.
- *
- * If more than one test is specified in 'what' then ALL
- * of them must be true for ISC_TRUE to be returned.
- * To test instead for traits that can be independently true,
- * use multiple calls to isc_file_test().
- *
- * Functionality is being added only as it is needed. See the list
- * at the start of the file for which tests have been implemented.
- *
- * It is intended that this function will supersede both
- * isc_file_isabsolute() and isc_file_iscurrentdir().
+ * Return ISC_TRUE iff the calling process can tell that the given file exists.
+ * Will not return true if the calling process has insufficient privileges
+ * to search the entire path.
*/
isc_boolean_t
* WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
*/
-/* $Id: file.c,v 1.34 2001/05/31 10:53:14 tale Exp $ */
+/* $Id: file.c,v 1.35 2001/06/08 21:53:49 tale Exp $ */
#include <config.h>
}
isc_boolean_t
-isc_file_test(const char *pathname, isc_uint32_t what) {
- isc_boolean_t tf = ISC_TRUE;
- isc_result_t result;
+isc_file_exists(const char *pathname) {
struct stat stats;
- INSIST(what != 0);
- INSIST((what & ~(ISC_FILE_EXISTS |
- ISC_FILE_ABSOLUTE |
- ISC_FILE_CURRENTDIR))
- == 0);
-
- if ((what & ISC_FILE_EXISTS) != 0) {
- /*
- * When file type tests are implemented, only one
- * file_stats() should be done.
- */
- result = file_stats(pathname, &stats);
- tf = ISC_TF(tf && result == ISC_R_SUCCESS);
- }
-
- if ((what & ISC_FILE_ABSOLUTE) != 0)
- tf = ISC_TF(tf && pathname[0] == '/');
-
- if ((what & ISC_FILE_CURRENTDIR) != 0)
- tf = ISC_TF(tf && pathname[0] == '.' && pathname[1] == '\0');
-
- return (tf);
+ return (ISC_TF(file_stats(pathname, &stats) == ISC_R_SUCCESS));
}
isc_boolean_t