Skip to content
Snippets Groups Projects
Select Git revision
  • 0e2d57fd50f61e668be3180bc8f25991ea88aa8c
  • passt default
  • master
  • pu
  • todo
  • next
  • maint
  • v2.8.0-rc1
  • v2.8.0-rc0
  • v2.7.2
  • v2.7.1
  • v2.7.0
  • v2.6.5
  • v2.7.0-rc3
  • v2.7.0-rc2
  • v2.7.0-rc1
  • v2.7.0-rc0
  • v2.6.4
  • v2.6.3
  • v2.6.2
  • v2.6.1
  • v2.3.10
  • v2.5.4
  • v2.4.10
  • v2.6.0
  • v2.6.0-rc3
  • v2.5.3
27 results

csum-file.h

Blame
  • user avatar
    Junio C Hamano authored
    It is useful to be able to rewind a check-summed file to a certain
    previous state after writing data into it using sha1write() API. The
    fast-import command does this after streaming a blob data to the packfile
    being generated and then noticing that the same blob has already been
    written, and it does this with a private code truncate_pack() that is
    commented as "Yes, this is a layering violation".
    
    Introduce two API functions, sha1file_checkpoint(), that allows the caller
    to save a state of a sha1file, and then later revert it to the saved state.
    Use it to reimplement truncate_pack().
    
    Signed-off-by: default avatarJunio C Hamano <gitster@pobox.com>
    6c526148
    History
    csum-file.h 1.05 KiB
    #ifndef CSUM_FILE_H
    #define CSUM_FILE_H
    
    struct progress;
    
    /* A SHA1-protected file */
    struct sha1file {
    	int fd;
    	int check_fd;
    	unsigned int offset;
    	git_SHA_CTX ctx;
    	off_t total;
    	struct progress *tp;
    	const char *name;
    	int do_crc;
    	uint32_t crc32;
    	unsigned char buffer[8192];
    };
    
    /* Checkpoint */
    struct sha1file_checkpoint {
    	off_t offset;
    	git_SHA_CTX ctx;
    };
    
    extern void sha1file_checkpoint(struct sha1file *, struct sha1file_checkpoint *);
    extern int sha1file_truncate(struct sha1file *, struct sha1file_checkpoint *);
    
    /* sha1close flags */
    #define CSUM_CLOSE	1
    #define CSUM_FSYNC	2
    
    extern struct sha1file *sha1fd(int fd, const char *name);
    extern struct sha1file *sha1fd_check(const char *name);
    extern struct sha1file *sha1fd_throughput(int fd, const char *name, struct progress *tp);
    extern int sha1close(struct sha1file *, unsigned char *, unsigned int);
    extern int sha1write(struct sha1file *, void *, unsigned int);
    extern void sha1flush(struct sha1file *f);
    extern void crc32_begin(struct sha1file *);
    extern uint32_t crc32_end(struct sha1file *);
    
    #endif