]> git.ipfire.org Git - thirdparty/git.git/commit - attr.h
attr: add flag `--source` to work with tree-ish
authorKarthik Nayak <karthik.188@gmail.com>
Sat, 14 Jan 2023 08:30:38 +0000 (09:30 +0100)
committerJunio C Hamano <gitster@pobox.com>
Sat, 14 Jan 2023 16:49:55 +0000 (08:49 -0800)
commit47cfc9bd7d0add617cf6d928e96b7d207be614f1
tree72af9265a72d2b08913a8bb1eb252e80fd7ebe29
parentc847e8c228a7820f11ce66d82dc68cd2241af031
attr: add flag `--source` to work with tree-ish

The contents of the .gitattributes files may evolve over time, but "git
check-attr" always checks attributes against them in the working tree
and/or in the index. It may be beneficial to optionally allow the users
to check attributes taken from a commit other than HEAD against paths.

Add a new flag `--source` which will allow users to check the
attributes against a commit (actually any tree-ish would do). When the
user uses this flag, we go through the stack of .gitattributes files but
instead of checking the current working tree and/or in the index, we
check the blobs from the provided tree-ish object. This allows the
command to also be used in bare repositories.

Since we use a tree-ish object, the user can pass "--source
HEAD:subdirectory" and all the attributes will be looked up as if
subdirectory was the root directory of the repository.

We cannot simply use the `<rev>:<path>` syntax without the `--source`
flag, similar to how it is used in `git show` because any non-flag
parameter before `--` is treated as an attribute and any parameter after
`--` is treated as a pathname.

The change involves creating a new function `read_attr_from_blob`, which
given the path reads the blob for the path against the provided source and
parses the attributes line by line. This function is plugged into
`read_attr()` function wherein we go through the stack of attributes
files.

Signed-off-by: Karthik Nayak <karthik.188@gmail.com>
Signed-off-by: Toon Claes <toon@iotcl.com>
Co-authored-by: toon@iotcl.com
Signed-off-by: Junio C Hamano <gitster@pobox.com>
12 files changed:
Documentation/git-check-attr.txt
archive.c
attr.c
attr.h
builtin/check-attr.c
builtin/pack-objects.c
convert.c
ll-merge.c
pathspec.c
t/t0003-attributes.sh
userdiff.c
ws.c