-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
[feat][command] implements update-index
- Loading branch information
Showing
3 changed files
with
112 additions
and
2 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,74 @@ | ||
import sys | ||
from pathlib import Path | ||
|
||
import typer | ||
from typer import Option, Argument | ||
from typing_extensions import Optional, Annotated | ||
|
||
from xgit.types.index import get_index | ||
from xgit.utils.utils import find_repo | ||
|
||
|
||
def update_index( | ||
files: Annotated[Optional[list[str]], Argument(help="要更新的文件")] = None, | ||
add: Annotated[bool, Option("--add", help="如果文件在暂存区中不存在,则加入暂存区")] = False, | ||
remove: Annotated[bool, Option("--remove", help="如果文件在暂存区存在,但在本地不存在,则从暂存区移除")] = False, | ||
force_remove: Annotated[bool, Option("--force-remove", help="从暂存区移除文件,即使文件在本地存在")] = False, | ||
refresh: Annotated[bool, Option("--refresh", help="检查当前 index 中的文件是否需要 merge 或 update")] = False, | ||
verbose: Annotated[bool, Option("-v", help="详细输出添加和删除的文件")] = False, | ||
cacheinfo: Annotated[ | ||
Optional[list[str]], Option("--cacheinfo", help="与 `--add` 一同使用,用 `<mode>,<object>,<path>` 指定一个 blob 加入暂存区") | ||
] = None, | ||
): | ||
""" | ||
更新暂存区 | ||
""" | ||
# 如果没有 git repo,会报错 | ||
index = get_index() | ||
|
||
# === 检查参数正确性 === | ||
# add, remove, force_remove, refresh 互斥 | ||
if add + remove + force_remove + refresh > 1: | ||
typer.echo("fatal: only one of the options can be used", err=True) | ||
sys.exit(1) | ||
|
||
# refresh 不能与 files 同时使用 | ||
if refresh and files: | ||
typer.echo("fatal: --refresh cannot be used with files", err=True) | ||
sys.exit(1) | ||
|
||
# cacheinfo 必须与 add 同时使用 | ||
if cacheinfo and not add: | ||
typer.echo("fatal: --cacheinfo can only be used with --add", err=True) | ||
sys.exit(1) | ||
|
||
# files 中的路径会被 ignore;将 files 分为本地存在和本地不存在两部分 | ||
repo = find_repo().resolve() | ||
files = files or [] | ||
update_files = [] | ||
|
||
for f in files: | ||
file_path = Path(f).resolve() | ||
|
||
if not file_path.is_relative_to(repo): | ||
typer.echo(f"fatal: '{f}' is outside repository at '{repo}'", err=True) | ||
sys.exit(128) | ||
elif file_path.is_dir(): | ||
typer.echo(f"Ignoring path '{f}'", err=True) | ||
else: | ||
update_files.append(f) | ||
|
||
# === 执行操作 === | ||
# refresh:刷新 index 中的 metadata,报告需要 update 的文件 | ||
# 我们暂时忽略 merge 相关的状态 | ||
if refresh: | ||
# 对于 index 中的每个 entry,检查其 metadata 是否与本地一致 | ||
# 如果不一致,检查文件 sha 是否一致:如果一致,更新 metadata;否则报告 needs update | ||
pass | ||
|
||
# 如果没有 add, remove, force_remove | ||
if not (add or remove or force_remove): | ||
# 对于 files 中的每一项 | ||
# 如果本地或 index 不存在,报错 | ||
# 如果都存在,更新其状态 | ||
pass |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters