CANN/cannbot-skills迁移手册
Legacy Repo Migration Playbook
【免费下载链接】cannbot-skillsCANNBot 是面向 CANN 开发的用于提升开发效率的系列智能体,本仓库为其提供可复用的 Skills 模块。项目地址: https://gitcode.com/cann/cannbot-skills
Use this playbook when you need to transform the originaleasyascrepository layout into the currentops-easyasc-dslskill-oriented layout.
Read this file first for migration tasks. Do not start by guessing folder moves from memory.
Goal State
The migrated repository should end in this shape:
- repository root name:
ops-easyasc-dsl agent/is the primary skill-facing surfaceagent/SKILL.mdis the entrypointagent/ROUTER.mddrives progressive disclosureagent/scripts/holds repository-maintenance scriptsagent/example/kernels/holds curated kernel examplesagent/example/demo/holds manual demo programsagent/assets/ops-easyasc-dsl-runtime.tar.gzstores the archivedeasyasc/,doc/, anddoc_cn/payloadagent/scripts/init.shrestoreseasyasc/,doc/, anddoc_cn/on demandtestcases/is removed from the delivered skill bundle- delivered
.py/.sh/.bashfiles carry the required script license header - delivered
.h/.cppfiles carry the required C/C++ license header
Migration Order
Apply the transformation in this order so paths stay valid while you edit the repository:
- Inspect the original tree.
- Remove obsolete top-level content.
- Move repository tools into the skill surface.
- Move runnable examples into the skill surface.
- Convert
agent/into a real skill entrypoint. - Archive the runtime/docs payload and add an initialization script.
- Rename the repository root.
- Repair documentation, routes, and path references.
- Apply the required license headers.
- Validate the migrated repository from a fresh-user workflow.
Detailed Steps
1. Inspect the original tree
Confirm the original repository still has the legacy layout:
- top-level
easyasc/ - top-level
doc/ - top-level
doc_cn/ - top-level
kernels/ - top-level
demo/ - top-level
tools/ - top-level
testcases/ - existing
agent/content that is not yet a complete skill entrypoint
Record which files describe structure or commands before moving anything:
README.mdREADME_CN.mdAGENTS.mdCLAUDE.mdagent/ROUTER.mdagent/references/repo-map.mdagent/references/code-paths.md
2. Remove obsolete top-level content
- Delete
testcases/from the delivered repository. - Treat removed tests as historical context only; if they need to be mentioned, describe them as removed from the skill bundle rather than still available.
3. Move repository tools into the skill surface
- Create
agent/scripts/if it does not exist. - Move every file from top-level
tools/intoagent/scripts/. - Preserve script filenames so existing references can be updated with simple path rewrites.
- Move or regenerate the tool summary file under
agent/scripts/tools_summary.md.
Expected path rewrite:
tools/<name>->agent/scripts/<name>
4. Move runnable examples into the skill surface
- Create
agent/example/. - Move top-level
kernels/intoagent/example/kernels/. - Move top-level
demo/intoagent/example/demo/. - Remove the original top-level
kernels/anddemo/directories after the move.
Expected path rewrites:
kernels/<path>->agent/example/kernels/<path>demo/<path>->agent/example/demo/<path>
5. Convertagent/into a real skill entrypoint
Add or rewrite these files:
agent/SKILL.md: user-facing skill entrypointagent/ROUTER.md: first routing layer with progressive disclosure
agent/SKILL.mdshould:
- explain that
agent/scripts/init.shmust run before reading archived runtime/docs content - point readers to
agent/ROUTER.md - describe the preferred read order: router -> one playbook -> one focused reference -> one source example
- list
agent/example/,agent/scripts/, andagent/assets/ - avoid machine-specific absolute paths in environment guidance
agent/ROUTER.mdshould:
- route kernel authoring to
agent/playbooks/kernel-authoring.md - route kernel debugging to
agent/playbooks/kernel-debugging.md - route tool work to
agent/playbooks/tool-authoring.md - route documentation work to
agent/playbooks/doc-authoring.md - route repo-structure questions to
agent/references/repo-map.md
6. Archive the runtime/docs payload and add an initialization script
Create a compressed archive that contains exactly:
easyasc/doc/doc_cn/
Recommended artifact path:
agent/assets/ops-easyasc-dsl-runtime.tar.gz
Then create:
agent/scripts/init.sh
init.shshould:
- resolve the repository root relative to itself
- verify that the archive exists
- restore
easyasc/,doc/, anddoc_cn/only when missing - be safe to run multiple times
After the archive and init script are in place:
- delete the unpacked
easyasc/,doc/, anddoc_cn/trees from the repository snapshot - rely on
init.shto restore them when needed - whenever you later edit restored files under
easyasc/,doc/, ordoc_cn/, rebuildagent/assets/ops-easyasc-dsl-runtime.tar.gzand delete the unpacked trees again so the delivered repository returns to the skill-only state
7. Rename the repository root
- Rename the top-level checkout directory from
easyasctoops-easyasc-dsl. - Update every document and script that still mentions the old repository root name when the new name matters.
8. Repair documentation, routes, and path references
Update all docs and scripts that referenced removed or moved paths.
Mandatory rewrite categories:
- command examples that referenced
kernels/... - command examples that referenced
demo/... - tool references that referenced
tools/... - repository maps that still describe
testcases/ - skill/router docs that do not yet mention
init.sh - environment guidance that hardcodes a machine-specific absolute path
- generated scripts or runtime helpers that hardcode a machine-specific CANN install root
Preferred style after the migration:
- use repo-relative paths such as
agent/example/kernels/... - use environment variables such as
ASCEND_HOME_PATHinstead of fixed host paths - if an environment name is mentioned, present it as an example rather than a required default
- check both the visible repository files and the archived
easyasc/,doc/,doc_cn/payload before declaring the migration complete
Practical repair checklist:
- update visible docs such as
README.md,README_CN.md,AGENTS.md,CLAUDE.md, andagent/SKILL.md - if the archive has already been restored once, inspect
easyasc/,doc/, anddoc_cn/for hardcoded host paths such as/home/ubuntu/...or/usr/local/Ascend/... - update
easyasc/kernelbase/kernelbase.pyso generated scripts prefer environment variables over a fixed CANN path - update any restored helper scripts under
easyasc/resources/that still assume a fixed local install path - normalize every validation example to
python agent/example/kernels/a5/matmul_float_mmad.py - after fixing restored files, rebuild
agent/assets/ops-easyasc-dsl-runtime.tar.gzand remove the unpacked trees again
9. Apply the required license headers
Before final delivery, add the required license headers to all delivered source and script files.
For.py,.sh, and.bashfiles, prepend this header. If a file has a shebang, keep the shebang as the first line and insert the header immediately after it:
# ---------------------------------------------------------------------------------------------------------- # Copyright (c) 2026 Huawei Technologies Co., Ltd. # This program is free software, you can redistribute it and/or modify it under the terms and conditions of # CANN Open Software License Agreement Version 2.0 (the "License"). # Please refer to the License for details. You may not use this file except in compliance with the License. # THIS SOFTWARE IS PROVIDED ON AN "AS IS" BASIS, WITHOUT WARRANTIES OF ANY KIND, EITHER EXPRESS OR IMPLIED, # INCLUDING BUT NOT LIMITED TO NON-INFRINGEMENT, MERCHANTABILITY, OR FITNESS FOR A PARTICULAR PURPOSE. # See LICENSE in the root of the software repository for the full text of the License. # ----------------------------------------------------------------------------------------------------------For.hand.cppfiles, prepend this header:
/** * Copyright (c) 2026 Huawei Technologies Co., Ltd. * This program is free software, you can redistribute it and/or modify it under the terms and conditions of * CANN Open Software License Agreement Version 2.0 (the "License"). * Please refer to the License for details. You may not use this file except in compliance with the License. * THIS SOFTWARE IS PROVIDED ON AN "AS IS" BASIS, WITHOUT WARRANTIES OF ANY KIND, EITHER EXPRESS OR IMPLIED, * INCLUDING BUT NOT LIMITED TO NON-INFRINGEMENT, MERCHANTABILITY, OR FITNESS FOR A PARTICULAR PURPOSE. * See LICENSE in the root of the software repository for the full text of the License. */ /* * Copyright (c) Huawei Technologies Co., Ltd. 2022-2023. All rights reserved. */License-header checklist:
- apply headers to the delivered repository tree, not just to manually edited files
- include files under
agent/, restoredeasyasc/, restoreddoc/helper scripts, generatedb.sh/r.sh, and generated runtime source files if they are part of the delivered snapshot - make the insertion idempotent so rerunning it does not duplicate headers
- after any validation run that creates new
.py,.sh,.bash,.h, or.cppfiles, rerun the license-header pass before finalizing the migration
10. Validate the migrated repository
Validate from the perspective of a fresh user:
- start from the migrated repository root
- run
bash agent/scripts/init.sh - confirm that
easyasc/,doc/, anddoc_cn/are restored - run
python agent/example/kernels/a5/matmul_float_mmad.py - confirm that the example validates both:
OpExec(..., simulator=True)OpExec(..., simulator=False)
- if the validation run generates fresh
b.sh,r.sh, or runtime source files, rerun the license-header pass - rebuild
agent/assets/ops-easyasc-dsl-runtime.tar.gzif the restored trees were edited during validation or repair - remove the unpacked
easyasc/,doc/, anddoc_cn/trees again so the final delivered repository stays skill-only
If the non-simulator path is slow, let it complete naturally instead of forcing a shell timeout into the repository script unless the user explicitly asks for that behavior.
Files Commonly Updated During This Migration
README.mdREADME_CN.mdAGENTS.mdCLAUDE.mdagent/SKILL.mdagent/ROUTER.mdagent/references/repo-map.mdagent/references/code-paths.mdagent/references/examples/kernel-catalog.mdagent/references/examples/tool-catalog.mdagent/index/kernels.jsonagent/index/tools.jsonagent/playbooks/*.mdagent/scripts/tools_summary.md- restored
easyasc/kernelbase/kernelbase.py - restored
easyasc/resources/debug/build.sh - restored
easyasc/resources/debug/run.sh - restored
doc/01_quickstart.md - restored
doc_cn/01_quickstart.md - restored
doc_cn/index.md
Anti-Patterns
Avoid these mistakes during the migration:
- leaving duplicate live copies of
kernels/ordemo/at the repository root - keeping
testcases/in the delivered skill bundle after claiming it was removed - hardcoding a workstation path such as
<user-home>/...into user-facing docs - hardcoding a generic fallback such as
/usr/local/Ascend/...into delivered scripts when the repository is supposed to be environment-driven - describing archived
easyasc/,doc/, ordoc_cn/as always present - forgetting to update validation commands after moving examples
- fixing restored archive contents but forgetting to rebuild
agent/assets/ops-easyasc-dsl-runtime.tar.gz - running validation, generating new source files, and forgetting to add license headers to those generated files
- introducing a shell
timeoutinto repository scripts just to simplify one local verification run
Completion Check
The migration is complete when all of the following are true:
agent/SKILL.mdis the repository entrypointagent/ROUTER.mdsupports progressive disclosureagent/scripts/owns the former tool scriptsagent/example/owns the formerkernels/anddemo/agent/assets/ops-easyasc-dsl-runtime.tar.gzexistsagent/scripts/init.shrestores the archived treestestcases/is gone- visible files and archived payloads no longer hardcode machine-specific absolute paths
- delivered
.py/.sh/.bashfiles carry the required script license header - delivered
.h/.cppfiles carry the required C/C++ license header - docs no longer tell users to use stale paths
- a fresh-user validation passes from
python agent/example/kernels/a5/matmul_float_mmad.py
【免费下载链接】cannbot-skillsCANNBot 是面向 CANN 开发的用于提升开发效率的系列智能体,本仓库为其提供可复用的 Skills 模块。项目地址: https://gitcode.com/cann/cannbot-skills
创作声明:本文部分内容由AI辅助生成(AIGC),仅供参考
