 1f010d6bdf
			
		
	
	1f010d6bdf
	
	
	
		
			
			We presently use the ".txt" extension for our AsciiDoc files. While not wrong, most editors do not associate this extension with AsciiDoc, meaning that contributors don't get automatic editor functionality that could be useful, such as syntax highlighting and prose linting. It is much more common to use the ".adoc" extension for AsciiDoc files, since this helps editors automatically detect files and also allows various forges to provide rich (HTML-like) rendering. Let's do that here, renaming all of the files and updating the includes where relevant. Adjust the various build scripts and makefiles to use the new extension as well. Note that this should not result in any user-visible changes to the documentation. Signed-off-by: brian m. carlson <sandals@crustytoothpaste.net> Signed-off-by: Junio C Hamano <gitster@pobox.com>
		
			
				
	
	
		
			122 lines
		
	
	
		
			4.2 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			122 lines
		
	
	
		
			4.2 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| Trivial merge rules
 | |
| ===================
 | |
| 
 | |
| This document describes the outcomes of the trivial merge logic in read-tree.
 | |
| 
 | |
| One-way merge
 | |
| -------------
 | |
| 
 | |
| This replaces the index with a different tree, keeping the stat info
 | |
| for entries that don't change, and allowing -u to make the minimum
 | |
| required changes to the working tree to have it match.
 | |
| 
 | |
| Entries marked '+' have stat information. Spaces marked '*' don't
 | |
| affect the result.
 | |
| 
 | |
|    index   tree    result
 | |
|    -----------------------
 | |
|    *       (empty) (empty)
 | |
|    (empty) tree    tree
 | |
|    index+  tree    tree
 | |
|    index+  index   index+
 | |
| 
 | |
| Two-way merge
 | |
| -------------
 | |
| 
 | |
| It is permitted for the index to lack an entry; this does not prevent
 | |
| any case from applying.
 | |
| 
 | |
| If the index exists, it is an error for it not to match either the old
 | |
| or the result.
 | |
| 
 | |
| If multiple cases apply, the one used is listed first.
 | |
| 
 | |
| A result which changes the index is an error if the index is not empty
 | |
| and not up to date.
 | |
| 
 | |
| Entries marked '+' have stat information. Spaces marked '*' don't
 | |
| affect the result.
 | |
| 
 | |
|  case  index   old     new     result
 | |
|  -------------------------------------
 | |
|  0/2   (empty) *       (empty) (empty)
 | |
|  1/3   (empty) *       new     new
 | |
|  4/5   index+  (empty) (empty) index+
 | |
|  6/7   index+  (empty) index   index+
 | |
|  10    index+  index   (empty) (empty)
 | |
|  14/15 index+  old     old     index+
 | |
|  18/19 index+  old     index   index+
 | |
|  20    index+  index   new     new
 | |
| 
 | |
| Three-way merge
 | |
| ---------------
 | |
| 
 | |
| It is permitted for the index to lack an entry; this does not prevent
 | |
| any case from applying.
 | |
| 
 | |
| If the index exists, it is an error for it not to match either the
 | |
| head or (if the merge is trivial) the result.
 | |
| 
 | |
| If multiple cases apply, the one used is listed first.
 | |
| 
 | |
| A result of "no merge" means that index is left in stage 0, ancest in
 | |
| stage 1, head in stage 2, and remote in stage 3 (if any of these are
 | |
| empty, no entry is left for that stage). Otherwise, the given entry is
 | |
| left in stage 0, and there are no other entries.
 | |
| 
 | |
| A result of "no merge" is an error if the index is not empty and not
 | |
| up to date.
 | |
| 
 | |
| *empty* means that the tree must not have a directory-file conflict
 | |
|  with the entry.
 | |
| 
 | |
| For multiple ancestors, a '+' means that this case applies even if
 | |
| only one ancestor or remote fits; a '^' means all of the ancestors
 | |
| must be the same.
 | |
| 
 | |
|  case  ancest    head    remote    result
 | |
|  ----------------------------------------
 | |
|  1     (empty)+  (empty) (empty)   (empty)
 | |
|  2ALT  (empty)+  *empty* remote    remote
 | |
|  2     (empty)^  (empty) remote    no merge
 | |
|  3ALT  (empty)+  head    *empty*   head
 | |
|  3     (empty)^  head    (empty)   no merge
 | |
|  4     (empty)^  head    remote    no merge
 | |
|  5ALT  *         head    head      head
 | |
|  6     ancest+   (empty) (empty)   no merge
 | |
|  8     ancest^   (empty) ancest    no merge
 | |
|  7     ancest+   (empty) remote    no merge
 | |
|  10    ancest^   ancest  (empty)   no merge
 | |
|  9     ancest+   head    (empty)   no merge
 | |
|  16    anc1/anc2 anc1    anc2      no merge
 | |
|  13    ancest+   head    ancest    head
 | |
|  14    ancest+   ancest  remote    remote
 | |
|  11    ancest+   head    remote    no merge
 | |
| 
 | |
| Only #2ALT and #3ALT use *empty*, because these are the only cases
 | |
| where there can be conflicts that didn't exist before. Note that we
 | |
| allow directory-file conflicts between things in different stages
 | |
| after the trivial merge.
 | |
| 
 | |
| A possible alternative for #6 is (empty), which would make it like
 | |
| #1. This is not used, due to the likelihood that it arises due to
 | |
| moving the file to multiple different locations or moving and deleting
 | |
| it in different branches.
 | |
| 
 | |
| Case #1 is included for completeness, and also in case we decide to
 | |
| put on '+' markings; any path that is never mentioned at all isn't
 | |
| handled.
 | |
| 
 | |
| Note that #16 is when both #13 and #14 apply; in this case, we refuse
 | |
| the trivial merge, because we can't tell from this data which is
 | |
| right. This is a case of a reverted patch (in some direction, maybe
 | |
| multiple times), and the right answer depends on looking at crossings
 | |
| of history or common ancestors of the ancestors.
 | |
| 
 | |
| Note that, between #6, #7, #9, and #11, all cases not otherwise
 | |
| covered are handled in this table.
 | |
| 
 | |
| For #8 and #10, there is alternative behavior, not currently
 | |
| implemented, where the result is (empty). As currently implemented,
 | |
| the automatic merge will generally give this effect.
 |