Teach git-diff-files the new option `--no-index`

With this flag and given two paths, git-diff-files behaves as a GNU diff
lookalike (plus the git goodies like --check, colour, etc.).  This flag
is also available in git-diff.  It also works outside of a git repository.

In addition, if git-diff{,-files} is called without revision or stage
parameter, and with exactly two paths at least one of which is not tracked,
the default is --no-index.

So, you can now say

	git diff /etc/inittab /etc/fstab

and it actually works!

This also unifies the duplicated argument parsing between cmd_diff_files()
and builtin_diff_files().

Signed-off-by: Johannes Schindelin <johannes.schindelin@gmx.de>
Signed-off-by: Junio C Hamano <junkio@cox.net>
8 files changed
tree: 7d9aa00054be3a60e6ababc94aa0ccaa573b768f
  1. arm/
  2. compat/
  3. contrib/
  4. Documentation/
  5. git-gui/
  6. gitweb/
  7. mozilla-sha1/
  8. perl/
  9. ppc/
  10. t/
  11. templates/
  12. xdiff/
  13. .gitignore
  14. .mailmap
  15. alloc.c
  16. archive-tar.c
  17. archive-zip.c
  18. archive.h
  19. base85.c
  20. blob.c
  21. blob.h
  22. builtin-add.c
  23. builtin-annotate.c
  24. builtin-apply.c
  25. builtin-archive.c
  26. builtin-blame.c
  27. builtin-branch.c
  28. builtin-cat-file.c
  29. builtin-check-ref-format.c
  30. builtin-checkout-index.c
  31. builtin-commit-tree.c
  32. builtin-config.c
  33. builtin-count-objects.c
  34. builtin-describe.c
  35. builtin-diff-files.c
  36. builtin-diff-index.c
  37. builtin-diff-tree.c
  38. builtin-diff.c
  39. builtin-fmt-merge-msg.c
  40. builtin-for-each-ref.c
  41. builtin-fsck.c
  42. builtin-grep.c
  43. builtin-init-db.c
  44. builtin-log.c
  45. builtin-ls-files.c
  46. builtin-ls-tree.c
  47. builtin-mailinfo.c
  48. builtin-mailsplit.c
  49. builtin-merge-base.c
  50. builtin-merge-file.c
  51. builtin-mv.c
  52. builtin-name-rev.c
  53. builtin-pack-objects.c
  54. builtin-pack-refs.c
  55. builtin-prune-packed.c
  56. builtin-prune.c
  57. builtin-push.c
  58. builtin-read-tree.c
  59. builtin-reflog.c
  60. builtin-rerere.c
  61. builtin-rev-list.c
  62. builtin-rev-parse.c
  63. builtin-rm.c
  64. builtin-runstatus.c
  65. builtin-shortlog.c
  66. builtin-show-branch.c
  67. builtin-show-ref.c
  68. builtin-stripspace.c
  69. builtin-symbolic-ref.c
  70. builtin-tar-tree.c
  71. builtin-unpack-objects.c
  72. builtin-update-index.c
  73. builtin-update-ref.c
  74. builtin-upload-archive.c
  75. builtin-verify-pack.c
  76. builtin-write-tree.c
  77. builtin.h
  78. cache-tree.c
  79. cache-tree.h
  80. cache.h
  81. check-builtins.sh
  82. check-racy.c
  83. color.c
  84. color.h
  85. combine-diff.c
  86. commit.c
  87. commit.h
  88. config.c
  89. config.mak.in
  90. configure.ac
  91. connect.c
  92. convert-objects.c
  93. copy.c
  94. COPYING
  95. csum-file.c
  96. csum-file.h
  97. ctype.c
  98. daemon.c
  99. date.c
  100. delta.h
  101. diff-delta.c
  102. diff-lib.c
  103. diff.c
  104. diff.h
  105. diffcore-break.c
  106. diffcore-delta.c
  107. diffcore-order.c
  108. diffcore-pickaxe.c
  109. diffcore-rename.c
  110. diffcore.h
  111. dir.c
  112. dir.h
  113. dump-cache-tree.c
  114. entry.c
  115. environment.c
  116. exec_cmd.c
  117. exec_cmd.h
  118. fast-import.c
  119. fetch-pack.c
  120. fetch.c
  121. fetch.h
  122. generate-cmdlist.sh
  123. git-add--interactive.perl
  124. git-am.sh
  125. git-applymbox.sh
  126. git-applypatch.sh
  127. git-archimport.perl
  128. git-bisect.sh
  129. git-checkout.sh
  130. git-clean.sh
  131. git-clone.sh
  132. git-commit.sh
  133. git-compat-util.h
  134. git-cvsexportcommit.perl
  135. git-cvsimport.perl
  136. git-cvsserver.perl
  137. git-fetch.sh
  138. git-gc.sh
  139. git-instaweb.sh
  140. git-lost-found.sh
  141. git-ls-remote.sh
  142. git-merge-octopus.sh
  143. git-merge-one-file.sh
  144. git-merge-ours.sh
  145. git-merge-resolve.sh
  146. git-merge-stupid.sh
  147. git-merge.sh
  148. git-p4import.py
  149. git-parse-remote.sh
  150. git-pull.sh
  151. git-quiltimport.sh
  152. git-rebase.sh
  153. git-relink.perl
  154. git-remote.perl
  155. git-repack.sh
  156. git-request-pull.sh
  157. git-reset.sh
  158. git-revert.sh
  159. git-send-email.perl
  160. git-sh-setup.sh
  161. git-svn.perl
  162. git-svnimport.perl
  163. git-tag.sh
  164. git-verify-tag.sh
  165. GIT-VERSION-GEN
  166. git.c
  167. git.spec.in
  168. gitk
  169. grep.c
  170. grep.h
  171. hash-object.c
  172. help.c
  173. http-fetch.c
  174. http-push.c
  175. http.c
  176. http.h
  177. ident.c
  178. imap-send.c
  179. index-pack.c
  180. INSTALL
  181. interpolate.c
  182. interpolate.h
  183. list-objects.c
  184. list-objects.h
  185. local-fetch.c
  186. lockfile.c
  187. log-tree.c
  188. log-tree.h
  189. Makefile
  190. merge-file.c
  191. merge-index.c
  192. merge-recursive.c
  193. merge-tree.c
  194. mktag.c
  195. mktree.c
  196. object-refs.c
  197. object.c
  198. object.h
  199. pack-check.c
  200. pack-redundant.c
  201. pack.h
  202. pager.c
  203. patch-delta.c
  204. patch-id.c
  205. path-list.c
  206. path-list.h
  207. path.c
  208. peek-remote.c
  209. pkt-line.c
  210. pkt-line.h
  211. quote.c
  212. quote.h
  213. reachable.c
  214. reachable.h
  215. read-cache.c
  216. README
  217. receive-pack.c
  218. reflog-walk.c
  219. reflog-walk.h
  220. refs.c
  221. refs.h
  222. revision.c
  223. revision.h
  224. rsh.c
  225. rsh.h
  226. run-command.c
  227. run-command.h
  228. send-pack.c
  229. server-info.c
  230. setup.c
  231. sha1_file.c
  232. sha1_name.c
  233. shallow.c
  234. shell.c
  235. show-index.c
  236. sideband.c
  237. sideband.h
  238. ssh-fetch.c
  239. ssh-pull.c
  240. ssh-push.c
  241. ssh-upload.c
  242. strbuf.c
  243. strbuf.h
  244. tag.c
  245. tag.h
  246. tar.h
  247. test-date.c
  248. test-delta.c
  249. test-sha1.c
  250. test-sha1.sh
  251. trace.c
  252. tree-diff.c
  253. tree-walk.c
  254. tree-walk.h
  255. tree.c
  256. tree.h
  257. unpack-file.c
  258. unpack-trees.c
  259. unpack-trees.h
  260. update-server-info.c
  261. upload-pack.c
  262. usage.c
  263. utf8.c
  264. utf8.h
  265. var.c
  266. write_or_die.c
  267. wt-status.c
  268. wt-status.h
  269. xdiff-interface.c
  270. xdiff-interface.h