使用 Git
此页面收集了关于使用 PostgreSQL Git 仓库 的各种经验。你可能还会使用 其他 Git 仓库,最值得注意的是官方的 Github 镜像,你可以在该网站上 fork 它。
入门
一个简单的入门方法可能如下所示
git clone https://git.postgresql.org/git/postgresql.git cd postgresql git checkout -b my-cool-feature $EDITOR git commit -a git diff --patience master my-cool-feature > ../my-cool-feature.patch
注意 git checkout -b my-cool-feature
会同时创建一个新分支并检出它。通常,你应该在不同的分支上开发每个功能。
查看 https://git-scm.cn/doc/ext 上的文档和教程,以获得更详细的 Git 介绍。要获得更深入的课程,请查看 Pro Git 书籍,并可能获取纸质版以帮助支持该网站。
你可能希望将以下内容放在你的 .git/info/exclude GitExclude 中。现在主仓库已经转换为 git,标准的 .gitignore 文件应该涵盖所有构建产物,所以你不需要在该参考中列出的大多数内容。你可能仍然希望排除 *~、标签和 /cscope.out,尽管如此。
保持本地主分支同步
首先,将 origin 添加为远程仓库。你只需要做一次
git remote add origin https://git.postgresql.org/git/postgresql.git
接下来,从你的公共 git 仓库中获取
git fetch origin master
合并来自你的公共仓库的任何新补丁
git merge FETCH_HEAD
合并来自主分支的任何更改
git fetch origin master git merge FETCH_HEAD
现在检查它是否仍然可以编译,通过回归测试等。确保你已经调用了 ./configure,然后
make check make maintainer-clean
假设所有这些都很好,进行一次试运行。
git push --dry-run origin master
如果一切顺利,就将其推送到你的公共仓库。
git push origin master
如果不是,修复任何合并错误,进行另一次试运行,然后推送。
跟踪其他分支
假设你乐于跟踪主分支,但你真的想跟踪 git.postgresql.org 上任何一个潜在的分支
git remote add <super-fun-branch> https://git.postgresql.org/super-fun-branch.git git fetch super-fun-branch git checkout super-fun-branch #this will stage your remote branch for a local checkout git checkout -b super-fun-branch-name #the name can be wahtever you choose
现在你在你的本地 git 仓库中有一个本地分支跟踪另一个分支的历史记录。最重要的是,如果你需要,你就可以推送该仓库,而无需明确克隆以跟踪历史记录。与主分支共享一些共同历史记录几乎是不可能的。
使用旧分支
由于 git 仓库包含 PostgreSQL 每个主要版本的各个分支,因此很容易使用旧版本的最新代码而不是当前版本。以下是如何列出可能性并检出旧版本
git branch -r git checkout -b REL_15_STABLE origin/REL_15_STABLE
请注意,如果你已经检出并使用了更高版本,你可能需要清理它留下的部分文件。建议运行
make maintainer-clean
尽可能地清除它们。你可能需要在 git 允许你执行检出之前删除一些遗留的文件(对于上面的特定示例,src/interfaces/ecpg/preproc/preproc.y 可能是一个问题)。
测试补丁
这是一个典型的设置,用于查看补丁文本文件,通常是通过电子邮件发送的
git checkout -b feature-to-review patch -p1 < feature.patch
如果补丁无法应用,就会留下 file.rej 文件,显示未应用的部分。如果你的目录树中没有构建信息,你可以很容易地使用以下方法找到它们
git status
补丁清理
补丁差异提交效果最好是作者对实际补丁进行一轮自我审查——不仅仅是代码,还有生成的物理差异文件。 创建干净的补丁 涵盖了通常用于生成更好的补丁差异输出的做法。
发布你的工作
如果你在较长时间内开发一个功能,你希望允许进行中间审查。传统的做法是将大型补丁通过电子邮件发送。我们想要尝试的更高级的方法(参见 Peter Eisentraut 的 博客条目)是,你将你的 Git 分支推送到 git.postgresql.org
上的私有区域,其他人可以在那里拉取你的工作,使用熟悉的 Git 工具操作它,甚至可以将改进以 Git 格式的补丁形式发送给你。查看 git.postgresql.org 网站,了解如何注册以及如何使用仓库。你可能最终需要通过电子邮件创建补丁,作为正式 提交补丁 的一部分。
推送新分支
如果你创建了一个新分支,通常用于新的功能测试,你需要将其推送到 git.postgresql.org。
git push origin new_feature_branch
注意,如果你有一个完全空白的仓库,那么甚至 "master" 分支也不存在,需要推送。
如果你在使用 postgresql 核心代码,请不要随意创建自己的分支并推送它们,而没有先在 pgsql-hackers 列表上清理。通常,你应该使用你的私有仓库区域。
删除分支
一旦你的功能被提交到 PostgreSQL 仓库,你通常可以删除你的本地功能分支。操作方法如下
# switch to a different branch git checkout master git branch -D my-cool-feature
使用 git hooks
Git hooks 是在发生某些事件(例如提交或推送)时运行的脚本。它们放置在你的 .git/hooks
目录中。这是一个示例脚本,用于检查你在提交代码时代码是否已正确缩进,并可以选择为你重新缩进它(通过将 PGAUTOINDENT
环境变量设置为 yes)。要使用它,请将其放在 .git/hooks/pre-commit
中,并使用 chmod +x .git/hooks/pre-commit
使其可执行
#!/bin/sh
set -u
: ${PGAUTOINDENT:=no}
# the files in the commit
if git diff --cached --name-only --diff-filter=ACMR | grep src/tools/pgindent/typedefs.list > /dev/null; then
# if typedefs.list is changed, we need to re-run pgindent on all files
files='src contrib'
else
files=$(git diff --cached --name-only --diff-filter=ACMR)
fi
check_indent () {
# no need to filter files - pgindent ignores everything that isn't a
# .c or .h file
if [ "$PGAUTOINDENT" = yes ] ; then
TEMPFILE=$(mktemp)
trap "rm $TEMPFILE" EXIT
if ! src/tools/pgindent/pgindent --check --diff $files > $TEMPFILE; then
patch -p0 < $TEMPFILE
echo "Commit abandoned. Rerun git add+commit to adopt pgindent changes"
exit 1
fi
elif ! src/tools/pgindent/pgindent --check $files; then
echo 'You need a pgindent run, e.g:'
echo -n 'src/tools/pgindent/pgindent '
if [ $files = 'src contrib' ]; then
echo $files
else
echo '$(git diff --name-only --diff-filter=ACMR)'
fi
exit 1
fi
}
# nothing to do if there are no files
test -z "$files" && exit 0
check_indent
使用 users/foo/postgres.git
在 git.postgresql.org 上请求项目时,一个选项是拥有主 postgresql 仓库的克隆。
这是一个非常好的功能,但是如何同步上游代码呢?
一种方法是在你自己的仓库中创建一个 git 克隆,并添加一个新的远程仓库来处理同步
# clone your repos git clone ssh://[email protected]/users/foo/postgres.git my_postgres
# add a new remote git remote add pgmaster https://git.postgresql.org/git/postgresql.git
# track some old versions git checkout -b REL8_3_STABLE origin/REL8_3_STABLE git checkout -b REL8_4_STABLE origin/REL8_4_STABLE
# change the remote of master and our old versions tracked git config branch.REL8_3_STABLE.remote pgmaster git config branch.REL8_4_STABLE.remote pgmaster git config branch.master.remote pgmaster
# pull from postgres official git for each branch # and finally push to origin git checkout master git pull git push origin git checkout REL8_3_STABLE git pull git push origin git checkout REL8_4_STABLE git pull git push origin
这样,PostgreSQL 就很容易为每个分支同步。从官方仓库拉取并推送到你自己的仓库。
创建你自己的分支并像往常一样工作。拥有 postgresql.git 本地克隆的用户可以在他们的仓库中添加你的分支,并且可以愉快地合并,就像你一样。
使用 Web 界面
尝试 https://git.postgresql.org/ 上的 Web 界面。它提供浏览、"blame" 功能、快照和其他高级功能,并且比 CVSweb 快得多。即使你不关心 Git 或版本控制系统,你也会喜欢这个 Web 界面。
RSS 订阅
Git 服务提供 RSS 订阅,用于报告对仓库的提交。有些人可能会发现这是一种替代订阅 pgsql-committers 邮件列表的方法。PostgreSQL 仓库的 RSS 订阅 URL 是 https://git.postgresql.org/gitweb/?p=postgresql.git;a=rss。还提供其他选项;它们可以在 Web 界面的 主页 上找到。
PostgreSQL 风格
PostgreSQL 源代码使用 4 个字符的制表符,这使得 git diff
的输出看起来很奇怪。你可以通过将以下内容放在你的 .git/config
文件中来解决此问题
[core] pager = less -x4
继续 "rsync the CVSROOT" 工作流
Aidan van Dyk 发布了一个很棒的教程,介绍如何使用历史对象的单个副本保留多个分支。这大致等同于保留 rsync'ed 的 CVSROOT 副本的多个检出,这正是某些提交者使用 CVS 时所做的事情。