Skip to main content

多分支 worktree 管理工具

Project description

ypp

多分支 worktree 管理工具(支持 krepo-nggit)。

安装

pip install ypp

使用

  • 创建 worktree:
ypp add <path> <branch>

这会在 ~/<path>/wpsmain~/<path>/wpsweb 下分别创建或切换到 <branch>

  • 列出 worktree:
ypp list
  • 移除 worktree:
ypp remove <path>

这会移除 ~/<path>/wpsmain~/<path>/wpsweb 的 worktree,并删除整个 <path> 目录。

  • 配置管理:
ypp set work_dir=~/workspace  # 设置工作目录
ypp config                    # 显示当前配置
  • 修改配置和生成构建脚本(仅限 Linux):
ypp modify                    # 修改 wpsweb/server/Makefile 和生成 build_server.sh
ypp modify --force            # 强制在非 Linux 系统上运行(不推荐)

这会自动查找 wpsweb 目录,并执行以下操作:

  1. 修改 server/Makefile
    • 去掉 -Wl,-s 参数
    • -O2 修改为 -g
  2. 生成 build_server.sh
    • 清空文件内容并写入构建脚本
    • 动态替换路径变量(基于当前执行路径)
    • 自动设置执行权限

注意: modify 命令仅在 Linux 系统上支持,因为它需要修改 Makefile 和生成 shell 脚本。

  • 初始化仓库:
ypp init wpsmain             # 初始化 wpsmain 仓库
ypp init wpsweb              # 初始化 wpsweb 仓库
ypp init                     # 依次初始化 wpsmain 和 wpsweb 仓库

这会执行以下操作:

  1. wpsmain 初始化:在当前目录执行 krepo-ng init -b master_kso_v12 --bundle all
  2. wpsweb 初始化:在当前目录执行 git clone git@ksogit.kingsoft.net:wow/wpsweb.git
  • 自动编译 wpsmain:
ypp build                     # 自动编译 wpsmain

这会自动查找 wpsmain 目录,并在 Docker 中执行以下操作:

  1. 配置 weboffice:执行 krepo-ng config --new -x weboffice
  2. 检查目录:验证 debug_weboffice 目录是否创建成功
  3. 编译项目:在 debug_weboffice 目录中执行 krepo-ng build
  4. 执行构建脚本:查找并执行 wpsweb/build_server.sh 脚本

注意: build 命令需要在 Docker 环境中执行,使用 kdocker -r qt5 命令。

  • 读取和清除 PPTX 文件属性:
ypp pptattr <filepath>                    # 读取 PPTX 文件属性
ypp pptattr <filepath> --clean           # 清除指定属性并保存到原文件

这会执行以下操作:

  1. 读取属性:显示 PPTX 文件的核心属性、应用属性和自定义属性
  2. 清除属性(使用 --clean 参数时):
    • 清除核心属性中的 lastModifiedBy
    • 清除自定义属性中的 ICV
    • 保持原有的 XML 结构,确保与 Office 应用程序兼容
    • 自动保存到原文件

注意: pptattr 命令只支持 .pptx 格式的文件。使用 --clean 参数会直接修改原文件,建议先备份。

  • WSL 端口转发管理:
ypp wsl port <本机端口> <WSL端口>        # 添加端口转发
ypp wsl port remove <本机端口>           # 移除端口转发
ypp wsl port list                       # 列出所有端口转发规则

这会执行以下操作:

  1. 添加端口转发:将本机的指定端口转发到 WSL 中的指定端口
  2. 移除端口转发:删除指定的端口转发规则
  3. 列出规则:显示当前所有的端口转发规则

注意: wsl port 命令仅在 Windows 系统上支持。添加和移除端口转发需要管理员权限,系统会自动检测并请求权限。查看端口转发规则不需要管理员权限。

依赖

  • 需要本机已安装并在 PATH 中可用:krepo-nggit
  • 配置文件位置:~/.ypp.json

许可

MIT

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

ypp-0.3.6.tar.gz (18.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

ypp-0.3.6-py3-none-any.whl (21.5 kB view details)

Uploaded Python 3

File details

Details for the file ypp-0.3.6.tar.gz.

File metadata

  • Download URL: ypp-0.3.6.tar.gz
  • Upload date:
  • Size: 18.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.10.12

File hashes

Hashes for ypp-0.3.6.tar.gz
Algorithm Hash digest
SHA256 7fc27bb8a84475b646f9b2f2797700425fd9ec54c69e7468841a60d4555c8a95
MD5 b335763aa1e697cc574aee64497b7ca6
BLAKE2b-256 a024ac07d3f16bd8ccf55640837d981cd934936eee7d81eb37b689fb010d3b0c

See more details on using hashes here.

File details

Details for the file ypp-0.3.6-py3-none-any.whl.

File metadata

  • Download URL: ypp-0.3.6-py3-none-any.whl
  • Upload date:
  • Size: 21.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.10.12

File hashes

Hashes for ypp-0.3.6-py3-none-any.whl
Algorithm Hash digest
SHA256 bae7b01fef68eb1b07b23a84f925569bbf5f944d5bb93ae26c8c93266d9b1252
MD5 abd877ba1e8f99d71538f2f34c55060b
BLAKE2b-256 06af6170b1397fd4e6385fcf3cc1231fa0ac4c44d37d80d566dc87656b96eee1

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page