diff options
Diffstat (limited to 'cache.h')
| -rw-r--r-- | cache.h | 132 | 
1 files changed, 69 insertions, 63 deletions
| @@ -817,6 +817,16 @@ struct cache_entry *index_file_exists(struct index_state *istate, const char *na  int index_name_pos(struct index_state *, const char *name, int namelen);  /* + * Determines whether an entry with the given name exists within the + * given index. The return value is 1 if an exact match is found, otherwise + * it is 0. Note that, unlike index_name_pos, this function does not expand + * the index if it is sparse. If an item exists within the full index but it + * is contained within a sparse directory (and not in the sparse index), 0 is + * returned. + */ +int index_entry_exists(struct index_state *, const char *name, int namelen); + +/*   * Some functions return the negative complement of an insert position when a   * precise match was not found but a position was found where the entry would   * need to be inserted. This helper protects that logic from any integer @@ -887,6 +897,7 @@ int ie_modified(struct index_state *, const struct cache_entry *, struct stat *,  #define HASH_WRITE_OBJECT 1  #define HASH_FORMAT_CHECK 2  #define HASH_RENORMALIZE  4 +#define HASH_SILENT 8  int index_fd(struct index_state *istate, struct object_id *oid, int fd, struct stat *st, enum object_type type, const char *path, unsigned flags);  int index_path(struct index_state *istate, struct object_id *oid, const char *path, struct stat *st, unsigned flags); @@ -995,14 +1006,6 @@ extern int core_apply_sparse_checkout;  extern int core_sparse_checkout_cone;  /* - * Include broken refs in all ref iterations, which will - * generally choke dangerous operations rather than letting - * them silently proceed without taking the broken ref into - * account. - */ -extern int ref_paranoia; - -/*   * Returns the boolean value of $GIT_OPTIONAL_LOCKS (or the default value).   */  int use_optional_locks(void); @@ -1210,51 +1213,10 @@ enum scld_error safe_create_leading_directories(char *path);  enum scld_error safe_create_leading_directories_const(const char *path);  enum scld_error safe_create_leading_directories_no_share(char *path); -/* - * Callback function for raceproof_create_file(). This function is - * expected to do something that makes dirname(path) permanent despite - * the fact that other processes might be cleaning up empty - * directories at the same time. Usually it will create a file named - * path, but alternatively it could create another file in that - * directory, or even chdir() into that directory. The function should - * return 0 if the action was completed successfully. On error, it - * should return a nonzero result and set errno. - * raceproof_create_file() treats two errno values specially: - * - * - ENOENT -- dirname(path) does not exist. In this case, - *             raceproof_create_file() tries creating dirname(path) - *             (and any parent directories, if necessary) and calls - *             the function again. - * - * - EISDIR -- the file already exists and is a directory. In this - *             case, raceproof_create_file() removes the directory if - *             it is empty (and recursively any empty directories that - *             it contains) and calls the function again. - * - * Any other errno causes raceproof_create_file() to fail with the - * callback's return value and errno. - * - * Obviously, this function should be OK with being called again if it - * fails with ENOENT or EISDIR. In other scenarios it will not be - * called again. - */ -typedef int create_file_fn(const char *path, void *cb); - -/* - * Create a file in dirname(path) by calling fn, creating leading - * directories if necessary. Retry a few times in case we are racing - * with another process that is trying to clean up the directory that - * contains path. See the documentation for create_file_fn for more - * details. - * - * Return the value and set the errno that resulted from the most - * recent call of fn. fn is always called at least once, and will be - * called more than once if it returns ENOENT or EISDIR. - */ -int raceproof_create_file(const char *path, create_file_fn fn, void *cb); -  int mkdir_in_gitdir(const char *path); -char *expand_user_path(const char *path, int real_home); +char *interpolate_path(const char *path, int real_home); +/* NEEDSWORK: remove this synonym once in-flight topics have migrated */ +#define expand_user_path interpolate_path  const char *enter_repo(const char *path, int strict);  static inline int is_absolute_path(const char *path)  { @@ -1296,6 +1258,13 @@ int looks_like_command_line_option(const char *str);  /**   * Return a newly allocated string with the evaluation of + * "$XDG_CONFIG_HOME/$subdir/$filename" if $XDG_CONFIG_HOME is non-empty, otherwise + * "$HOME/.config/$subdir/$filename". Return NULL upon error. + */ +char *xdg_config_home_for(const char *subdir, const char *filename); + +/** + * Return a newly allocated string with the evaluation of   * "$XDG_CONFIG_HOME/git/$filename" if $XDG_CONFIG_HOME is non-empty, otherwise   * "$HOME/.config/git/$filename". Return NULL upon error.   */ @@ -1310,11 +1279,50 @@ char *xdg_cache_home(const char *filename);  int git_open_cloexec(const char *name, int flags);  #define git_open(name) git_open_cloexec(name, O_RDONLY) -int unpack_loose_header(git_zstream *stream, unsigned char *map, unsigned long mapsize, void *buffer, unsigned long bufsiz); -int parse_loose_header(const char *hdr, unsigned long *sizep); + +/** + * unpack_loose_header() initializes the data stream needed to unpack + * a loose object header. + * + * Returns: + * + * - ULHR_OK on success + * - ULHR_BAD on error + * - ULHR_TOO_LONG if the header was too long + * + * It will only parse up to MAX_HEADER_LEN bytes unless an optional + * "hdrbuf" argument is non-NULL. This is intended for use with + * OBJECT_INFO_ALLOW_UNKNOWN_TYPE to extract the bad type for (error) + * reporting. The full header will be extracted to "hdrbuf" for use + * with parse_loose_header(), ULHR_TOO_LONG will still be returned + * from this function to indicate that the header was too long. + */ +enum unpack_loose_header_result { +	ULHR_OK, +	ULHR_BAD, +	ULHR_TOO_LONG, +}; +enum unpack_loose_header_result unpack_loose_header(git_zstream *stream, +						    unsigned char *map, +						    unsigned long mapsize, +						    void *buffer, +						    unsigned long bufsiz, +						    struct strbuf *hdrbuf); + +/** + * parse_loose_header() parses the starting "<type> <len>\0" of an + * object. If it doesn't follow that format -1 is returned. To check + * the validity of the <type> populate the "typep" in the "struct + * object_info". It will be OBJ_BAD if the object type is unknown. The + * parsed <len> can be retrieved via "oi->sizep", and from there + * passed to unpack_loose_rest(). + */ +struct object_info; +int parse_loose_header(const char *hdr, struct object_info *oi);  int check_object_signature(struct repository *r, const struct object_id *oid, -			   void *buf, unsigned long size, const char *type); +			   void *buf, unsigned long size, const char *type, +			   struct object_id *real_oidp);  int finalize_object_file(const char *tmpfile, const char *filename); @@ -1590,6 +1598,7 @@ timestamp_t approxidate_careful(const char *, int *);  timestamp_t approxidate_relative(const char *date);  void parse_date_format(const char *format, struct date_mode *mode);  int date_overflows(timestamp_t date); +time_t tm_to_time_t(const struct tm *tm);  #define IDENT_STRICT	       1  #define IDENT_NO_DATE	       2 @@ -1659,7 +1668,9 @@ struct cache_def {  	int track_flags;  	int prefix_len_stat_func;  }; -#define CACHE_DEF_INIT { STRBUF_INIT, 0, 0, 0 } +#define CACHE_DEF_INIT { \ +	.path = STRBUF_INIT, \ +}  static inline void cache_def_clear(struct cache_def *cache)  {  	strbuf_release(&cache->path); @@ -1716,13 +1727,6 @@ int update_server_info(int);  const char *get_log_output_encoding(void);  const char *get_commit_output_encoding(void); -/* - * This is a hack for test programs like test-dump-untracked-cache to - * ensure that they do not modify the untracked cache when reading it. - * Do not use it otherwise! - */ -extern int ignore_untracked_cache_config; -  int committer_ident_sufficiently_given(void);  int author_ident_sufficiently_given(void); @@ -1735,6 +1739,8 @@ extern const char *git_mailmap_blob;  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);  #define COPY_READ_ERROR (-2)  #define COPY_WRITE_ERROR (-3) | 
