arboris-cli 1.0.0 → 1.1.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (451) hide show
  1. package/dist/cli.mjs +420 -0
  2. package/manifest.json +602 -0
  3. package/package.json +22 -10
  4. package/prisma/skills/accessibility/SKILL.md +147 -0
  5. package/prisma/skills/agent-architecture-audit/SKILL.md +257 -0
  6. package/prisma/skills/agent-eval/SKILL.md +146 -0
  7. package/prisma/skills/agent-harness-construction/SKILL.md +74 -0
  8. package/prisma/skills/agent-introspection-debugging/SKILL.md +154 -0
  9. package/prisma/skills/agent-payment-x402/SKILL.md +225 -0
  10. package/prisma/skills/agent-self-evaluation/SKILL.md +182 -0
  11. package/prisma/skills/agent-self-evaluation/examples/high-score-example.md +87 -0
  12. package/prisma/skills/agent-self-evaluation/examples/low-score-example.md +86 -0
  13. package/prisma/skills/agent-self-evaluation/references/evaluation-criteria.md +71 -0
  14. package/prisma/skills/agent-self-evaluation/references/hook-integration.md +64 -0
  15. package/prisma/skills/agent-self-evaluation/scripts/evaluate.py +408 -0
  16. package/prisma/skills/agent-self-evaluation/templates/evaluation-report.md +86 -0
  17. package/prisma/skills/agent-sort/SKILL.md +216 -0
  18. package/prisma/skills/agentic-engineering/SKILL.md +64 -0
  19. package/prisma/skills/agentic-os/SKILL.md +388 -0
  20. package/prisma/skills/ai-first-engineering/SKILL.md +52 -0
  21. package/prisma/skills/ai-regression-testing/SKILL.md +386 -0
  22. package/prisma/skills/android-clean-architecture/SKILL.md +340 -0
  23. package/prisma/skills/angular-developer/SKILL.md +155 -0
  24. package/prisma/skills/angular-developer/references/angular-animations.md +160 -0
  25. package/prisma/skills/angular-developer/references/angular-aria.md +410 -0
  26. package/prisma/skills/angular-developer/references/cli.md +86 -0
  27. package/prisma/skills/angular-developer/references/component-harnesses.md +59 -0
  28. package/prisma/skills/angular-developer/references/component-styling.md +91 -0
  29. package/prisma/skills/angular-developer/references/components.md +117 -0
  30. package/prisma/skills/angular-developer/references/creating-services.md +97 -0
  31. package/prisma/skills/angular-developer/references/data-resolvers.md +69 -0
  32. package/prisma/skills/angular-developer/references/define-routes.md +67 -0
  33. package/prisma/skills/angular-developer/references/defining-providers.md +72 -0
  34. package/prisma/skills/angular-developer/references/di-fundamentals.md +120 -0
  35. package/prisma/skills/angular-developer/references/e2e-testing.md +56 -0
  36. package/prisma/skills/angular-developer/references/effects.md +83 -0
  37. package/prisma/skills/angular-developer/references/hierarchical-injectors.md +43 -0
  38. package/prisma/skills/angular-developer/references/host-elements.md +80 -0
  39. package/prisma/skills/angular-developer/references/injection-context.md +63 -0
  40. package/prisma/skills/angular-developer/references/inputs.md +101 -0
  41. package/prisma/skills/angular-developer/references/linked-signal.md +59 -0
  42. package/prisma/skills/angular-developer/references/loading-strategies.md +61 -0
  43. package/prisma/skills/angular-developer/references/mcp.md +108 -0
  44. package/prisma/skills/angular-developer/references/navigate-to-routes.md +69 -0
  45. package/prisma/skills/angular-developer/references/outputs.md +86 -0
  46. package/prisma/skills/angular-developer/references/reactive-forms.md +122 -0
  47. package/prisma/skills/angular-developer/references/rendering-strategies.md +44 -0
  48. package/prisma/skills/angular-developer/references/resource.md +77 -0
  49. package/prisma/skills/angular-developer/references/route-animations.md +56 -0
  50. package/prisma/skills/angular-developer/references/route-guards.md +52 -0
  51. package/prisma/skills/angular-developer/references/router-lifecycle.md +45 -0
  52. package/prisma/skills/angular-developer/references/router-testing.md +87 -0
  53. package/prisma/skills/angular-developer/references/show-routes-with-outlets.md +68 -0
  54. package/prisma/skills/angular-developer/references/signal-forms.md +795 -0
  55. package/prisma/skills/angular-developer/references/signals-overview.md +94 -0
  56. package/prisma/skills/angular-developer/references/tailwind-css.md +69 -0
  57. package/prisma/skills/angular-developer/references/template-driven-forms.md +114 -0
  58. package/prisma/skills/angular-developer/references/testing-fundamentals.md +65 -0
  59. package/prisma/skills/api-connector-builder/SKILL.md +121 -0
  60. package/prisma/skills/api-design/SKILL.md +524 -0
  61. package/prisma/skills/architecture-decision-records/SKILL.md +180 -0
  62. package/prisma/skills/article-writing/SKILL.md +80 -0
  63. package/prisma/skills/automation-audit-ops/SKILL.md +143 -0
  64. package/prisma/skills/autonomous-agent-harness/SKILL.md +274 -0
  65. package/prisma/skills/autonomous-loops/SKILL.md +611 -0
  66. package/prisma/skills/backend-patterns/SKILL.md +562 -0
  67. package/prisma/skills/benchmark/SKILL.md +94 -0
  68. package/prisma/skills/benchmark-methodology/SKILL.md +190 -0
  69. package/prisma/skills/benchmark-optimization-loop/SKILL.md +70 -0
  70. package/prisma/skills/blender-motion-state-inspection/SKILL.md +165 -0
  71. package/prisma/skills/blueprint/SKILL.md +106 -0
  72. package/prisma/skills/brand-discovery/SKILL.md +145 -0
  73. package/prisma/skills/brand-discovery/references/10_purpose-why.md +40 -0
  74. package/prisma/skills/brand-discovery/references/20_positioning.md +44 -0
  75. package/prisma/skills/brand-discovery/references/30_audience-niche.md +52 -0
  76. package/prisma/skills/brand-discovery/references/40_personality-archetype.md +57 -0
  77. package/prisma/skills/brand-discovery/references/50_voice-tone.md +59 -0
  78. package/prisma/skills/brand-discovery/references/60_narrative-story.md +50 -0
  79. package/prisma/skills/brand-discovery/references/70_founder-tension.md +49 -0
  80. package/prisma/skills/brand-discovery/references/90_SYNTHESIS.md +133 -0
  81. package/prisma/skills/brand-voice/SKILL.md +98 -0
  82. package/prisma/skills/brand-voice/references/voice-profile-schema.md +55 -0
  83. package/prisma/skills/browser-qa/SKILL.md +105 -0
  84. package/prisma/skills/bun-runtime/SKILL.md +85 -0
  85. package/prisma/skills/canary-watch/SKILL.md +108 -0
  86. package/prisma/skills/carrier-relationship-management/SKILL.md +212 -0
  87. package/prisma/skills/cisco-ios-patterns/SKILL.md +164 -0
  88. package/prisma/skills/ck/SKILL.md +148 -0
  89. package/prisma/skills/ck/commands/forget.mjs +44 -0
  90. package/prisma/skills/ck/commands/info.mjs +24 -0
  91. package/prisma/skills/ck/commands/init.mjs +143 -0
  92. package/prisma/skills/ck/commands/list.mjs +40 -0
  93. package/prisma/skills/ck/commands/migrate.mjs +202 -0
  94. package/prisma/skills/ck/commands/resume.mjs +36 -0
  95. package/prisma/skills/ck/commands/save.mjs +210 -0
  96. package/prisma/skills/ck/commands/shared.mjs +387 -0
  97. package/prisma/skills/ck/hooks/session-start.mjs +224 -0
  98. package/prisma/skills/claude-devfleet/SKILL.md +112 -0
  99. package/prisma/skills/click-path-audit/SKILL.md +245 -0
  100. package/prisma/skills/clickhouse-io/SKILL.md +440 -0
  101. package/prisma/skills/code-tour/SKILL.md +254 -0
  102. package/prisma/skills/codebase-onboarding/SKILL.md +234 -0
  103. package/prisma/skills/codehealth-mcp/SKILL.md +167 -0
  104. package/prisma/skills/coding-standards/SKILL.md +551 -0
  105. package/prisma/skills/competitive-platform-analysis/SKILL.md +214 -0
  106. package/prisma/skills/competitive-report-structure/SKILL.md +162 -0
  107. package/prisma/skills/compose-multiplatform-patterns/SKILL.md +300 -0
  108. package/prisma/skills/config-gc/SKILL.md +120 -0
  109. package/prisma/skills/configure-ecc/SKILL.md +385 -0
  110. package/prisma/skills/connections-optimizer/SKILL.md +190 -0
  111. package/prisma/skills/content-engine/SKILL.md +132 -0
  112. package/prisma/skills/content-hash-cache-pattern/SKILL.md +162 -0
  113. package/prisma/skills/context-budget/SKILL.md +136 -0
  114. package/prisma/skills/continuous-agent-loop/SKILL.md +46 -0
  115. package/prisma/skills/continuous-learning/SKILL.md +132 -0
  116. package/prisma/skills/continuous-learning/config.json +18 -0
  117. package/prisma/skills/continuous-learning/evaluate-session.sh +69 -0
  118. package/prisma/skills/continuous-learning-v2/SKILL.md +361 -0
  119. package/prisma/skills/continuous-learning-v2/agents/observer-loop.sh +359 -0
  120. package/prisma/skills/continuous-learning-v2/agents/observer.md +189 -0
  121. package/prisma/skills/continuous-learning-v2/agents/session-guardian.sh +150 -0
  122. package/prisma/skills/continuous-learning-v2/agents/start-observer.sh +248 -0
  123. package/prisma/skills/continuous-learning-v2/config.json +8 -0
  124. package/prisma/skills/continuous-learning-v2/hooks/observe.sh +585 -0
  125. package/prisma/skills/continuous-learning-v2/scripts/detect-project.sh +322 -0
  126. package/prisma/skills/continuous-learning-v2/scripts/instinct-cli.py +1956 -0
  127. package/prisma/skills/continuous-learning-v2/scripts/lib/homunculus-dir.sh +31 -0
  128. package/prisma/skills/continuous-learning-v2/scripts/migrate-homunculus.sh +68 -0
  129. package/prisma/skills/continuous-learning-v2/scripts/test_parse_instinct.py +1421 -0
  130. package/prisma/skills/cost-aware-llm-pipeline/SKILL.md +184 -0
  131. package/prisma/skills/cost-tracking/SKILL.md +97 -0
  132. package/prisma/skills/council/SKILL.md +204 -0
  133. package/prisma/skills/cpp-coding-standards/SKILL.md +724 -0
  134. package/prisma/skills/cpp-testing/SKILL.md +325 -0
  135. package/prisma/skills/crosspost/SKILL.md +112 -0
  136. package/prisma/skills/csharp-testing/SKILL.md +322 -0
  137. package/prisma/skills/customer-billing-ops/SKILL.md +141 -0
  138. package/prisma/skills/customs-trade-compliance/SKILL.md +263 -0
  139. package/prisma/skills/dart-flutter-patterns/SKILL.md +564 -0
  140. package/prisma/skills/dashboard-builder/SKILL.md +109 -0
  141. package/prisma/skills/data-scraper-agent/SKILL.md +765 -0
  142. package/prisma/skills/data-throughput-accelerator/SKILL.md +73 -0
  143. package/prisma/skills/database-migrations/SKILL.md +430 -0
  144. package/prisma/skills/deep-research/SKILL.md +160 -0
  145. package/prisma/skills/defi-amm-security/SKILL.md +167 -0
  146. package/prisma/skills/delivery-gate/SKILL.md +126 -0
  147. package/prisma/skills/delivery-gate/hooks/quality-gate.py +220 -0
  148. package/prisma/skills/deployment-patterns/SKILL.md +428 -0
  149. package/prisma/skills/design-system/SKILL.md +83 -0
  150. package/prisma/skills/django-celery/SKILL.md +458 -0
  151. package/prisma/skills/django-patterns/SKILL.md +735 -0
  152. package/prisma/skills/django-security/SKILL.md +644 -0
  153. package/prisma/skills/django-tdd/SKILL.md +730 -0
  154. package/prisma/skills/django-verification/SKILL.md +470 -0
  155. package/prisma/skills/dmux-workflows/SKILL.md +192 -0
  156. package/prisma/skills/docker-patterns/SKILL.md +365 -0
  157. package/prisma/skills/documentation-lookup/SKILL.md +91 -0
  158. package/prisma/skills/dotnet-patterns/SKILL.md +322 -0
  159. package/prisma/skills/dynamic-workflow-mode/SKILL.md +124 -0
  160. package/prisma/skills/e2e-testing/SKILL.md +327 -0
  161. package/prisma/skills/ecc-guide/SKILL.md +190 -0
  162. package/prisma/skills/ecc-recipes/SKILL.md +149 -0
  163. package/prisma/skills/ecc-tools-cost-audit/SKILL.md +161 -0
  164. package/prisma/skills/email-ops/SKILL.md +122 -0
  165. package/prisma/skills/energy-procurement/SKILL.md +228 -0
  166. package/prisma/skills/enterprise-agent-ops/SKILL.md +51 -0
  167. package/prisma/skills/error-handling/SKILL.md +377 -0
  168. package/prisma/skills/eval-harness/SKILL.md +271 -0
  169. package/prisma/skills/evm-token-decimals/SKILL.md +131 -0
  170. package/prisma/skills/exa-search/SKILL.md +108 -0
  171. package/prisma/skills/fal-ai-media/SKILL.md +289 -0
  172. package/prisma/skills/fastapi-patterns/SKILL.md +514 -0
  173. package/prisma/skills/finance-billing-ops/SKILL.md +128 -0
  174. package/prisma/skills/flox-environments/SKILL.md +497 -0
  175. package/prisma/skills/flutter-dart-code-review/SKILL.md +436 -0
  176. package/prisma/skills/foundation-models-on-device/SKILL.md +243 -0
  177. package/prisma/skills/frontend-a11y/SKILL.md +446 -0
  178. package/prisma/skills/frontend-design-direction/SKILL.md +93 -0
  179. package/prisma/skills/frontend-patterns/SKILL.md +657 -0
  180. package/prisma/skills/frontend-slides/SKILL.md +185 -0
  181. package/prisma/skills/frontend-slides/STYLE_PRESETS.md +330 -0
  182. package/prisma/skills/frontend-slides/animation-patterns.md +122 -0
  183. package/prisma/skills/frontend-slides/html-template.md +419 -0
  184. package/prisma/skills/frontend-slides/scripts/export-pdf.sh +418 -0
  185. package/prisma/skills/frontend-slides/scripts/extract-pptx.py +96 -0
  186. package/prisma/skills/frontend-slides/viewport-base.css +153 -0
  187. package/prisma/skills/fsharp-testing/SKILL.md +281 -0
  188. package/prisma/skills/gan-style-harness/SKILL.md +279 -0
  189. package/prisma/skills/gateguard/SKILL.md +133 -0
  190. package/prisma/skills/generating-python-installer/SKILL.md +820 -0
  191. package/prisma/skills/git-workflow/SKILL.md +716 -0
  192. package/prisma/skills/github-ops/SKILL.md +145 -0
  193. package/prisma/skills/golang-patterns/SKILL.md +675 -0
  194. package/prisma/skills/golang-testing/SKILL.md +721 -0
  195. package/prisma/skills/google-workspace-ops/SKILL.md +96 -0
  196. package/prisma/skills/growth-log/SKILL.md +128 -0
  197. package/prisma/skills/healthcare-cdss-patterns/SKILL.md +246 -0
  198. package/prisma/skills/healthcare-emr-patterns/SKILL.md +160 -0
  199. package/prisma/skills/healthcare-eval-harness/SKILL.md +208 -0
  200. package/prisma/skills/healthcare-phi-compliance/SKILL.md +146 -0
  201. package/prisma/skills/hermes-imports/SKILL.md +89 -0
  202. package/prisma/skills/hexagonal-architecture/SKILL.md +277 -0
  203. package/prisma/skills/hipaa-compliance/SKILL.md +79 -0
  204. package/prisma/skills/homelab-network-readiness/SKILL.md +170 -0
  205. package/prisma/skills/homelab-network-setup/SKILL.md +130 -0
  206. package/prisma/skills/homelab-pihole-dns/SKILL.md +275 -0
  207. package/prisma/skills/homelab-vlan-segmentation/SKILL.md +312 -0
  208. package/prisma/skills/homelab-wireguard-vpn/SKILL.md +306 -0
  209. package/prisma/skills/hookify-rules/SKILL.md +128 -0
  210. package/prisma/skills/inherit-legacy-style/SKILL.md +157 -0
  211. package/prisma/skills/intent-driven-development/SKILL.md +360 -0
  212. package/prisma/skills/inventory-demand-planning/SKILL.md +247 -0
  213. package/prisma/skills/investor-materials/SKILL.md +97 -0
  214. package/prisma/skills/investor-outreach/SKILL.md +92 -0
  215. package/prisma/skills/ios-icon-gen/SKILL.md +158 -0
  216. package/prisma/skills/ios-icon-gen/scripts/generate_icons.swift +258 -0
  217. package/prisma/skills/ios-icon-gen/scripts/iconify_gen.sh +235 -0
  218. package/prisma/skills/iterative-retrieval/SKILL.md +212 -0
  219. package/prisma/skills/ito-basket-compare/SKILL.md +64 -0
  220. package/prisma/skills/ito-data-atlas-agent/SKILL.md +64 -0
  221. package/prisma/skills/ito-market-intelligence/SKILL.md +61 -0
  222. package/prisma/skills/ito-trade-planner/SKILL.md +68 -0
  223. package/prisma/skills/java-coding-standards/SKILL.md +384 -0
  224. package/prisma/skills/jira-integration/SKILL.md +303 -0
  225. package/prisma/skills/jpa-patterns/SKILL.md +152 -0
  226. package/prisma/skills/knowledge-ops/SKILL.md +155 -0
  227. package/prisma/skills/kotlin-coroutines-flows/SKILL.md +285 -0
  228. package/prisma/skills/kotlin-exposed-patterns/SKILL.md +720 -0
  229. package/prisma/skills/kotlin-ktor-patterns/SKILL.md +690 -0
  230. package/prisma/skills/kotlin-patterns/SKILL.md +712 -0
  231. package/prisma/skills/kotlin-testing/SKILL.md +825 -0
  232. package/prisma/skills/kubernetes-patterns/SKILL.md +756 -0
  233. package/prisma/skills/laravel-patterns/SKILL.md +416 -0
  234. package/prisma/skills/laravel-plugin-discovery/SKILL.md +230 -0
  235. package/prisma/skills/laravel-security/SKILL.md +948 -0
  236. package/prisma/skills/laravel-tdd/SKILL.md +675 -0
  237. package/prisma/skills/laravel-verification/SKILL.md +180 -0
  238. package/prisma/skills/latency-critical-systems/SKILL.md +74 -0
  239. package/prisma/skills/lead-intelligence/SKILL.md +322 -0
  240. package/prisma/skills/lead-intelligence/agents/enrichment-agent.md +85 -0
  241. package/prisma/skills/lead-intelligence/agents/mutual-mapper.md +75 -0
  242. package/prisma/skills/lead-intelligence/agents/outreach-drafter.md +98 -0
  243. package/prisma/skills/lead-intelligence/agents/signal-scorer.md +60 -0
  244. package/prisma/skills/liquid-glass-design/SKILL.md +279 -0
  245. package/prisma/skills/llm-trading-agent-security/SKILL.md +147 -0
  246. package/prisma/skills/logistics-exception-management/SKILL.md +222 -0
  247. package/prisma/skills/loop-design-check/SKILL.md +143 -0
  248. package/prisma/skills/mailtrap-email-integration/SKILL.md +77 -0
  249. package/prisma/skills/make-interfaces-feel-better/SKILL.md +152 -0
  250. package/prisma/skills/manim-video/SKILL.md +90 -0
  251. package/prisma/skills/manim-video/assets/network_graph_scene.py +52 -0
  252. package/prisma/skills/market-research/SKILL.md +76 -0
  253. package/prisma/skills/marketing-campaign/SKILL.md +114 -0
  254. package/prisma/skills/mcp-server-patterns/SKILL.md +70 -0
  255. package/prisma/skills/messages-ops/SKILL.md +105 -0
  256. package/prisma/skills/ml-adoption-playbook/SKILL.md +57 -0
  257. package/prisma/skills/mle-workflow/SKILL.md +347 -0
  258. package/prisma/skills/motion-advanced/SKILL.md +596 -0
  259. package/prisma/skills/motion-foundations/SKILL.md +299 -0
  260. package/prisma/skills/motion-patterns/SKILL.md +434 -0
  261. package/prisma/skills/motion-ui/SKILL.md +576 -0
  262. package/prisma/skills/mysql-patterns/SKILL.md +413 -0
  263. package/prisma/skills/nanoclaw-repl/SKILL.md +34 -0
  264. package/prisma/skills/nestjs-patterns/SKILL.md +231 -0
  265. package/prisma/skills/netmiko-ssh-automation/SKILL.md +174 -0
  266. package/prisma/skills/network-bgp-diagnostics/SKILL.md +168 -0
  267. package/prisma/skills/network-config-validation/SKILL.md +211 -0
  268. package/prisma/skills/network-interface-health/SKILL.md +153 -0
  269. package/prisma/skills/nextjs-turbopack/SKILL.md +58 -0
  270. package/prisma/skills/nodejs-keccak256/SKILL.md +103 -0
  271. package/prisma/skills/nutrient-document-processing/SKILL.md +168 -0
  272. package/prisma/skills/nuxt4-patterns/SKILL.md +101 -0
  273. package/prisma/skills/openclaw-persona-forge/SKILL.md +289 -0
  274. package/prisma/skills/openclaw-persona-forge/gacha.py +224 -0
  275. package/prisma/skills/openclaw-persona-forge/gacha.sh +5 -0
  276. package/prisma/skills/openclaw-persona-forge/references/avatar-style.md +124 -0
  277. package/prisma/skills/openclaw-persona-forge/references/boundary-rules.md +53 -0
  278. package/prisma/skills/openclaw-persona-forge/references/error-handling.md +53 -0
  279. package/prisma/skills/openclaw-persona-forge/references/identity-tension.md +48 -0
  280. package/prisma/skills/openclaw-persona-forge/references/naming-system.md +39 -0
  281. package/prisma/skills/openclaw-persona-forge/references/output-template.md +166 -0
  282. package/prisma/skills/opensource-pipeline/SKILL.md +256 -0
  283. package/prisma/skills/orch-add-feature/SKILL.md +45 -0
  284. package/prisma/skills/orch-build-mvp/SKILL.md +49 -0
  285. package/prisma/skills/orch-change-feature/SKILL.md +43 -0
  286. package/prisma/skills/orch-fix-defect/SKILL.md +43 -0
  287. package/prisma/skills/orch-pipeline/SKILL.md +121 -0
  288. package/prisma/skills/orch-refine-code/SKILL.md +44 -0
  289. package/prisma/skills/parallel-execution-optimizer/SKILL.md +73 -0
  290. package/prisma/skills/perl-patterns/SKILL.md +505 -0
  291. package/prisma/skills/perl-security/SKILL.md +504 -0
  292. package/prisma/skills/perl-testing/SKILL.md +476 -0
  293. package/prisma/skills/plan-orchestrate/SKILL.md +263 -0
  294. package/prisma/skills/plankton-code-quality/SKILL.md +237 -0
  295. package/prisma/skills/postgres-patterns/SKILL.md +148 -0
  296. package/prisma/skills/prediction-market-oracle-research/SKILL.md +64 -0
  297. package/prisma/skills/prediction-market-risk-review/SKILL.md +61 -0
  298. package/prisma/skills/prisma-patterns/SKILL.md +401 -0
  299. package/prisma/skills/product-capability/SKILL.md +142 -0
  300. package/prisma/skills/product-lens/SKILL.md +93 -0
  301. package/prisma/skills/production-audit/SKILL.md +207 -0
  302. package/prisma/skills/production-scheduling/SKILL.md +238 -0
  303. package/prisma/skills/project-flow-ops/SKILL.md +112 -0
  304. package/prisma/skills/prompt-optimizer/SKILL.md +398 -0
  305. package/prisma/skills/python-patterns/SKILL.md +751 -0
  306. package/prisma/skills/python-testing/SKILL.md +817 -0
  307. package/prisma/skills/pytorch-patterns/SKILL.md +397 -0
  308. package/prisma/skills/quality-nonconformance/SKILL.md +260 -0
  309. package/prisma/skills/quarkus-patterns/SKILL.md +723 -0
  310. package/prisma/skills/quarkus-security/SKILL.md +468 -0
  311. package/prisma/skills/quarkus-tdd/SKILL.md +812 -0
  312. package/prisma/skills/quarkus-verification/SKILL.md +480 -0
  313. package/prisma/skills/ralphinho-rfc-pipeline/SKILL.md +68 -0
  314. package/prisma/skills/react-native-patterns/SKILL.md +326 -0
  315. package/prisma/skills/react-patterns/SKILL.md +342 -0
  316. package/prisma/skills/react-performance/SKILL.md +575 -0
  317. package/prisma/skills/react-testing/SKILL.md +424 -0
  318. package/prisma/skills/recsys-pipeline-architect/SKILL.md +115 -0
  319. package/prisma/skills/recursive-decision-ledger/SKILL.md +80 -0
  320. package/prisma/skills/redis-patterns/SKILL.md +404 -0
  321. package/prisma/skills/regex-vs-llm-structured-text/SKILL.md +221 -0
  322. package/prisma/skills/remotion-video-creation/SKILL.md +43 -0
  323. package/prisma/skills/remotion-video-creation/rules/3d.md +86 -0
  324. package/prisma/skills/remotion-video-creation/rules/animations.md +29 -0
  325. package/prisma/skills/remotion-video-creation/rules/assets/charts-bar-chart.tsx +173 -0
  326. package/prisma/skills/remotion-video-creation/rules/assets/text-animations-typewriter.tsx +100 -0
  327. package/prisma/skills/remotion-video-creation/rules/assets/text-animations-word-highlight.tsx +108 -0
  328. package/prisma/skills/remotion-video-creation/rules/assets.md +78 -0
  329. package/prisma/skills/remotion-video-creation/rules/audio.md +172 -0
  330. package/prisma/skills/remotion-video-creation/rules/calculate-metadata.md +104 -0
  331. package/prisma/skills/remotion-video-creation/rules/can-decode.md +75 -0
  332. package/prisma/skills/remotion-video-creation/rules/charts.md +58 -0
  333. package/prisma/skills/remotion-video-creation/rules/compositions.md +146 -0
  334. package/prisma/skills/remotion-video-creation/rules/display-captions.md +126 -0
  335. package/prisma/skills/remotion-video-creation/rules/extract-frames.md +229 -0
  336. package/prisma/skills/remotion-video-creation/rules/fonts.md +152 -0
  337. package/prisma/skills/remotion-video-creation/rules/get-audio-duration.md +58 -0
  338. package/prisma/skills/remotion-video-creation/rules/get-video-dimensions.md +68 -0
  339. package/prisma/skills/remotion-video-creation/rules/get-video-duration.md +58 -0
  340. package/prisma/skills/remotion-video-creation/rules/gifs.md +138 -0
  341. package/prisma/skills/remotion-video-creation/rules/images.md +130 -0
  342. package/prisma/skills/remotion-video-creation/rules/import-srt-captions.md +67 -0
  343. package/prisma/skills/remotion-video-creation/rules/lottie.md +67 -0
  344. package/prisma/skills/remotion-video-creation/rules/measuring-dom-nodes.md +34 -0
  345. package/prisma/skills/remotion-video-creation/rules/measuring-text.md +143 -0
  346. package/prisma/skills/remotion-video-creation/rules/sequencing.md +106 -0
  347. package/prisma/skills/remotion-video-creation/rules/tailwind.md +11 -0
  348. package/prisma/skills/remotion-video-creation/rules/text-animations.md +20 -0
  349. package/prisma/skills/remotion-video-creation/rules/timing.md +179 -0
  350. package/prisma/skills/remotion-video-creation/rules/transcribe-captions.md +19 -0
  351. package/prisma/skills/remotion-video-creation/rules/transitions.md +122 -0
  352. package/prisma/skills/remotion-video-creation/rules/trimming.md +52 -0
  353. package/prisma/skills/remotion-video-creation/rules/videos.md +171 -0
  354. package/prisma/skills/repo-scan/SKILL.md +79 -0
  355. package/prisma/skills/research-ops/SKILL.md +113 -0
  356. package/prisma/skills/returns-reverse-logistics/SKILL.md +240 -0
  357. package/prisma/skills/rules-distill/SKILL.md +265 -0
  358. package/prisma/skills/rules-distill/scripts/scan-rules.sh +58 -0
  359. package/prisma/skills/rules-distill/scripts/scan-skills.sh +129 -0
  360. package/prisma/skills/rust-patterns/SKILL.md +500 -0
  361. package/prisma/skills/rust-testing/SKILL.md +501 -0
  362. package/prisma/skills/safety-guard/SKILL.md +76 -0
  363. package/prisma/skills/santa-method/SKILL.md +307 -0
  364. package/prisma/skills/scientific-db-pubmed-database/SKILL.md +176 -0
  365. package/prisma/skills/scientific-db-uspto-database/SKILL.md +178 -0
  366. package/prisma/skills/scientific-pkg-gget/SKILL.md +167 -0
  367. package/prisma/skills/scientific-thinking-literature-review/SKILL.md +193 -0
  368. package/prisma/skills/scientific-thinking-scholar-evaluation/SKILL.md +161 -0
  369. package/prisma/skills/search-first/SKILL.md +183 -0
  370. package/prisma/skills/security-bounty-hunter/SKILL.md +100 -0
  371. package/prisma/skills/security-review/SKILL.md +504 -0
  372. package/prisma/skills/security-review/cloud-infrastructure-security.md +361 -0
  373. package/prisma/skills/security-scan/SKILL.md +166 -0
  374. package/prisma/skills/seo/SKILL.md +155 -0
  375. package/prisma/skills/skill-comply/SKILL.md +59 -0
  376. package/prisma/skills/skill-comply/fixtures/compliant_trace.jsonl +5 -0
  377. package/prisma/skills/skill-comply/fixtures/noncompliant_trace.jsonl +3 -0
  378. package/prisma/skills/skill-comply/fixtures/tdd_spec.yaml +44 -0
  379. package/prisma/skills/skill-comply/prompts/classifier.md +24 -0
  380. package/prisma/skills/skill-comply/prompts/scenario_generator.md +62 -0
  381. package/prisma/skills/skill-comply/prompts/spec_generator.md +42 -0
  382. package/prisma/skills/skill-comply/pyproject.toml +15 -0
  383. package/prisma/skills/skill-comply/scripts/__init__.py +0 -0
  384. package/prisma/skills/skill-comply/scripts/classifier.py +85 -0
  385. package/prisma/skills/skill-comply/scripts/grader.py +124 -0
  386. package/prisma/skills/skill-comply/scripts/parser.py +107 -0
  387. package/prisma/skills/skill-comply/scripts/report.py +170 -0
  388. package/prisma/skills/skill-comply/scripts/run.py +127 -0
  389. package/prisma/skills/skill-comply/scripts/runner.py +194 -0
  390. package/prisma/skills/skill-comply/scripts/scenario_generator.py +70 -0
  391. package/prisma/skills/skill-comply/scripts/spec_generator.py +72 -0
  392. package/prisma/skills/skill-comply/scripts/utils.py +13 -0
  393. package/prisma/skills/skill-comply/tests/test_grader.py +197 -0
  394. package/prisma/skills/skill-comply/tests/test_parser.py +90 -0
  395. package/prisma/skills/skill-comply/tests/test_runner.py +172 -0
  396. package/prisma/skills/skill-scout/SKILL.md +141 -0
  397. package/prisma/skills/skill-stocktake/SKILL.md +195 -0
  398. package/prisma/skills/skill-stocktake/scripts/quick-diff.sh +87 -0
  399. package/prisma/skills/skill-stocktake/scripts/save-results.sh +56 -0
  400. package/prisma/skills/skill-stocktake/scripts/scan.sh +170 -0
  401. package/prisma/skills/social-graph-ranker/SKILL.md +155 -0
  402. package/prisma/skills/social-publisher/SKILL.md +130 -0
  403. package/prisma/skills/springboot-patterns/SKILL.md +315 -0
  404. package/prisma/skills/springboot-security/SKILL.md +273 -0
  405. package/prisma/skills/springboot-tdd/SKILL.md +159 -0
  406. package/prisma/skills/springboot-verification/SKILL.md +232 -0
  407. package/prisma/skills/strategic-compact/SKILL.md +136 -0
  408. package/prisma/skills/swift-actor-persistence/SKILL.md +144 -0
  409. package/prisma/skills/swift-concurrency-6-2/SKILL.md +216 -0
  410. package/prisma/skills/swift-protocol-di-testing/SKILL.md +191 -0
  411. package/prisma/skills/swiftui-patterns/SKILL.md +259 -0
  412. package/prisma/skills/taste/SKILL.md +264 -0
  413. package/prisma/skills/taste/references/genre-taxonomy.md +87 -0
  414. package/prisma/skills/tdd-workflow/SKILL.md +583 -0
  415. package/prisma/skills/team-agent-orchestration/SKILL.md +111 -0
  416. package/prisma/skills/team-builder/SKILL.md +169 -0
  417. package/prisma/skills/terminal-ops/SKILL.md +110 -0
  418. package/prisma/skills/tinystruct-patterns/SKILL.md +279 -0
  419. package/prisma/skills/tinystruct-patterns/references/architecture.md +90 -0
  420. package/prisma/skills/tinystruct-patterns/references/data-handling.md +60 -0
  421. package/prisma/skills/tinystruct-patterns/references/database.md +99 -0
  422. package/prisma/skills/tinystruct-patterns/references/routing.md +64 -0
  423. package/prisma/skills/tinystruct-patterns/references/system-usage.md +97 -0
  424. package/prisma/skills/tinystruct-patterns/references/testing.md +72 -0
  425. package/prisma/skills/token-budget-advisor/SKILL.md +134 -0
  426. package/prisma/skills/ui-demo/SKILL.md +466 -0
  427. package/prisma/skills/ui-to-vue/SKILL.md +135 -0
  428. package/prisma/skills/uncloud/SKILL.md +344 -0
  429. package/prisma/skills/unified-notifications-ops/SKILL.md +188 -0
  430. package/prisma/skills/verification-loop/SKILL.md +127 -0
  431. package/prisma/skills/video-editing/SKILL.md +311 -0
  432. package/prisma/skills/videodb/SKILL.md +375 -0
  433. package/prisma/skills/videodb/reference/api-reference.md +550 -0
  434. package/prisma/skills/videodb/reference/capture-reference.md +407 -0
  435. package/prisma/skills/videodb/reference/capture.md +101 -0
  436. package/prisma/skills/videodb/reference/editor.md +443 -0
  437. package/prisma/skills/videodb/reference/generative.md +331 -0
  438. package/prisma/skills/videodb/reference/rtstream-reference.md +564 -0
  439. package/prisma/skills/videodb/reference/rtstream.md +65 -0
  440. package/prisma/skills/videodb/reference/search.md +230 -0
  441. package/prisma/skills/videodb/reference/streaming.md +406 -0
  442. package/prisma/skills/videodb/reference/use-cases.md +118 -0
  443. package/prisma/skills/videodb/scripts/ws_listener.py +282 -0
  444. package/prisma/skills/visa-doc-translate/README.md +86 -0
  445. package/prisma/skills/visa-doc-translate/SKILL.md +117 -0
  446. package/prisma/skills/vite-patterns/SKILL.md +450 -0
  447. package/prisma/skills/vue-patterns/SKILL.md +471 -0
  448. package/prisma/skills/windows-desktop-e2e/SKILL.md +888 -0
  449. package/prisma/skills/workspace-surface-audit/SKILL.md +126 -0
  450. package/prisma/skills/x-api/SKILL.md +235 -0
  451. package/run.mjs +0 -10
@@ -0,0 +1,820 @@
1
+ ---
2
+ name: generating-python-installer
3
+ description: "Commercial-grade Python installer expert for Windows: Nuitka extreme compilation, dist slimming, DLL footprint analysis, and Inno Setup packaging to ship the smallest, fastest installers. Use only for advanced packaging/optimization (minimal size, fast startup), not basic script-to-exe conversion. 中文触发:Nuitka 极限优化、Python 商业打包、极限编译 Python、dist 瘦身、DLL 分析、最小安装包、最快启动、商业级打包风格"
4
+ ---
5
+
6
+ # Generating Python Installer (Commercial-Grade)
7
+
8
+ You are a **Python commercial deployment expert**. Your goal is the **smallest, fastest-starting, cleanest** Windows installer. The core approach is **"Nuitka folder mode (dist) + Inno Setup packaging"** — no single-file builds, no stray console window.
9
+
10
+ ## When to Activate
11
+
12
+ Activate when the user explicitly asks for **advanced** Python packaging or size/startup optimization on Windows:
13
+
14
+ - Nuitka extreme / commercial-grade compilation, smallest-size or fastest-startup builds
15
+ - `dist` folder slimming, DLL footprint analysis, 32-bit vs 64-bit size tradeoffs
16
+ - Inno Setup packaging with full metadata and a clean, residue-free uninstall
17
+
18
+ This skill targets advanced size/startup optimization — not basic one-file "script to exe" conversion.
19
+
20
+ ## How It Works
21
+
22
+ 1. **Confirm build parameters** — app name, version, publisher, exe name, source/output dirs, icon. Never auto-fill; ask the user.
23
+ 2. **Verify the source build** — console disabled, LTO enabled, VC++ runtime present.
24
+ 3. **Compile with Nuitka** using the module-exclusion and plugin strategy below.
25
+ 4. **Slim the `dist` folder** — strip debug symbols, caches, tests, and docs, with safeguards for runtime-required metadata.
26
+ 5. **Analyze DLLs** to find and trim the largest dependencies.
27
+ 6. **Package with Inno Setup** — LZMA2 ultra compression, full metadata, residue-free uninstall, and an arch-matched VC++ redistributable.
28
+
29
+ ## Examples
30
+
31
+ - "用 Nuitka 把这个 PySide2 项目打成最小体积的商业安装包" → run the full workflow: recommend 32-bit, exclude WebEngine/3D/Charts, slim `dist`, package with Inno Setup.
32
+ - "我的 exe 有 400 MB,怎么瘦身到一半" → analyze DLLs, switch to `opencv-python-headless`, drop `opengl32sw`, apply `dist` slimming.
33
+ - "安装后在纯净系统打不开" → ensure the matching-arch VC++ redistributable is bundled in the Inno Setup script.
34
+
35
+ ---
36
+
37
+ ## 核心理念
38
+
39
+ 坚持 **"Nuitka 文件夹模式(dist) + Inno Setup 封装"** 方案。拒绝单文件版,拒绝黑窗。
40
+
41
+ ---
42
+
43
+ ## 实战参考案例(生产级 PySide2 桌面应用,323 MB,含 OpenCV / Playwright)
44
+
45
+ ### 项目概况
46
+ - **总体积**: 323 MB
47
+ - **打包工具**: PyInstaller 4.7 (32位)
48
+ - **主要依赖**: PySide2 (22.52 MB), OpenCV (62.38 MB), Playwright (76.74 MB)
49
+ - **Python 版本**: Python 3.8 (32位)
50
+ - **DLL 数量**: 71 个,总计 93.23 MB
51
+
52
+ ### 关键优化策略
53
+ 1. PASS: **使用 32 位 Python** → 体积减少 20-30%
54
+ 2. PASS: **base_library.zip 压缩标准库** → 0.74 MB
55
+ 3. PASS: **精简模块排除** → 无 pytest/unittest/setuptools
56
+ 4. PASS: **精简 Qt 插件** → 只保留必要插件
57
+
58
+ ### 体积分布
59
+
60
+ | 组件 | 体积 | 占比 | 优化建议 |
61
+ |------|------|------|---------|
62
+ | playwright | 76.74 MB | 23.8% | 非必要可移除 |
63
+ | OpenCV | 62.38 MB | 19.3% | 用 opencv-python-headless |
64
+ | PySide2 | 22.52 MB | 7.0% | 排除 WebEngine/3D/Charts |
65
+ | 其他依赖 | 161.36 MB | 49.9% | - |
66
+
67
+ ### 预期效果对比
68
+
69
+ | 项目类型 | Nuitka 原始 | 优化后 | 参考项目实测 |
70
+ |---------|------------|--------|----------------|
71
+ | Tkinter + 标准库 | 150-250 MB | **80-120 MB** | - |
72
+ | PyQt/PySide | 200-400 MB | **120-250 MB** | 323 MB (含 OpenCV 等) |
73
+ | 含 numpy/pandas | 300-600 MB | **180-350 MB** | - |
74
+
75
+ ---
76
+
77
+ ## 核心工作流 (Workflow) - WARNING: 严格执行
78
+
79
+ 当用户请求打包时,按照以下步骤操作:
80
+
81
+ **步骤 1:强制参数确认(FAIL: 禁止使用默认值)**
82
+
83
+ > **WARNING: 重要规则:以下所有参数必须逐一向用户确认,禁止自动填充或使用默认值!**
84
+
85
+ 必须向用户询问并确认以下信息(*等待用户明确回复后才能继续*):
86
+
87
+ | 参数 | 说明 | 示例 |
88
+ |------|------|------|
89
+ | **软件名称** (App Name) | 软件显示名称 | `红墨批注` |
90
+ | **版本号** (Version) | 语义化版本号 | `1.0.0` |
91
+ | **发布者/公司名** (Publisher) | 控制面板显示的发布者 | `YourCompany` |
92
+ | **主程序** (Exe Name) | 主可执行文件名 | `RedInk.exe` |
93
+ | **源路径** (Source Dir) | Nuitka dist 文件夹绝对路径 | `D:\project\dist` |
94
+ | **输出路径** (Output Dir) | 安装包生成位置 | `D:\project\output` |
95
+ | **图标路径** (Icon Path) | .ico 文件绝对路径(可选但推荐) | `D:\project\icon.ico` |
96
+ | **官网地址** (URL) | 可选,用于控制面板链接 | `https://example.com` |
97
+
98
+ **询问模板:**
99
+ > "请提供以下打包参数,我需要您逐一确认:
100
+ > 1. 软件名称:
101
+ > 2. 版本号:
102
+ > 3. 发布者/公司名:
103
+ > 4. 主程序文件名(如 xxx.exe):
104
+ > 5. 源路径(Nuitka dist 文件夹):
105
+ > 6. 输出路径(安装包保存位置):
106
+ > 7. 图标路径(.ico 文件,可留空):
107
+ > 8. 官网地址(可留空):
108
+ >
109
+ > 请逐一填写,或回复"跳过"表示使用空值。"
110
+
111
+ **步骤 2:源文件质量与编译检查(关键)**
112
+ 在生成代码之前,必须向用户发出以下**关键确认**(因为 Inno Setup 只是打包工具,无法改变程序本身的运行属性):
113
+
114
+ > "WARNING: **编译参数检查**:
115
+ > 1. **去黑窗**:请确认您的 dist 文件夹是使用 `nuitka --windows-console-mode=disable` 编译的。(否则安装后依然会有黑框)
116
+ > 2. **高性能**:请确认是否使用了 `--lto=yes`。(否则启动速度可能不理想)
117
+ > 3. **运行库**:请确保 dist 文件夹内已包含必要的 VC++ 运行库,防止在纯净系统上无法运行。
118
+ >
119
+ > **确认源文件已准备好请回复"确认",否则请先重新编译。**"
120
+
121
+ **步骤 3:生成代码**
122
+ 用户确认后,输出包含 **完整元数据** 和 **卸载图标修复** 的代码。
123
+
124
+ ---
125
+
126
+ ## Nuitka 极限优化编译(基于 参考项目经验)
127
+
128
+ ### 一、32 位 vs 64 位选择策略
129
+
130
+ **参考项目使用 32 位 Python 的原因**:
131
+
132
+ | 组件 | 64位体积 | 32位体积 | 节省 |
133
+ |------|---------|---------|------|
134
+ | python3x.dll | ~4.5 MB | ~3.8 MB | 15% |
135
+ | Qt5Core.dll | ~8 MB | ~5 MB | 37% |
136
+ | numpy | ~30 MB | ~20 MB | 33% |
137
+ | **总体** | 基准 | **-20~30%** | - |
138
+
139
+ **推荐使用 32 位条件**:
140
+ - PASS: 程序内存占用 < 2GB
141
+ - PASS: 不处理超大文件(< 2GB)
142
+ - PASS: 目标用户是普通办公电脑
143
+
144
+ **32 位编译方法**:
145
+ ```bash
146
+ # 1. 安装 32 位 Python(和 64 位可以共存)
147
+ # 下载地址:https://www.python.org/downloads/windows/
148
+
149
+ # 2. 用 32 位 Python 安装依赖
150
+ py -3.12-32 -m pip install -r requirements.txt
151
+
152
+ # 3. 用 32 位 Python 编译
153
+ py -3.12-32 -m nuitka --standalone ...你的参数
154
+ ```
155
+
156
+ ### 二、模块排除清单(参考项目验证过的)
157
+
158
+ **安全排除列表**(运行时不需要):
159
+ ```
160
+ unittest,test,pytest,_pytest,doctest,pdb,pdbpp,
161
+ setuptools,pip,distutils,pkg_resources,
162
+ email.mime,http.server,xmlrpc,pydoc
163
+ ```
164
+
165
+ **预期效果**:节省 **30-50 MB**
166
+
167
+ ### 三、GUI 框架专用优化
168
+
169
+ #### Tkinter 极限优化(推荐,最轻量)
170
+ ```bash
171
+ nuitka --standalone --windows-console-mode=disable ^
172
+ --lto=yes ^
173
+ --jobs=8 ^
174
+ --enable-plugin=tk-inter ^
175
+ --enable-plugin=anti-bloat ^
176
+ --noinclude-pytest-mode=nofollow ^
177
+ --noinclude-setuptools-mode=nofollow ^
178
+ --nofollow-import-to=unittest,test,pytest,_pytest,doctest,pdb,pdbpp ^
179
+ --nofollow-import-to=setuptools,pip,distutils,pkg_resources ^
180
+ --nofollow-import-to=email.mime,http.server,xmlrpc,pydoc ^
181
+ --python-flag=no_docstrings ^
182
+ --output-dir=dist ^
183
+ --windows-icon-from-ico=icon.ico ^
184
+ --remove-output ^
185
+ main.py
186
+ ```
187
+
188
+ **预期体积**:80-120 MB(优化后)
189
+
190
+ #### PyQt5 / PySide2 优化
191
+ ```bash
192
+ nuitka --standalone --windows-console-mode=disable ^
193
+ --lto=yes ^
194
+ --jobs=8 ^
195
+ --enable-plugin=pyqt5 ^
196
+ --enable-plugin=anti-bloat ^
197
+ --noinclude-pytest-mode=nofollow ^
198
+ --noinclude-setuptools-mode=nofollow ^
199
+ --nofollow-import-to=unittest,test,pytest,_pytest,doctest,pdb ^
200
+ --nofollow-import-to=setuptools,pip,distutils,pkg_resources ^
201
+ --nofollow-import-to=PyQt5.QtWebEngine,PyQt5.QtWebEngineWidgets ^
202
+ --nofollow-import-to=PyQt5.Qt3D,PyQt5.QtCharts ^
203
+ --python-flag=no_docstrings ^
204
+ --include-qt-plugins=sensible,styles,platforms ^
205
+ --output-dir=dist ^
206
+ --windows-icon-from-ico=icon.ico ^
207
+ --remove-output ^
208
+ main.py
209
+ ```
210
+
211
+ **预期体积**:120-250 MB(优化后)
212
+
213
+ ### 四、一键编译脚本模板
214
+
215
+ **保存为 `build_optimized.bat`(项目根目录)**:
216
+
217
+ ```batch
218
+ @echo off
219
+ chcp 65001 >nul
220
+ setlocal enabledelayedexpansion
221
+
222
+ echo ========================================
223
+ echo Nuitka 极限优化编译(参考 参考项目)
224
+ echo ========================================
225
+
226
+ REM === 配置区域(请修改为你的实际值) ===
227
+ set APP_NAME=你的软件名
228
+ set MAIN_FILE=main.py
229
+ set ICON_FILE=icon.ico
230
+
231
+ REM === 自动检测 CPU 核心数 ===
232
+ REM 用 Windows 自带环境变量(wmic 在 Win11 22H2+ 已移除,探不到会让 --jobs=0 单线程编译)
233
+ set CPU_CORES=%NUMBER_OF_PROCESSORS%
234
+ if not defined CPU_CORES set CPU_CORES=4
235
+ set /a BUILD_JOBS=%CPU_CORES%
236
+
237
+ REM === 参考项目的模块排除清单 ===
238
+ set EXCLUDE_MODULES=unittest,test,pytest,_pytest,doctest,pdb,pdbpp
239
+ set EXCLUDE_MODULES=%EXCLUDE_MODULES%,setuptools,pip,distutils,pkg_resources
240
+ set EXCLUDE_MODULES=%EXCLUDE_MODULES%,email.mime,http.server,xmlrpc,pydoc
241
+
242
+ echo.
243
+ echo [1/4] 清理旧编译...
244
+ if exist dist rd /s /q dist
245
+ if exist build rd /s /q build
246
+
247
+ echo.
248
+ echo [2/4] Nuitka 编译中(应用 参考项目优化策略)...
249
+ echo - CPU 核心: %CPU_CORES% (使用 %BUILD_JOBS% 线程)
250
+ echo - 模块排除: %EXCLUDE_MODULES%
251
+ echo.
252
+
253
+ nuitka --standalone ^
254
+ --windows-console-mode=disable ^
255
+ --lto=yes ^
256
+ --jobs=%BUILD_JOBS% ^
257
+ --enable-plugin=anti-bloat ^
258
+ --enable-plugin=tk-inter ^
259
+ --noinclude-pytest-mode=nofollow ^
260
+ --noinclude-setuptools-mode=nofollow ^
261
+ --nofollow-import-to=%EXCLUDE_MODULES% ^
262
+ --python-flag=no_docstrings ^
263
+ --output-dir=dist ^
264
+ --windows-icon-from-ico=%ICON_FILE% ^
265
+ --remove-output ^
266
+ %MAIN_FILE%
267
+
268
+ if %errorlevel% neq 0 (
269
+ echo.
270
+ echo [错误] 编译失败!
271
+ pause
272
+ exit /b 1
273
+ )
274
+
275
+ echo.
276
+ echo [3/4] 统计编译结果...
277
+ for /f %%a in ('powershell -NoProfile -Command "(Get-ChildItem -LiteralPath 'dist\%APP_NAME%.dist' -Recurse -File | Measure-Object -Property Length -Sum).Sum"') do set TOTAL_SIZE=%%a
278
+ set TOTAL_SIZE=%TOTAL_SIZE:,=%
279
+ set /a SIZE_MB=%TOTAL_SIZE% / 1048576
280
+ echo - 编译后体积: %SIZE_MB% MB
281
+
282
+ echo.
283
+ echo [4/4] 执行瘦身清理(参考 参考项目策略)...
284
+ powershell -ExecutionPolicy Bypass -File slim_dist.ps1 -DistPath "dist\%APP_NAME%.dist"
285
+
286
+ echo.
287
+ echo ========================================
288
+ echo 编译完成!
289
+ echo ========================================
290
+ pause
291
+ ```
292
+
293
+ ### 五、dist 瘦身脚本(参考项目级别清理)
294
+
295
+ **保存为 `slim_dist.ps1`(和 build_optimized.bat 同目录)**:
296
+
297
+ ```powershell
298
+ param(
299
+ [string]$DistPath
300
+ )
301
+
302
+ $ErrorActionPreference = "Continue" # 不静默吞错:删除失败会显示出来,避免假成功
303
+
304
+ Write-Host "`n========================================" -ForegroundColor Cyan
305
+ Write-Host "dist 瘦身清理(参考 参考项目策略)" -ForegroundColor Cyan
306
+ Write-Host "========================================" -ForegroundColor Cyan
307
+
308
+ if (-not (Test-Path $DistPath)) {
309
+ Write-Host "[错误] 找不到目录: $DistPath" -ForegroundColor Red
310
+ exit 1
311
+ }
312
+
313
+ # 统计初始体积
314
+ $InitialSize = (Get-ChildItem -Path $DistPath -Recurse -File | Measure-Object -Property Length -Sum).Sum / 1MB
315
+ Write-Host "`n初始体积: $([math]::Round($InitialSize, 2)) MB" -ForegroundColor Yellow
316
+
317
+ # 参考项目特征:没有 .pdb, .pyi, __pycache__, test 等
318
+ Write-Host "`n[应用 参考项目的清理策略...]" -ForegroundColor Green
319
+
320
+ # 1. 删除调试符号
321
+ Write-Host "`n[1/7] 删除 .pdb 调试符号..." -ForegroundColor Green
322
+ $pdbFiles = Get-ChildItem -Path $DistPath -Recurse -Include *.pdb -File
323
+ $pdbSize = ($pdbFiles | Measure-Object -Property Length -Sum).Sum / 1MB
324
+ if ($pdbFiles.Count -gt 0) {
325
+ $pdbFiles | Remove-Item -Force
326
+ Write-Host " 删除 $($pdbFiles.Count) 个文件,节省 $([math]::Round($pdbSize, 2)) MB"
327
+ } else {
328
+ Write-Host " 未发现 .pdb 文件(已优化)" -ForegroundColor Gray
329
+ }
330
+
331
+ # 2. 删除类型提示
332
+ Write-Host "`n[2/7] 删除 .pyi 类型提示..." -ForegroundColor Green
333
+ $pyiFiles = Get-ChildItem -Path $DistPath -Recurse -Include *.pyi -File
334
+ $pyiSize = ($pyiFiles | Measure-Object -Property Length -Sum).Sum / 1MB
335
+ if ($pyiFiles.Count -gt 0) {
336
+ $pyiFiles | Remove-Item -Force
337
+ Write-Host " 删除 $($pyiFiles.Count) 个文件,节省 $([math]::Round($pyiSize, 2)) MB"
338
+ } else {
339
+ Write-Host " 未发现 .pyi 文件(已优化)" -ForegroundColor Gray
340
+ }
341
+
342
+ # 3. 删除 __pycache__
343
+ Write-Host "`n[3/7] 删除 __pycache__ 缓存..." -ForegroundColor Green
344
+ $pycacheDirs = Get-ChildItem -Path $DistPath -Recurse -Directory -Filter "__pycache__"
345
+ $pycacheSize = 0
346
+ foreach ($dir in $pycacheDirs) {
347
+ $size = (Get-ChildItem -Path $dir.FullName -Recurse -File | Measure-Object -Property Length -Sum).Sum
348
+ $pycacheSize += $size
349
+ Remove-Item -Path $dir.FullName -Recurse -Force
350
+ }
351
+ if ($pycacheDirs.Count -gt 0) {
352
+ Write-Host " 删除 $($pycacheDirs.Count) 个目录,节省 $([math]::Round($pycacheSize / 1MB, 2)) MB"
353
+ } else {
354
+ Write-Host " 未发现 __pycache__(已优化)" -ForegroundColor Gray
355
+ }
356
+
357
+ # 4. 删除测试目录
358
+ Write-Host "`n[4/7] 删除 test/tests 测试目录..." -ForegroundColor Green
359
+ $testDirs = Get-ChildItem -Path $DistPath -Recurse -Directory | Where-Object { $_.Name -match '^tests?$' }
360
+ $testSize = 0
361
+ foreach ($dir in $testDirs) {
362
+ $size = (Get-ChildItem -Path $dir.FullName -Recurse -File | Measure-Object -Property Length -Sum).Sum
363
+ $testSize += $size
364
+ Remove-Item -Path $dir.FullName -Recurse -Force
365
+ }
366
+ if ($testDirs.Count -gt 0) {
367
+ Write-Host " 删除 $($testDirs.Count) 个目录,节省 $([math]::Round($testSize / 1MB, 2)) MB"
368
+ } else {
369
+ Write-Host " 未发现测试目录(已优化)" -ForegroundColor Gray
370
+ }
371
+
372
+ # 5. 删除文档和示例
373
+ Write-Host "`n[5/7] 删除 docs/examples 文档目录..." -ForegroundColor Green
374
+ $docDirs = Get-ChildItem -Path $DistPath -Recurse -Directory | Where-Object { $_.Name -match '^(docs|examples|samples|demo)$' }
375
+ $docSize = 0
376
+ foreach ($dir in $docDirs) {
377
+ $size = (Get-ChildItem -Path $dir.FullName -Recurse -File | Measure-Object -Property Length -Sum).Sum
378
+ $docSize += $size
379
+ Remove-Item -Path $dir.FullName -Recurse -Force
380
+ }
381
+ if ($docDirs.Count -gt 0) {
382
+ Write-Host " 删除 $($docDirs.Count) 个目录,节省 $([math]::Round($docSize / 1MB, 2)) MB"
383
+ } else {
384
+ Write-Host " 未发现文档目录(已优化)" -ForegroundColor Gray
385
+ }
386
+
387
+ # 6. 删除 .pyc 文件
388
+ Write-Host "`n[6/7] 删除 .pyc 字节码..." -ForegroundColor Green
389
+ $pycFiles = Get-ChildItem -Path $DistPath -Recurse -Include *.pyc -File
390
+ $pycSize = ($pycFiles | Measure-Object -Property Length -Sum).Sum / 1MB
391
+ if ($pycFiles.Count -gt 0) {
392
+ $pycFiles | Remove-Item -Force
393
+ Write-Host " 删除 $($pycFiles.Count) 个文件,节省 $([math]::Round($pycSize, 2)) MB"
394
+ } else {
395
+ Write-Host " 未发现 .pyc 文件(已优化)" -ForegroundColor Gray
396
+ }
397
+
398
+ # 7. 精简 .dist-info 元数据
399
+ Write-Host "`n[7/7] 精简 .dist-info 元数据..." -ForegroundColor Green
400
+ $distInfoDirs = Get-ChildItem -Path $DistPath -Recurse -Directory -Filter "*.dist-info"
401
+ $removedCount = 0
402
+ $removedSize = 0
403
+ foreach ($infoDir in $distInfoDirs) {
404
+ # 仅删安装期记账文件;保留 METADATA 与 entry_points.txt(运行期被 importlib.metadata 读取,删除会破坏插件发现)
405
+ $filesToRemove = @("RECORD", "INSTALLER", "direct_url.json")
406
+ foreach ($fileName in $filesToRemove) {
407
+ $file = Join-Path $infoDir.FullName $fileName
408
+ if (Test-Path $file) {
409
+ $size = (Get-Item $file).Length
410
+ $removedSize += $size
411
+ Remove-Item $file -Force
412
+ $removedCount++
413
+ }
414
+ }
415
+ }
416
+ if ($removedCount -gt 0) {
417
+ Write-Host " 删除 $removedCount 个元数据文件,节省 $([math]::Round($removedSize / 1MB, 2)) MB"
418
+ } else {
419
+ Write-Host " 未发现可清理的元数据(已优化)" -ForegroundColor Gray
420
+ }
421
+
422
+ # 统计最终体积
423
+ $FinalSize = (Get-ChildItem -Path $DistPath -Recurse -File | Measure-Object -Property Length -Sum).Sum / 1MB
424
+ $SavedSize = $InitialSize - $FinalSize
425
+ $SavedPercent = if ($InitialSize -gt 0) { ($SavedSize / $InitialSize) * 100 } else { 0 }
426
+
427
+ Write-Host "`n========================================" -ForegroundColor Cyan
428
+ Write-Host "清理完成!" -ForegroundColor Green
429
+ Write-Host "========================================" -ForegroundColor Cyan
430
+ Write-Host "初始体积: $([math]::Round($InitialSize, 2)) MB" -ForegroundColor Yellow
431
+ Write-Host "最终体积: $([math]::Round($FinalSize, 2)) MB" -ForegroundColor Green
432
+ Write-Host "节省空间: $([math]::Round($SavedSize, 2)) MB ($([math]::Round($SavedPercent, 1))%)" -ForegroundColor Cyan
433
+ Write-Host "========================================`n" -ForegroundColor Cyan
434
+
435
+ # 对比 参考项目
436
+ Write-Host "[对比参考]" -ForegroundColor Yellow
437
+ Write-Host "参考项目总体积: 323 MB (包含 PyQt, OpenCV, Playwright 等重量级库)" -ForegroundColor Gray
438
+ Write-Host "如果你的项目是纯 Tkinter + 标准库,目标应该在 80-150 MB" -ForegroundColor Gray
439
+ ```
440
+
441
+ **预期效果**:节省 **15-30%** 体积
442
+
443
+ ### 六、DLL 依赖分析工具
444
+
445
+ **保存为 `analyze_dlls.py`(用于找出体积大户)**:
446
+
447
+ ```python
448
+ """
449
+ DLL 依赖分析工具
450
+ 参考 参考项目的 DLL 管理策略,帮助识别体积大户和优化建议
451
+ """
452
+ import sys
453
+ from pathlib import Path
454
+
455
+ def analyze_dlls(dist_path: str):
456
+ """分析 dist 目录中的 DLL 依赖"""
457
+ dist_dir = Path(dist_path)
458
+
459
+ if not dist_dir.exists():
460
+ print(f"[错误] 目录不存在: {dist_path}")
461
+ return
462
+
463
+ print("=" * 70)
464
+ print("DLL 依赖分析(参考 参考项目策略)")
465
+ print("=" * 70)
466
+
467
+ # 收集所有 DLL
468
+ dll_files = list(dist_dir.rglob("*.dll"))
469
+
470
+ if not dll_files:
471
+ print("\n未发现 DLL 文件")
472
+ return
473
+
474
+ # 按大小排序
475
+ dll_data = [(dll, dll.stat().st_size) for dll in dll_files]
476
+ dll_data.sort(key=lambda x: x[1], reverse=True)
477
+
478
+ total_size = sum(size for _, size in dll_data)
479
+
480
+ print(f"\n总 DLL 数量: {len(dll_files)}")
481
+ print(f"总 DLL 体积: {total_size / 1024 / 1024:.2f} MB\n")
482
+
483
+ # 参考项目对比
484
+ print("[对比参考] 参考项目的 DLL 情况:")
485
+ print(" - 总数量: 71 个")
486
+ print(" - 总体积: 93.23 MB")
487
+ print(" - 最大的: libopenblas (26.85 MB), opengl32sw (15.25 MB)\n")
488
+
489
+ # 分析大于 3MB 的 DLL
490
+ large_dlls = [(dll, size) for dll, size in dll_data if size > 3 * 1024 * 1024]
491
+
492
+ if large_dlls:
493
+ print("=" * 70)
494
+ print("WARNING: 大于 3MB 的 DLL(需重点关注)")
495
+ print("=" * 70)
496
+
497
+ for dll, size in large_dlls:
498
+ size_mb = size / 1024 / 1024
499
+ relative_path = dll.relative_to(dist_dir)
500
+ name_lower = dll.name.lower()
501
+
502
+ print(f"\n{size_mb:8.2f} MB {dll.name}")
503
+ print(f" 位置: {relative_path.parent}")
504
+
505
+ # 优化建议
506
+ suggestions = get_optimization_suggestion(name_lower)
507
+ if suggestions:
508
+ for suggestion in suggestions:
509
+ print(f" {suggestion}")
510
+
511
+ # 检查冗余 DLL
512
+ print("\n" + "=" * 70)
513
+ print(" 冗余检查")
514
+ print("=" * 70)
515
+
516
+ # 检查调试版本
517
+ debug_dlls = [dll for dll, _ in dll_data if dll.stem.endswith('d')]
518
+ if debug_dlls:
519
+ print(f"\nWARNING: 发现 {len(debug_dlls)} 个调试版本 DLL(可以删除):")
520
+ for dll in debug_dlls:
521
+ print(f" - {dll.name}")
522
+ else:
523
+ print("\nPASS: 未发现调试版本 DLL(已优化)")
524
+
525
+ # VC++ Runtime
526
+ vc_runtimes = [dll for dll, _ in dll_data if 'vcruntime' in dll.name.lower() or 'msvcp' in dll.name.lower()]
527
+ if vc_runtimes:
528
+ print(f"\n[VC++ Runtime 库] 发现 {len(vc_runtimes)} 个:")
529
+ for dll in vc_runtimes:
530
+ size_mb = dll.stat().st_size / 1024 / 1024
531
+ print(f" - {dll.name} ({size_mb:.2f} MB)")
532
+ print(" 这些是必需的,参考项目也包含了这些文件")
533
+
534
+ # 全部 DLL 列表
535
+ print("\n" + "=" * 70)
536
+ print(" 完整 DLL 列表(按体积排序,前 20)")
537
+ print("=" * 70)
538
+ print(f"\n{'体积 (MB)':>10} {'文件名':<30} 位置")
539
+ print("-" * 70)
540
+
541
+ for dll, size in dll_data[:20]:
542
+ size_mb = size / 1024 / 1024
543
+ relative_path = dll.relative_to(dist_dir)
544
+ location = str(relative_path.parent) if relative_path.parent != Path('.') else "根目录"
545
+ print(f"{size_mb:10.2f} {dll.name:<30} {location}")
546
+
547
+ if len(dll_data) > 20:
548
+ remaining_size = sum(size for _, size in dll_data[20:]) / 1024 / 1024
549
+ print(f"... 还有 {len(dll_data) - 20} 个 DLL,共 {remaining_size:.2f} MB")
550
+
551
+
552
+ def get_optimization_suggestion(dll_name: str) -> list:
553
+ """根据 DLL 名称给出优化建议"""
554
+ suggestions = []
555
+
556
+ if "openblas" in dll_name or "mkl" in dll_name:
557
+ suggestions.append("数学运算库,参考项目的 libopenblas 有 26.85 MB")
558
+ suggestions.append("如不需要高性能计算可考虑轻量版")
559
+
560
+ elif "opencv" in dll_name or "ffmpeg" in dll_name:
561
+ suggestions.append("OpenCV 相关,参考项目的 opencv_videoio_ffmpeg 有 18.48 MB")
562
+ suggestions.append("考虑用 opencv-python-headless")
563
+
564
+ elif "qt5" in dll_name or "qt6" in dll_name or "pyside" in dll_name:
565
+ suggestions.append("Qt 库,参考项目的 Qt5Core 有 5.13 MB")
566
+ suggestions.append("可排除不需要的模块(WebEngine, 3D, Charts)")
567
+
568
+ elif "opengl" in dll_name and "sw" in dll_name:
569
+ suggestions.append("OpenGL 软件渲染器,参考项目保留了 15.25 MB")
570
+ suggestions.append("通常可以删除(使用硬件渲染)")
571
+
572
+ elif "d3dcompiler" in dll_name:
573
+ suggestions.append("DirectX 编译器,参考项目有 3.53 MB")
574
+
575
+ elif "mfc140" in dll_name:
576
+ suggestions.append("MFC 库,参考项目有 4.89 MB")
577
+
578
+ return suggestions
579
+
580
+
581
+ if __name__ == "__main__":
582
+ if len(sys.argv) < 2:
583
+ print("用法: python analyze_dlls.py <dist目录路径>")
584
+ print("示例: python analyze_dlls.py dist/main.dist")
585
+ sys.exit(1)
586
+
587
+ analyze_dlls(sys.argv[1])
588
+ ```
589
+
590
+ **使用方法**:
591
+ ```bash
592
+ python analyze_dlls.py dist/你的软件名.dist
593
+ ```
594
+
595
+ ---
596
+
597
+ ## 完整优化工作流
598
+
599
+ ### 步骤 1:修改编译脚本配置
600
+
601
+ 编辑 `build_optimized.bat`,修改这 3 行:
602
+
603
+ ```batch
604
+ set APP_NAME=你的软件名 REM 改成实际名称
605
+ set MAIN_FILE=main.py REM 你的主程序文件
606
+ set ICON_FILE=icon.ico REM 你的图标文件
607
+ ```
608
+
609
+ ### 步骤 2:一键编译+瘦身
610
+
611
+ ```bash
612
+ # 在项目根目录执行
613
+ build_optimized.bat
614
+ ```
615
+
616
+ ### 步骤 3:分析 DLL 依赖
617
+
618
+ ```bash
619
+ python analyze_dlls.py dist/你的软件名.dist
620
+ ```
621
+
622
+ ### 步骤 4:根据分析结果优化
623
+
624
+ **如果用了 OpenCV** → 改用无头版
625
+ ```bash
626
+ pip uninstall opencv-python
627
+ pip install opencv-python-headless
628
+ ```
629
+
630
+ **如果用了 Qt** → 排除不需要的模块
631
+ ```batch
632
+ # 在编译命令中添加
633
+ --nofollow-import-to=PyQt5.QtWebEngine,PyQt5.Qt3D,PyQt5.QtCharts
634
+ ```
635
+
636
+ **删除软件渲染器**(如果不需要)
637
+ ```powershell
638
+ # 在 dist 目录执行
639
+ Remove-Item "opengl32sw.dll" -Force
640
+ ```
641
+
642
+ ---
643
+
644
+ ## VC++ 运行库处理方案
645
+
646
+ ### 方案一:静态链接(推荐)
647
+ ```bash
648
+ nuitka --static-libpython=yes ...
649
+ ```
650
+
651
+ ### 方案二:捆绑运行库安装(商业发布推荐)
652
+ 在 Inno Setup 脚本中添加:
653
+
654
+ ```iss
655
+ ; WARNING: VC++ 运行库架构必须与 Python/Nuitka 构建架构一致。
656
+ ; 本 skill 推荐 32 位 Python,故默认捆绑 vc_redist.x86.exe;
657
+ ; 若用 64 位 Python 编译,请把下面两处改为 vc_redist.x64.exe。
658
+ [Files]
659
+ Source: "{#MySourceDir}\..\vc_redist.x86.exe"; DestDir: "{tmp}"; Flags: deleteafterinstall
660
+
661
+ [Run]
662
+ Filename: "{tmp}\vc_redist.x86.exe"; Parameters: "/quiet /norestart"; StatusMsg: "正在安装运行库..."; Flags: waituntilterminated
663
+ ```
664
+
665
+ > 下载地址:[Microsoft Visual C++ Redistributable](https://learn.microsoft.com/en-us/cpp/windows/latest-supported-vc-redist)
666
+
667
+ ---
668
+
669
+ ## Inno Setup 脚本模板(商业终极版)
670
+
671
+ ```iss
672
+ ; =====================================================================
673
+ ; WARNING: 商业级 Python 安装脚本 (Inno Setup 6.x)
674
+ ; 特性:LZMA2 极限压缩 | 全中文 | 完整元数据 | 无残留卸载
675
+ ; 参考:参考项目(323 MB, LZMA2 压缩)
676
+ ; =====================================================================
677
+
678
+ ; --- 1. 参数定义 ---
679
+ #define MyAppName "{{APP_NAME}}"
680
+ #define MyAppVersion "{{APP_VERSION}}"
681
+ #define MyAppPublisher "{{PUBLISHER}}"
682
+ #define MyAppURL "{{APP_URL}}"
683
+ #define MyAppExeName "{{EXE_NAME}}"
684
+ #define MySourceDir "{{SOURCE_DIR}}"
685
+ #define MyOutputDir "{{OUTPUT_DIR}}"
686
+ ;#define MyIconPath "{{ICON_PATH}}"
687
+
688
+ [Setup]
689
+ ; --- 身份识别 ---
690
+ AppId={{GENERATE_RANDOM_GUID}}
691
+ AppName={#MyAppName}
692
+ AppVersion={#MyAppVersion}
693
+ AppPublisher={#MyAppPublisher}
694
+ AppPublisherURL={#MyAppURL}
695
+ AppSupportURL={#MyAppURL}
696
+ AppUpdatesURL={#MyAppURL}
697
+
698
+ ; --- 安装路径与权限 ---
699
+ DefaultDirName={autopf}\{#MyAppName}
700
+ DefaultGroupName={#MyAppName}
701
+ DisableDirPage=no
702
+ DisableProgramGroupPage=no
703
+ PrivilegesRequired=admin
704
+
705
+ ; --- 输出设置 ---
706
+ OutputDir={#MyOutputDir}
707
+ OutputBaseFilename=Setup_{#MyAppName}_v{#MyAppVersion}
708
+
709
+ ; --- 视觉体验 ---
710
+ WizardStyle=modern
711
+ #ifdef MyIconPath
712
+ SetupIconFile={#MyIconPath}
713
+ UninstallDisplayIcon={app}\{#MyAppExeName}
714
+ #endif
715
+
716
+ ; --- 核心压缩 (参考 参考项目) ---
717
+ Compression=lzma2/ultra64
718
+ SolidCompression=yes
719
+ LZMAUseSeparateProcess=yes
720
+
721
+ ; --- 架构 ---
722
+ ; 注意:仅 64 位 Python 构建才设此项。本 skill 推荐 32 位 Python——
723
+ ; 32 位构建请保持注释,使应用按 32 位安装并与上面捆绑的 vc_redist.x86.exe 匹配。
724
+ ; 仅当用 64 位 Python 编译时才取消注释。
725
+ ;ArchitecturesInstallIn64BitMode=x64compatible
726
+
727
+ [Languages]
728
+ Name: "chinesesimplified"; MessagesFile: "compiler:Languages\ChineseSimplified.isl"
729
+
730
+ [Files]
731
+ Source: "{#MySourceDir}\*"; DestDir: "{app}"; Flags: ignoreversion recursesubdirs createallsubdirs
732
+
733
+ [UninstallDelete]
734
+ Type: filesandordirs; Name: "{app}\*"
735
+
736
+ [Icons]
737
+ Name: "{autodesktop}\{#MyAppName}"; Filename: "{app}\{#MyAppExeName}"; Tasks: desktopicon
738
+ Name: "{group}\{#MyAppName}"; Filename: "{app}\{#MyAppExeName}"
739
+ Name: "{group}\卸载 {#MyAppName}"; Filename: "{uninstallexe}"
740
+
741
+ [Tasks]
742
+ Name: "desktopicon"; Description: "{cm:CreateDesktopIcon}"; GroupDescription: "{cm:AdditionalIcons}"; Flags: unchecked
743
+
744
+ [Run]
745
+ Filename: "{app}\{#MyAppExeName}"; Description: "{cm:LaunchProgram,{#MyAppName}}"; Flags: nowait postinstall skipifsilent
746
+ ```
747
+
748
+ ---
749
+
750
+ ## 占位符说明
751
+
752
+ | 占位符 | 说明 | 示例值 |
753
+ |--------|------|--------|
754
+ | `{{APP_NAME}}` | 软件显示名称 | `红墨批注` |
755
+ | `{{APP_VERSION}}` | 版本号 | `1.0.0` |
756
+ | `{{PUBLISHER}}` | 发布者/公司名 | `MyCompany` |
757
+ | `{{APP_URL}}` | 官网地址 | `https://example.com` |
758
+ | `{{EXE_NAME}}` | 主程序文件名 | `RedInk.exe` |
759
+ | `{{SOURCE_DIR}}` | Nuitka dist 文件夹路径 | `D:\project\dist\RedInk.dist` |
760
+ | `{{OUTPUT_DIR}}` | 安装包输出路径 | `D:\project\output` |
761
+ | `{{ICON_PATH}}` | 图标文件路径 | `D:\project\icon.ico` |
762
+ | `{{GENERATE_RANDOM_GUID}}` | **需生成唯一GUID** | 使用 Inno Setup "Tools > Generate GUID" |
763
+
764
+ ---
765
+
766
+ ## 常见问题 (FAQ)
767
+
768
+ ### Q1: 安装后双击程序无反应?
769
+ 1. 打开 CMD,手动运行 exe 查看错误信息
770
+ 2. 检查是否缺少 VC++ 运行库
771
+ 3. 检查 Nuitka 编译是否成功
772
+
773
+ ### Q2: 安装包体积过大?
774
+ **优化方法**:
775
+ 1. 使用 32 位 Python 编译(节省 20-30%)
776
+ 2. 应用 参考项目的模块排除清单
777
+ 3. 启用 Anti-Bloat 插件
778
+ 4. 执行 dist 文件夹瘦身脚本
779
+ 5. 分析 DLL,移除不必要的大文件
780
+
781
+ ### Q3: 杀毒软件误报?
782
+ **解决方案**:
783
+ - 提交到主流杀毒厂商进行白名单申请
784
+ - 购买代码签名证书(推荐:Sectigo, DigiCert)
785
+ - 避免使用 UPX 压缩
786
+
787
+ ### Q4: 安装时提示 Windows 已保护你的电脑?
788
+ - 购买 EV 代码签名证书(可立即获得信任)
789
+ - 普通代码签名证书需要积累安装量后逐渐获得信任
790
+
791
+ ---
792
+
793
+ ## 实战问题处理记录(更新 2026-02-07)
794
+
795
+ - **安装后提示缺少 python3xx.dll**:必须使用 Nuitka `--standalone`;确认 dist 内存在该 dll;不要打单文件版。
796
+ - **安装后点击无反应**:GUI 启动期可能被重依赖阻塞;将重依赖延迟到"开始导出"再 import;添加日志排查。
797
+ - **Nuitka + MinGW 在非 ASCII 路径报错**:把源码复制到 ASCII 目录再编译;设置 `PYTHONIOENCODING=utf-8`。
798
+ - **Inno Setup 警告 `x64` 已弃用(仅 64 位构建需要 64 位安装模式时)**:改为 `ArchitecturesInstallIn64BitMode=x64compatible`;32 位构建无需此项。
799
+ - **`--disable-console` 已废弃**:改用 `--windows-console-mode=disable`。
800
+ - **dist 出现 `_nuitka_temp.exe`**:在 [Files] 中排除它。
801
+
802
+ ---
803
+
804
+ ## 优化效果预期
805
+
806
+ | 优化组合 | 体积减少 | 启动提升 | 风险等级 |
807
+ |----------|----------|----------|----------|
808
+ | 基础编译 | 基准 | 基准 | 无 |
809
+ | + `--lto=yes` | 5-10% | 10-20% | PASS: 无 |
810
+ | + anti-bloat | 15-25% | - | PASS: 无 |
811
+ | + 模块排除 | 20-35% | 5% | PASS: 无 |
812
+ | + dist 瘦身 | 25-40% | - | PASS: 无 |
813
+ | + 32 位编译 | 40-60% | - | PASS: 无 |
814
+ | **全部组合** | **45-65%** | **15-25%** | PASS: **无风险** |
815
+
816
+ > WARNING: **不建议使用 UPX 压缩**,虽然能进一步减小体积,但极易触发杀毒软件误报。
817
+
818
+ ---
819
+
820
+ **基于 参考项目实战经验优化,助你打造商业级安装包!**