Skip to main content

Multi-language automated build tool with domestic mirror acceleration support

Project description

🚀 AutoBuild

多语言自动化构建工具
支持前端 pnpm、后端 Go、Python,一键加速国内镜像

PyPI version Python versions License Build Status

特性快速开始IDE 集成安装详细文档许可证


✨ 特性

🎯 多语言支持

  • Go - 支持多入口编译、交叉编译
  • Python - 自动检测 Poetry/Setuptools/PDM
  • PNPM - 自动检测项目根目录

⚡ 镜像加速

  • 自动配置国内镜像源
  • 提升依赖下载速度
  • 支持切换多种镜像

🔧 开发者友好

  • 完整的类型注解
  • 统一的 API 接口
  • CLI 命令行支持

🚀 快速开始

安装

pip install multi-lang-build

1. 构建 Go 项目(支持多入口)

from multi_lang_build import GoCompiler
from pathlib import Path

compiler = GoCompiler()

# 指定入口文件编译(同一目录多 main 文件)
compiler.build_binary(
    source_dir=Path("./myproject"),
    output_path=Path("./bin/server"),
    target="server.go",  # 🎯 指定入口文件
    mirror_enabled=True
)

# 指定子目录编译(cmd 结构)
compiler.build_binary(
    source_dir=Path("./myproject"),
    output_path=Path("./bin/client"),
    target="./cmd/client",  # 📁 指定包路径
    mirror_enabled=True
)

2. 构建 Python 项目

from multi_lang_build import PythonCompiler

compiler = PythonCompiler()

# 自动检测并安装依赖(支持 Poetry/Setuptools/PDM)
compiler.install_dependencies(
    source_dir=Path("./myproject"),
    mirror_enabled=True,
    dev=True
)

# 构建项目
compiler.build(
    source_dir=Path("./myproject"),
    output_dir=Path("./dist"),
    mirror_enabled=True
)

3. 构建前端项目

from multi_lang_build import PnpmCompiler

compiler = PnpmCompiler()

# 自动检测项目根目录(支持子目录调用)
compiler.build(
    source_dir=Path("./packages/ui/src"),  # 即使在子目录也能正确构建
    output_dir=Path("./dist"),
    mirror_enabled=True
)

🎯 IDE 集成

将 multi-lang-build 注册为 IDE 技能,获得更智能的构建体验。

支持的 IDE

IDE 命令 说明
🤖 Claude Code multi-lang-build register 默认,AI 助手原生支持
💠 OpenCode multi-lang-build register opencode 智能代码助手集成
🔷 Trae multi-lang-build register trae 字节跳动 AI IDE
🎯 CodeBuddy multi-lang-build register codebuddy 代码伙伴插件

注册 Claude Code(默认)

# 默认注册到 Claude Code
multi-lang-build register

# 或使用完整命令
multi-lang-build register claude

注册其他 IDE

# 注册到 OpenCode
multi-lang-build register opencode

# 注册到 Trae
multi-lang-build register trae

# 注册到 CodeBuddy
multi-lang-build register codebuddy

注册功能说明

注册命令会将 skill 配置添加到指定 IDE 的配置目录:

  • Claude Code: ~/.claude/CLAUDE.md - 添加构建技能配置
  • OpenCode: ~/.opencode/skill/multi-lang-build.md - 技能描述文件
  • Trae: ~/.trae/.trae/.rules - IDE 规则文件
  • CodeBuddy: ~/.codebuddy/agents/multi-lang-build.yaml - Agent 配置文件

注册后,IDE 将自动识别项目类型并提供智能构建建议。

📦 安装

使用 pip 安装

# 基础安装
pip install multi-lang-build

# 开发环境(包含测试工具)
pip install multi-lang-build[dev]

系统要求

  • Python 3.11+
  • 对应语言的构建工具:
    • Go: go 命令
    • Python: python3pip
    • PNPM: pnpmnode

📚 详细文档

语言 文档 说明
🐹 Go go.md 多入口编译、交叉编译、target 参数详解
🐍 Python python.md 依赖管理、虚拟环境、构建系统检测
📦 PNPM pnpm.md 项目根目录检测、Monorepo 支持、镜像配置

🛠️ CLI 命令行

# Go 项目构建
go-build ./myproject --output ./bin/app --target server.go --mirror

# Python 项目构建  
python-build ./myproject --output ./dist --mirror

# PNPM 项目构建
pnpm-build ./myproject --output ./dist --mirror

# 注册到 IDE(默认 Claude Code)
multi-lang-build register

# 注册到指定 IDE
multi-lang-build register opencode
multi-lang-build register trae
multi-lang-build register codebuddy

🌟 核心特性对比

特性 GoCompiler PythonCompiler PnpmCompiler
自动检测项目 ✅ go.mod ✅ pyproject.toml/setup.py ✅ package.json
多入口支持 target 参数 ✅ 自动检测
镜像加速 ✅ goproxy.cn ✅ 清华/阿里云等 ✅ npmmirror
CLI 支持 ✅ go-build ✅ python-build ✅ pnpm-build
类型安全 ✅ Type Hints ✅ Type Hints ✅ Type Hints

📝 示例项目

Go 多入口项目

myproject/
├── go.mod
├── server.go          # package main - API 服务
├── client.go          # package main - CLI 工具
└── worker.go          # package main - 后台任务
# 构建所有入口
compiler = GoCompiler()

entries = ["server.go", "client.go", "worker.go"]
for entry in entries:
    name = entry.replace(".go", "")
    compiler.build_binary(
        source_dir=Path("./myproject"),
        output_path=Path(f"./bin/{name}"),
        target=entry
    )

Python Poetry 项目

myproject/
├── pyproject.toml     # Poetry 配置
├── poetry.lock
└── src/
    └── mypackage/
# 一键安装依赖并构建
compiler = PythonCompiler()
compiler.install_dependencies(source_dir=Path("./myproject"), dev=True)
compiler.build(source_dir=Path("./myproject"), output_dir=Path("./dist"))

前端 Monorepo

monorepo/
├── package.json
├── pnpm-workspace.yaml
└── packages/
    ├── ui/
    ├── utils/
    └── app/
# 批量构建所有包
compiler = PnpmCompiler()

for pkg in ["ui", "utils", "app"]:
    compiler.build(
        source_dir=Path(f"./packages/{pkg}"),
        output_dir=Path(f"./packages/{pkg}/dist")
    )

🤝 贡献

欢迎提交 Issue 和 Pull Request!

📄 许可证

MIT © Multi-Lang Build Team


用 ❤️ 构建 | 让多语言开发更简单

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

multi_lang_build-0.2.3.tar.gz (29.8 kB view details)

Uploaded Source

Built Distribution

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

multi_lang_build-0.2.3-py3-none-any.whl (34.1 kB view details)

Uploaded Python 3

File details

Details for the file multi_lang_build-0.2.3.tar.gz.

File metadata

  • Download URL: multi_lang_build-0.2.3.tar.gz
  • Upload date:
  • Size: 29.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.2

File hashes

Hashes for multi_lang_build-0.2.3.tar.gz
Algorithm Hash digest
SHA256 150790759b18c4984d16817d6fc040bd62f5c55808f7112d014fb6ee55e36f37
MD5 92c7a68ec19cd9e7e8173a978632e1fd
BLAKE2b-256 26d4ad7c22281b2348439e16b2aeffa4afa0bcfa5404db8561d02255fd4ace7e

See more details on using hashes here.

File details

Details for the file multi_lang_build-0.2.3-py3-none-any.whl.

File metadata

File hashes

Hashes for multi_lang_build-0.2.3-py3-none-any.whl
Algorithm Hash digest
SHA256 cb796461359d27fb0c989b63af70718d8659fda7a723e84f5288dbf2e8b9818a
MD5 4b8f48efbf02fb7cfa0ec6ab5e71a960
BLAKE2b-256 9251dd1ab18bb1d56e5d5a5662ff3a3738950e9952c223953fa9e73e466b91a5

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