}
if (!state->cached && !previous) {
- struct repo_config_values *cfg = repo_config_values(the_repository);
+ struct repo_config_values *cfg = repo_config_values(state->repo);
if (*ce && !(*ce)->ce_mode)
BUG("ce_mode == 0 for path '%s'", old_name);
if (cfg->trust_executable_bit || !S_ISREG(st->st_mode))
- st_mode = ce_mode_from_stat(*ce, st->st_mode);
+ st_mode = ce_mode_from_stat(state->repo->index, *ce, st->st_mode);
else if (*ce)
st_mode = (*ce)->ce_mode;
else
ce->ce_flags = create_ce_flags(0);
ce->ce_namelen = len;
fill_stat_cache_info(the_repository->index, ce, st);
- ce->ce_mode = ce_mode_from_stat(old, st->st_mode);
+ ce->ce_mode = ce_mode_from_stat(the_repository->index, old, st->st_mode);
if (index_path(the_repository->index, &ce->oid, path, st,
info_only ? 0 : INDEX_WRITE_OBJECT)) {
* exists for ce that is a submodule -- it is a submodule that is not
* checked out). Return negative for an error.
*/
-static int check_removed(const struct cache_entry *ce, struct stat *st)
+static int check_removed(struct index_state *istate, const struct cache_entry *ce, struct stat *st)
{
int stat_err;
if (!(ce->ce_flags & CE_FSMONITOR_VALID))
stat_err = lstat(ce->name, st);
else
- stat_err = fake_lstat(ce, st);
+ stat_err = fake_lstat(istate, ce, st);
if (stat_err < 0) {
if (!is_missing_file_error(errno))
return -1;
int num_compare_stages = 0;
struct stat st;
- changed = check_removed(ce, &st);
+ changed = check_removed(revs->repo->index, ce, &st);
if (!changed)
- wt_mode = ce_mode_from_stat(ce, st.st_mode);
+ wt_mode = ce_mode_from_stat(revs->repo->index, ce, st.st_mode);
else {
if (changed < 0) {
perror(ce->name);
num_compare_stages++;
oidcpy(&dpath->parent[stage - 2].oid,
&nce->oid);
- dpath->parent[stage-2].mode = ce_mode_from_stat(nce, mode);
+ dpath->parent[stage-2].mode = ce_mode_from_stat(revs->repo->index, nce, mode);
dpath->parent[stage-2].status =
DIFF_STATUS_MODIFIED;
}
} else {
struct stat st;
- changed = check_removed(ce, &st);
+ changed = check_removed(revs->repo->index, ce, &st);
if (changed) {
if (changed < 0) {
perror(ce->name);
continue;
} else if (revs->diffopt.ita_invisible_in_index &&
ce_intent_to_add(ce)) {
- newmode = ce_mode_from_stat(ce, st.st_mode);
+ newmode = ce_mode_from_stat(revs->repo->index, ce, st.st_mode);
diff_addremove(&revs->diffopt, '+', newmode,
null_oid(the_hash_algo), 0, ce->name, 0);
continue;
changed = match_stat_with_submodule(&revs->diffopt, ce, &st,
ce_option, &dirty_submodule);
- newmode = ce_mode_from_stat(ce, st.st_mode);
+ newmode = ce_mode_from_stat(revs->repo->index, ce, st.st_mode);
}
if (!changed && !dirty_submodule) {
if (!cached && !ce_uptodate(ce)) {
int changed;
struct stat st;
- changed = check_removed(ce, &st);
+ changed = check_removed(diffopt->repo->index, ce, &st);
if (changed < 0)
return -1;
else if (changed) {
changed = match_stat_with_submodule(diffopt, ce, &st,
0, dirty_submodule);
if (changed) {
- mode = ce_mode_from_stat(ce, st.st_mode);
+ mode = ce_mode_from_stat(diffopt->repo->index, ce, st.st_mode);
oid = null_oid(the_hash_algo);
}
}
* for lstat() for a tracked path that is known to be up-to-date via
* some out-of-line means (like fsmonitor).
*/
-int fake_lstat(const struct cache_entry *ce, struct stat *st);
+int fake_lstat(struct index_state *istate, const struct cache_entry *ce, struct stat *st);
#define REFRESH_REALLY (1 << 0) /* ignore_valid */
#define REFRESH_UNMERGED (1 << 1) /* allow unmerged */
}
}
-unsigned int ce_mode_from_stat(const struct cache_entry *ce, unsigned int mode)
+unsigned int ce_mode_from_stat(struct index_state *istate,
+ const struct cache_entry *ce,
+ unsigned int mode)
{
- struct repo_config_values *cfg = repo_config_values(the_repository);
+ struct repository *repo = (istate && istate->repo) ? istate->repo : the_repository;
+ struct repo_config_values *cfg = repo_config_values(repo);
if (!has_symlinks && S_ISREG(mode) &&
ce && S_ISLNK(ce->ce_mode))
return create_ce_mode(mode);
}
-static unsigned int st_mode_from_ce(const struct cache_entry *ce)
+static unsigned int st_mode_from_ce(struct index_state *istate, const struct cache_entry *ce)
{
- struct repo_config_values *cfg = repo_config_values(the_repository);
+ struct repository *repo = (istate && istate->repo) ? istate->repo : the_repository;
+ struct repo_config_values *cfg = repo_config_values(repo);
switch (ce->ce_mode & S_IFMT) {
case S_IFLNK:
}
}
-int fake_lstat(const struct cache_entry *ce, struct stat *st)
+int fake_lstat(struct index_state *istate, const struct cache_entry *ce, struct stat *st)
{
fake_lstat_data(&ce->ce_stat_data, st);
- st->st_mode = st_mode_from_ce(ce);
+ st->st_mode = st_mode_from_ce(istate, ce);
/* always succeed as lstat() replacement */
return 0;
return 0;
}
-static int ce_match_stat_basic(const struct cache_entry *ce, struct stat *st)
+static int ce_match_stat_basic(struct index_state *istate,
+ const struct cache_entry *ce, struct stat *st)
{
unsigned int changed = 0;
- struct repo_config_values *cfg = repo_config_values(the_repository);
+ struct repository *repo = (istate && istate->repo) ? istate->repo : the_repository;
+ struct repo_config_values *cfg = repo_config_values(repo);
if (ce->ce_flags & CE_REMOVE)
return MODE_CHANGED | DATA_CHANGED | TYPE_CHANGED;
if (ce_intent_to_add(ce))
return DATA_CHANGED | TYPE_CHANGED | MODE_CHANGED;
- changed = ce_match_stat_basic(ce, st);
+ changed = ce_match_stat_basic(istate, ce, st);
/*
* Within 1 second of this sequence:
(intent_only ? ADD_CACHE_NEW_ONLY : 0));
unsigned hash_flags = pretend ? 0 : INDEX_WRITE_OBJECT;
- struct repo_config_values *cfg = repo_config_values(the_repository);
+ struct repository *repo = (istate && istate->repo) ? istate->repo : the_repository;
+ struct repo_config_values *cfg = repo_config_values(repo);
if (flags & ADD_CACHE_RENORMALIZE)
hash_flags |= INDEX_RENORMALIZE;
int pos = index_name_pos_also_unmerged(istate, path, namelen);
ent = (0 <= pos) ? istate->cache[pos] : NULL;
- ce->ce_mode = ce_mode_from_stat(ent, st_mode);
+ ce->ce_mode = ce_mode_from_stat(istate, ent, st_mode);
}
/* When core.ignorecase=true, determine if a directory of the same name but differing
if (lstat(ce->name, &st) < 0)
return;
- if (ce_match_stat_basic(ce, &st))
+ if (ce_match_stat_basic(istate, ce, &st))
return;
if (ce_modified_check_fs(istate, ce, &st)) {
/* This is "racily clean"; smudge it. Note that this
#include "object.h"
#include "pathspec.h"
-unsigned int ce_mode_from_stat(const struct cache_entry *ce,
+unsigned int ce_mode_from_stat(struct index_state *istate,
+ const struct cache_entry *ce,
unsigned int mode);
static inline int ce_to_dtype(const struct cache_entry *ce)