2020-02-11 12:52:06 +00:00
|
|
|
/* Detecting file changes using modification times.
|
2023-01-06 21:08:04 +00:00
|
|
|
Copyright (C) 2017-2023 Free Software Foundation, Inc.
|
2020-02-11 12:52:06 +00:00
|
|
|
This file is part of the GNU C Library.
|
|
|
|
|
|
|
|
The GNU 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 2.1 of the License, or (at your option) any later version.
|
|
|
|
|
|
|
|
The GNU 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 GNU C Library; if not, see
|
|
|
|
<https://www.gnu.org/licenses/>. */
|
|
|
|
|
2020-02-18 12:44:48 +00:00
|
|
|
#ifndef _FILE_CHANGE_DETECTION_H
|
|
|
|
#define _FILE_CHANGE_DETECTION_H
|
|
|
|
|
2020-02-11 12:52:06 +00:00
|
|
|
#include <stdbool.h>
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <sys/stat.h>
|
|
|
|
#include <sys/types.h>
|
|
|
|
|
|
|
|
/* Items for identifying a particular file version. Excerpt from
|
|
|
|
struct stat64. */
|
|
|
|
struct file_change_detection
|
|
|
|
{
|
|
|
|
/* Special values: 0 if file does not exist. -1 to force mismatch
|
|
|
|
with the next comparison. */
|
|
|
|
off64_t size;
|
|
|
|
|
|
|
|
ino64_t ino;
|
2021-03-02 20:06:02 +00:00
|
|
|
struct __timespec64 mtime;
|
|
|
|
struct __timespec64 ctime;
|
2020-02-11 12:52:06 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
/* Returns true if *LEFT and *RIGHT describe the same version of the
|
|
|
|
same file. */
|
2020-02-18 12:44:48 +00:00
|
|
|
bool __file_is_unchanged (const struct file_change_detection *left,
|
|
|
|
const struct file_change_detection *right);
|
2020-02-11 12:52:06 +00:00
|
|
|
|
|
|
|
/* Extract file change information to *FILE from the stat buffer
|
|
|
|
*ST. */
|
2020-02-18 12:44:48 +00:00
|
|
|
void __file_change_detection_for_stat (struct file_change_detection *file,
|
2021-03-02 20:06:02 +00:00
|
|
|
const struct __stat64_t64 *st);
|
2020-02-11 12:52:06 +00:00
|
|
|
|
|
|
|
/* Writes file change information for PATH to *FILE. Returns true on
|
|
|
|
success. For benign errors, *FILE is cleared, and true is
|
|
|
|
returned. For errors indicating resource outages and the like,
|
|
|
|
false is returned. */
|
2020-02-18 12:44:48 +00:00
|
|
|
bool __file_change_detection_for_path (struct file_change_detection *file,
|
|
|
|
const char *path);
|
2020-02-11 12:52:06 +00:00
|
|
|
|
|
|
|
/* Writes file change information for the stream FP to *FILE. Returns
|
2023-05-20 13:37:47 +00:00
|
|
|
true on success, false on failure. If FP is NULL, treat the file
|
2020-02-11 12:52:06 +00:00
|
|
|
as non-existing. */
|
2020-02-18 12:44:48 +00:00
|
|
|
bool __file_change_detection_for_fp (struct file_change_detection *file,
|
|
|
|
FILE *fp);
|
|
|
|
|
|
|
|
#ifndef _ISOMAC
|
|
|
|
libc_hidden_proto (__file_is_unchanged)
|
|
|
|
libc_hidden_proto (__file_change_detection_for_stat)
|
|
|
|
libc_hidden_proto (__file_change_detection_for_path)
|
|
|
|
libc_hidden_proto (__file_change_detection_for_fp)
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif /* _FILE_CHANGE_DETECTION_H */
|