mirror of
https://code.forgejo.org/actions/checkout.git
synced 2024-12-23 04:05:59 +01:00
revise adr to support submodules (#157)
This commit is contained in:
parent
f219062370
commit
204620207c
1 changed files with 15 additions and 3 deletions
|
@ -60,13 +60,17 @@ We want to take this opportunity to make behavioral changes, from v1. This docum
|
||||||
lfs:
|
lfs:
|
||||||
description: 'Whether to download Git-LFS files'
|
description: 'Whether to download Git-LFS files'
|
||||||
default: false
|
default: false
|
||||||
|
submodules:
|
||||||
|
description: >
|
||||||
|
Whether to checkout submodules: `true` to checkout submodules or `recursive` to
|
||||||
|
recursively checkout submodules.
|
||||||
|
default: 'false'
|
||||||
```
|
```
|
||||||
|
|
||||||
Note:
|
Note:
|
||||||
- SSH support is new
|
- SSH support is new
|
||||||
- `persist-credentials` is new
|
- `persist-credentials` is new
|
||||||
- `path` behavior is different (refer [below](#path) for details)
|
- `path` behavior is different (refer [below](#path) for details)
|
||||||
- `submodules` was removed (error if specified; add later if needed)
|
|
||||||
|
|
||||||
### Fallback to GitHub API
|
### Fallback to GitHub API
|
||||||
|
|
||||||
|
@ -74,7 +78,7 @@ When a sufficient version of git is not in the PATH, fallback to the [web API](h
|
||||||
|
|
||||||
Note:
|
Note:
|
||||||
- LFS files are not included in the archive. Therefore fail if LFS is set to true.
|
- LFS files are not included in the archive. Therefore fail if LFS is set to true.
|
||||||
- Submodules are also not included in the archive. However submodules are not supported by checkout v2 anyway.
|
- Submodules are also not included in the archive.
|
||||||
|
|
||||||
### Persist credentials
|
### Persist credentials
|
||||||
|
|
||||||
|
@ -95,7 +99,6 @@ Note:
|
||||||
- The auth header is scoped to all of github `http.https://github.com/.extraheader`
|
- The auth header is scoped to all of github `http.https://github.com/.extraheader`
|
||||||
- Additional public remotes also just work.
|
- Additional public remotes also just work.
|
||||||
- If users want to authenticate to an additional private remote, they should provide the `token` input.
|
- If users want to authenticate to an additional private remote, they should provide the `token` input.
|
||||||
- Lines up if we add submodule support in the future. Don't need to worry about calculating relative URLs. Just works, although needs to be persisted in each submodule git config.
|
|
||||||
|
|
||||||
#### SSH key
|
#### SSH key
|
||||||
|
|
||||||
|
@ -229,6 +232,15 @@ A better solution is:
|
||||||
|
|
||||||
Given a source file path, walk up the directories until the first `.git/config` is found. Check if it matches the self repo (`url = https://github.com/OWNER/REPO`). If not, drop the source file path.
|
Given a source file path, walk up the directories until the first `.git/config` is found. Check if it matches the self repo (`url = https://github.com/OWNER/REPO`). If not, drop the source file path.
|
||||||
|
|
||||||
|
### Submodules
|
||||||
|
|
||||||
|
With both PAT and SSH key support, we should be able to provide frictionless support for
|
||||||
|
submodules scenarios: recursive, non-recursive, relative submodule paths.
|
||||||
|
|
||||||
|
When fetching submodules, follow the `fetch-depth` settings.
|
||||||
|
|
||||||
|
Credentials will be persisted in the submodules local git config too.
|
||||||
|
|
||||||
### Port to typescript
|
### Port to typescript
|
||||||
|
|
||||||
The checkout action should be a typescript action on the GitHub graph, for the following reasons:
|
The checkout action should be a typescript action on the GitHub graph, for the following reasons:
|
||||||
|
|
Loading…
Reference in a new issue