|
|
# 代码仓库[](#代码仓库 "Permalink")
|
|
|
# 代码仓库[](#repository "Permalink")
|
|
|
|
|
|
[存储库](https://git-scm.com/book/en/v2/Git-Basics-Getting-a-Git-Repository)是用于将代码库存储在 GitLab 中并通过版本控制对其进行更改的存储库. 存储库是[项目的](../index.html)一部分,它具有许多其他功能.
|
|
|
[代码仓库](https://git-scm.com/book/en/v2/Git-Basics-Getting-a-Git-Repository)是用于将代码库存储在 CODEChina 中并通过版本控制对其进行更改的存储库。代码仓库是[项目](/docs/user/project.md)的一部分,它具有许多其他功能。
|
|
|
|
|
|
## Create a repository[](#create-a-repository "Permalink")
|
|
|
## 新建一个代码仓库[](#create-a-repository "Permalink")
|
|
|
|
|
|
要创建一个新的存储库,您需要做的就是[创建一个新项目](../../../gitlab-basics/create-project.html)或[创建](../../../gitlab-basics/create-project.html) [一个现有项目](forking_workflow.html) .
|
|
|
要创建一个新的代码仓库,您需要做的就是[创建一个新项目](/docs/basic/create-project.md)或 fork 一个现有项目。
|
|
|
|
|
|
创建新项目后,您可以通过 UI(请参阅以下部分)或通过命令行添加新文件. 要从命令行添加文件,请遵循创建新项目时在屏幕上显示的说明,或在[命令行基础](../../../gitlab-basics/start-using-git.html)文档中通读它们.
|
|
|
创建新项目后,您可以通过界面或通过命令行添加新文件, 要从命令行添加文件,请遵循创建新项目时在屏幕上显示的说明。
|
|
|
|
|
|
> **重要提示:**出于安全原因,强烈建议您在使用命令行时[通过 SSH 与 GitLab 连接](../../../ssh/README.html) .
|
|
|
> **重要提示:**出于安全原因,强烈建议您在使用命令行时[通过 SSH 与 GitLab 连接](/docs/ssh.md) 。
|
|
|
|
|
|
## Files[](#files "Permalink")
|
|
|
## 文件[](#files "Permalink")
|
|
|
|
|
|
使用存储库将文件存储在 GitLab 中. 在[GitLab 12.10 及更高版本中](https://gitlab.com/gitlab-org/gitlab/-/issues/33806) ,您将在存储库的文件树中根据其扩展名在文件名旁边看到一个图标:
|
|
|
在 CODEChina 上我们使用代码仓库来存储您的文件,您将在代码仓库的文件树中在文件名旁边看到一个与其扩展名称想对应的图标。
|
|
|
|
|
|
[![Repository file icons](img/8489a6c45ad75964ea7b4b54b9d9fcaa.png)](img/file_ext_icons_repo_v12_10.png)
|
|
|
### 新建和编辑文件[](#create-and-edit-files "Permalink")
|
|
|
|
|
|
### Create and edit files[](#create-and-edit-files "Permalink")
|
|
|
|
|
|
通过将文件推送到 GitLab,将代码库托管在 GitLab 存储库中. 您可以使用用户界面(UI),也可以[通过命令行将](../../../gitlab-basics/command-line-commands.html#start-working-on-your-project)本地计算机与 GitLab 连接.
|
|
|
|
|
|
要配置[GitLab CI / CD](../../../ci/README.html)来构建,测试和部署代码,请在存储库的根目录中添加一个名为[`.gitlab-ci.yml`](../../../ci/quick_start/README.html)的文件.
|
|
|
通过将文件推送到 CODEChina,您就可以将代码库托管在代码仓库中。您可以使用用户界面也可以通过命令行将本地计算机与我们相连。
|
|
|
|
|
|
**从用户界面:**
|
|
|
|
|
|
GitLab 的用户界面允许您执行许多 Git 命令,而无需触摸命令行. 即使您定期使用命令行,有时[通过 GitLab UI](web_editor.html)也更容易做到:
|
|
|
|
|
|
* [Create a file](web_editor.html#create-a-file)
|
|
|
* [Upload a file](web_editor.html#upload-a-file)
|
|
|
* [File templates](web_editor.html#template-dropdowns)
|
|
|
* [Create a directory](web_editor.html#create-a-directory)
|
|
|
* [Start a merge request](web_editor.html#tips)
|
|
|
* [Find file history](git_history.html)
|
|
|
* [Identify changes by line (Git blame)](git_blame.html)
|
|
|
用户界面允许您执行许多 Git 命令,而无在命令行中执行命令。您可以通过用户界面很容易的实现以下操作:
|
|
|
|
|
|
**在命令行中:**
|
|
|
* [新建文件](/docs/user/project/repo/web-editor.md#create-a-file)
|
|
|
* [上传文件](/docs/user/project/repo/web-editor.md#upload-a-file)
|
|
|
* [文件模板](/docs/user/project/repo/web-editor.md#template-dropdowns)
|
|
|
* [新建目录](/docs/user/project/repo/web-editor.md#create-a-directory)
|
|
|
* [新建合并请求](/docs/user/project/repo/web-editor.md#tips)
|
|
|
* [查找文件](/docs/user/project/repo/file-find.md)
|
|
|
* [blame](/docs/user/project/repo/blame.md))
|
|
|
|
|
|
要开始使用命令行,请通读[命令行基础文档](../../../gitlab-basics/command-line-commands.html) .
|
|
|
### 查找文件[](#find-files "Permalink")
|
|
|
|
|
|
### Find files[](#find-files "Permalink")
|
|
|
使用[文件查找器](/docs/user/project/repo/file-find.md)在代码仓库中搜索文件。
|
|
|
|
|
|
使用 GitLab 的[文件查找器](file_finder.html)在存储库中搜索文件.
|
|
|
### 支持的语言标记[](#supported-markup-languages-and-extensions "Permalink")
|
|
|
|
|
|
### Supported markup languages and extensions[](#supported-markup-languages-and-extensions "Permalink")
|
|
|
我们支持多种标记语言(有时称为[轻量标记语言](https://en.wikipedia.org/wiki/Lightweight_markup_language) ),您可以将其用于存储库中文件的内容,它们主要用于文档目的。
|
|
|
|
|
|
GitLab 支持多种标记语言(有时称为[轻量标记语言](https://en.wikipedia.org/wiki/Lightweight_markup_language) ),您可以将其用于存储库中文件的内容. 它们主要用于文档目的.
|
|
|
只需为文件选择正确的扩展名,系统就会根据标记语言来渲染它们。
|
|
|
|
|
|
只需为文件选择正确的扩展名,GitLab 就会根据标记语言来渲染它们.
|
|
|
|
|
|
| 标记语言 | Extensions |
|
|
|
| 标记语言 | 扩展名 |
|
|
|
| --- | --- |
|
|
|
| 纯文本 | `txt` |
|
|
|
| [Markdown](../../markdown.html) | `mdown`, `mkd`, `mkdn`, `md`, `markdown` |
|
|
|
| [Markdown](/docs/user/markdown.md) | `mdown`, `mkd`, `mkdn`, `md`, `markdown` |
|
|
|
| [reStructuredText](https://docutils.sourceforge.io/rst.html) | `rst` |
|
|
|
| [AsciiDoc](../../asciidoc.html) | `adoc`, `ad`, `asciidoc` |
|
|
|
| AsciiDoc | `adoc`, `ad`, `asciidoc` |
|
|
|
| [Textile](https://textile-lang.com/) | `textile` |
|
|
|
| [rdoc](http://rdoc.sourceforge.net/doc/index.html) | `rdoc` |
|
|
|
| [Org mode](https://orgmode.org/) | `org` |
|
|
|
| [creole](http://www.wikicreole.org/) | `creole` |
|
|
|
| [MediaWiki](https://www.mediawiki.org/wiki/MediaWiki) | `wiki`, `mediawiki` |
|
|
|
|
|
|
### Repository README and index files[](#repository-readme-and-index-files "Permalink")
|
|
|
### 项目 Readme 和 Index 文件[](#repository-readme-and-index-files "Permalink")
|
|
|
|
|
|
当存储库中存在`README`或`index`文件时,它的内容将由 GitLab 自动预渲染,而无需打开它.
|
|
|
当代码仓库中存在`README`或`index`文件时,我们将自动渲染他们的内容,用户无需打开它。
|
|
|
|
|
|
它们可以是纯文本,也可以具有[受支持的标记语言](#supported-markup-languages-and-extensions)的扩展名:
|
|
|
|
|
|
有关优先级的一些注意事项:
|
|
|
|
|
|
1. 当`README`文件和`index`文件同时存在时, `README`文件将始终优先.
|
|
|
2. 如果存在多个具有不同扩展名的文件,则按字母顺序排列,但不带扩展名的文件例外,该扩展名始终优先. 例如, `README.adoc`将优先于`README.md` ,而`README.rst`将优先于`README` .
|
|
|
1. 当`README`文件和`index`文件同时存在时, `README`文件将始终优先
|
|
|
2. 如果存在多个具有不同扩展名的文件,则按字母顺序排列,但不带扩展名的文件例外,该扩展名始终优先。例如, `README.adoc`将优先于`README.md` ,而`README.rst`将优先于`README`
|
|
|
|
|
|
### Jupyter Notebook files[](#jupyter-notebook-files "Permalink")
|
|
|
|
|
|
[Jupyter](https://jupyter.org/) Notebook(以前的 IPython Notebook)文件用于许多领域的交互式计算,并且包含用户会话的完整记录,并包括代码,叙述性文本,方程式和丰富的输出.
|
|
|
|
|
|
[Read how to use Jupyter notebooks with GitLab.](jupyter_notebooks/index.html)
|
|
|
[Jupyter](https://jupyter.org/) Notebook(以前的 IPython Notebook)文件用于许多领域的交互式计算,并且包含用户会话的完整记录,并包括代码,叙述性文本,方程式和丰富的输出。
|
|
|
|
|
|
### OpenAPI viewer[](#openapi-viewer "Permalink")
|
|
|
|
|
|
在 GitLab 12.6 中[引入](https://gitlab.com/gitlab-org/gitlab/-/issues/19515) .
|
|
|
|
|
|
如果文件名包含`openapi`或`swagger`且扩展名为`yaml` , `yml`或`json` ,则 GitLab 可以使用其文件查看器呈现 OpenAPI 规范文件. 以下示例都是正确的:
|
|
|
如果文件名包含`openapi`或`swagger`且扩展名为`yaml` , `yml`或`json` ,就可以使用其文件查看器呈现 OpenAPI 规范文件。以下示例都是正确的:
|
|
|
|
|
|
* `openapi.yml`
|
|
|
* `openapi.yaml`
|
... | ... | @@ -99,83 +87,61 @@ GitLab 支持多种标记语言(有时称为[轻量标记语言](https://en.wi |
|
|
|
|
|
然后,渲染它们:
|
|
|
|
|
|
1. 在 GitLab 的用户界面中导航至存储库中的 OpenAPI 文件.
|
|
|
1. 用户界面中导航至存储库中的 OpenAPI 文件.
|
|
|
2. 单击位于"显示源"和"编辑"按钮之间的"显示 OpenAPI"按钮(找到 OpenAPI 文件后,它将替换"显示渲染的文件"按钮).
|
|
|
|
|
|
## Branches[](#branches "Permalink")
|
|
|
## 分支[](#branches "Permalink")
|
|
|
|
|
|
有关详细信息,请参见[分支](branches/index.html) .
|
|
|
有关详细信息,请参见[分支](/docs/user/project/repo/branches.md) 。
|
|
|
|
|
|
## Commits[](#commits "Permalink")
|
|
|
## 提交[](#commits "Permalink")
|
|
|
|
|
|
[提交更改时](https://git-scm.com/book/en/v2/Git-Basics-Recording-Changes-to-the-Repository) ,您会将这些更改引入分支机构. 通过命令行,您可以在提交之前多次提交.
|
|
|
[提交更改时](https://git-scm.com/book/en/v2/Git-Basics-Recording-Changes-to-the-Repository) ,您会将这些更改引入分支机构。通过命令行,您可以在提交之前多次提交。
|
|
|
|
|
|
* **提交消息:**提交消息对于标识正在更改的内容以及更重要的原因至关重要. 在 GitLab 中,您可以将关键字添加到提交消息中,以执行以下操作之一:
|
|
|
* **触发 GitLab CI / CD 管道:**如果您的项目配置有[GitLab CI / CD](../../../ci/README.html) ,则将在每次推送而不是每次提交时触发一个管道.
|
|
|
* **跳过管道:**您可以在提交消息中添加关键字[`[ci skip]`](../../../ci/yaml/README.html#skip-pipeline) ,GitLab CI / CD 将跳过该管道.
|
|
|
* **交叉链接问题和合并请求:** [交叉链接](../issues/crosslinking_issues.html#from-commit-messages)非常适合跟踪工作流程中与之相关的内容. 如果您在提交消息中提到问题或合并请求,它们将显示在各自的线程上.
|
|
|
* **樱桃选择提交:**在 GitLab 中,您可以直接从 UI [樱桃选择提交](../merge_requests/cherry_pick_changes.html#cherry-picking-a-commit) .
|
|
|
* **还原提交:**轻松[将提交](../merge_requests/revert_changes.html#reverting-a-commit)从 UI [还原](../merge_requests/revert_changes.html#reverting-a-commit)到所选分支.
|
|
|
* **签署提交:**使用 GPG [签署您的提交](gpg_signed_commits/index.html) .
|
|
|
|
|
|
## Project and repository size[](#project-and-repository-size "Permalink")
|
|
|
|
|
|
在项目的" **详细信息"**页面上报告项目的大小. 报告的大小最多每 15 分钟更新一次,因此可能无法反映最近的活动. 显示的文件大小包括存储库文件,工件和 LFS.
|
|
|
|
|
|
由于压缩,内务处理和其他因素,每个项目的项目规模可能会略有不同.
|
|
|
* **交叉链接问题和合并请求:** [交叉链接](/docs/user/project/issues/crosslinking.md#from-commit-messages)非常适合跟踪工作流程中与之相关的内容. 如果您在提交消息中提到问题或合并请求,它们将显示在各自的线程上
|
|
|
* ** Cherry-pick 提交:**您可以直接从界面 [cherry-pick](/docs/user/project/merge-request/cherry-pick.md)
|
|
|
* **Revert 提交:**可以将提交从界面[还原](/docs/user/project/merge-request/revert.md#reverting-a-commit)到所选分支
|
|
|
* **签署提交:**使用 GPG [签署您的提交](/docs/user/project/repo/gpg-sign.md)
|
|
|
|
|
|
[储存库大小限制](../../admin_area/settings/account_and_limit_settings.html)可以由管理员设置. GitLab.com 的存储库大小限制[由 GitLab 设置](../../gitlab_com/index.html#repository-size-limit) .
|
|
|
## 项目和仓库大小[](#project-and-repository-size "Permalink")
|
|
|
|
|
|
## Contributors[](#contributors "Permalink")
|
|
|
在项目的**详细信息**页面上报告项目的大小 报告的大小最多每 15 分钟更新一次,因此可能无法反映最近的活动。显示的文件大小包括存储库文件,工件和 LFS。
|
|
|
|
|
|
代码库的所有贡献者都显示在项目的**设置>贡献者下** .
|
|
|
由于压缩,内务处理和其他因素,每个项目的项目规模可能会略有不同。
|
|
|
|
|
|
它们是从协作者中以最少的提交次数排序的,并显示在一个漂亮的图形上:
|
|
|
## 贡献者[](#contributors "Permalink")
|
|
|
|
|
|
[![contributors to code](img/d69ab181c07176aa054b0ceac08b702c.png)](img/contributors_graph.png)
|
|
|
代码库的所有贡献者都显示在项目的**代码>贡献者下**,按照协作者中的提交次数从多到少排序。
|
|
|
|
|
|
## Repository graph[](#repository-graph "Permalink")
|
|
|
## 分析[](#repository-graph "Permalink")
|
|
|
|
|
|
存储库图形以可视方式显示存储网络的历史记录,包括分支和合并. 这可以帮助您可视化存储库中使用的 Git 流策略:
|
|
|
代码仓库分析以可视方式显示存储网络的历史记录,包括分支和合并。这可以帮助您可视化存储库中使用的 Git 流策略:
|
|
|
|
|
|
[![repository Git flow](img/a1efb7c23a97e2901852465c9168914f.png)](img/repo_graph.png)
|
|
|
在您项目的**分析**下找到它。
|
|
|
|
|
|
在您项目的**Repository> Graph**下找到它.
|
|
|
## 代码语言[](#repository-languages "Permalink")
|
|
|
|
|
|
## Repository Languages[](#repository-languages "Permalink")
|
|
|
对于每个代码仓库的默认分支,系统将确定使用了哪些编程语言,并将其显示在项目页面上。如果缺少此信息,将在更新项目上的默认分支后添加,此过程最多可能需要 5 分钟。
|
|
|
|
|
|
对于每个存储库的默认分支,GitLab 将确定使用了哪种编程语言,并将其显示在项目页面上. 如果缺少此信息,将在更新项目上的默认分支后添加. 此过程最多可能需要 5 分钟.
|
|
|
并非所有文件都被检测到,比如文档、供应商代码和大多数标记语言都不会被检测。可以通过重写默认值来调整此行为。例如,为了能够检测到“.proto”文件,请在存储库根目录下的“.gittributes”中添加以下内容:
|
|
|
|
|
|
[![Repository Languages bar](img/e2e835cd5cd1be1afaa876fde2475fe5.png)](img/repository_languages_v12_2.gif)
|
|
|
|
|
|
Not all files are detected, among others; documentation, vendored code, and most markup languages are excluded. This behavior can be adjusted by overriding the default. For example, to enable `.proto` files to be detected, add the following to `.gitattributes` in the root of your repository.
|
|
|
|
|
|
```
|
|
|
```markdown
|
|
|
*.proto linguist-detectable=true
|
|
|
```
|
|
|
|
|
|
## Locked files[](#locked-files-premium "Permalink")
|
|
|
## 锁定文件[](#locked-files-premium "Permalink")
|
|
|
|
|
|
使用[文件锁定](../file_lock.html)来锁定文件,以防止发生任何冲突的更改.
|
|
|
使用文件锁定来锁定文件,以防止发生任何冲突的更改.
|
|
|
|
|
|
## Repository’s API[](#repositorys-api "Permalink")
|
|
|
|
|
|
您可以通过[存储库 API](../../../api/repositories.html)访问您的[存储库](../../../api/repositories.html) .
|
|
|
|
|
|
## Clone in Apple Xcode[](#clone-in-apple-xcode "Permalink")
|
|
|
|
|
|
[Introduced](https://gitlab.com/gitlab-org/gitlab-foss/-/issues/45820) in GitLab 11.0
|
|
|
|
|
|
现在,可以使用位于用于克隆项目的 Git URL 旁边的新的" **在 Xcode 中打开"**按钮**在 Xcode 中**克隆包含`.xcodeproj`或`.xcworkspace`目录的项目. 该按钮仅在 macOS 上显示.
|
|
|
|
|
|
## Download Source Code[](#download-source-code "Permalink")
|
|
|
|
|
|
在 GitLab 11.11 中[引入](https://gitlab.com/gitlab-org/gitlab-foss/-/issues/24704)了对目录下载的支持.
|
|
|
您可以通过存储库 API访问您的存储库。
|
|
|
|
|
|
可以从 UI 下载存储在存储库中的源代码. 单击下载图标,将打开一个下拉列表,其中包含下载以下内容的链接:
|
|
|
## 下载源码[](#download-source-code "Permalink")
|
|
|
|
|
|
[![Download source code](img/0f88b0e1a49600472f2922218cec1ed7.png)](img/download_source_code.png)
|
|
|
可以从界面下载存储在代码仓库中的源代码,单击下载图标,将打开一个下拉列表,其中包含下载以下内容的链接:
|
|
|
|
|
|
* **源代码:**允许用户在他们当前正在查看的分支上下载源代码. 可用扩展名: `zip` , `tar` , `tar.gz`和`tar.bz2` .
|
|
|
* **目录:**仅在查看子目录时显示. 这使用户可以下载他们当前正在查看的特定目录. 也可以在`zip` , `tar` , `tar.gz`和`tar.bz2` .
|
|
|
* **工件:**允许用户下载最新 CI 构建的工件. |
|
|
\ No newline at end of file |
|
|
* **源代码:**允许用户在他们当前正在查看的分支上下载源代码。 可用扩展名: `zip` , `tar` , `tar.gz`和`tar.bz2`
|
|
|
* **目录:**仅在查看子目录时显示, 这使用户可以下载他们当前正在查看的特定目录, 也可以在`zip` , `tar` , `tar.gz`和`tar.bz2`
|
|
|
* **工件:**允许用户下载最新 CI 构建的工件 |
|
|
\ No newline at end of file |