5 #include "write-or-die.h"
9 /* A SHA1-protected file */
21 unsigned char *buffer
;
22 unsigned char *check_buffer
;
25 * If non-zero, skip_hash indicates that we should
26 * not actually compute the hash for this hashfile and
27 * instead only use it as a buffered write.
33 struct hashfile_checkpoint
{
38 void hashfile_checkpoint(struct hashfile
*, struct hashfile_checkpoint
*);
39 int hashfile_truncate(struct hashfile
*, struct hashfile_checkpoint
*);
41 /* finalize_hashfile flags */
44 #define CSUM_HASH_IN_STREAM 4
46 struct hashfile
*hashfd(int fd
, const char *name
);
47 struct hashfile
*hashfd_check(const char *name
);
48 struct hashfile
*hashfd_throughput(int fd
, const char *name
, struct progress
*tp
);
51 * Free the hashfile without flushing its contents to disk. This only
52 * needs to be called when not calling `finalize_hashfile()`.
54 void free_hashfile(struct hashfile
*f
);
57 * Finalize the hashfile by flushing data to disk and free'ing it.
59 int finalize_hashfile(struct hashfile
*, unsigned char *, enum fsync_component
, unsigned int);
60 void discard_hashfile(struct hashfile
*);
61 void hashwrite(struct hashfile
*, const void *, unsigned int);
62 void hashflush(struct hashfile
*f
);
63 void crc32_begin(struct hashfile
*);
64 uint32_t crc32_end(struct hashfile
*);
66 /* Verify checksum validity while reading. Returns non-zero on success. */
67 int hashfile_checksum_valid(const unsigned char *data
, size_t len
);
70 * Returns the total number of bytes fed to the hashfile so far (including ones
71 * that have not been written out to the descriptor yet).
73 static inline off_t
hashfile_total(struct hashfile
*f
)
75 return f
->total
+ f
->offset
;
78 static inline void hashwrite_u8(struct hashfile
*f
, uint8_t data
)
80 hashwrite(f
, &data
, sizeof(data
));
83 static inline void hashwrite_be32(struct hashfile
*f
, uint32_t data
)
86 hashwrite(f
, &data
, sizeof(data
));
89 static inline size_t hashwrite_be64(struct hashfile
*f
, uint64_t data
)
92 hashwrite(f
, &data
, sizeof(data
));