| Git Protocol Capabilities | 
 | ========================= | 
 |  | 
 | Servers SHOULD support all capabilities defined in this document. | 
 |  | 
 | On the very first line of the initial server response of either | 
 | receive-pack and upload-pack the first reference is followed by | 
 | a NUL byte and then a list of space delimited server capabilities. | 
 | These allow the server to declare what it can and cannot support | 
 | to the client. | 
 |  | 
 | Client will then send a space separated list of capabilities it wants | 
 | to be in effect. The client MUST NOT ask for capabilities the server | 
 | did not say it supports. | 
 |  | 
 | Server MUST diagnose and abort if capabilities it does not understand | 
 | was sent.  Server MUST NOT ignore capabilities that client requested | 
 | and server advertised.  As a consequence of these rules, server MUST | 
 | NOT advertise capabilities it does not understand. | 
 |  | 
 | The 'report-status' and 'delete-refs' capabilities are sent and | 
 | recognized by the receive-pack (push to server) process. | 
 |  | 
 | The 'ofs-delta' capability is sent and recognized by both upload-pack | 
 | and receive-pack protocols. | 
 |  | 
 | All other capabilities are only recognized by the upload-pack (fetch | 
 | from server) process. | 
 |  | 
 | multi_ack | 
 | --------- | 
 |  | 
 | The 'multi_ack' capability allows the server to return "ACK obj-id | 
 | continue" as soon as it finds a commit that it can use as a common | 
 | base, between the client's wants and the client's have set. | 
 |  | 
 | By sending this early, the server can potentially head off the client | 
 | from walking any further down that particular branch of the client's | 
 | repository history.  The client may still need to walk down other | 
 | branches, sending have lines for those, until the server has a | 
 | complete cut across the DAG, or the client has said "done". | 
 |  | 
 | Without multi_ack, a client sends have lines in --date-order until | 
 | the server has found a common base.  That means the client will send | 
 | have lines that are already known by the server to be common, because | 
 | they overlap in time with another branch that the server hasn't found | 
 | a common base on yet. | 
 |  | 
 | For example suppose the client has commits in caps that the server | 
 | doesn't and the server has commits in lower case that the client | 
 | doesn't, as in the following diagram: | 
 |  | 
 |        +---- u ---------------------- x | 
 |       /              +----- y | 
 |      /              / | 
 |     a -- b -- c -- d -- E -- F | 
 |        \ | 
 | 	+--- Q -- R -- S | 
 |  | 
 | If the client wants x,y and starts out by saying have F,S, the server | 
 | doesn't know what F,S is.  Eventually the client says "have d" and | 
 | the server sends "ACK d continue" to let the client know to stop | 
 | walking down that line (so don't send c-b-a), but it's not done yet, | 
 | it needs a base for x. The client keeps going with S-R-Q, until a | 
 | gets reached, at which point the server has a clear base and it all | 
 | ends. | 
 |  | 
 | Without multi_ack the client would have sent that c-b-a chain anyway, | 
 | interleaved with S-R-Q. | 
 |  | 
 | thin-pack | 
 | --------- | 
 |  | 
 | This capability means that the server can send a 'thin' pack, a pack | 
 | which does not contain base objects; if those base objects are available | 
 | on client side. Client requests 'thin-pack' capability when it | 
 | understands how to "thicken" it by adding required delta bases making | 
 | it self-contained. | 
 |  | 
 | Client MUST NOT request 'thin-pack' capability if it cannot turn a thin | 
 | pack into a self-contained pack. | 
 |  | 
 |  | 
 | side-band, side-band-64k | 
 | ------------------------ | 
 |  | 
 | This capability means that server can send, and client understand multiplexed | 
 | progress reports and error info interleaved with the packfile itself. | 
 |  | 
 | These two options are mutually exclusive. A modern client always | 
 | favors 'side-band-64k'. | 
 |  | 
 | Either mode indicates that the packfile data will be streamed broken | 
 | up into packets of up to either 1000 bytes in the case of 'side_band', | 
 | or 65520 bytes in the case of 'side_band_64k'. Each packet is made up | 
 | of a leading 4-byte pkt-line length of how much data is in the packet, | 
 | followed by a 1-byte stream code, followed by the actual data. | 
 |  | 
 | The stream code can be one of: | 
 |  | 
 |  1 - pack data | 
 |  2 - progress messages | 
 |  3 - fatal error message just before stream aborts | 
 |  | 
 | The "side-band-64k" capability came about as a way for newer clients | 
 | that can handle much larger packets to request packets that are | 
 | actually crammed nearly full, while maintaining backward compatibility | 
 | for the older clients. | 
 |  | 
 | Further, with side-band and its up to 1000-byte messages, it's actually | 
 | 999 bytes of payload and 1 byte for the stream code. With side-band-64k, | 
 | same deal, you have up to 65519 bytes of data and 1 byte for the stream | 
 | code. | 
 |  | 
 | The client MUST send only maximum of one of "side-band" and "side- | 
 | band-64k".  Server MUST diagnose it as an error if client requests | 
 | both. | 
 |  | 
 | ofs-delta | 
 | --------- | 
 |  | 
 | Server can send, and client understand PACKv2 with delta referring to | 
 | its base by position in pack rather than by an obj-id.  That is, they can | 
 | send/read OBJ_OFS_DELTA (aka type 6) in a packfile. | 
 |  | 
 | shallow | 
 | ------- | 
 |  | 
 | This capability adds "deepen", "shallow" and "unshallow" commands to | 
 | the  fetch-pack/upload-pack protocol so clients can request shallow | 
 | clones. | 
 |  | 
 | no-progress | 
 | ----------- | 
 |  | 
 | The client was started with "git clone -q" or something, and doesn't | 
 | want that side band 2.  Basically the client just says "I do not | 
 | wish to receive stream 2 on sideband, so do not send it to me, and if | 
 | you did, I will drop it on the floor anyway".  However, the sideband | 
 | channel 3 is still used for error responses. | 
 |  | 
 | include-tag | 
 | ----------- | 
 |  | 
 | The 'include-tag' capability is about sending annotated tags if we are | 
 | sending objects they point to.  If we pack an object to the client, and | 
 | a tag object points exactly at that object, we pack the tag object too. | 
 | In general this allows a client to get all new annotated tags when it | 
 | fetches a branch, in a single network connection. | 
 |  | 
 | Clients MAY always send include-tag, hardcoding it into a request when | 
 | the server advertises this capability. The decision for a client to | 
 | request include-tag only has to do with the client's desires for tag | 
 | data, whether or not a server had advertised objects in the | 
 | refs/tags/* namespace. | 
 |  | 
 | Servers MUST pack the tags if their referrant is packed and the client | 
 | has requested include-tags. | 
 |  | 
 | Clients MUST be prepared for the case where a server has ignored | 
 | include-tag and has not actually sent tags in the pack.  In such | 
 | cases the client SHOULD issue a subsequent fetch to acquire the tags | 
 | that include-tag would have otherwise given the client. | 
 |  | 
 | The server SHOULD send include-tag, if it supports it, regardless | 
 | of whether or not there are tags available. | 
 |  | 
 | report-status | 
 | ------------- | 
 |  | 
 | The upload-pack process can receive a 'report-status' capability, | 
 | which tells it that the client wants a report of what happened after | 
 | a packfile upload and reference update.  If the pushing client requests | 
 | this capability, after unpacking and updating references the server | 
 | will respond with whether the packfile unpacked successfully and if | 
 | each reference was updated successfully.  If any of those were not | 
 | successful, it will send back an error message.  See pack-protocol.txt | 
 | for example messages. | 
 |  | 
 | delete-refs | 
 | ----------- | 
 |  | 
 | If the server sends back the 'delete-refs' capability, it means that | 
 | it is capable of accepting a zero-id value as the target | 
 | value of a reference update.  It is not sent back by the client, it | 
 | simply informs the client that it can be sent zero-id values | 
 | to delete references. |