2000-05-11 16:14:05 +00:00
|
|
|
/*
|
2012-02-29 23:47:21 +00:00
|
|
|
* Copyright (C) Internet Systems Consortium, Inc. ("ISC")
|
2000-05-11 16:14:05 +00:00
|
|
|
*
|
|
|
|
* SPDX-License-Identifier: MPL-2.0
|
2021-06-03 08:37:05 +02:00
|
|
|
*
|
2000-05-11 16:14:05 +00:00
|
|
|
* This Source Code Form is subject to the terms of the Mozilla Public
|
|
|
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
|
|
* file, you can obtain one at https://mozilla.org/MPL/2.0/.
|
2018-02-23 09:53:12 +01:00
|
|
|
*
|
2000-05-11 16:14:05 +00:00
|
|
|
* See the COPYRIGHT file distributed with this work for additional
|
|
|
|
* information regarding copyright ownership.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <errno.h>
|
2022-12-16 11:59:48 +00:00
|
|
|
#include <sys/stat.h>
|
2000-05-11 16:14:05 +00:00
|
|
|
#include <unistd.h>
|
|
|
|
|
|
|
|
#include <isc/stdio.h>
|
2013-06-17 09:09:43 -07:00
|
|
|
#include <isc/util.h>
|
2000-05-11 16:14:05 +00:00
|
|
|
|
|
|
|
#include "errno2result.h"
|
|
|
|
|
|
|
|
isc_result_t
|
|
|
|
isc_stdio_open(const char *filename, const char *mode, FILE **fp) {
|
|
|
|
FILE *f;
|
2000-08-01 01:33:37 +00:00
|
|
|
|
2000-05-11 16:14:05 +00:00
|
|
|
f = fopen(filename, mode);
|
|
|
|
if (f == NULL) {
|
|
|
|
return (isc__errno2result(errno));
|
2020-02-13 21:48:23 +01:00
|
|
|
}
|
2000-05-11 16:14:05 +00:00
|
|
|
*fp = f;
|
|
|
|
return (ISC_R_SUCCESS);
|
|
|
|
}
|
|
|
|
|
|
|
|
isc_result_t
|
|
|
|
isc_stdio_close(FILE *f) {
|
|
|
|
int r;
|
|
|
|
|
|
|
|
r = fclose(f);
|
|
|
|
if (r == 0) {
|
|
|
|
return (ISC_R_SUCCESS);
|
|
|
|
} else {
|
|
|
|
return (isc__errno2result(errno));
|
2020-02-13 21:48:23 +01:00
|
|
|
}
|
2000-05-11 16:14:05 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
isc_result_t
|
2013-06-17 09:09:43 -07:00
|
|
|
isc_stdio_seek(FILE *f, off_t offset, int whence) {
|
2000-05-11 16:14:05 +00:00
|
|
|
int r;
|
|
|
|
|
2013-06-17 09:09:43 -07:00
|
|
|
r = fseeko(f, offset, whence);
|
2000-05-11 16:14:05 +00:00
|
|
|
if (r == 0) {
|
|
|
|
return (ISC_R_SUCCESS);
|
|
|
|
} else {
|
|
|
|
return (isc__errno2result(errno));
|
2020-02-13 21:48:23 +01:00
|
|
|
}
|
2000-05-11 16:14:05 +00:00
|
|
|
}
|
|
|
|
|
2013-06-17 09:09:43 -07:00
|
|
|
isc_result_t
|
|
|
|
isc_stdio_tell(FILE *f, off_t *offsetp) {
|
|
|
|
off_t r;
|
|
|
|
|
|
|
|
REQUIRE(offsetp != NULL);
|
|
|
|
|
|
|
|
r = ftello(f);
|
|
|
|
if (r >= 0) {
|
|
|
|
*offsetp = r;
|
|
|
|
return (ISC_R_SUCCESS);
|
|
|
|
} else {
|
|
|
|
return (isc__errno2result(errno));
|
2020-02-13 21:48:23 +01:00
|
|
|
}
|
2013-06-17 09:09:43 -07:00
|
|
|
}
|
|
|
|
|
2000-05-11 16:14:05 +00:00
|
|
|
isc_result_t
|
|
|
|
isc_stdio_read(void *ptr, size_t size, size_t nmemb, FILE *f, size_t *nret) {
|
|
|
|
isc_result_t result = ISC_R_SUCCESS;
|
|
|
|
size_t r;
|
2000-08-01 01:33:37 +00:00
|
|
|
|
2000-05-11 16:14:05 +00:00
|
|
|
clearerr(f);
|
|
|
|
r = fread(ptr, size, nmemb, f);
|
|
|
|
if (r != nmemb) {
|
|
|
|
if (feof(f)) {
|
|
|
|
result = ISC_R_EOF;
|
|
|
|
} else {
|
|
|
|
result = isc__errno2result(errno);
|
2020-02-13 21:48:23 +01:00
|
|
|
}
|
2000-05-11 16:14:05 +00:00
|
|
|
}
|
2023-04-06 16:32:16 +01:00
|
|
|
SET_IF_NOT_NULL(nret, r);
|
2000-05-11 16:14:05 +00:00
|
|
|
return (result);
|
|
|
|
}
|
|
|
|
|
|
|
|
isc_result_t
|
|
|
|
isc_stdio_write(const void *ptr, size_t size, size_t nmemb, FILE *f,
|
|
|
|
size_t *nret) {
|
|
|
|
isc_result_t result = ISC_R_SUCCESS;
|
|
|
|
size_t r;
|
2000-08-01 01:33:37 +00:00
|
|
|
|
2000-05-11 16:14:05 +00:00
|
|
|
clearerr(f);
|
|
|
|
r = fwrite(ptr, size, nmemb, f);
|
|
|
|
if (r != nmemb) {
|
|
|
|
result = isc__errno2result(errno);
|
2020-02-13 21:48:23 +01:00
|
|
|
}
|
2023-04-06 16:32:16 +01:00
|
|
|
SET_IF_NOT_NULL(nret, r);
|
2000-05-11 16:14:05 +00:00
|
|
|
return (result);
|
|
|
|
}
|
|
|
|
|
|
|
|
isc_result_t
|
|
|
|
isc_stdio_flush(FILE *f) {
|
|
|
|
int r;
|
2000-08-01 01:33:37 +00:00
|
|
|
|
2000-05-11 16:14:05 +00:00
|
|
|
r = fflush(f);
|
|
|
|
if (r == 0) {
|
|
|
|
return (ISC_R_SUCCESS);
|
|
|
|
} else {
|
|
|
|
return (isc__errno2result(errno));
|
2020-02-13 21:48:23 +01:00
|
|
|
}
|
2000-05-11 16:14:05 +00:00
|
|
|
}
|
|
|
|
|
2012-02-29 21:28:17 +00:00
|
|
|
/*
|
|
|
|
* OpenBSD has deprecated ENOTSUP in favor of EOPNOTSUPP.
|
|
|
|
*/
|
|
|
|
#if defined(EOPNOTSUPP) && !defined(ENOTSUP)
|
|
|
|
#define ENOTSUP EOPNOTSUPP
|
|
|
|
#endif /* if defined(EOPNOTSUPP) && !defined(ENOTSUP) */
|
|
|
|
|
2000-05-11 16:14:05 +00:00
|
|
|
isc_result_t
|
|
|
|
isc_stdio_sync(FILE *f) {
|
2016-10-05 12:20:02 +11:00
|
|
|
struct stat buf;
|
2000-05-11 16:14:05 +00:00
|
|
|
int r;
|
2000-08-01 01:33:37 +00:00
|
|
|
|
2016-10-05 12:20:02 +11:00
|
|
|
if (fstat(fileno(f), &buf) != 0) {
|
|
|
|
return (isc__errno2result(errno));
|
2020-02-13 21:48:23 +01:00
|
|
|
}
|
2016-10-05 23:45:39 +00:00
|
|
|
|
2011-12-22 08:49:01 +00:00
|
|
|
/*
|
2016-10-05 12:20:02 +11:00
|
|
|
* Only call fsync() on regular files.
|
2011-12-22 08:49:01 +00:00
|
|
|
*/
|
2016-10-05 12:20:02 +11:00
|
|
|
if ((buf.st_mode & S_IFMT) != S_IFREG) {
|
|
|
|
return (ISC_R_SUCCESS);
|
2020-02-13 21:48:23 +01:00
|
|
|
}
|
2016-10-05 12:20:02 +11:00
|
|
|
|
|
|
|
r = fsync(fileno(f));
|
|
|
|
if (r == 0) {
|
2000-05-11 16:14:05 +00:00
|
|
|
return (ISC_R_SUCCESS);
|
|
|
|
} else {
|
|
|
|
return (isc__errno2result(errno));
|
2020-02-13 21:48:23 +01:00
|
|
|
}
|
2000-05-11 16:14:05 +00:00
|
|
|
}
|