Go to file
Eli Schwartz f5e3c6c57d meson: do a full usage-based compile check for sysinfo
On Solaris, sys/sysinfo.h is a completely different file and doesn't
resemble the linux file at all. There is also a sysinfo() function, but
it takes a totally different call signature, which asks for:

- the field you wish to receive
- a `char *buf` to copy the data to

and is very useful IFF you want to know, say, the hardware provider. Or,
get *specific* fields from uname(2).

https://docs.oracle.com/cd/E86824_01/html/E54765/sysinfo-2.html

It is surely possible to do this manually via `sysconf(3)` without the
nice API. I can't find anything more direct. Either way, I'm not very
attached to Solaris, so someone who cares can add it. Either way, it's
wrong to assume that sysinfo.h contains what we are looking for.

Check that sysinfo.h defines the struct we actually utilize in
builtins/gc.c, which will correctly fail on systems that don't have it.

Signed-off-by: Eli Schwartz <eschwartz@gentoo.org>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
2025-04-25 09:35:55 -07:00
.github Merge branch 'ps/misc-build-fixes' 2025-04-16 13:54:18 -07:00
Documentation The seventh batch 2025-04-17 10:28:20 -07:00
bin-wrappers
block-sha1
builtin Merge branch 'ua/update-update-server-info' 2025-04-17 10:28:19 -07:00
ci Merge branch 'en/merge-recursive-debug' 2025-04-17 10:28:18 -07:00
compat Merge branch 'js/comma-semicolon-confusion' 2025-04-15 13:50:17 -07:00
compiler-tricks git-compat-util: add NOT_CONSTANT macro and use it in atfork_prepare() 2025-03-17 17:30:49 -07:00
contrib Merge branch 'ps/misc-build-fixes' 2025-04-16 13:54:18 -07:00
ewah ewah: implement `struct ewah_or_iterator` 2025-03-21 04:34:04 -07:00
git-gui Merge branch 'ad/set-default-target-in-makefiles' 2025-02-25 14:19:36 -08:00
gitk-git Merge branch 'master' of https://github.com/j6t/gitk 2025-02-20 05:59:56 -08:00
gitweb meson: distinguish build and target host binaries 2025-04-01 02:20:44 -07:00
mergetools Merge branch 'fr/vimdiff-layout-fixes' 2025-04-08 11:43:16 -07:00
negotiator prio-queue: use size_t rather than int for size 2024-12-20 07:21:45 -08:00
oss-fuzz meson: simplify use of the common-main library 2025-02-26 09:09:35 -08:00
perl meson: fix perl dependencies 2025-01-08 08:05:39 -08:00
po Merge branch 'l10n/zh-TW/2025-03-09' of github.com:l10n-tw/git-po 2025-03-13 21:57:56 +08:00
refs Merge branch 'ps/refname-avail-check-optim' 2025-04-17 10:28:19 -07:00
reftable Merge branch 'ps/reftable-windows-unlink-fix' 2025-04-15 13:50:13 -07:00
sha1
sha1collisiondetection@855827c583
sha1dc
sha256
subprojects
t Merge branch 'ps/refname-avail-check-optim' 2025-04-17 10:28:19 -07:00
templates meson: distinguish build and target host binaries 2025-04-01 02:20:44 -07:00
trace2 trace2/tr2_sysenv.c: *.txt -> *.adoc fixes 2025-03-03 13:49:26 -08:00
xdiff Merge branch 'js/comma-semicolon-confusion' 2025-04-15 13:50:17 -07:00
.cirrus.yml
.clang-format
.editorconfig editorconfig: add .bash extension 2025-03-03 08:39:47 -08:00
.gitattributes merge-file doc: set conflict-marker-size attribute 2025-03-29 10:31:19 +09:00
.gitignore builtin: introduce diff-pairs command 2025-03-03 08:17:47 -08:00
.gitlab-ci.yml ci: use Visual Studio for win+meson job on GitHub Workflows 2025-04-01 02:20:44 -07:00
.gitmodules
.mailmap
.tsan-suppressions
CODE_OF_CONDUCT.md
COPYING
GIT-BUILD-OPTIONS.in GIT-BUILD-OPTIONS: propagate project's source directory 2025-02-18 11:40:02 -08:00
GIT-VERSION-FILE.in
GIT-VERSION-GEN Start 2.50 cycle (batch #1) 2025-03-26 16:26:11 +09:00
INSTALL
LGPL-2.1
Makefile Merge branch 'en/merge-recursive-debug' 2025-04-17 10:28:18 -07:00
README.md README: *.txt -> *.adoc fixes 2025-03-03 13:49:19 -08:00
RelNotes Start 2.50 cycle (batch #1) 2025-03-26 16:26:11 +09:00
SECURITY.md
abspath.c
abspath.h
aclocal.m4
add-interactive.c add-interactive: stop using `the_repository` 2024-12-18 10:44:31 -08:00
add-interactive.h
add-patch.c pager: stop using `the_repository` 2024-12-18 10:44:30 -08:00
advice.c advice: allow disabling default branch name advice 2025-03-25 16:09:28 -07:00
advice.h advice: allow disabling default branch name advice 2025-03-25 16:09:28 -07:00
alias.c
alias.h
alloc.c
alloc.h
apply.c apply.c: *.txt -> *.adoc fixes 2025-03-03 13:49:22 -08:00
apply.h
archive-tar.c compat/zlib: provide stubs for `deflateSetHeader()` 2025-01-28 13:03:23 -08:00
archive-zip.c
archive.c hash: stop depending on `the_repository` in `null_oid()` 2025-03-10 13:16:20 -07:00
archive.h
attr.c Merge branch 'ps/build-sign-compare' 2024-12-23 09:32:11 -08:00
attr.h
banned.h
base85.c
base85.h
bisect.c path: drop `git_pathdup()` in favor of `repo_git_path()` 2025-02-07 09:59:22 -08:00
bisect.h
blame.c hash: stop depending on `the_repository` in `null_oid()` 2025-03-10 13:16:20 -07:00
blame.h
blob.c
blob.h
bloom.c
bloom.h
branch.c hash: stop depending on `the_repository` in `null_oid()` 2025-03-10 13:16:20 -07:00
branch.h
builtin.h Merge branch 'jt/diff-pairs' 2025-03-26 16:26:09 +09:00
bulk-checkin.c Merge branch 'ps/object-wo-the-repository' 2025-04-15 13:50:15 -07:00
bulk-checkin.h
bundle-uri.c Merge branch 'ps/build-sign-compare' 2024-12-23 09:32:11 -08:00
bundle-uri.h
bundle.c bundle: avoid closing file descriptor twice 2025-01-25 18:38:11 -08:00
bundle.h bundle: avoid closing file descriptor twice 2025-01-25 18:38:11 -08:00
cache-tree.c
cache-tree.h
cbtree.c
cbtree.h
chdir-notify.c
chdir-notify.h
check-builtins.sh
checkout.c
checkout.h
chunk-format.c
chunk-format.h
color.c
color.h
column.c
column.h
combine-diff.c hash: stop depending on `the_repository` in `null_oid()` 2025-03-10 13:16:20 -07:00
command-list.txt builtin: introduce diff-pairs command 2025-03-03 08:17:47 -08:00
commit-graph.c csum-file: stop depending on `the_repository` 2025-03-10 13:16:18 -07:00
commit-graph.h
commit-reach.c commit-reach: use `size_t` to track indices when computing merge bases 2024-12-27 08:12:40 -08:00
commit-reach.h commit-reach: use `size_t` to track indices when computing merge bases 2024-12-27 08:12:40 -08:00
commit-slab-decl.h
commit-slab-impl.h
commit-slab.h
commit.c Merge branch 'ps/object-wo-the-repository' 2025-04-15 13:50:15 -07:00
commit.h commit-reach: use `size_t` to track indices in `get_reachable_subset()` 2024-12-27 08:11:45 -08:00
common-exit.c common-main: split init and exit code into new files 2025-01-28 14:39:16 -08:00
common-init.c common-main: split init and exit code into new files 2025-01-28 14:39:16 -08:00
common-init.h common-main: split init and exit code into new files 2025-01-28 14:39:16 -08:00
common-main.c common-main: split init and exit code into new files 2025-01-28 14:39:16 -08:00
config.c Merge branch 'ps/object-wo-the-repository' 2025-04-15 13:50:15 -07:00
config.h config: teach repo_config to allow `repo` to be NULL 2025-03-07 16:52:00 -08:00
config.mak.dev Merge branch 'js/comma-semicolon-confusion' 2025-04-15 13:50:17 -07:00
config.mak.in
config.mak.uname cmake/vcxproj: stop special-casing `remote-ext` 2024-12-17 12:48:54 -08:00
configure.ac
connect.c Merge branch 'cc/lop-remote' 2025-03-05 10:37:44 -08:00
connect.h
connected.c
connected.h
convert.c
convert.h
copy.c path: adjust last remaining users of `the_repository` 2025-02-28 13:54:11 -08:00
copy.h
credential.c Merge branch 'ps/the-repository' 2025-01-21 08:44:54 -08:00
credential.h Merge branch 'ps/the-repository' 2025-01-21 08:44:54 -08:00
csum-file.c csum-file: stop depending on `the_repository` 2025-03-10 13:16:18 -07:00
csum-file.h csum-file: stop depending on `the_repository` 2025-03-10 13:16:18 -07:00
ctype.c
daemon.c Merge branch 'ps/build-sign-compare' 2024-12-23 09:32:11 -08:00
date.c date.c: Fix type missmatch warings from msvc 2024-12-26 13:34:28 -08:00
date.h
decorate.c decorate: fix sign comparison warnings 2025-03-10 13:21:13 -07:00
decorate.h
delta-islands.c delta-islands: stop depending on `the_repository` 2025-03-10 13:16:20 -07:00
delta-islands.h delta-islands: stop depending on `the_repository` 2025-03-10 13:16:20 -07:00
delta.h
detect-compiler detect-compiler: detect clang even if it found CUDA 2025-03-28 17:38:12 -07:00
diagnose.c diagnose: stop using `the_repository` 2024-12-18 10:44:31 -08:00
diagnose.h diagnose: stop using `the_repository` 2024-12-18 10:44:31 -08:00
diff-delta.c diff-delta: avoid using the comma operator 2025-03-28 17:38:10 -07:00
diff-lib.c hash: stop depending on `the_repository` in `null_oid()` 2025-03-10 13:16:20 -07:00
diff-merges.c
diff-merges.h
diff-no-index.c hash: stop depending on `the_repository` in `null_oid()` 2025-03-10 13:16:20 -07:00
diff.c Merge branch 'ps/object-wo-the-repository' 2025-04-15 13:50:15 -07:00
diff.h Merge branch 'ps/object-wo-the-repository' 2025-04-15 13:50:15 -07:00
diffcore-break.c
diffcore-delta.c
diffcore-order.c
diffcore-pickaxe.c
diffcore-rename.c Merge branch 'en/assert-wo-side-effects' 2025-04-08 11:43:12 -07:00
diffcore-rotate.c
diffcore.h diffcore.h: *.txt -> *.adoc fixes 2025-03-03 13:49:23 -08:00
dir-iterator.c refs/iterator: separate lifecycle from iteration 2025-03-12 11:31:18 -07:00
dir-iterator.h refs/iterator: separate lifecycle from iteration 2025-03-12 11:31:18 -07:00
dir.c hash: stop depending on `the_repository` in `null_oid()` 2025-03-10 13:16:20 -07:00
dir.h Merge branch 'am/dir-dedup-decl-of-repository' 2025-03-29 16:39:09 +09:00
editor.c path: refactor `repo_git_path()` family of functions 2025-02-07 09:59:21 -08:00
editor.h
entry.c progress: stop using `the_repository` 2024-12-18 10:44:30 -08:00
entry.h
environment.c environment: move access to "core.bigFileThreshold" into repo settings 2025-03-10 13:16:18 -07:00
environment.h Merge branch 'ab/environment-clean-header' 2025-04-17 10:28:20 -07:00
exec-cmd.c
exec-cmd.h
fetch-negotiator.c
fetch-negotiator.h
fetch-pack.c Merge branch 'kn/pack-write-with-reduced-globals' 2025-02-03 10:23:34 -08:00
fetch-pack.h
fmt-merge-msg.c
fmt-merge-msg.h
fsck.c fsck: reject misconfigured fsck.skipList 2025-01-07 09:22:25 -08:00
fsck.h Merge branch 'sj/ref-consistency-checks-more' 2025-03-26 16:26:10 +09:00
fsmonitor--daemon.h
fsmonitor-ipc.c
fsmonitor-ipc.h
fsmonitor-ll.h
fsmonitor-path-utils.h
fsmonitor-settings.c
fsmonitor-settings.h
fsmonitor.c
fsmonitor.h
generate-cmdlist.sh doc: use .adoc extension for AsciiDoc files 2025-01-21 12:56:06 -08:00
generate-configlist.sh completion: take into account the formatting backticks for options 2025-03-20 19:27:29 -07:00
generate-hooklist.sh doc: use .adoc extension for AsciiDoc files 2025-01-21 12:56:06 -08:00
generate-perl.sh
generate-python.sh
generate-script.sh
gettext.c
gettext.h
git-archimport.perl
git-compat-util.h Merge branch 'ps/reftable-sans-compat-util' 2025-04-08 11:43:14 -07:00
git-curl-compat.h http.c: allow custom TCP keepalive behavior via config 2025-03-21 01:38:52 -07:00
git-cvsexportcommit.perl
git-cvsimport.perl
git-cvsserver.perl
git-difftool--helper.sh
git-filter-branch.sh
git-instaweb.sh instaweb: fix ip binding for the python http.server 2025-01-10 15:27:52 -08:00
git-merge-octopus.sh
git-merge-one-file.sh
git-merge-resolve.sh
git-mergetool--lib.sh
git-mergetool.sh
git-p4.py
git-quiltimport.sh
git-request-pull.sh
git-send-email.perl send-email: finer-grained SMTP error handling 2025-04-07 14:54:05 -07:00
git-sh-i18n.sh
git-sh-setup.sh
git-submodule.sh
git-svn.perl
git-web--browse.sh
git-zlib.c Merge branch 'jk/zlib-inflate-fixes' 2025-04-15 13:50:14 -07:00
git-zlib.h git-compat-util: move include of "compat/zlib.h" into "git-zlib.h" 2025-01-28 13:03:22 -08:00
git.c builtin: introduce diff-pairs command 2025-03-03 08:17:47 -08:00
git.rc.in
gpg-interface.c
gpg-interface.h
graph.c graph: stop using `the_repository` 2024-12-18 10:44:31 -08:00
graph.h
grep.c hash: stop depending on `the_repository` in `null_oid()` 2025-03-10 13:16:20 -07:00
grep.h
hash-lookup.c
hash-lookup.h
hash.c hash: stop depending on `the_repository` in `null_oid()` 2025-03-10 13:16:20 -07:00
hash.h Merge branch 'jt/help-sha-backend-info-in-build-options' 2025-04-16 13:54:20 -07:00
hashmap.c
hashmap.h
help.c help: include unsafe SHA-1 build info in version 2025-04-07 14:39:27 -07:00
help.h
hex-ll.c
hex-ll.h
hex.c
hex.h
hook.c path: refactor `repo_git_path()` family of functions 2025-02-07 09:59:21 -08:00
hook.h
http-backend.c path: drop `git_pathdup()` in favor of `repo_git_path()` 2025-02-07 09:59:22 -08:00
http-fetch.c
http-push.c global: adapt callers to use generic hash context helpers 2025-01-31 10:06:11 -08:00
http-walker.c
http.c http.c: allow custom TCP keepalive behavior via config 2025-03-21 01:38:52 -07:00
http.h hash: stop typedeffing the hash context 2025-01-31 10:06:10 -08:00
ident.c ident: stop assuming that `gw_gecos` is writable 2025-03-06 08:35:07 -08:00
ident.h
imap-send.c imap-send: explicitly verify the peer certificate 2025-03-25 15:48:58 -07:00
iterator.h refs/iterator: separate lifecycle from iteration 2025-03-12 11:31:18 -07:00
json-writer.c
json-writer.h
khash.h
kwset.c kwset: avoid using the comma operator unnecessarily 2025-03-28 17:38:09 -07:00
kwset.h
levenshtein.c
levenshtein.h
line-log.c
line-log.h
line-range.c
line-range.h
linear-assignment.c
linear-assignment.h
list-objects-filter-options.c
list-objects-filter-options.h list-objects-filter-options.h: *.txt -> *.adoc fixes 2025-03-03 13:49:23 -08:00
list-objects-filter.c
list-objects-filter.h
list-objects.c Merge branch 'ps/build-sign-compare' 2024-12-23 09:32:11 -08:00
list-objects.h
list.h
lockfile.c
lockfile.h
log-tree.c hash: stop depending on `the_repository` in `null_oid()` 2025-03-10 13:16:20 -07:00
log-tree.h
loose.c path: adjust last remaining users of `the_repository` 2025-02-28 13:54:11 -08:00
loose.h
ls-refs.c
ls-refs.h
mailinfo.c mailinfo: stop using `the_repository` 2024-12-18 10:44:31 -08:00
mailinfo.h mailinfo: stop using `the_repository` 2024-12-18 10:44:31 -08:00
mailmap.c
mailmap.h
match-trees.c match-trees: stop using `the_repository` 2024-12-18 10:44:31 -08:00
match-trees.h
mem-pool.c
mem-pool.h
merge-blobs.c
merge-blobs.h
merge-ll.c
merge-ll.h
merge-ort-wrappers.c merge-ort: support having merge verbosity be set to 0 2025-03-18 09:48:51 -07:00
merge-ort-wrappers.h merge-recursive.[ch]: thoroughly debug these 2025-04-08 13:59:13 -07:00
merge-ort.c Merge branch 'en/merge-recursive-debug' 2025-04-17 10:28:18 -07:00
merge-ort.h merge-recursive.[ch]: thoroughly debug these 2025-04-08 13:59:13 -07:00
merge.c
merge.h
mergesort.h
meson.build meson: do a full usage-based compile check for sysinfo 2025-04-25 09:35:55 -07:00
meson_options.txt Merge branch 'ps/meson-contrib-bits' 2025-03-03 08:53:03 -08:00
midx-write.c Merge branch 'ps/object-wo-the-repository' 2025-04-15 13:50:15 -07:00
midx.c csum-file: stop depending on `the_repository` 2025-03-10 13:16:18 -07:00
midx.h
name-hash.c
name-hash.h
notes-cache.c
notes-cache.h
notes-merge.c hash: stop depending on `the_repository` in `null_oid()` 2025-03-10 13:16:20 -07:00
notes-merge.h
notes-utils.c
notes-utils.h
notes.c hash: stop depending on `the_repository` in `null_oid()` 2025-03-10 13:16:20 -07:00
notes.h
object-file-convert.c object-file-convert: stop depending on `the_repository` 2025-03-10 13:16:19 -07:00
object-file-convert.h object-file-convert: stop depending on `the_repository` 2025-03-10 13:16:19 -07:00
object-file.c Merge branch 'ps/object-wo-the-repository' 2025-04-15 13:50:15 -07:00
object-file.h
object-name.c Merge branch 'ps/refname-avail-check-optim' 2025-03-29 16:39:07 +09:00
object-name.h object-name: introduce `repo_get_oid_with_flags()` 2025-03-12 11:31:16 -07:00
object-store-ll.h
object-store.h
object.c object: stop depending on `the_repository` 2025-03-10 13:16:18 -07:00
object.h object: stop depending on `the_repository` 2025-03-10 13:16:18 -07:00
oid-array.c
oid-array.h
oidmap.c
oidmap.h
oidset.c
oidset.h
oidtree.c
oidtree.h
pack-bitmap-write.c Merge branch 'ps/object-wo-the-repository' 2025-04-15 13:50:15 -07:00
pack-bitmap.c Merge branch 'ps/cat-file-filter-batch' 2025-04-16 13:54:21 -07:00
pack-bitmap.h Merge branch 'ps/cat-file-filter-batch' 2025-04-16 13:54:21 -07:00
pack-check.c pack-check: stop depending on `the_repository` 2025-03-10 13:16:19 -07:00
pack-mtimes.c
pack-mtimes.h
pack-objects.c
pack-objects.h Merge branch 'ds/name-hash-tweaks' 2025-02-12 10:08:51 -08:00
pack-revindex.c Merge branch 'ps/object-wo-the-repository' 2025-04-15 13:50:15 -07:00
pack-revindex.h
pack-write.c pack-write: stop depending on `the_repository` and `the_hash_algo` 2025-03-10 13:16:18 -07:00
pack.h pack-write: stop depending on `the_repository` and `the_hash_algo` 2025-03-10 13:16:18 -07:00
packfile.c builtin/pack-objects.c: freshen objects from existing cruft packs 2025-03-13 11:48:04 -07:00
packfile.h builtin/pack-objects.c: freshen objects from existing cruft packs 2025-03-13 11:48:04 -07:00
pager.c pager: stop using `the_repository` 2024-12-18 10:44:30 -08:00
pager.h pager: stop using `the_repository` 2024-12-18 10:44:30 -08:00
parallel-checkout.c treewide: replace assert() with ASSERT() in special cases 2025-03-21 03:32:10 -07:00
parallel-checkout.h
parse-options-cb.c hash: stop depending on `the_repository` in `null_oid()` 2025-03-10 13:16:20 -07:00
parse-options.c Merge branch 'jc/show-usage-help' 2025-01-28 13:02:22 -08:00
parse-options.h parse-options.h: *.txt -> *.adoc fixes 2025-03-03 13:49:24 -08:00
parse.c
parse.h
patch-delta.c
patch-ids.c
patch-ids.h
path-walk.c backfill: add --sparse option 2025-02-03 16:12:42 -08:00
path-walk.h backfill: add --sparse option 2025-02-03 16:12:42 -08:00
path.c path: adjust last remaining users of `the_repository` 2025-02-28 13:54:11 -08:00
path.h path: adjust last remaining users of `the_repository` 2025-02-28 13:54:11 -08:00
pathspec.c pathspec: fix sign comparison warnings 2025-04-01 02:51:47 -07:00
pathspec.h
pkt-line.c
pkt-line.h
preload-index.c progress: stop using `the_repository` 2024-12-18 10:44:30 -08:00
preload-index.h
pretty.c
pretty.h
prio-queue.c prio-queue: use size_t rather than int for size 2024-12-20 07:21:45 -08:00
prio-queue.h prio-queue: fix type of `insertion_ctr` 2024-12-27 08:10:41 -08:00
progress.c progress: stop using `the_repository` 2024-12-18 10:44:30 -08:00
progress.h progress: stop using `the_repository` 2024-12-18 10:44:30 -08:00
promisor-remote.c promisor-remote: compare remote names case sensitively 2025-03-18 12:22:34 -07:00
promisor-remote.h Add 'promisor-remote' capability to protocol v2 2025-02-18 11:05:37 -08:00
prompt.c
prompt.h
protocol-caps.c
protocol-caps.h
protocol.c
protocol.h
prune-packed.c progress: stop using `the_repository` 2024-12-18 10:44:30 -08:00
prune-packed.h
pseudo-merge.c progress: stop using `the_repository` 2024-12-18 10:44:30 -08:00
pseudo-merge.h Merge branch 'tb/bitamp-typofix' 2025-04-07 14:23:20 -07:00
quote.c
quote.h
range-diff.c hash: stop depending on `the_repository` in `null_oid()` 2025-03-10 13:16:20 -07:00
range-diff.h range-diff: optionally include merge commits' diffs in the analysis 2024-12-16 08:45:48 -08:00
reachable.c Merge branch 'ps/cat-file-filter-batch' 2025-04-16 13:54:21 -07:00
reachable.h
read-cache-ll.h
read-cache.c hash: stop depending on `the_repository` in `null_oid()` 2025-03-10 13:16:20 -07:00
read-cache.h
rebase-interactive.c
rebase-interactive.h
rebase.c
rebase.h
ref-filter.c Merge branch 'rs/ref-fitler-used-atoms-value-fix' 2025-01-29 14:05:09 -08:00
ref-filter.h ref-filter: remove ref_format_clear() 2025-01-21 09:06:24 -08:00
reflog-walk.c
reflog-walk.h
reflog.c builtin/reflog: make functions regarding `reflog_expire_options` public 2025-04-08 07:53:27 -07:00
reflog.h builtin/reflog: make functions regarding `reflog_expire_options` public 2025-04-08 07:53:27 -07:00
refs.c Merge branch 'cj/refname-avail-check-optim-typofix' 2025-04-17 10:28:19 -07:00
refs.h Merge branch 'kn/non-transactional-batch-updates' 2025-04-16 13:54:19 -07:00
refspec.c refspec: replace `refspec_item_init()` with fetch/push variants 2025-03-21 01:45:16 -07:00
refspec.h refspec: replace `refspec_item_init()` with fetch/push variants 2025-03-21 01:45:16 -07:00
remote-curl.c remote-curl: avoid using the comma operator unnecessarily 2025-03-28 17:38:08 -07:00
remote.c Merge branch 'jt/clone-guess-remote-head-fix' 2025-04-15 13:50:16 -07:00
remote.h remote: allow `guess_remote_head()` to suppress advice 2025-03-25 16:09:27 -07:00
replace-object.c
replace-object.h
repo-settings.c environment: move access to "core.bigFileThreshold" into repo settings 2025-03-10 13:16:18 -07:00
repo-settings.h environment: move access to "core.bigFileThreshold" into repo settings 2025-03-10 13:16:18 -07:00
repository.c repo-settings: introduce function to clear struct 2025-02-28 13:54:11 -08:00
repository.h
rerere.c Merge branch 'ps/path-sans-the-repository' 2025-03-05 10:37:43 -08:00
rerere.h rerere: let `rerere_path()` write paths into a caller-provided buffer 2025-02-28 13:54:11 -08:00
reset.c hash: stop depending on `the_repository` in `null_oid()` 2025-03-10 13:16:20 -07:00
reset.h
resolve-undo.c resolve-undo: stop using `the_repository` 2024-12-18 10:44:31 -08:00
resolve-undo.h resolve-undo: stop using `the_repository` 2024-12-18 10:44:31 -08:00
revision.c Merge branch 'jt/rev-list-z' 2025-04-16 13:54:18 -07:00
revision.h rev-list: inline `show_object_with_name()` in `show_object()` 2025-03-21 03:40:02 -07:00
run-command.c git-compat-util: add NOT_CONSTANT macro and use it in atfork_prepare() 2025-03-17 17:30:49 -07:00
run-command.h
sane-ctype.h
scalar.c treewide: replace assert() with ASSERT() in special cases 2025-03-21 03:32:10 -07:00
send-pack.c send-pack: gracefully close the connection for atomic push 2025-02-03 15:24:58 -08:00
send-pack.h send-pack: new return code "ERROR_SEND_PACK_BAD_REF_STATUS" 2025-02-03 15:24:57 -08:00
sequencer.c Merge branch 'en/merge-recursive-debug' 2025-04-17 10:28:18 -07:00
sequencer.h
serve.c Add 'promisor-remote' capability to protocol v2 2025-02-18 11:05:37 -08:00
serve.h serve: stop using `the_repository` 2024-12-18 10:44:30 -08:00
server-info.c path: adjust last remaining users of `the_repository` 2025-02-28 13:54:11 -08:00
server-info.h server-info: stop using `the_repository` 2024-12-18 10:44:30 -08:00
setup.c Merge branch 'tz/doc-txt-to-adoc-fixes' 2025-03-06 14:06:31 -08:00
setup.h
sh-i18n--envsubst.c
sha1dc_git.c
sha1dc_git.h
shallow.c object: stop depending on `the_repository` 2025-03-10 13:16:18 -07:00
shallow.h shallow: fix -Wsign-compare warnings 2024-12-27 08:12:40 -08:00
shared.mak GIT-VERSION-GEN: fix overriding GIT_BUILT_FROM_COMMIT and GIT_DATE 2024-12-20 12:36:45 -08:00
shell.c
shortlog.h
sideband.c
sideband.h
sigchain.c
sigchain.h
simple-ipc.h simple-ipc.h: *.txt -> *.adoc fixes 2025-03-03 13:49:25 -08:00
sparse-index.c
sparse-index.h
split-index.c
split-index.h
stable-qsort.c
statinfo.c
statinfo.h
strbuf.c Git 2.47.2 2025-01-13 12:55:26 -08:00
strbuf.h Git 2.47.2 2025-01-13 12:55:26 -08:00
streaming.c environment: move access to "core.bigFileThreshold" into repo settings 2025-03-10 13:16:18 -07:00
streaming.h
string-list.c
string-list.h
strmap.c
strmap.h
strvec.c Merge branch 'ps/build-sign-compare' 2024-12-23 09:32:11 -08:00
strvec.h
sub-process.c
sub-process.h
submodule-config.c hash: stop depending on `the_repository` in `null_oid()` 2025-03-10 13:16:20 -07:00
submodule-config.h
submodule.c hash: stop depending on `the_repository` in `null_oid()` 2025-03-10 13:16:20 -07:00
submodule.h submodule: refactor `submodule_to_gitdir()` to accept a repo 2025-02-07 09:59:21 -08:00
symlinks.c
symlinks.h
tag.c Merge branch 'ps/build-sign-compare' 2024-12-23 09:32:11 -08:00
tag.h
tar.h
tempfile.c path: adjust last remaining users of `the_repository` 2025-02-28 13:54:11 -08:00
tempfile.h
thread-utils.c
thread-utils.h Revert barrier-based LSan threading race workaround 2025-01-01 14:13:01 -08:00
tmp-objdir.c path: adjust last remaining users of `the_repository` 2025-02-28 13:54:11 -08:00
tmp-objdir.h tmp-objdir: stop using `the_repository` 2024-12-18 10:44:31 -08:00
trace.c trace: stop using `the_repository` 2024-12-18 10:44:30 -08:00
trace.h trace: stop using `the_repository` 2024-12-18 10:44:30 -08:00
trace2.c Merge branch 'am/trace2-with-valueless-true' 2025-01-29 14:05:10 -08:00
trace2.h trace2.h: *.txt -> *.adoc fixes 2025-03-03 13:49:26 -08:00
trailer.c
trailer.h
transport-helper.c refspec: replace `refspec_init()` with fetch/push variants 2025-03-21 01:45:16 -07:00
transport-internal.h
transport.c Merge branch 'ps/send-pack-unhide-error-in-atomic-push' 2025-02-18 15:30:32 -08:00
transport.h transport.h: *.txt -> *.adoc fixes 2025-03-03 13:49:27 -08:00
tree-diff.c hash: stop depending on `the_repository` in `null_oid()` 2025-03-10 13:16:20 -07:00
tree-walk.c
tree-walk.h
tree.c
tree.h
unicode-width.h
unimplemented.sh
unix-socket.c Merge branch 'ps/leakfixes-0129' 2025-02-06 14:56:45 -08:00
unix-socket.h
unix-stream-server.c
unix-stream-server.h
unpack-trees.c unpack-trees.c: *.txt -> *.adoc fixes 2025-03-03 13:49:27 -08:00
unpack-trees.h
upload-pack.c hash: stop depending on `the_repository` in `null_oid()` 2025-03-10 13:16:20 -07:00
upload-pack.h
url.c
url.h
urlmatch.c
urlmatch.h
usage.c usage: add show_usage_if_asked() 2025-01-17 13:30:02 -08:00
userdiff.c userdiff: add builtin driver for INI files 2025-04-01 03:02:09 -07:00
userdiff.h
utf8.c
utf8.h
varint.c
varint.h
version-def.h.in
version.c Merge branch 'ua/os-version-capability' 2025-02-27 15:23:00 -08:00
version.h agent: advertise OS name via agent capability 2025-02-19 09:48:37 -08:00
versioncmp.c
versioncmp.h
walker.c progress: stop using `the_repository` 2024-12-18 10:44:30 -08:00
walker.h
wildmatch.c wildmatch: avoid using of the comma operator 2025-03-28 17:38:11 -07:00
wildmatch.h
worktree.c Merge branch 'sj/ref-consistency-checks-more' 2025-03-26 16:26:10 +09:00
worktree.h Merge branch 'sj/ref-consistency-checks-more' 2025-03-26 16:26:10 +09:00
wrapper.c wrapper: allow generating insecure random bytes 2025-01-07 09:04:18 -08:00
wrapper.h wrapper: allow generating insecure random bytes 2025-01-07 09:04:18 -08:00
write-or-die.c
write-or-die.h
ws.c
ws.h
wt-status.c hash: stop depending on `the_repository` in `null_oid()` 2025-03-10 13:16:20 -07:00
wt-status.h
xdiff-interface.c hash: stop depending on `the_repository` in `null_oid()` 2025-03-10 13:16:20 -07:00
xdiff-interface.h

README.md

Build status

Git - fast, scalable, distributed revision control system

Git is a fast, scalable, distributed revision control system with an unusually rich command set that provides both high-level operations and full access to internals.

Git is an Open Source project covered by the GNU General Public License version 2 (some parts of it are under different licenses, compatible with the GPLv2). It was originally written by Linus Torvalds with help of a group of hackers around the net.

Please read the file INSTALL for installation instructions.

Many Git online resources are accessible from https://git-scm.com/ including full documentation and Git related tools.

See Documentation/gittutorial.adoc to get started, then see Documentation/giteveryday.adoc for a useful minimum set of commands, and Documentation/git-<commandname>.adoc for documentation of each command. If git has been correctly installed, then the tutorial can also be read with man gittutorial or git help tutorial, and the documentation of each command with man git-<commandname> or git help <commandname>.

CVS users may also want to read Documentation/gitcvs-migration.adoc (man gitcvs-migration or git help cvs-migration if git is installed).

The user discussion and development of Git take place on the Git mailing list -- everyone is welcome to post bug reports, feature requests, comments and patches to git@vger.kernel.org (read Documentation/SubmittingPatches for instructions on patch submission and Documentation/CodingGuidelines).

Those wishing to help with error message, usage and informational message string translations (localization l10) should see po/README.md (a po file is a Portable Object file that holds the translations).

To subscribe to the list, send an email to git+subscribe@vger.kernel.org (see https://subspace.kernel.org/subscribing.html for details). The mailing list archives are available at https://lore.kernel.org/git/, https://marc.info/?l=git and other archival sites.

Issues which are security relevant should be disclosed privately to the Git Security mailing list git-security@googlegroups.com.

The maintainer frequently sends the "What's cooking" reports that list the current status of various development topics to the mailing list. The discussion following them give a good reference for project status, development direction and remaining tasks.

The name "git" was given by Linus Torvalds when he wrote the very first version. He described the tool as "the stupid content tracker" and the name as (depending on your mood):

  • random three-letter combination that is pronounceable, and not actually used by any common UNIX command. The fact that it is a mispronunciation of "get" may or may not be relevant.
  • stupid. contemptible and despicable. simple. Take your pick from the dictionary of slang.
  • "global information tracker": you're in a good mood, and it actually works for you. Angels sing, and a light suddenly fills the room.
  • "goddamn idiotic truckload of sh*t": when it breaks