Also known as ISC bind. This import adds utilities such as host(1), dig(1), and nslookup(1), as well as many other tools and libraries. Change-Id: I035ca46e64f1965d57019e773f4ff0ef035e4aa3
373 lines
11 KiB
C
373 lines
11 KiB
C
/* $NetBSD: file.h,v 1.9 2014/12/10 04:38:00 christos Exp $ */
|
|
|
|
/*
|
|
* Copyright (C) 2004-2007, 2009, 2011, 2012, 2014 Internet Systems Consortium, Inc. ("ISC")
|
|
* Copyright (C) 2000, 2001 Internet Software Consortium.
|
|
*
|
|
* Permission to use, copy, modify, and/or distribute this software for any
|
|
* purpose with or without fee is hereby granted, provided that the above
|
|
* copyright notice and this permission notice appear in all copies.
|
|
*
|
|
* THE SOFTWARE IS PROVIDED "AS IS" AND ISC DISCLAIMS ALL WARRANTIES WITH
|
|
* REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
|
|
* AND FITNESS. IN NO EVENT SHALL ISC BE LIABLE FOR ANY SPECIAL, DIRECT,
|
|
* INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
|
|
* LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE
|
|
* OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
|
|
* PERFORMANCE OF THIS SOFTWARE.
|
|
*/
|
|
|
|
/* Id */
|
|
|
|
#ifndef ISC_FILE_H
|
|
#define ISC_FILE_H 1
|
|
|
|
/*! \file isc/file.h */
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <isc/lang.h>
|
|
#include <isc/stat.h>
|
|
#include <isc/types.h>
|
|
|
|
ISC_LANG_BEGINDECLS
|
|
|
|
isc_result_t
|
|
isc_file_settime(const char *file, isc_time_t *time);
|
|
|
|
isc_result_t
|
|
isc_file_mode(const char *file, mode_t *modep);
|
|
|
|
isc_result_t
|
|
isc_file_getmodtime(const char *file, isc_time_t *time);
|
|
/*!<
|
|
* \brief Get the time of last modification of a file.
|
|
*
|
|
* Notes:
|
|
*\li The time that is set is relative to the (OS-specific) epoch, as are
|
|
* all isc_time_t structures.
|
|
*
|
|
* Requires:
|
|
*\li file != NULL.
|
|
*\li time != NULL.
|
|
*
|
|
* Ensures:
|
|
*\li If the file could not be accessed, 'time' is unchanged.
|
|
*
|
|
* Returns:
|
|
*\li #ISC_R_SUCCESS
|
|
* Success.
|
|
*\li #ISC_R_NOTFOUND
|
|
* No such file exists.
|
|
*\li #ISC_R_INVALIDFILE
|
|
* The path specified was not usable by the operating system.
|
|
*\li #ISC_R_NOPERM
|
|
* The file's metainformation could not be retrieved because
|
|
* permission was denied to some part of the file's path.
|
|
*\li #ISC_R_IOERROR
|
|
* Hardware error interacting with the filesystem.
|
|
*\li #ISC_R_UNEXPECTED
|
|
* Something totally unexpected happened.
|
|
*
|
|
*/
|
|
|
|
isc_result_t
|
|
isc_file_mktemplate(const char *path, char *buf, size_t buflen);
|
|
/*!<
|
|
* \brief Generate a template string suitable for use with isc_file_openunique().
|
|
*
|
|
* Notes:
|
|
*\li This function is intended to make creating temporary files
|
|
* portable between different operating systems.
|
|
*
|
|
*\li The path is prepended to an implementation-defined string and
|
|
* placed into buf. The string has no path characters in it,
|
|
* and its maximum length is 14 characters plus a NUL. Thus
|
|
* buflen should be at least strlen(path) + 15 characters or
|
|
* an error will be returned.
|
|
*
|
|
* Requires:
|
|
*\li buf != NULL.
|
|
*
|
|
* Ensures:
|
|
*\li If result == #ISC_R_SUCCESS:
|
|
* buf contains a string suitable for use as the template argument
|
|
* to isc_file_openunique().
|
|
*
|
|
*\li If result != #ISC_R_SUCCESS:
|
|
* buf is unchanged.
|
|
*
|
|
* Returns:
|
|
*\li #ISC_R_SUCCESS Success.
|
|
*\li #ISC_R_NOSPACE buflen indicates buf is too small for the catenation
|
|
* of the path with the internal template string.
|
|
*/
|
|
|
|
isc_result_t
|
|
isc_file_openunique(char *templet, FILE **fp);
|
|
isc_result_t
|
|
isc_file_openuniqueprivate(char *templet, FILE **fp);
|
|
isc_result_t
|
|
isc_file_openuniquemode(char *templet, int mode, FILE **fp);
|
|
isc_result_t
|
|
isc_file_bopenunique(char *templet, FILE **fp);
|
|
isc_result_t
|
|
isc_file_bopenuniqueprivate(char *templet, FILE **fp);
|
|
isc_result_t
|
|
isc_file_bopenuniquemode(char *templet, int mode, FILE **fp);
|
|
/*!<
|
|
* \brief Create and open a file with a unique name based on 'templet'.
|
|
* isc_file_bopen*() open the file in binary mode in Windows.
|
|
* isc_file_open*() open the file in text mode in Windows.
|
|
*
|
|
* Notes:
|
|
*\li 'template' is a reserved work in C++. If you want to complain
|
|
* about the spelling of 'templet', first look it up in the
|
|
* Merriam-Webster English dictionary. (http://www.m-w.com/)
|
|
*
|
|
*\li This function works by using the template to generate file names.
|
|
* The template must be a writable string, as it is modified in place.
|
|
* Trailing X characters in the file name (full file name on Unix,
|
|
* basename on Win32 -- eg, tmp-XXXXXX vs XXXXXX.tmp, respectively)
|
|
* are replaced with ASCII characters until a non-existent filename
|
|
* is found. If the template does not include pathname information,
|
|
* the files in the working directory of the program are searched.
|
|
*
|
|
*\li isc_file_mktemplate is a good, portable way to get a template.
|
|
*
|
|
* Requires:
|
|
*\li 'fp' is non-NULL and '*fp' is NULL.
|
|
*
|
|
*\li 'template' is non-NULL, and of a form suitable for use by
|
|
* the system as described above.
|
|
*
|
|
* Ensures:
|
|
*\li If result is #ISC_R_SUCCESS:
|
|
* *fp points to an stream opening in stdio's "w+" mode.
|
|
*
|
|
*\li If result is not #ISC_R_SUCCESS:
|
|
* *fp is NULL.
|
|
*
|
|
* No file is open. Even if one was created (but unable
|
|
* to be reopened as a stdio FILE pointer) then it has been
|
|
* removed.
|
|
*
|
|
*\li This function does *not* ensure that the template string has not been
|
|
* modified, even if the operation was unsuccessful.
|
|
*
|
|
* Returns:
|
|
*\li #ISC_R_SUCCESS
|
|
* Success.
|
|
*\li #ISC_R_EXISTS
|
|
* No file with a unique name could be created based on the
|
|
* template.
|
|
*\li #ISC_R_INVALIDFILE
|
|
* The path specified was not usable by the operating system.
|
|
*\li #ISC_R_NOPERM
|
|
* The file could not be created because permission was denied
|
|
* to some part of the file's path.
|
|
*\li #ISC_R_IOERROR
|
|
* Hardware error interacting with the filesystem.
|
|
*\li #ISC_R_UNEXPECTED
|
|
* Something totally unexpected happened.
|
|
*/
|
|
|
|
isc_result_t
|
|
isc_file_remove(const char *filename);
|
|
/*!<
|
|
* \brief Remove the file named by 'filename'.
|
|
*/
|
|
|
|
isc_result_t
|
|
isc_file_rename(const char *oldname, const char *newname);
|
|
/*!<
|
|
* \brief Rename the file 'oldname' to 'newname'.
|
|
*/
|
|
|
|
isc_boolean_t
|
|
isc_file_exists(const char *pathname);
|
|
/*!<
|
|
* \brief Return #ISC_TRUE if 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
|
|
isc_file_isabsolute(const char *filename);
|
|
/*!<
|
|
* \brief Return #ISC_TRUE if the given file name is absolute.
|
|
*/
|
|
|
|
isc_result_t
|
|
isc_file_isplainfile(const char *name);
|
|
|
|
isc_result_t
|
|
isc_file_isplainfilefd(int fd);
|
|
/*!<
|
|
* \brief Check that the file is a plain file
|
|
*
|
|
* Returns:
|
|
*\li #ISC_R_SUCCESS
|
|
* Success. The file is a plain file.
|
|
*\li #ISC_R_INVALIDFILE
|
|
* The path specified was not usable by the operating system.
|
|
*\li #ISC_R_FILENOTFOUND
|
|
* The file does not exist. This return code comes from
|
|
* errno=ENOENT when stat returns -1. This code is mentioned
|
|
* here, because in logconf.c, it is the one rcode that is
|
|
* permitted in addition to ISC_R_SUCCESS. This is done since
|
|
* the next call in logconf.c is to isc_stdio_open(), which
|
|
* will create the file if it can.
|
|
*\li other ISC_R_* errors translated from errno
|
|
* These occur when stat returns -1 and an errno.
|
|
*/
|
|
|
|
isc_result_t
|
|
isc_file_isdirectory(const char *name);
|
|
/*!<
|
|
* \brief Check that 'name' exists and is a directory.
|
|
*
|
|
* Returns:
|
|
*\li #ISC_R_SUCCESS
|
|
* Success, file is a directory.
|
|
*\li #ISC_R_INVALIDFILE
|
|
* File is not a directory.
|
|
*\li #ISC_R_FILENOTFOUND
|
|
* File does not exist.
|
|
*\li other ISC_R_* errors translated from errno
|
|
* These occur when stat returns -1 and an errno.
|
|
*/
|
|
|
|
isc_boolean_t
|
|
isc_file_iscurrentdir(const char *filename);
|
|
/*!<
|
|
* \brief Return #ISC_TRUE if the given file name is the current directory (".").
|
|
*/
|
|
|
|
isc_boolean_t
|
|
isc_file_ischdiridempotent(const char *filename);
|
|
/*%<
|
|
* Return #ISC_TRUE if calling chdir(filename) multiple times will give
|
|
* the same result as calling it once.
|
|
*/
|
|
|
|
const char *
|
|
isc_file_basename(const char *filename);
|
|
/*%<
|
|
* Return the final component of the path in the file name.
|
|
*/
|
|
|
|
isc_result_t
|
|
isc_file_progname(const char *filename, char *buf, size_t buflen);
|
|
/*!<
|
|
* \brief Given an operating system specific file name "filename"
|
|
* referring to a program, return the canonical program name.
|
|
*
|
|
*
|
|
* Any directory prefix or executable file name extension (if
|
|
* used on the OS in case) is stripped. On systems where program
|
|
* names are case insensitive, the name is canonicalized to all
|
|
* lower case. The name is written to 'buf', an array of 'buflen'
|
|
* chars, and null terminated.
|
|
*
|
|
* Returns:
|
|
*\li #ISC_R_SUCCESS
|
|
*\li #ISC_R_NOSPACE The name did not fit in 'buf'.
|
|
*/
|
|
|
|
isc_result_t
|
|
isc_file_template(const char *path, const char *templet, char *buf,
|
|
size_t buflen);
|
|
/*%<
|
|
* Create an OS specific template using 'path' to define the directory
|
|
* 'templet' to describe the filename and store the result in 'buf'
|
|
* such that path can be renamed to buf atomically.
|
|
*/
|
|
|
|
isc_result_t
|
|
isc_file_renameunique(const char *file, char *templet);
|
|
/*%<
|
|
* Rename 'file' using 'templet' as a template for the new file name.
|
|
*/
|
|
|
|
isc_result_t
|
|
isc_file_absolutepath(const char *filename, char *path, size_t pathlen);
|
|
/*%<
|
|
* Given a file name, return the fully qualified path to the file.
|
|
*/
|
|
|
|
/*
|
|
* XXX We should also have a isc_file_writeeopen() function
|
|
* for safely open a file in a publicly writable directory
|
|
* (see write_open() in BIND 8's ns_config.c).
|
|
*/
|
|
|
|
isc_result_t
|
|
isc_file_truncate(const char *filename, isc_offset_t size);
|
|
/*%<
|
|
* Truncate/extend the file specified to 'size' bytes.
|
|
*/
|
|
|
|
isc_result_t
|
|
isc_file_safecreate(const char *filename, FILE **fp);
|
|
/*%<
|
|
* Open 'filename' for writing, truncating if necessary. Ensure that
|
|
* if it existed it was a normal file. If creating the file, ensure
|
|
* that only the owner can read/write it.
|
|
*/
|
|
|
|
isc_result_t
|
|
isc_file_splitpath(isc_mem_t *mctx, char *path,
|
|
char **dirname, char **basename);
|
|
/*%<
|
|
* Split a path into dirname and basename. If 'path' contains no slash
|
|
* (or, on windows, backslash), then '*dirname' is set to ".".
|
|
*
|
|
* Allocates memory for '*dirname', which can be freed with isc_mem_free().
|
|
*
|
|
* Returns:
|
|
* - ISC_R_SUCCESS on success
|
|
* - ISC_R_INVALIDFILE if 'path' is empty or ends with '/'
|
|
* - ISC_R_NOMEMORY if unable to allocate memory
|
|
*/
|
|
|
|
isc_result_t
|
|
isc_file_getsize(const char *file, off_t *size);
|
|
/*%<
|
|
* Return the size of the file (stored in the parameter pointed
|
|
* to by 'size') in bytes.
|
|
*
|
|
* Returns:
|
|
* - ISC_R_SUCCESS on success
|
|
*/
|
|
|
|
isc_result_t
|
|
isc_file_getsizefd(int fd, off_t *size);
|
|
/*%<
|
|
* Return the size of the file (stored in the parameter pointed
|
|
* to by 'size') in bytes.
|
|
*
|
|
* Returns:
|
|
* - ISC_R_SUCCESS on success
|
|
*/
|
|
|
|
void *
|
|
isc_file_mmap(void *addr, size_t len, int prot,
|
|
int flags, int fd, off_t offset);
|
|
/*%<
|
|
* Portable front-end to mmap(). If mmap() is not defined on this
|
|
* platform, then we simulate it by calling malloc() and read().
|
|
* (In this event, the addr, prot, and flags parameters are ignored).
|
|
*/
|
|
|
|
int
|
|
isc_file_munmap(void *addr, size_t len);
|
|
/*%<
|
|
* Portable front-end to munmap(). If munmap() is not defined on
|
|
* this platform, then we simply free the memory.
|
|
*/
|
|
|
|
ISC_LANG_ENDDECLS
|
|
|
|
#endif /* ISC_FILE_H */
|