reftable/stack: adjust permissions of compacted tables
When creating a new compacted table from a range of preexisting ones we don't set the default permissions on the resulting table when specified by the user. This has the effect that the "core.sharedRepository" config will not be honored correctly. Fix this bug and add a test to catch this issue. Note that we only test on non-Windows platforms because Windows does not use POSIX permissions natively. Signed-off-by: Patrick Steinhardt <ps@pks.im> Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:

committed by
Junio C Hamano

parent
e02ecfcc53
commit
b3a79dd4e9
@ -731,6 +731,12 @@ static int stack_compact_locked(struct reftable_stack *st, int first, int last,
|
||||
strbuf_addstr(temp_tab, ".temp.XXXXXX");
|
||||
|
||||
tab_fd = mkstemp(temp_tab->buf);
|
||||
if (st->config.default_permissions &&
|
||||
chmod(temp_tab->buf, st->config.default_permissions) < 0) {
|
||||
err = REFTABLE_IO_ERROR;
|
||||
goto done;
|
||||
}
|
||||
|
||||
wr = reftable_new_writer(reftable_fd_write, &tab_fd, &st->config);
|
||||
|
||||
err = stack_write_compact(st, wr, first, last, config);
|
||||
|
Reference in New Issue
Block a user