Installer/upgrader CLI for qiongli (Codex / Claude Code / Gemini) without requiring a git fork.
Project description
qiongli
qiongli is the lightweight updater CLI for Qiongli (穷理), a contract-driven academic workflow system for Codex, Claude Code, and Gemini.
The full system name is Qiongli Zhengche (穷理证澈): Qiongli names the public research workflow, while Zhengche names the evidence-governance method that keeps claims, citations, assumptions, and output paths auditable.
What it does
- Install or refresh global
qiongli-workflowskill assets - Upgrade assets to newer upstream versions
- Support
codex,claude,gemini, oralltargets - Run doctor checks before/after installation
Installation
For a global CLI command, pipx is recommended:
pipx install qiongli
Upgrade an existing PyPI install with:
pipx upgrade qiongli
You can also install with pip:
pip install qiongli
If you use pip inside an active virtual environment, the CLI is installed into that environment. That only affects where the Python command lives; it does not make the workflow assets project-local.
Global-first update model
Current releases separate the package install from workflow asset installation:
pipx install qiongli/pipx upgrade qiongliupdates the lightweight Python CLI.qiongli upgrade --target allrefreshes the globalqiongli-workflowskill assets for Codex, Claude Code, Gemini, and Antigravity.--project-diris not required for normal global upgrades. It only selects a project when you rundoctor, load project-levelqiongli.toml/.qiongli.toml, or explicitly write project files withqiongli init/--parts project.
Global assets are written under client home directories such as:
~/.codex/skills/qiongli-workflow
~/.claude/skills/qiongli-workflow
~/.gemini/skills/qiongli-workflow
CLI
Main command and aliases:
qiongliqlresearch-skills(legacy)rskrsw
Check updates
qiongli check
Upgrade assets
qiongli upgrade --target all
Run doctor only when you want to check a specific project runtime:
qiongli upgrade --target all --doctor --project-dir /path/to/project
The package includes a default upstream repo (jxpeng98/qiongli), so --repo is optional.
Use --repo only when you want to override the default.
Override default repo (optional)
The CLI resolves upstream repo in this order:
--repoargumentQIONGLI_REPOenvironment variable- legacy
RESEARCH_SKILLS_REPOenvironment variable qiongli.tomlor.qiongli.tomlin your project path- Packaged default (
qiongli/project.toml)
Option A: Global override
Add this to your shell profile (~/.zshrc, ~/.bashrc, etc.):
export QIONGLI_REPO="<owner>/<repo>"
Then reload shell:
source ~/.zshrc
Now you can run:
qiongli check
qiongli upgrade --target all
Option B: Project-level override
Create qiongli.toml in your project root:
[upstream]
repo = "jxpeng98/qiongli"
url = "https://github.com/<owner>/<repo>"
This keeps the override local to that project.
Typical usage
# Install or update the CLI from PyPI
pipx install qiongli
pipx upgrade qiongli
# Refresh global workflow assets
qiongli upgrade --target all
# Optional: initialize project-local files only when you want them
qiongli init --project-dir /path/to/project
Links
- Repository: https://github.com/jxpeng98/qiongli
- Issues: https://github.com/jxpeng98/qiongli/issues
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file qiongli-0.10.1b1.tar.gz.
File metadata
- Download URL: qiongli-0.10.1b1.tar.gz
- Upload date:
- Size: 138.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
3de8ffadb44fb074aaede5439076b9e714e9e7f744455b3ded6ce791548a8911
|
|
| MD5 |
bd6c128ddc3a821e8197b1e659b8614a
|
|
| BLAKE2b-256 |
b56764b9bba33ea7c8856ebbbcdf5f1546e458e71961baa6f0fb9401191bed3a
|
Provenance
The following attestation bundles were made for qiongli-0.10.1b1.tar.gz:
Publisher:
publish-pypi.yml on jxpeng98/qiongli
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
qiongli-0.10.1b1.tar.gz -
Subject digest:
3de8ffadb44fb074aaede5439076b9e714e9e7f744455b3ded6ce791548a8911 - Sigstore transparency entry: 1602958528
- Sigstore integration time:
-
Permalink:
jxpeng98/qiongli@e1204317a8f321b7b85e2ad8d3e3b99f3fae62fc -
Branch / Tag:
refs/tags/v0.10.1-beta.1 - Owner: https://github.com/jxpeng98
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish-pypi.yml@e1204317a8f321b7b85e2ad8d3e3b99f3fae62fc -
Trigger Event:
push
-
Statement type:
File details
Details for the file qiongli-0.10.1b1-py3-none-any.whl.
File metadata
- Download URL: qiongli-0.10.1b1-py3-none-any.whl
- Upload date:
- Size: 43.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b07b6258f217bacbefe4435115d0437a1a17335ef261be125d67265a48b5790c
|
|
| MD5 |
75ca0c967fa72f2b6a66fce6d62352a5
|
|
| BLAKE2b-256 |
ef8bd7e125ab6b308637488506530b4b4b97ea00d96d44022acd9cdb32b04549
|
Provenance
The following attestation bundles were made for qiongli-0.10.1b1-py3-none-any.whl:
Publisher:
publish-pypi.yml on jxpeng98/qiongli
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
qiongli-0.10.1b1-py3-none-any.whl -
Subject digest:
b07b6258f217bacbefe4435115d0437a1a17335ef261be125d67265a48b5790c - Sigstore transparency entry: 1602958636
- Sigstore integration time:
-
Permalink:
jxpeng98/qiongli@e1204317a8f321b7b85e2ad8d3e3b99f3fae62fc -
Branch / Tag:
refs/tags/v0.10.1-beta.1 - Owner: https://github.com/jxpeng98
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish-pypi.yml@e1204317a8f321b7b85e2ad8d3e3b99f3fae62fc -
Trigger Event:
push
-
Statement type: