79 lines
2.4 KiB
C
79 lines
2.4 KiB
C
#ifndef WRITE_OR_DIE_H
|
|
#define WRITE_OR_DIE_H
|
|
|
|
void maybe_flush_or_die(FILE *, const char *);
|
|
__attribute__((format (printf, 2, 3)))
|
|
void fprintf_or_die(FILE *, const char *fmt, ...);
|
|
void fwrite_or_die(FILE *f, const void *buf, size_t count);
|
|
void fflush_or_die(FILE *f);
|
|
void write_or_die(int fd, const void *buf, size_t count);
|
|
|
|
/*
|
|
* These values are used to help identify parts of a repository to fsync.
|
|
* FSYNC_COMPONENT_NONE identifies data that will not be a persistent part of the
|
|
* repository and so shouldn't be fsynced.
|
|
*/
|
|
enum fsync_component {
|
|
FSYNC_COMPONENT_NONE,
|
|
FSYNC_COMPONENT_LOOSE_OBJECT = 1 << 0,
|
|
FSYNC_COMPONENT_PACK = 1 << 1,
|
|
FSYNC_COMPONENT_PACK_METADATA = 1 << 2,
|
|
FSYNC_COMPONENT_COMMIT_GRAPH = 1 << 3,
|
|
FSYNC_COMPONENT_INDEX = 1 << 4,
|
|
FSYNC_COMPONENT_REFERENCE = 1 << 5,
|
|
};
|
|
|
|
#define FSYNC_COMPONENTS_OBJECTS (FSYNC_COMPONENT_LOOSE_OBJECT | \
|
|
FSYNC_COMPONENT_PACK)
|
|
|
|
#define FSYNC_COMPONENTS_DERIVED_METADATA (FSYNC_COMPONENT_PACK_METADATA | \
|
|
FSYNC_COMPONENT_COMMIT_GRAPH)
|
|
|
|
#define FSYNC_COMPONENTS_DEFAULT ((FSYNC_COMPONENTS_OBJECTS | \
|
|
FSYNC_COMPONENTS_DERIVED_METADATA) & \
|
|
~FSYNC_COMPONENT_LOOSE_OBJECT)
|
|
|
|
#define FSYNC_COMPONENTS_COMMITTED (FSYNC_COMPONENTS_OBJECTS | \
|
|
FSYNC_COMPONENT_REFERENCE)
|
|
|
|
#define FSYNC_COMPONENTS_ADDED (FSYNC_COMPONENTS_COMMITTED | \
|
|
FSYNC_COMPONENT_INDEX)
|
|
|
|
#define FSYNC_COMPONENTS_ALL (FSYNC_COMPONENT_LOOSE_OBJECT | \
|
|
FSYNC_COMPONENT_PACK | \
|
|
FSYNC_COMPONENT_PACK_METADATA | \
|
|
FSYNC_COMPONENT_COMMIT_GRAPH | \
|
|
FSYNC_COMPONENT_INDEX | \
|
|
FSYNC_COMPONENT_REFERENCE)
|
|
|
|
#ifndef FSYNC_COMPONENTS_PLATFORM_DEFAULT
|
|
#define FSYNC_COMPONENTS_PLATFORM_DEFAULT FSYNC_COMPONENTS_DEFAULT
|
|
#endif
|
|
|
|
/* IO helper functions */
|
|
void fsync_or_die(int fd, const char *);
|
|
int fsync_component(enum fsync_component component, int fd);
|
|
void fsync_component_or_die(enum fsync_component component, int fd, const char *msg);
|
|
|
|
/*
|
|
* A bitmask indicating which components of the repo should be fsynced.
|
|
*/
|
|
extern enum fsync_component fsync_components;
|
|
extern int fsync_object_files;
|
|
extern int use_fsync;
|
|
|
|
enum fsync_method {
|
|
FSYNC_METHOD_FSYNC,
|
|
FSYNC_METHOD_WRITEOUT_ONLY,
|
|
FSYNC_METHOD_BATCH,
|
|
};
|
|
|
|
extern enum fsync_method fsync_method;
|
|
|
|
static inline int batch_fsync_enabled(enum fsync_component component)
|
|
{
|
|
return (fsync_components & component) && (fsync_method == FSYNC_METHOD_BATCH);
|
|
}
|
|
|
|
#endif /* WRITE_OR_DIE_H */
|