Skip to main content

No project description provided

Project description

Mina Package Structure

简体中文 | English

Mina 是基于 pdm-backend 的 "模块分包" 实现.

Mina 同样也是 Mina Package Structure 的实现, 作为一门独特的规范, 其具有以下特性:

  • 将整个项目作为工作区环境, 通过现有的设施统一管理所有分包使用的依赖树;
  • 分包各自声明自己的信息和工作区中引用的依赖;
  • pdm-backend 构建发布时所读取的 Metadata 进行修补以复用其构建流程;
  • 通过提供完整的 PEP-517 构建后端 (build backend), 避免了一些潜在的问题.

Mina 提供了名为 mina-buildPEP-517 实现, 同时还提供作为 PDM Plugin 的简易 CLI 实现;

mina-build 仅在配置了需要构建的分包名称时才会注入 pdm-backend 的构建流程, 其他情况下的行为与 pdm-backend 无异.

CLI 中虽提供了一个 pdm mina build <package> 指令, 但你也可以通过环境变量 MINA_BUILD_TARGET 或是 config-setting 中设置 mina-target 指定需要打包的分包.

Quick Start

安装插件

目前, Mina 仅支持将 pdm 作为主要的用户功能入口, 但或许 poetry 会在之后得到支持?

elaina@localhost $ pipx inject pdm pdm-mina
# or pdm
elaina@localhost $ pdm self add pdm-mina

或者在 pyproject.toml 指定:

[tool.pdm]
plugins = ["pdm-mina"]

然后运行:

elaina@localhost $ pdm install --plugins

运行成功后将在当前项目中启用 pdm-mina 插件。

引入 mina-build

在项目的 pyproject.toml 中配置以下项:

[build-system]
requires = ["mina-build>=0.2.5"]
build-backend = "pdm.backend"

编辑 pyproject.toml

假设你有如下的目录结构:

mina-example/
├── avilla/
│   ├── core/
│   │   └── __init__.py
│   ├── io/
│   │   └── __init__.py
│   ├── onebot/
│   │   └── __init__.py
│   └── elizabeth/
│       └── __init__.py
└── pyproject.toml

如果需要将 avilla 下的模块发为多个包, 用 Mina 可以简单的做到, 比如上面这种我们就可以在 pyproject.toml 内填入以下几个表来声明分包:

[tool.mina.packages."core"]
[tool.mina.packages."io"]
[tool.mina.packages."onebot"]
[tool.mina.packages."elizabeth"]

Mina 的分包声明沿用了 PEP-621 中的声明方式. 我们这里以配置分包 core 举例.

[tool.mina.packages."core"]
includes = [
    "avilla/core"
]
# 相当于 tool.pdm.includes, 如果不填我不知道会发生什么, 可能就是普通的情况 -- 打包 name 所指向的模块.

# override = false

[tool.mina.packages."core".project]
name = "avilla-core"  # 分包在 `pypi` 上的名称, 必填
description = "..."
authors = ["..."]
version = "0.1.0"  # 版本, 不保证支持动态获取(因为我没用过也没试过)
requires-python = ">=3.9"
dependencies = [  # 建议填入
    "aiohttp",  # 这里虽然使用 `PEP-508` 规范, 但所有包都会被重定向至 project.dependencies 上的同名项.
    "starlette",
    "pydantic"
]
optional-dependencies = {
    "amnesia": ["graia-amnesia"]  # optional dependencies 示例
}
entry-points = {pdm = {mina = "mina.plugin:ensure_pdm"}}  # entry-points 的声明方式

填入后, 你可以通过 CLI 的 pdm mina list 简单的检查, 或是直接 pdm mina build <pkg> 测试;

构建发布包

使用 pdm mina build <pkg> 可以构建对应的分包.

如果你希望, 你可以使用 pdm mina build -a/--all 一次性构建所有的分包.

这里推荐使用 twine + keyring 发布到 PyPI 上, 当然 pdm-publish, 或是用 Github Actions 也是可以的.

覆盖工作区配置

如果你希望, 你可以让 Mina 在处理和注入分包的 project 定义时, 使用覆盖工作区配置的形式来获得 Project Spec; 本特性默认不启用:

[tool.mina]
override-global = true  # 全局启用该特性

[tool.mina.packages."core"]
override = true  # 仅在 core 分包启用该特性

开源协议

本项目使用 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

pdm_mina-0.3.2.tar.gz (5.5 kB view details)

Uploaded Source

Built Distribution

pdm_mina-0.3.2-py3-none-any.whl (5.8 kB view details)

Uploaded Python 3

File details

Details for the file pdm_mina-0.3.2.tar.gz.

File metadata

  • Download URL: pdm_mina-0.3.2.tar.gz
  • Upload date:
  • Size: 5.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/4.0.2 CPython/3.11.7

File hashes

Hashes for pdm_mina-0.3.2.tar.gz
Algorithm Hash digest
SHA256 4f6dfeda64d518a00967b8cca8963fe0f35463910616bd1afd1740b73d2e9e64
MD5 c8dbd0619e3c69d8390ad7e3679b62dd
BLAKE2b-256 35aa69068b528ceba2de7dd67364bb8a8aa800fe44dab3f47cb02cf7ac34b272

See more details on using hashes here.

File details

Details for the file pdm_mina-0.3.2-py3-none-any.whl.

File metadata

  • Download URL: pdm_mina-0.3.2-py3-none-any.whl
  • Upload date:
  • Size: 5.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/4.0.2 CPython/3.11.7

File hashes

Hashes for pdm_mina-0.3.2-py3-none-any.whl
Algorithm Hash digest
SHA256 bf51a72586d8202881694b7b8c2aa8a58eebedf3daa035028425e0fbd20d5e2c
MD5 3094298f1f43085826429b72fcb63cf6
BLAKE2b-256 0cba3a7d8464ba41f0a5e092d35f1764b15d717b188587959cab8816c19cede5

See more details on using hashes here.

Supported by

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