1#ifndef CACHE_H 2#define CACHE_H 3 4#include <stdio.h> 5#include <sys/stat.h> 6#include <fcntl.h> 7#include <stddef.h> 8#include <stdlib.h> 9#include <stdarg.h> 10#include <string.h> 11#include <errno.h> 12#include <sys/mman.h> 13#include <netinet/in.h> 14 15#include <openssl/sha.h> 16#include <zlib.h> 17 18/* 19 * Basic data structures for the directory cache 20 * 21 * NOTE NOTE NOTE! This is all in the native CPU byte format. It's 22 * not even trying to be portable. It's trying to be efficient. It's 23 * just a cache, after all. 24 */ 25 26#define CACHE_SIGNATURE 0x44495243/* "DIRC" */ 27struct cache_header { 28unsigned int hdr_signature; 29unsigned int hdr_version; 30unsigned int hdr_entries; 31unsigned char sha1[20]; 32}; 33 34/* 35 * The "cache_time" is just the low 32 bits of the 36 * time. It doesn't matter if it overflows - we only 37 * check it for equality in the 32 bits we save. 38 */ 39struct cache_time { 40unsigned int sec; 41unsigned int nsec; 42}; 43 44/* 45 * dev/ino/uid/gid/size are also just tracked to the low 32 bits 46 * Again - this is just a (very strong in practice) heuristic that 47 * the inode hasn't changed. 48 * 49 * We save the fields in big-endian order to allow using the 50 * index file over NFS transparently. 51 */ 52struct cache_entry { 53struct cache_time ce_ctime; 54struct cache_time ce_mtime; 55unsigned int ce_dev; 56unsigned int ce_ino; 57unsigned int ce_mode; 58unsigned int ce_uid; 59unsigned int ce_gid; 60unsigned int ce_size; 61unsigned char sha1[20]; 62unsigned short ce_flags; 63char name[0]; 64}; 65 66#define CE_NAMEMASK (0x0fff) 67#define CE_STAGE1 (0x1000) 68#define CE_STAGE2 (0x2000) 69 70const char*sha1_file_directory; 71struct cache_entry **active_cache; 72unsigned int active_nr, active_alloc; 73 74#define DB_ENVIRONMENT"SHA1_FILE_DIRECTORY" 75#define DEFAULT_DB_ENVIRONMENT".git/objects" 76 77#define cache_entry_size(len) ((offsetof(struct cache_entry,name) + (len) + 8) & ~7) 78#define ce_namelen(ce) (CE_NAMEMASK & ntohs((ce)->ce_flags)) 79#define ce_size(ce) cache_entry_size(ce_namelen(ce)) 80 81#define alloc_nr(x) (((x)+16)*3/2) 82 83/* Initialize and use the cache information */ 84externintread_cache(void); 85externintwrite_cache(int newfd,struct cache_entry **cache,int entries); 86externintcache_name_pos(const char*name,int namelen); 87externintadd_cache_entry(struct cache_entry *ce,int ok_to_add); 88externintremove_file_from_cache(char*path); 89externintcache_match_stat(struct cache_entry *ce,struct stat *st); 90 91#define MTIME_CHANGED 0x0001 92#define CTIME_CHANGED 0x0002 93#define OWNER_CHANGED 0x0004 94#define MODE_CHANGED 0x0008 95#define INODE_CHANGED 0x0010 96#define DATA_CHANGED 0x0020 97 98/* Return a statically allocated filename matching the sha1 signature */ 99externchar*sha1_file_name(const unsigned char*sha1); 100 101/* Write a memory buffer out to the sha file */ 102externintwrite_sha1_buffer(const unsigned char*sha1,void*buf,unsigned int size); 103 104/* Read and unpack a sha1 file into memory, write memory to a sha1 file */ 105externvoid*map_sha1_file(const unsigned char*sha1,unsigned long*size); 106externvoid*unpack_sha1_file(void*map,unsigned long mapsize,char*type,unsigned long*size); 107externvoid*read_sha1_file(const unsigned char*sha1,char*type,unsigned long*size); 108externintwrite_sha1_file(char*buf,unsigned len,unsigned char*return_sha1); 109externintcheck_sha1_signature(unsigned char*sha1,void*buf,unsigned long size); 110 111/* Convert to/from hex/sha1 representation */ 112externintget_sha1_hex(const char*hex,unsigned char*sha1); 113externchar*sha1_to_hex(const unsigned char*sha1);/* static buffer result! */ 114 115/* General helper functions */ 116externvoidusage(const char*err); 117externvoiddie(const char*err, ...); 118externinterror(const char*err, ...); 119 120externintcache_name_compare(const char*name1,int len1,const char*name2,int len2); 121 122#endif/* CACHE_H */