docs/protocol-v2: clarify some ls-refs ref-prefix details

We've never documented the fact that a client can provide multiple
ref-prefix capabilities. Let's describe the behavior.

We also never discussed the "best effort" nature of the prefixes. The
client side of git.git has always treated them this way, filtering the
result with local patterns. And indeed any client must do this, because
the prefix patterns are not sufficient to express the usual refspecs
(and so for "foo" we ask for "refs/heads/foo", "refs/tags/foo", and so
on).

So this may be considered a change in the spec with respect to client
expectations / requirements, but it's mostly codifying existing
behavior.

Signed-off-by: Jeff King <peff@peff.net>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
Jeff King 2021-09-15 14:35:34 -04:00 committed by Junio C Hamano
parent 7f0e4f6ac2
commit 9db5fb4fb3

View File

@ -193,7 +193,11 @@ ls-refs takes in the following arguments:
Show peeled tags. Show peeled tags.
ref-prefix <prefix> ref-prefix <prefix>
When specified, only references having a prefix matching one of When specified, only references having a prefix matching one of
the provided prefixes are displayed. the provided prefixes are displayed. Multiple instances may be
given, in which case references matching any prefix will be
shown. Note that this is purely for optimization; a server MAY
show refs not matching the prefix if it chooses, and clients
should filter the result themselves.
If the 'unborn' feature is advertised the following argument can be If the 'unborn' feature is advertised the following argument can be
included in the client's request. included in the client's request.