@oriro/orirocli 0.1.11 → 0.1.12
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.
- package/ATTRIBUTION.md +53 -53
- package/LICENSE +21 -21
- package/README.md +2 -7
- package/dist/cli.js +402 -40
- package/package.json +64 -64
- package/skills/1password/SKILL.md +118 -118
- package/skills/1password/references/cli-examples.md +29 -29
- package/skills/1password/references/get-started.md +21 -21
- package/skills/21stdev/SKILL.md +64 -64
- package/skills/algorithmic-art/LICENSE +21 -21
- package/skills/algorithmic-art/SKILL.md +446 -446
- package/skills/algorithmic-art/templates/generator_template.js +223 -223
- package/skills/algorithmic-art/templates/viewer.html +598 -598
- package/skills/apple-notes/SKILL.md +81 -81
- package/skills/apple-reminders/SKILL.md +122 -122
- package/skills/bear-notes/SKILL.md +111 -111
- package/skills/blogwatcher/SKILL.md +73 -73
- package/skills/blucli/SKILL.md +51 -51
- package/skills/brand-guidelines/LICENSE +21 -21
- package/skills/brand-guidelines/SKILL.md +76 -76
- package/skills/business/biz-analysis/LICENSE +21 -21
- package/skills/business/biz-analysis/SKILL.md +103 -103
- package/skills/business/biz-corporate-strategy/LICENSE +21 -21
- package/skills/business/biz-corporate-strategy/SKILL.md +76 -76
- package/skills/business/biz-customer-success/LICENSE +21 -21
- package/skills/business/biz-customer-success/SKILL.md +55 -55
- package/skills/business/biz-entrepreneurship/LICENSE +21 -21
- package/skills/business/biz-entrepreneurship/SKILL.md +72 -72
- package/skills/business/biz-hr/LICENSE +21 -21
- package/skills/business/biz-hr/SKILL.md +67 -67
- package/skills/business/biz-international/LICENSE +21 -21
- package/skills/business/biz-international/SKILL.md +51 -51
- package/skills/business/biz-leadership/LICENSE +21 -21
- package/skills/business/biz-leadership/SKILL.md +106 -106
- package/skills/business/biz-marketing-strategy/LICENSE +21 -21
- package/skills/business/biz-marketing-strategy/SKILL.md +119 -119
- package/skills/business/biz-negotiation/LICENSE +21 -21
- package/skills/business/biz-negotiation/SKILL.md +152 -152
- package/skills/business/biz-operations/LICENSE +21 -21
- package/skills/business/biz-operations/SKILL.md +74 -74
- package/skills/business/biz-project/LICENSE +21 -21
- package/skills/business/biz-project/SKILL.md +203 -203
- package/skills/business/biz-risk/LICENSE +21 -21
- package/skills/business/biz-risk/SKILL.md +85 -85
- package/skills/business/biz-sales/LICENSE +21 -21
- package/skills/business/biz-sales/SKILL.md +92 -92
- package/skills/business/biz-startup-ops/LICENSE +21 -21
- package/skills/business/biz-startup-ops/SKILL.md +70 -70
- package/skills/business/biz-strategy/LICENSE +21 -21
- package/skills/business/biz-strategy/SKILL.md +233 -233
- package/skills/business/biz-supply-chain-advanced/LICENSE +21 -21
- package/skills/business/biz-supply-chain-advanced/SKILL.md +68 -68
- package/skills/business/fin-chartered-exams/LICENSE +21 -21
- package/skills/business/fin-chartered-exams/SKILL.md +69 -69
- package/skills/camsnap/SKILL.md +49 -49
- package/skills/canvas/SKILL.md +82 -82
- package/skills/canvas-design/LICENSE +21 -21
- package/skills/canvas-design/SKILL.md +140 -140
- package/skills/canvas-design/canvas-fonts/ArsenalSC-OFL.txt +93 -93
- package/skills/canvas-design/canvas-fonts/BigShoulders-OFL.txt +93 -93
- package/skills/canvas-design/canvas-fonts/Boldonse-OFL.txt +93 -93
- package/skills/canvas-design/canvas-fonts/BricolageGrotesque-OFL.txt +93 -93
- package/skills/canvas-design/canvas-fonts/CrimsonPro-OFL.txt +93 -93
- package/skills/canvas-design/canvas-fonts/DMMono-OFL.txt +93 -93
- package/skills/canvas-design/canvas-fonts/EricaOne-OFL.txt +94 -94
- package/skills/canvas-design/canvas-fonts/GeistMono-OFL.txt +93 -93
- package/skills/canvas-design/canvas-fonts/Gloock-OFL.txt +93 -93
- package/skills/canvas-design/canvas-fonts/IBMPlexMono-OFL.txt +93 -93
- package/skills/canvas-design/canvas-fonts/InstrumentSans-OFL.txt +93 -93
- package/skills/canvas-design/canvas-fonts/JetBrainsMono-OFL.txt +93 -93
- package/skills/canvas-design/canvas-fonts/Jura-OFL.txt +93 -93
- package/skills/canvas-design/canvas-fonts/LibreBaskerville-OFL.txt +93 -93
- package/skills/canvas-design/canvas-fonts/Lora-OFL.txt +93 -93
- package/skills/canvas-design/canvas-fonts/NationalPark-OFL.txt +93 -93
- package/skills/canvas-design/canvas-fonts/Outfit-OFL.txt +93 -93
- package/skills/canvas-design/canvas-fonts/PixelifySans-OFL.txt +93 -93
- package/skills/canvas-design/canvas-fonts/RedHatMono-OFL.txt +93 -93
- package/skills/canvas-design/canvas-fonts/Silkscreen-OFL.txt +93 -93
- package/skills/canvas-design/canvas-fonts/SmoochSans-OFL.txt +93 -93
- package/skills/canvas-design/canvas-fonts/Tektur-OFL.txt +93 -93
- package/skills/canvas-design/canvas-fonts/WorkSans-OFL.txt +93 -93
- package/skills/canvas-design/canvas-fonts/YoungSerif-OFL.txt +93 -93
- package/skills/coding-agent/SKILL.md +146 -146
- package/skills/communication/comm-business-writing/LICENSE +21 -21
- package/skills/communication/comm-business-writing/SKILL.md +67 -67
- package/skills/communication/comm-cross-cultural/LICENSE +21 -21
- package/skills/communication/comm-cross-cultural/SKILL.md +88 -88
- package/skills/communication/comm-journalism/LICENSE +21 -21
- package/skills/communication/comm-journalism/SKILL.md +81 -81
- package/skills/communication/comm-linguistics/LICENSE +21 -21
- package/skills/communication/comm-linguistics/SKILL.md +82 -82
- package/skills/communication/comm-negotiation/LICENSE +21 -21
- package/skills/communication/comm-negotiation/SKILL.md +120 -120
- package/skills/communication/comm-presentations/LICENSE +21 -21
- package/skills/communication/comm-presentations/SKILL.md +93 -93
- package/skills/communication/comm-public-speaking/LICENSE +21 -21
- package/skills/communication/comm-public-speaking/SKILL.md +68 -68
- package/skills/communication/comm-writing/LICENSE +21 -21
- package/skills/communication/comm-writing/SKILL.md +69 -69
- package/skills/craft/ai-engineering/LICENSE +21 -21
- package/skills/craft/ai-engineering/SKILL.md +828 -828
- package/skills/craft/app-builder-guide/LICENSE +21 -21
- package/skills/craft/app-builder-guide/SKILL.md +332 -332
- package/skills/craft/become-an-ai-engineer-26/CONTRIBUTING.md +46 -46
- package/skills/craft/become-an-ai-engineer-26/LICENSE +21 -21
- package/skills/craft/become-an-ai-engineer-26/README.md +270 -270
- package/skills/craft/become-an-ai-engineer-26/SKILL.md +667 -667
- package/skills/craft/become-an-ai-engineer-26/community/BUILDS.md +13 -13
- package/skills/craft/become-an-ai-engineer-26/community/DISCUSSIONS.md +8 -8
- package/skills/craft/become-an-ai-engineer-26/phases/phase-0-mental-models/README.md +14 -14
- package/skills/craft/become-an-ai-engineer-26/phases/phase-0-mental-models/project/TEMPLATE.md +33 -33
- package/skills/craft/become-an-ai-engineer-26/phases/phase-1-first-agent/README.md +25 -25
- package/skills/craft/become-an-ai-engineer-26/phases/phase-1-first-agent/code/raw_loop.py +126 -126
- package/skills/craft/become-an-ai-engineer-26/phases/phase-2-architecture/README.md +17 -17
- package/skills/craft/become-an-ai-engineer-26/phases/phase-3-harness/README.md +17 -17
- package/skills/craft/become-an-ai-engineer-26/phases/phase-4-evals/README.md +21 -21
- package/skills/craft/become-an-ai-engineer-26/phases/phase-4-evals/code/.github/workflows/eval.yml +40 -40
- package/skills/craft/become-an-ai-engineer-26/phases/phase-5-production/README.md +16 -16
- package/skills/craft/become-an-ai-engineer-26/projects/1-mobile-app-slm/README.md +11 -11
- package/skills/craft/become-an-ai-engineer-26/projects/2-self-improving-coder/README.md +11 -11
- package/skills/craft/become-an-ai-engineer-26/projects/3-video-editor-agent/README.md +11 -11
- package/skills/craft/become-an-ai-engineer-26/projects/4-personal-life-os/README.md +12 -12
- package/skills/craft/become-an-ai-engineer-26/projects/5-enterprise-workflow/README.md +12 -12
- package/skills/craft/become-an-ai-engineer-26/references/benchmark-numbers.md +41 -41
- package/skills/craft/become-an-ai-engineer-26/references/mhc-stable-training.md +73 -73
- package/skills/craft/become-an-ai-engineer-26/references/stack-decisions.md +37 -37
- package/skills/craft/become-an-ai-engineer-26/references/yarn-context-extension.md +123 -123
- package/skills/craft/codex-result-handling/LICENSE +21 -21
- package/skills/craft/codex-result-handling/SKILL.md +26 -26
- package/skills/craft/debug-and-build-methodology/LICENSE +21 -21
- package/skills/craft/debug-and-build-methodology/SKILL.md +432 -432
- package/skills/craft/design/LICENSE +21 -21
- package/skills/craft/design/SKILL.md +274 -274
- package/skills/craft/dev/LICENSE +21 -21
- package/skills/craft/dev/SKILL.md +12 -12
- package/skills/craft/dev/release.md +85 -85
- package/skills/craft/dev/roll.md +50 -50
- package/skills/craft/doc-coauthoring/LICENSE +21 -21
- package/skills/craft/doc-coauthoring/SKILL.md +397 -397
- package/skills/craft/focus/LICENSE +21 -21
- package/skills/craft/focus/SKILL.md +432 -432
- package/skills/craft/focus/UPSTREAM_README.md +233 -233
- package/skills/craft/gh/LICENSE +21 -21
- package/skills/craft/gh/SKILL.md +84 -84
- package/skills/craft/gh-skill/LICENSE +21 -21
- package/skills/craft/gh-skill/SKILL.md +121 -121
- package/skills/craft/godmode/LICENSE +21 -21
- package/skills/craft/godmode/SKILL.md +87 -87
- package/skills/craft/godmode/references/android-launch.md +680 -680
- package/skills/craft/godmode/references/data-gcp.md +1038 -1038
- package/skills/craft/godmode/references/expo-eas.md +816 -816
- package/skills/craft/godmode/references/ios-launch.md +734 -734
- package/skills/craft/google-ai-latest/LICENSE +21 -21
- package/skills/craft/google-ai-latest/SKILL.md +682 -682
- package/skills/craft/gpt-5-4-prompting/LICENSE +21 -21
- package/skills/craft/gpt-5-4-prompting/SKILL.md +63 -63
- package/skills/craft/gpt-5-4-prompting/references/codex-prompt-antipatterns.md +101 -101
- package/skills/craft/gpt-5-4-prompting/references/codex-prompt-recipes.md +150 -150
- package/skills/craft/gpt-5-4-prompting/references/prompt-blocks.md +172 -172
- package/skills/craft/grill-me/LICENSE +21 -21
- package/skills/craft/grill-me/SKILL.md +13 -13
- package/skills/craft/idea-to-deploy/LICENSE +21 -21
- package/skills/craft/idea-to-deploy/SKILL.md +292 -292
- package/skills/craft/idea-to-deploy/references/auth-playbook.md +195 -195
- package/skills/craft/idea-to-deploy/references/gcp-deployment.md +268 -268
- package/skills/craft/idea-to-deploy/references/stack-selection.md +117 -117
- package/skills/craft/image-generation-engineer/LICENSE +21 -21
- package/skills/craft/image-generation-engineer/SKILL.md +183 -183
- package/skills/craft/image-generation-engineer/references/architectures.md +260 -260
- package/skills/craft/image-generation-engineer/references/foundations.md +107 -107
- package/skills/craft/image-generation-engineer/references/inference-and-serving.md +253 -253
- package/skills/craft/image-generation-engineer/references/training.md +149 -149
- package/skills/craft/marketing/LICENSE +21 -21
- package/skills/craft/marketing/SKILL.md +1954 -1954
- package/skills/craft/master-architect/LICENSE +21 -21
- package/skills/craft/master-architect/SKILL.md +361 -361
- package/skills/craft/master-architect/references/ai-ml.md +317 -317
- package/skills/craft/master-architect/references/architecture.md +268 -268
- package/skills/craft/master-architect/references/auth-playbook.md +195 -195
- package/skills/craft/master-architect/references/cloud.md +323 -323
- package/skills/craft/master-architect/references/cyber.md +839 -839
- package/skills/craft/master-architect/references/data-eng.md +366 -366
- package/skills/craft/master-architect/references/devops.md +550 -550
- package/skills/craft/master-architect/references/gcp-deployment.md +268 -268
- package/skills/craft/master-architect/references/languages.md +748 -748
- package/skills/craft/master-architect/references/legacy.md +240 -240
- package/skills/craft/master-architect/references/mobile.md +447 -447
- package/skills/craft/master-architect/references/patterns.md +451 -451
- package/skills/craft/master-architect/references/saas-patterns.md +379 -379
- package/skills/craft/master-architect/references/sdlc.md +349 -349
- package/skills/craft/master-architect/references/stack-selection.md +117 -117
- package/skills/craft/oriro-ui-2026/LICENSE +21 -21
- package/skills/craft/oriro-ui-2026/SKILL.md +329 -329
- package/skills/craft/playwright-cli/LICENSE +21 -21
- package/skills/craft/playwright-cli/SKILL.md +393 -393
- package/skills/craft/playwright-cli/references/element-attributes.md +23 -23
- package/skills/craft/playwright-cli/references/playwright-tests.md +39 -39
- package/skills/craft/playwright-cli/references/request-mocking.md +87 -87
- package/skills/craft/playwright-cli/references/running-code.md +240 -240
- package/skills/craft/playwright-cli/references/session-management.md +226 -226
- package/skills/craft/playwright-cli/references/spec-driven-testing.md +312 -312
- package/skills/craft/playwright-cli/references/storage-state.md +275 -275
- package/skills/craft/playwright-cli/references/test-generation.md +134 -134
- package/skills/craft/playwright-cli/references/tracing.md +142 -142
- package/skills/craft/playwright-cli/references/video-recording.md +150 -150
- package/skills/craft/remotion-best-practices/LICENSE +21 -21
- package/skills/craft/remotion-best-practices/SKILL.md +345 -345
- package/skills/craft/remotion-best-practices/rules/3d.md +86 -86
- package/skills/craft/remotion-best-practices/rules/assets/charts-bar-chart.tsx +165 -165
- package/skills/craft/remotion-best-practices/rules/assets/text-animations-typewriter.tsx +89 -89
- package/skills/craft/remotion-best-practices/rules/assets/text-animations-word-highlight.tsx +101 -101
- package/skills/craft/remotion-best-practices/rules/audio-visualization.md +195 -195
- package/skills/craft/remotion-best-practices/rules/audio.md +167 -167
- package/skills/craft/remotion-best-practices/rules/calculate-metadata.md +118 -118
- package/skills/craft/remotion-best-practices/rules/compositions.md +132 -132
- package/skills/craft/remotion-best-practices/rules/display-captions.md +176 -176
- package/skills/craft/remotion-best-practices/rules/ffmpeg.md +34 -34
- package/skills/craft/remotion-best-practices/rules/get-audio-duration.md +58 -58
- package/skills/craft/remotion-best-practices/rules/get-video-dimensions.md +68 -68
- package/skills/craft/remotion-best-practices/rules/get-video-duration.md +60 -60
- package/skills/craft/remotion-best-practices/rules/gifs.md +135 -135
- package/skills/craft/remotion-best-practices/rules/google-fonts.md +72 -72
- package/skills/craft/remotion-best-practices/rules/html-in-canvas.md +122 -122
- package/skills/craft/remotion-best-practices/rules/images.md +67 -67
- package/skills/craft/remotion-best-practices/rules/import-srt-captions.md +69 -69
- package/skills/craft/remotion-best-practices/rules/light-leaks.md +73 -73
- package/skills/craft/remotion-best-practices/rules/local-fonts.md +65 -65
- package/skills/craft/remotion-best-practices/rules/lottie.md +67 -67
- package/skills/craft/remotion-best-practices/rules/maplibre.md +441 -441
- package/skills/craft/remotion-best-practices/rules/measuring-dom-nodes.md +34 -34
- package/skills/craft/remotion-best-practices/rules/measuring-text.md +140 -140
- package/skills/craft/remotion-best-practices/rules/parameters.md +109 -109
- package/skills/craft/remotion-best-practices/rules/sequencing.md +144 -144
- package/skills/craft/remotion-best-practices/rules/sfx.md +30 -30
- package/skills/craft/remotion-best-practices/rules/silence-detection.md +73 -73
- package/skills/craft/remotion-best-practices/rules/subtitles.md +36 -36
- package/skills/craft/remotion-best-practices/rules/tailwind.md +11 -11
- package/skills/craft/remotion-best-practices/rules/text-animations.md +20 -20
- package/skills/craft/remotion-best-practices/rules/timing.md +130 -130
- package/skills/craft/remotion-best-practices/rules/transcribe-captions.md +70 -70
- package/skills/craft/remotion-best-practices/rules/transitions.md +193 -193
- package/skills/craft/remotion-best-practices/rules/transparent-videos.md +102 -102
- package/skills/craft/remotion-best-practices/rules/trimming.md +51 -51
- package/skills/craft/remotion-best-practices/rules/videos.md +169 -169
- package/skills/craft/remotion-best-practices/rules/voiceover.md +94 -94
- package/skills/craft/supabase-postgres-best-practices/CHANGELOG.md +25 -25
- package/skills/craft/supabase-postgres-best-practices/LICENSE +21 -21
- package/skills/craft/supabase-postgres-best-practices/SKILL.md +69 -69
- package/skills/craft/supabase-postgres-best-practices/references/_contributing.md +166 -166
- package/skills/craft/supabase-postgres-best-practices/references/_sections.md +47 -47
- package/skills/craft/supabase-postgres-best-practices/references/_template.md +34 -34
- package/skills/craft/supabase-postgres-best-practices/references/advanced-full-text-search.md +55 -55
- package/skills/craft/supabase-postgres-best-practices/references/advanced-jsonb-indexing.md +49 -49
- package/skills/craft/supabase-postgres-best-practices/references/conn-idle-timeout.md +46 -46
- package/skills/craft/supabase-postgres-best-practices/references/conn-limits.md +44 -44
- package/skills/craft/supabase-postgres-best-practices/references/conn-pooling.md +41 -41
- package/skills/craft/supabase-postgres-best-practices/references/conn-prepared-statements.md +46 -46
- package/skills/craft/supabase-postgres-best-practices/references/data-batch-inserts.md +54 -54
- package/skills/craft/supabase-postgres-best-practices/references/data-n-plus-one.md +53 -53
- package/skills/craft/supabase-postgres-best-practices/references/data-pagination.md +50 -50
- package/skills/craft/supabase-postgres-best-practices/references/data-upsert.md +50 -50
- package/skills/craft/supabase-postgres-best-practices/references/lock-advisory.md +56 -56
- package/skills/craft/supabase-postgres-best-practices/references/lock-deadlock-prevention.md +68 -68
- package/skills/craft/supabase-postgres-best-practices/references/lock-short-transactions.md +50 -50
- package/skills/craft/supabase-postgres-best-practices/references/lock-skip-locked.md +54 -54
- package/skills/craft/supabase-postgres-best-practices/references/monitor-explain-analyze.md +45 -45
- package/skills/craft/supabase-postgres-best-practices/references/monitor-pg-stat-statements.md +55 -55
- package/skills/craft/supabase-postgres-best-practices/references/monitor-vacuum-analyze.md +55 -55
- package/skills/craft/supabase-postgres-best-practices/references/query-composite-indexes.md +44 -44
- package/skills/craft/supabase-postgres-best-practices/references/query-covering-indexes.md +40 -40
- package/skills/craft/supabase-postgres-best-practices/references/query-index-types.md +48 -48
- package/skills/craft/supabase-postgres-best-practices/references/query-missing-indexes.md +43 -43
- package/skills/craft/supabase-postgres-best-practices/references/query-partial-indexes.md +45 -45
- package/skills/craft/supabase-postgres-best-practices/references/schema-constraints.md +80 -80
- package/skills/craft/supabase-postgres-best-practices/references/schema-data-types.md +46 -46
- package/skills/craft/supabase-postgres-best-practices/references/schema-foreign-key-indexes.md +59 -59
- package/skills/craft/supabase-postgres-best-practices/references/schema-lowercase-identifiers.md +55 -55
- package/skills/craft/supabase-postgres-best-practices/references/schema-partitioning.md +55 -55
- package/skills/craft/supabase-postgres-best-practices/references/schema-primary-keys.md +61 -61
- package/skills/craft/supabase-postgres-best-practices/references/security-privileges.md +54 -54
- package/skills/craft/supabase-postgres-best-practices/references/security-rls-basics.md +50 -50
- package/skills/craft/supabase-postgres-best-practices/references/security-rls-performance.md +63 -63
- package/skills/craft/uipm-banner-design/LICENSE +21 -21
- package/skills/craft/uipm-banner-design/SKILL.md +201 -201
- package/skills/craft/uipm-banner-design/references/banner-sizes-and-styles.md +129 -129
- package/skills/craft/uipm-brand/LICENSE +21 -21
- package/skills/craft/uipm-brand/SKILL.md +104 -104
- package/skills/craft/uipm-brand/references/approval-checklist.md +184 -184
- package/skills/craft/uipm-brand/references/asset-organization.md +167 -167
- package/skills/craft/uipm-brand/references/brand-guideline-template.md +161 -161
- package/skills/craft/uipm-brand/references/color-palette-management.md +203 -203
- package/skills/craft/uipm-brand/references/consistency-checklist.md +105 -105
- package/skills/craft/uipm-brand/references/logo-usage-rules.md +204 -204
- package/skills/craft/uipm-brand/references/messaging-framework.md +91 -91
- package/skills/craft/uipm-brand/references/typography-specifications.md +265 -265
- package/skills/craft/uipm-brand/references/update.md +128 -128
- package/skills/craft/uipm-brand/references/visual-identity.md +109 -109
- package/skills/craft/uipm-brand/references/voice-framework.md +99 -99
- package/skills/craft/uipm-brand/scripts/extract-colors.cjs +333 -333
- package/skills/craft/uipm-brand/scripts/inject-brand-context.cjs +324 -324
- package/skills/craft/uipm-brand/scripts/sync-brand-to-tokens.cjs +269 -269
- package/skills/craft/uipm-brand/scripts/validate-asset.cjs +361 -361
- package/skills/craft/uipm-brand/templates/brand-guidelines-starter.md +280 -280
- package/skills/craft/uipm-design/LICENSE +21 -21
- package/skills/craft/uipm-design/SKILL.md +305 -305
- package/skills/craft/uipm-design/data/cip/deliverables.csv +50 -50
- package/skills/craft/uipm-design/data/cip/industries.csv +20 -20
- package/skills/craft/uipm-design/data/cip/mockup-contexts.csv +20 -20
- package/skills/craft/uipm-design/data/cip/styles.csv +20 -20
- package/skills/craft/uipm-design/data/icon/styles.csv +16 -16
- package/skills/craft/uipm-design/data/logo/colors.csv +56 -56
- package/skills/craft/uipm-design/data/logo/industries.csv +56 -56
- package/skills/craft/uipm-design/data/logo/styles.csv +56 -56
- package/skills/craft/uipm-design/references/banner-sizes-and-styles.md +129 -129
- package/skills/craft/uipm-design/references/cip-deliverable-guide.md +111 -111
- package/skills/craft/uipm-design/references/cip-design.md +121 -121
- package/skills/craft/uipm-design/references/cip-prompt-engineering.md +94 -94
- package/skills/craft/uipm-design/references/cip-style-guide.md +76 -76
- package/skills/craft/uipm-design/references/design-routing.md +226 -226
- package/skills/craft/uipm-design/references/icon-design.md +122 -122
- package/skills/craft/uipm-design/references/logo-color-psychology.md +113 -113
- package/skills/craft/uipm-design/references/logo-design.md +92 -92
- package/skills/craft/uipm-design/references/logo-prompt-engineering.md +176 -176
- package/skills/craft/uipm-design/references/logo-style-guide.md +129 -129
- package/skills/craft/uipm-design/references/slides-copywriting-formulas.md +92 -92
- package/skills/craft/uipm-design/references/slides-create.md +5 -5
- package/skills/craft/uipm-design/references/slides-html-template.md +374 -374
- package/skills/craft/uipm-design/references/slides-layout-patterns.md +155 -155
- package/skills/craft/uipm-design/references/slides-strategies.md +97 -97
- package/skills/craft/uipm-design/references/slides.md +42 -42
- package/skills/craft/uipm-design/references/social-photos-design.md +353 -353
- package/skills/craft/uipm-design/scripts/cip/core.py +215 -215
- package/skills/craft/uipm-design/scripts/cip/generate.py +484 -484
- package/skills/craft/uipm-design/scripts/cip/render-html.py +424 -424
- package/skills/craft/uipm-design/scripts/cip/search.py +127 -127
- package/skills/craft/uipm-design/scripts/icon/generate.py +487 -487
- package/skills/craft/uipm-design/scripts/logo/core.py +175 -175
- package/skills/craft/uipm-design/scripts/logo/generate.py +362 -362
- package/skills/craft/uipm-design/scripts/logo/search.py +114 -114
- package/skills/craft/uipm-design-system/LICENSE +21 -21
- package/skills/craft/uipm-design-system/SKILL.md +255 -255
- package/skills/craft/uipm-design-system/data/slide-backgrounds.csv +11 -11
- package/skills/craft/uipm-design-system/data/slide-charts.csv +26 -26
- package/skills/craft/uipm-design-system/data/slide-color-logic.csv +14 -14
- package/skills/craft/uipm-design-system/data/slide-copy.csv +26 -26
- package/skills/craft/uipm-design-system/data/slide-layout-logic.csv +16 -16
- package/skills/craft/uipm-design-system/data/slide-layouts.csv +26 -26
- package/skills/craft/uipm-design-system/data/slide-strategies.csv +16 -16
- package/skills/craft/uipm-design-system/data/slide-typography.csv +15 -15
- package/skills/craft/uipm-design-system/references/component-specs.md +236 -236
- package/skills/craft/uipm-design-system/references/component-tokens.md +214 -214
- package/skills/craft/uipm-design-system/references/primitive-tokens.md +199 -199
- package/skills/craft/uipm-design-system/references/semantic-tokens.md +215 -215
- package/skills/craft/uipm-design-system/references/states-and-variants.md +243 -243
- package/skills/craft/uipm-design-system/references/tailwind-integration.md +257 -257
- package/skills/craft/uipm-design-system/references/token-architecture.md +226 -226
- package/skills/craft/uipm-design-system/scripts/embed-tokens.cjs +97 -97
- package/skills/craft/uipm-design-system/scripts/fetch-background.py +317 -317
- package/skills/craft/uipm-design-system/scripts/generate-slide.py +753 -753
- package/skills/craft/uipm-design-system/scripts/generate-tokens.cjs +213 -213
- package/skills/craft/uipm-design-system/scripts/html-token-validator.py +327 -327
- package/skills/craft/uipm-design-system/scripts/search-slides.py +218 -218
- package/skills/craft/uipm-design-system/scripts/slide-token-validator.py +35 -35
- package/skills/craft/uipm-design-system/scripts/slide_search_core.py +453 -453
- package/skills/craft/uipm-design-system/scripts/validate-tokens.cjs +254 -254
- package/skills/craft/uipm-design-system/templates/design-tokens-starter.json +143 -143
- package/skills/craft/uipm-slides/LICENSE +21 -21
- package/skills/craft/uipm-slides/SKILL.md +45 -45
- package/skills/craft/uipm-slides/references/copywriting-formulas.md +92 -92
- package/skills/craft/uipm-slides/references/create.md +5 -5
- package/skills/craft/uipm-slides/references/html-template.md +374 -374
- package/skills/craft/uipm-slides/references/layout-patterns.md +155 -155
- package/skills/craft/uipm-slides/references/slide-strategies.md +97 -97
- package/skills/craft/uipm-ui-ux-pro-max/LICENSE +21 -21
- package/skills/craft/uipm-ui-ux-pro-max/SKILL.md +678 -678
- package/skills/craft/uipm-ui-ux-pro-max/data/_sync_all.py +414 -414
- package/skills/craft/uipm-ui-ux-pro-max/data/app-interface.csv +30 -30
- package/skills/craft/uipm-ui-ux-pro-max/data/charts.csv +26 -26
- package/skills/craft/uipm-ui-ux-pro-max/data/colors.csv +161 -161
- package/skills/craft/uipm-ui-ux-pro-max/data/design.csv +1775 -1775
- package/skills/craft/uipm-ui-ux-pro-max/data/draft.csv +1778 -1778
- package/skills/craft/uipm-ui-ux-pro-max/data/google-fonts.csv +1924 -1924
- package/skills/craft/uipm-ui-ux-pro-max/data/icons.csv +105 -105
- package/skills/craft/uipm-ui-ux-pro-max/data/landing.csv +35 -35
- package/skills/craft/uipm-ui-ux-pro-max/data/products.csv +162 -162
- package/skills/craft/uipm-ui-ux-pro-max/data/react-performance.csv +45 -45
- package/skills/craft/uipm-ui-ux-pro-max/data/stacks/angular.csv +51 -51
- package/skills/craft/uipm-ui-ux-pro-max/data/stacks/astro.csv +54 -54
- package/skills/craft/uipm-ui-ux-pro-max/data/stacks/flutter.csv +53 -53
- package/skills/craft/uipm-ui-ux-pro-max/data/stacks/html-tailwind.csv +56 -56
- package/skills/craft/uipm-ui-ux-pro-max/data/stacks/jetpack-compose.csv +53 -53
- package/skills/craft/uipm-ui-ux-pro-max/data/stacks/laravel.csv +51 -51
- package/skills/craft/uipm-ui-ux-pro-max/data/stacks/nextjs.csv +53 -53
- package/skills/craft/uipm-ui-ux-pro-max/data/stacks/nuxt-ui.csv +51 -51
- package/skills/craft/uipm-ui-ux-pro-max/data/stacks/nuxtjs.csv +59 -59
- package/skills/craft/uipm-ui-ux-pro-max/data/stacks/react-native.csv +52 -52
- package/skills/craft/uipm-ui-ux-pro-max/data/stacks/react.csv +54 -54
- package/skills/craft/uipm-ui-ux-pro-max/data/stacks/shadcn.csv +61 -61
- package/skills/craft/uipm-ui-ux-pro-max/data/stacks/svelte.csv +54 -54
- package/skills/craft/uipm-ui-ux-pro-max/data/stacks/swiftui.csv +51 -51
- package/skills/craft/uipm-ui-ux-pro-max/data/stacks/threejs.csv +54 -54
- package/skills/craft/uipm-ui-ux-pro-max/data/stacks/vue.csv +50 -50
- package/skills/craft/uipm-ui-ux-pro-max/data/styles.csv +85 -85
- package/skills/craft/uipm-ui-ux-pro-max/data/typography.csv +74 -74
- package/skills/craft/uipm-ui-ux-pro-max/data/ui-reasoning.csv +162 -162
- package/skills/craft/uipm-ui-ux-pro-max/data/ux-guidelines.csv +99 -99
- package/skills/craft/uipm-ui-ux-pro-max/scripts/core.py +262 -262
- package/skills/craft/uipm-ui-ux-pro-max/scripts/design_system.py +1148 -1148
- package/skills/craft/uipm-ui-ux-pro-max/scripts/search.py +114 -114
- package/skills/craft/uipm-ui-ux-pro-max/templates/base/quick-reference.md +297 -297
- package/skills/craft/uipm-ui-ux-pro-max/templates/base/skill-content.md +375 -375
- package/skills/craft/uipm-ui-ux-pro-max/templates/platforms/agent.json +21 -21
- package/skills/craft/uipm-ui-ux-pro-max/templates/platforms/augment.json +18 -18
- package/skills/craft/uipm-ui-ux-pro-max/templates/platforms/claude.json +21 -21
- package/skills/craft/uipm-ui-ux-pro-max/templates/platforms/codebuddy.json +21 -21
- package/skills/craft/uipm-ui-ux-pro-max/templates/platforms/codex.json +21 -21
- package/skills/craft/uipm-ui-ux-pro-max/templates/platforms/continue.json +21 -21
- package/skills/craft/uipm-ui-ux-pro-max/templates/platforms/copilot.json +21 -21
- package/skills/craft/uipm-ui-ux-pro-max/templates/platforms/cursor.json +21 -21
- package/skills/craft/uipm-ui-ux-pro-max/templates/platforms/droid.json +21 -21
- package/skills/craft/uipm-ui-ux-pro-max/templates/platforms/gemini.json +21 -21
- package/skills/craft/uipm-ui-ux-pro-max/templates/platforms/kilocode.json +21 -21
- package/skills/craft/uipm-ui-ux-pro-max/templates/platforms/kiro.json +21 -21
- package/skills/craft/uipm-ui-ux-pro-max/templates/platforms/opencode.json +21 -21
- package/skills/craft/uipm-ui-ux-pro-max/templates/platforms/qoder.json +21 -21
- package/skills/craft/uipm-ui-ux-pro-max/templates/platforms/roocode.json +21 -21
- package/skills/craft/uipm-ui-ux-pro-max/templates/platforms/trae.json +21 -21
- package/skills/craft/uipm-ui-ux-pro-max/templates/platforms/warp.json +18 -18
- package/skills/craft/uipm-ui-ux-pro-max/templates/platforms/windsurf.json +21 -21
- package/skills/craft/vercel-optimize/AGENTS.md +48 -48
- package/skills/craft/vercel-optimize/CONTRIBUTING.md +41 -41
- package/skills/craft/vercel-optimize/LICENSE +21 -21
- package/skills/craft/vercel-optimize/README.md +91 -91
- package/skills/craft/vercel-optimize/SKILL.md +325 -325
- package/skills/craft/vercel-optimize/lib/auth-route.mjs +23 -23
- package/skills/craft/vercel-optimize/lib/budget-summary.mjs +208 -208
- package/skills/craft/vercel-optimize/lib/citations.mjs +147 -147
- package/skills/craft/vercel-optimize/lib/cost-coverage.mjs +162 -162
- package/skills/craft/vercel-optimize/lib/dedup-recs.mjs +340 -340
- package/skills/craft/vercel-optimize/lib/deep-dive.mjs +371 -371
- package/skills/craft/vercel-optimize/lib/display-labels.mjs +219 -219
- package/skills/craft/vercel-optimize/lib/extract-claims.mjs +640 -640
- package/skills/craft/vercel-optimize/lib/framework-support.mjs +69 -69
- package/skills/craft/vercel-optimize/lib/gates/build-minutes-fanout.mjs +73 -73
- package/skills/craft/vercel-optimize/lib/gates/cold-start.mjs +72 -72
- package/skills/craft/vercel-optimize/lib/gates/contract.mjs +82 -82
- package/skills/craft/vercel-optimize/lib/gates/cwv-poor.mjs +95 -95
- package/skills/craft/vercel-optimize/lib/gates/external-api-slow.mjs +60 -60
- package/skills/craft/vercel-optimize/lib/gates/hard-gates.mjs +70 -70
- package/skills/craft/vercel-optimize/lib/gates/index.mjs +45 -45
- package/skills/craft/vercel-optimize/lib/gates/isr-overrevalidation.mjs +62 -62
- package/skills/craft/vercel-optimize/lib/gates/middleware-heavy.mjs +53 -53
- package/skills/craft/vercel-optimize/lib/gates/observability-events-attribution.mjs +58 -58
- package/skills/craft/vercel-optimize/lib/gates/platform-bot-protection.mjs +123 -123
- package/skills/craft/vercel-optimize/lib/gates/platform-fluid-compute.mjs +94 -94
- package/skills/craft/vercel-optimize/lib/gates/region-misconfig.mjs +71 -71
- package/skills/craft/vercel-optimize/lib/gates/route-errors.mjs +95 -95
- package/skills/craft/vercel-optimize/lib/gates/scanner-driven.mjs +150 -150
- package/skills/craft/vercel-optimize/lib/gates/select-candidates.mjs +137 -137
- package/skills/craft/vercel-optimize/lib/gates/slow-route.mjs +97 -97
- package/skills/craft/vercel-optimize/lib/gates/types.d.ts +38 -38
- package/skills/craft/vercel-optimize/lib/gates/uncached-route.mjs +103 -103
- package/skills/craft/vercel-optimize/lib/gates/usage-spike-triage.mjs +122 -122
- package/skills/craft/vercel-optimize/lib/grade-recommendation.mjs +170 -170
- package/skills/craft/vercel-optimize/lib/impact-label.mjs +128 -128
- package/skills/craft/vercel-optimize/lib/impact-magnitude.mjs +66 -66
- package/skills/craft/vercel-optimize/lib/investigation-brief.mjs +751 -751
- package/skills/craft/vercel-optimize/lib/observation-safety.mjs +217 -217
- package/skills/craft/vercel-optimize/lib/project-facts.mjs +101 -101
- package/skills/craft/vercel-optimize/lib/queries.mjs +333 -333
- package/skills/craft/vercel-optimize/lib/reconcile-candidates.mjs +388 -388
- package/skills/craft/vercel-optimize/lib/render-report.mjs +1065 -1065
- package/skills/craft/vercel-optimize/lib/repo-root.mjs +97 -97
- package/skills/craft/vercel-optimize/lib/route-normalize.mjs +224 -224
- package/skills/craft/vercel-optimize/lib/sanitizers/bot-protection-certainty.mjs +56 -56
- package/skills/craft/vercel-optimize/lib/sanitizers/cache-tag-invalidation-certainty.mjs +33 -33
- package/skills/craft/vercel-optimize/lib/sanitizers/count-correct.mjs +53 -53
- package/skills/craft/vercel-optimize/lib/sanitizers/function-duration-invocations.mjs +32 -32
- package/skills/craft/vercel-optimize/lib/sanitizers/index.mjs +87 -87
- package/skills/craft/vercel-optimize/lib/sanitizers/middleware-conflict.mjs +37 -37
- package/skills/craft/vercel-optimize/lib/sanitizers/missing-citation.mjs +16 -16
- package/skills/craft/vercel-optimize/lib/sanitizers/pre-release.mjs +75 -75
- package/skills/craft/vercel-optimize/lib/sanitizers/rate-limit.mjs +73 -73
- package/skills/craft/vercel-optimize/lib/sanitizers/rendering-mode-mislabel.mjs +42 -42
- package/skills/craft/vercel-optimize/lib/sanitizers/undeclared-dep.mjs +110 -110
- package/skills/craft/vercel-optimize/lib/sanitizers/vercel-directive-strip.mjs +37 -37
- package/skills/craft/vercel-optimize/lib/sanitizers/window-units.mjs +26 -26
- package/skills/craft/vercel-optimize/lib/scanners/cache-components-suspense-dedupe.mjs +114 -114
- package/skills/craft/vercel-optimize/lib/scanners/edge-heavy-import.mjs +102 -102
- package/skills/craft/vercel-optimize/lib/scanners/force-dynamic.mjs +39 -39
- package/skills/craft/vercel-optimize/lib/scanners/headers-in-page.mjs +43 -43
- package/skills/craft/vercel-optimize/lib/scanners/index.mjs +35 -35
- package/skills/craft/vercel-optimize/lib/scanners/large-static-asset.mjs +93 -93
- package/skills/craft/vercel-optimize/lib/scanners/max-age-without-s-maxage.mjs +47 -47
- package/skills/craft/vercel-optimize/lib/scanners/middleware-broad-matcher.mjs +53 -53
- package/skills/craft/vercel-optimize/lib/scanners/missing-cache-headers.mjs +97 -97
- package/skills/craft/vercel-optimize/lib/scanners/prisma-include-tree.mjs +39 -39
- package/skills/craft/vercel-optimize/lib/scanners/region-pin-in-config.mjs +89 -89
- package/skills/craft/vercel-optimize/lib/scanners/source-maps-production.mjs +33 -33
- package/skills/craft/vercel-optimize/lib/scanners/sveltekit-prerender-missing.mjs +47 -47
- package/skills/craft/vercel-optimize/lib/scanners/turbo-force-bypass.mjs +136 -136
- package/skills/craft/vercel-optimize/lib/scanners/unoptimized-image.mjs +127 -127
- package/skills/craft/vercel-optimize/lib/scanners/use-cache-date-stamp.mjs +112 -112
- package/skills/craft/vercel-optimize/lib/support-topics.mjs +365 -365
- package/skills/craft/vercel-optimize/lib/throttle.mjs +280 -280
- package/skills/craft/vercel-optimize/lib/util.mjs +17 -17
- package/skills/craft/vercel-optimize/lib/vercel.mjs +855 -855
- package/skills/craft/vercel-optimize/lib/verify-claim.mjs +1843 -1843
- package/skills/craft/vercel-optimize/lib/workspace-resolver.mjs +552 -552
- package/skills/craft/vercel-optimize/metadata.json +14 -14
- package/skills/craft/vercel-optimize/references/candidates.md +176 -176
- package/skills/craft/vercel-optimize/references/data-collection.md +224 -224
- package/skills/craft/vercel-optimize/references/docs-library.json +683 -683
- package/skills/craft/vercel-optimize/references/doctrine.md +108 -108
- package/skills/craft/vercel-optimize/references/observability-plus.md +109 -109
- package/skills/craft/vercel-optimize/references/playbooks/README.md +57 -57
- package/skills/craft/vercel-optimize/references/playbooks/ai-application.md +32 -32
- package/skills/craft/vercel-optimize/references/playbooks/api-service.md +30 -30
- package/skills/craft/vercel-optimize/references/playbooks/content-site.md +30 -30
- package/skills/craft/vercel-optimize/references/playbooks/ecommerce.md +30 -30
- package/skills/craft/vercel-optimize/references/playbooks/marketing.md +30 -30
- package/skills/craft/vercel-optimize/references/playbooks/saas.md +31 -31
- package/skills/craft/vercel-optimize/references/playbooks/sveltekit.md +75 -75
- package/skills/craft/vercel-optimize/references/recommendations.md +214 -214
- package/skills/craft/vercel-optimize/references/scanner-patterns.md +266 -266
- package/skills/craft/vercel-optimize/references/scoring.md +208 -208
- package/skills/craft/vercel-optimize/references/support-topics/README.md +50 -50
- package/skills/craft/vercel-optimize/references/support-topics/astro-edge-middleware-scope.md +30 -30
- package/skills/craft/vercel-optimize/references/support-topics/astro-output-mode-and-isr.md +31 -31
- package/skills/craft/vercel-optimize/references/support-topics/auth-preserving-parallelization.md +30 -30
- package/skills/craft/vercel-optimize/references/support-topics/bot-protection-product-guardrails.md +32 -32
- package/skills/craft/vercel-optimize/references/support-topics/build-minutes-monorepo-fanout.md +32 -32
- package/skills/craft/vercel-optimize/references/support-topics/cache-components-static-shell-boundaries.md +31 -31
- package/skills/craft/vercel-optimize/references/support-topics/cache-components-suspense-dedupe-pitfall.md +32 -32
- package/skills/craft/vercel-optimize/references/support-topics/cdn-cache-auth-safety.md +31 -31
- package/skills/craft/vercel-optimize/references/support-topics/cold-start-initialization-bundle.md +31 -31
- package/skills/craft/vercel-optimize/references/support-topics/core-web-vitals-client-bottlenecks.md +33 -33
- package/skills/craft/vercel-optimize/references/support-topics/database-egress-pooling-region.md +32 -32
- package/skills/craft/vercel-optimize/references/support-topics/dynamic-rendering-traps.md +31 -31
- package/skills/craft/vercel-optimize/references/support-topics/external-api-critical-path-platform.md +31 -31
- package/skills/craft/vercel-optimize/references/support-topics/external-api-critical-path.md +31 -31
- package/skills/craft/vercel-optimize/references/support-topics/fast-data-transfer-payloads.md +26 -26
- package/skills/craft/vercel-optimize/references/support-topics/fluid-compute-caveats.md +26 -26
- package/skills/craft/vercel-optimize/references/support-topics/function-duration-io-and-after.md +31 -31
- package/skills/craft/vercel-optimize/references/support-topics/function-invocation-reduction.md +31 -31
- package/skills/craft/vercel-optimize/references/support-topics/function-region-misconfiguration-ttfb.md +31 -31
- package/skills/craft/vercel-optimize/references/support-topics/image-optimization-cost-control.md +31 -31
- package/skills/craft/vercel-optimize/references/support-topics/isr-revalidation-static-generation.md +31 -31
- package/skills/craft/vercel-optimize/references/support-topics/middleware-proxy-edge-cost.md +30 -30
- package/skills/craft/vercel-optimize/references/support-topics/next-fetch-revalidate-floor.md +30 -30
- package/skills/craft/vercel-optimize/references/support-topics/next-font-cls-self-hosting.md +31 -31
- package/skills/craft/vercel-optimize/references/support-topics/next-heavy-ui-lazy-load-boundaries.md +28 -28
- package/skills/craft/vercel-optimize/references/support-topics/next-image-lcp-preload-sizes.md +31 -31
- package/skills/craft/vercel-optimize/references/support-topics/next-route-handler-get-cache-defaults.md +30 -30
- package/skills/craft/vercel-optimize/references/support-topics/next-script-third-party-strategy.md +31 -31
- package/skills/craft/vercel-optimize/references/support-topics/nextjs-version-cache-semantics.md +31 -31
- package/skills/craft/vercel-optimize/references/support-topics/not-found-catchall-request-waste.md +33 -33
- package/skills/craft/vercel-optimize/references/support-topics/nuxt-route-rules-cache-isr.md +31 -31
- package/skills/craft/vercel-optimize/references/support-topics/observability-events-cost-attribution.md +27 -27
- package/skills/craft/vercel-optimize/references/support-topics/post-response-work-waituntil.md +26 -26
- package/skills/craft/vercel-optimize/references/support-topics/route-error-durable-offload.md +33 -33
- package/skills/craft/vercel-optimize/references/support-topics/route-error-runtime-limits.md +31 -31
- package/skills/craft/vercel-optimize/references/support-topics/runtime-cache-reusable-data.md +30 -30
- package/skills/craft/vercel-optimize/references/support-topics/sveltekit-isr-prerender-safety.md +31 -31
- package/skills/craft/vercel-optimize/references/support-topics/sveltekit-split-cold-start-tradeoff.md +30 -30
- package/skills/craft/vercel-optimize/references/support-topics/usage-spike-triage.md +31 -31
- package/skills/craft/vercel-optimize/references/support-topics/use-cache-date-stamp-isr-write-amplifier.md +31 -31
- package/skills/craft/vercel-optimize/references/support-topics/use-cache-remote-shared-origin-data.md +30 -30
- package/skills/craft/vercel-optimize/references/support-topics/workflow-resumable-stream-routes.md +32 -32
- package/skills/craft/vercel-optimize/references/verification.md +102 -102
- package/skills/craft/vercel-optimize/references/voice.md +76 -76
- package/skills/craft/vercel-optimize/scripts/budget-summary.mjs +58 -58
- package/skills/craft/vercel-optimize/scripts/build-docs.mjs +76 -76
- package/skills/craft/vercel-optimize/scripts/check-citations.mjs +91 -91
- package/skills/craft/vercel-optimize/scripts/check-docs-fresh.mjs +100 -100
- package/skills/craft/vercel-optimize/scripts/collect-signals.mjs +638 -638
- package/skills/craft/vercel-optimize/scripts/collect-sub-agent-outputs.mjs +306 -306
- package/skills/craft/vercel-optimize/scripts/deep-dive.mjs +358 -358
- package/skills/craft/vercel-optimize/scripts/gate-investigations.mjs +178 -178
- package/skills/craft/vercel-optimize/scripts/merge-signals.mjs +203 -203
- package/skills/craft/vercel-optimize/scripts/prepare-investigation-brief.mjs +249 -249
- package/skills/craft/vercel-optimize/scripts/reconcile-candidates.mjs +69 -69
- package/skills/craft/vercel-optimize/scripts/render-report.mjs +462 -462
- package/skills/craft/vercel-optimize/scripts/scan-codebase.mjs +361 -361
- package/skills/craft/vercel-optimize/scripts/verify-and-regen.mjs +379 -379
- package/skills/craft/vercel-optimize/scripts/verify-finding.mjs +21 -21
- package/skills/craft/web-design-guidelines/LICENSE +21 -21
- package/skills/craft/web-design-guidelines/SKILL.md +43 -43
- package/skills/craft/zero-to-live/LICENSE +21 -21
- package/skills/craft/zero-to-live/SKILL.md +422 -422
- package/skills/creative/creative-3d-modeling/LICENSE +21 -21
- package/skills/creative/creative-3d-modeling/SKILL.md +70 -70
- package/skills/creative/creative-architecture/LICENSE +21 -21
- package/skills/creative/creative-architecture/SKILL.md +94 -94
- package/skills/creative/creative-design-principles/LICENSE +21 -21
- package/skills/creative/creative-design-principles/SKILL.md +95 -95
- package/skills/creative/creative-fashion-advanced/LICENSE +21 -21
- package/skills/creative/creative-fashion-advanced/SKILL.md +68 -68
- package/skills/creative/creative-fashion-design/LICENSE +21 -21
- package/skills/creative/creative-fashion-design/SKILL.md +66 -66
- package/skills/creative/creative-game-design/LICENSE +21 -21
- package/skills/creative/creative-game-design/SKILL.md +77 -77
- package/skills/creative/creative-industrial-design/LICENSE +21 -21
- package/skills/creative/creative-industrial-design/SKILL.md +57 -57
- package/skills/creative/creative-interior-design/LICENSE +21 -21
- package/skills/creative/creative-interior-design/SKILL.md +59 -59
- package/skills/creative/creative-music-theory/LICENSE +21 -21
- package/skills/creative/creative-music-theory/SKILL.md +98 -98
- package/skills/creative/creative-photography/LICENSE +21 -21
- package/skills/creative/creative-photography/SKILL.md +87 -87
- package/skills/creative/creative-textile-science/LICENSE +21 -21
- package/skills/creative/creative-textile-science/SKILL.md +67 -67
- package/skills/creative/creative-ux/LICENSE +21 -21
- package/skills/creative/creative-ux/SKILL.md +81 -81
- package/skills/creative/creative-video/LICENSE +21 -21
- package/skills/creative/creative-video/SKILL.md +84 -84
- package/skills/creative/creative-writing-craft/LICENSE +21 -21
- package/skills/creative/creative-writing-craft/SKILL.md +91 -91
- package/skills/diagram-maker/SKILL.md +56 -56
- package/skills/diagram-maker/references/excalidraw-patterns.md +85 -85
- package/skills/diagram-maker/references/svg-template.md +112 -112
- package/skills/discord/SKILL.md +140 -140
- package/skills/education/edu-adult-learning/LICENSE +21 -21
- package/skills/education/edu-adult-learning/SKILL.md +81 -81
- package/skills/education/edu-africa-multilingual/LICENSE +21 -21
- package/skills/education/edu-africa-multilingual/SKILL.md +55 -55
- package/skills/education/edu-arabic/LICENSE +21 -21
- package/skills/education/edu-arabic/SKILL.md +60 -60
- package/skills/education/edu-australia-nz/LICENSE +21 -21
- package/skills/education/edu-australia-nz/SKILL.md +48 -48
- package/skills/education/edu-china-mandarin/LICENSE +21 -21
- package/skills/education/edu-china-mandarin/SKILL.md +58 -58
- package/skills/education/edu-critical-thinking/LICENSE +21 -21
- package/skills/education/edu-critical-thinking/SKILL.md +86 -86
- package/skills/education/edu-curriculum/LICENSE +21 -21
- package/skills/education/edu-curriculum/SKILL.md +87 -87
- package/skills/education/edu-ed-tech/LICENSE +21 -21
- package/skills/education/edu-ed-tech/SKILL.md +73 -73
- package/skills/education/edu-france/LICENSE +21 -21
- package/skills/education/edu-france/SKILL.md +42 -42
- package/skills/education/edu-germany/LICENSE +21 -21
- package/skills/education/edu-germany/SKILL.md +46 -46
- package/skills/education/edu-india-competitive/LICENSE +21 -21
- package/skills/education/edu-india-competitive/SKILL.md +159 -159
- package/skills/education/edu-india-east/LICENSE +21 -21
- package/skills/education/edu-india-east/SKILL.md +60 -60
- package/skills/education/edu-india-hindi/LICENSE +21 -21
- package/skills/education/edu-india-hindi/SKILL.md +107 -107
- package/skills/education/edu-india-south/LICENSE +21 -21
- package/skills/education/edu-india-south/SKILL.md +64 -64
- package/skills/education/edu-india-west/LICENSE +21 -21
- package/skills/education/edu-india-west/SKILL.md +68 -68
- package/skills/education/edu-indonesia-malay/LICENSE +21 -21
- package/skills/education/edu-indonesia-malay/SKILL.md +57 -57
- package/skills/education/edu-international-ib/LICENSE +21 -21
- package/skills/education/edu-international-ib/SKILL.md +61 -61
- package/skills/education/edu-japan/LICENSE +21 -21
- package/skills/education/edu-japan/SKILL.md +48 -48
- package/skills/education/edu-korea/LICENSE +21 -21
- package/skills/education/edu-korea/SKILL.md +48 -48
- package/skills/education/edu-learning-science/LICENSE +21 -21
- package/skills/education/edu-learning-science/SKILL.md +76 -76
- package/skills/education/edu-portuguese-brazil/LICENSE +21 -21
- package/skills/education/edu-portuguese-brazil/SKILL.md +51 -51
- package/skills/education/edu-russia/LICENSE +21 -21
- package/skills/education/edu-russia/SKILL.md +50 -50
- package/skills/education/edu-spain-latam/LICENSE +21 -21
- package/skills/education/edu-spain-latam/SKILL.md +55 -55
- package/skills/education/edu-special/LICENSE +21 -21
- package/skills/education/edu-special/SKILL.md +76 -76
- package/skills/education/edu-thailand/LICENSE +21 -21
- package/skills/education/edu-thailand/SKILL.md +55 -55
- package/skills/education/edu-turkey/LICENSE +21 -21
- package/skills/education/edu-turkey/SKILL.md +58 -58
- package/skills/education/edu-uk-gcse-alevel/LICENSE +21 -21
- package/skills/education/edu-uk-gcse-alevel/SKILL.md +51 -51
- package/skills/education/edu-usa-graduate/LICENSE +21 -21
- package/skills/education/edu-usa-graduate/SKILL.md +57 -57
- package/skills/education/edu-usa-sat-act/LICENSE +21 -21
- package/skills/education/edu-usa-sat-act/SKILL.md +55 -55
- package/skills/education/edu-vietnam/LICENSE +21 -21
- package/skills/education/edu-vietnam/SKILL.md +53 -53
- package/skills/eightctl/SKILL.md +54 -54
- package/skills/engineering/eng-aerospace/LICENSE +21 -21
- package/skills/engineering/eng-aerospace/SKILL.md +117 -117
- package/skills/engineering/eng-chemical/LICENSE +21 -21
- package/skills/engineering/eng-chemical/SKILL.md +63 -63
- package/skills/engineering/eng-civil/LICENSE +21 -21
- package/skills/engineering/eng-civil/SKILL.md +223 -223
- package/skills/engineering/eng-control-systems/LICENSE +21 -21
- package/skills/engineering/eng-control-systems/SKILL.md +158 -158
- package/skills/engineering/eng-cryogenics/LICENSE +21 -21
- package/skills/engineering/eng-cryogenics/SKILL.md +151 -151
- package/skills/engineering/eng-electrical/LICENSE +21 -21
- package/skills/engineering/eng-electrical/SKILL.md +70 -70
- package/skills/engineering/eng-electronics-embedded/LICENSE +21 -21
- package/skills/engineering/eng-electronics-embedded/SKILL.md +89 -89
- package/skills/engineering/eng-environmental/LICENSE +21 -21
- package/skills/engineering/eng-environmental/SKILL.md +66 -66
- package/skills/engineering/eng-manufacturing/LICENSE +21 -21
- package/skills/engineering/eng-manufacturing/SKILL.md +78 -78
- package/skills/engineering/eng-mechanical/LICENSE +21 -21
- package/skills/engineering/eng-mechanical/SKILL.md +66 -66
- package/skills/engineering/eng-project/LICENSE +21 -21
- package/skills/engineering/eng-project/SKILL.md +72 -72
- package/skills/engineering/eng-propulsion/LICENSE +21 -21
- package/skills/engineering/eng-propulsion/SKILL.md +133 -133
- package/skills/engineering/eng-robotics/LICENSE +21 -21
- package/skills/engineering/eng-robotics/SKILL.md +92 -92
- package/skills/engineering/eng-systems/LICENSE +21 -21
- package/skills/engineering/eng-systems/SKILL.md +81 -81
- package/skills/environment/env-biodiversity/LICENSE +21 -21
- package/skills/environment/env-biodiversity/SKILL.md +66 -66
- package/skills/environment/env-circular-economy/LICENSE +21 -21
- package/skills/environment/env-circular-economy/SKILL.md +71 -71
- package/skills/environment/env-climate-action/LICENSE +21 -21
- package/skills/environment/env-climate-action/SKILL.md +55 -55
- package/skills/environment/env-energy/LICENSE +21 -21
- package/skills/environment/env-energy/SKILL.md +83 -83
- package/skills/environment/env-sustainability-biz/LICENSE +21 -21
- package/skills/environment/env-sustainability-biz/SKILL.md +65 -65
- package/skills/environment/env-water/LICENSE +21 -21
- package/skills/environment/env-water/SKILL.md +67 -67
- package/skills/finance/finance-accounting/LICENSE +21 -21
- package/skills/finance/finance-accounting/SKILL.md +239 -239
- package/skills/finance/finance-banking/LICENSE +21 -21
- package/skills/finance/finance-banking/SKILL.md +54 -54
- package/skills/finance/finance-corporate/LICENSE +21 -21
- package/skills/finance/finance-corporate/SKILL.md +105 -105
- package/skills/finance/finance-crypto/LICENSE +21 -21
- package/skills/finance/finance-crypto/SKILL.md +94 -94
- package/skills/finance/finance-debt-management/LICENSE +21 -21
- package/skills/finance/finance-debt-management/SKILL.md +87 -87
- package/skills/finance/finance-insurance/LICENSE +21 -21
- package/skills/finance/finance-insurance/SKILL.md +91 -91
- package/skills/finance/finance-investing/LICENSE +21 -21
- package/skills/finance/finance-investing/SKILL.md +269 -269
- package/skills/finance/finance-options-derivatives/LICENSE +21 -21
- package/skills/finance/finance-options-derivatives/SKILL.md +68 -68
- package/skills/finance/finance-personal/LICENSE +21 -21
- package/skills/finance/finance-personal/SKILL.md +268 -268
- package/skills/finance/finance-real-estate/LICENSE +21 -21
- package/skills/finance/finance-real-estate/SKILL.md +110 -110
- package/skills/finance/finance-startup/LICENSE +21 -21
- package/skills/finance/finance-startup/SKILL.md +253 -253
- package/skills/finance/finance-tax-planning/LICENSE +21 -21
- package/skills/finance/finance-tax-planning/SKILL.md +89 -89
- package/skills/finance/finance-trading/LICENSE +21 -21
- package/skills/finance/finance-trading/SKILL.md +112 -112
- package/skills/gemini/SKILL.md +51 -51
- package/skills/gh-issues/SKILL.md +216 -216
- package/skills/gifgrep/SKILL.md +89 -89
- package/skills/github/SKILL.md +87 -87
- package/skills/gog/SKILL.md +120 -120
- package/skills/goplaces/SKILL.md +56 -56
- package/skills/health/health-aging/LICENSE +21 -21
- package/skills/health/health-aging/SKILL.md +82 -82
- package/skills/health/health-chronic/LICENSE +21 -21
- package/skills/health/health-chronic/SKILL.md +202 -202
- package/skills/health/health-dental/LICENSE +21 -21
- package/skills/health/health-dental/SKILL.md +41 -41
- package/skills/health/health-eye-care/LICENSE +21 -21
- package/skills/health/health-eye-care/SKILL.md +56 -56
- package/skills/health/health-first-aid/LICENSE +21 -21
- package/skills/health/health-first-aid/SKILL.md +201 -201
- package/skills/health/health-fitness/LICENSE +21 -21
- package/skills/health/health-fitness/SKILL.md +111 -111
- package/skills/health/health-general/LICENSE +21 -21
- package/skills/health/health-general/SKILL.md +277 -277
- package/skills/health/health-mens/LICENSE +21 -21
- package/skills/health/health-mens/SKILL.md +53 -53
- package/skills/health/health-mental/LICENSE +21 -21
- package/skills/health/health-mental/SKILL.md +221 -221
- package/skills/health/health-naturopathy-ayurveda/LICENSE +21 -21
- package/skills/health/health-naturopathy-ayurveda/SKILL.md +60 -60
- package/skills/health/health-nutrition/LICENSE +21 -21
- package/skills/health/health-nutrition/SKILL.md +262 -262
- package/skills/health/health-pediatric/LICENSE +21 -21
- package/skills/health/health-pediatric/SKILL.md +94 -94
- package/skills/health/health-pharmacology/LICENSE +21 -21
- package/skills/health/health-pharmacology/SKILL.md +87 -87
- package/skills/health/health-pregnancy/LICENSE +21 -21
- package/skills/health/health-pregnancy/SKILL.md +71 -71
- package/skills/health/health-skin/LICENSE +21 -21
- package/skills/health/health-skin/SKILL.md +71 -71
- package/skills/health/health-sleep/LICENSE +21 -21
- package/skills/health/health-sleep/SKILL.md +81 -81
- package/skills/health/health-womens/LICENSE +21 -21
- package/skills/health/health-womens/SKILL.md +72 -72
- package/skills/health/health-yoga-wellness/LICENSE +21 -21
- package/skills/health/health-yoga-wellness/SKILL.md +58 -58
- package/skills/healthcare-systems/health-sys-global/LICENSE +21 -21
- package/skills/healthcare-systems/health-sys-global/SKILL.md +69 -69
- package/skills/healthcare-systems/health-sys-management/LICENSE +21 -21
- package/skills/healthcare-systems/health-sys-management/SKILL.md +71 -71
- package/skills/healthcare-systems/health-sys-navigation/LICENSE +21 -21
- package/skills/healthcare-systems/health-sys-navigation/SKILL.md +60 -60
- package/skills/healthcare-systems/health-sys-public/LICENSE +21 -21
- package/skills/healthcare-systems/health-sys-public/SKILL.md +71 -71
- package/skills/healthcheck/SKILL.md +109 -109
- package/skills/himalaya/SKILL.md +84 -84
- package/skills/himalaya/references/configuration.md +184 -184
- package/skills/himalaya/references/message-composition.md +199 -199
- package/skills/humanities/humanities-history-world/LICENSE +21 -21
- package/skills/humanities/humanities-history-world/SKILL.md +59 -59
- package/skills/humanities/humanities-indian-classical/LICENSE +21 -21
- package/skills/humanities/humanities-indian-classical/SKILL.md +104 -104
- package/skills/humanities/humanities-philosophy/LICENSE +21 -21
- package/skills/humanities/humanities-philosophy/SKILL.md +105 -105
- package/skills/humanities/humanities-world-religions/LICENSE +21 -21
- package/skills/humanities/humanities-world-religions/SKILL.md +67 -67
- package/skills/impeccable/SKILL.md +185 -185
- package/skills/imsg/SKILL.md +126 -126
- package/skills/industry/industry-construction/LICENSE +21 -21
- package/skills/industry/industry-construction/SKILL.md +81 -81
- package/skills/industry/industry-education-sector/LICENSE +21 -21
- package/skills/industry/industry-education-sector/SKILL.md +49 -49
- package/skills/industry/industry-fashion/LICENSE +21 -21
- package/skills/industry/industry-fashion/SKILL.md +82 -82
- package/skills/industry/industry-food/LICENSE +21 -21
- package/skills/industry/industry-food/SKILL.md +79 -79
- package/skills/industry/industry-government/LICENSE +21 -21
- package/skills/industry/industry-government/SKILL.md +80 -80
- package/skills/industry/industry-hospitality/LICENSE +21 -21
- package/skills/industry/industry-hospitality/SKILL.md +73 -73
- package/skills/industry/industry-insurance-sector/LICENSE +21 -21
- package/skills/industry/industry-insurance-sector/SKILL.md +57 -57
- package/skills/industry/industry-logistics/LICENSE +21 -21
- package/skills/industry/industry-logistics/SKILL.md +80 -80
- package/skills/industry/industry-media/LICENSE +21 -21
- package/skills/industry/industry-media/SKILL.md +66 -66
- package/skills/industry/industry-nonprofit/LICENSE +21 -21
- package/skills/industry/industry-nonprofit/SKILL.md +77 -77
- package/skills/industry/industry-pharma/LICENSE +21 -21
- package/skills/industry/industry-pharma/SKILL.md +69 -69
- package/skills/industry/industry-real-estate/LICENSE +21 -21
- package/skills/industry/industry-real-estate/SKILL.md +61 -61
- package/skills/industry/industry-sports/LICENSE +21 -21
- package/skills/industry/industry-sports/SKILL.md +71 -71
- package/skills/industry/industry-tech-startup/LICENSE +21 -21
- package/skills/industry/industry-tech-startup/SKILL.md +82 -82
- package/skills/internal-comms/LICENSE +21 -21
- package/skills/internal-comms/SKILL.md +38 -38
- package/skills/internal-comms/examples/3p-updates.md +49 -49
- package/skills/internal-comms/examples/company-newsletter.md +76 -76
- package/skills/internal-comms/examples/faq-answers.md +35 -35
- package/skills/internal-comms/examples/general-comms.md +19 -19
- package/skills/legal/legal-business/LICENSE +21 -21
- package/skills/legal/legal-business/SKILL.md +227 -227
- package/skills/legal/legal-consumer/LICENSE +21 -21
- package/skills/legal/legal-consumer/SKILL.md +155 -155
- package/skills/legal/legal-contracts/LICENSE +21 -21
- package/skills/legal/legal-contracts/SKILL.md +268 -268
- package/skills/legal/legal-corporate-governance/LICENSE +21 -21
- package/skills/legal/legal-corporate-governance/SKILL.md +53 -53
- package/skills/legal/legal-employment/LICENSE +21 -21
- package/skills/legal/legal-employment/SKILL.md +291 -291
- package/skills/legal/legal-immigration/LICENSE +21 -21
- package/skills/legal/legal-immigration/SKILL.md +146 -146
- package/skills/legal/legal-international/LICENSE +21 -21
- package/skills/legal/legal-international/SKILL.md +51 -51
- package/skills/legal/legal-ip/LICENSE +21 -21
- package/skills/legal/legal-ip/SKILL.md +264 -264
- package/skills/legal/legal-privacy/LICENSE +21 -21
- package/skills/legal/legal-privacy/SKILL.md +161 -161
- package/skills/legal/legal-real-estate/LICENSE +21 -21
- package/skills/legal/legal-real-estate/SKILL.md +142 -142
- package/skills/legal/legal-startup/LICENSE +21 -21
- package/skills/legal/legal-startup/SKILL.md +182 -182
- package/skills/legal/legal-tax/LICENSE +21 -21
- package/skills/legal/legal-tax/SKILL.md +156 -156
- package/skills/mcp-builder/LICENSE +21 -21
- package/skills/mcp-builder/SKILL.md +257 -257
- package/skills/mcp-builder/reference/evaluation.md +630 -630
- package/skills/mcp-builder/reference/mcp_best_practices.md +269 -269
- package/skills/mcp-builder/reference/node_mcp_server.md +980 -980
- package/skills/mcp-builder/reference/python_mcp_server.md +737 -737
- package/skills/mcp-builder/scripts/connections.py +151 -151
- package/skills/mcp-builder/scripts/evaluation.py +373 -373
- package/skills/mcp-builder/scripts/example_evaluation.xml +22 -22
- package/skills/mcp-builder/scripts/requirements.txt +2 -2
- package/skills/mcporter/SKILL.md +65 -65
- package/skills/meme-maker/SKILL.md +46 -46
- package/skills/meme-maker/references/templates.json +358 -358
- package/skills/meme-maker/scripts/meme.mjs +398 -398
- package/skills/mental-health/mental-health-cbt/LICENSE +21 -21
- package/skills/mental-health/mental-health-cbt/SKILL.md +254 -254
- package/skills/mental-health/psych-addiction/LICENSE +21 -21
- package/skills/mental-health/psych-addiction/SKILL.md +79 -79
- package/skills/mental-health/psych-behavioral-econ/LICENSE +21 -21
- package/skills/mental-health/psych-behavioral-econ/SKILL.md +84 -84
- package/skills/mental-health/psych-child/LICENSE +21 -21
- package/skills/mental-health/psych-child/SKILL.md +84 -84
- package/skills/mental-health/psych-grief/LICENSE +21 -21
- package/skills/mental-health/psych-grief/SKILL.md +85 -85
- package/skills/mental-health/psych-mindfulness/LICENSE +21 -21
- package/skills/mental-health/psych-mindfulness/SKILL.md +71 -71
- package/skills/mental-health/psych-org/LICENSE +21 -21
- package/skills/mental-health/psych-org/SKILL.md +115 -115
- package/skills/mental-health/psych-positive/LICENSE +21 -21
- package/skills/mental-health/psych-positive/SKILL.md +86 -86
- package/skills/mental-health/psych-relationships/LICENSE +21 -21
- package/skills/mental-health/psych-relationships/SKILL.md +100 -100
- package/skills/mental-health/psych-trauma/LICENSE +21 -21
- package/skills/mental-health/psych-trauma/SKILL.md +109 -109
- package/skills/model-usage/SKILL.md +75 -75
- package/skills/model-usage/references/codexbar-cli.md +33 -33
- package/skills/model-usage/scripts/model_usage.py +319 -319
- package/skills/model-usage/scripts/test_model_usage.py +40 -40
- package/skills/nano-pdf/SKILL.md +42 -42
- package/skills/node-connect/SKILL.md +147 -147
- package/skills/node-inspect-debugger/SKILL.md +88 -88
- package/skills/notion/SKILL.md +154 -154
- package/skills/obsidian/SKILL.md +123 -123
- package/skills/openai-whisper/SKILL.md +42 -42
- package/skills/openai-whisper-api/SKILL.md +75 -75
- package/skills/openai-whisper-api/scripts/transcribe.sh +154 -154
- package/skills/openhue/SKILL.md +116 -116
- package/skills/oracle/SKILL.md +130 -130
- package/skills/ordercli/SKILL.md +82 -82
- package/skills/peekaboo/SKILL.md +217 -217
- package/skills/pyproject.toml +10 -10
- package/skills/python-debugpy/SKILL.md +76 -76
- package/skills/sag/SKILL.md +91 -91
- package/skills/science/sci-astronomy/LICENSE +21 -21
- package/skills/science/sci-astronomy/SKILL.md +80 -80
- package/skills/science/sci-biology/LICENSE +21 -21
- package/skills/science/sci-biology/SKILL.md +74 -74
- package/skills/science/sci-chemistry/LICENSE +21 -21
- package/skills/science/sci-chemistry/SKILL.md +89 -89
- package/skills/science/sci-climate/LICENSE +21 -21
- package/skills/science/sci-climate/SKILL.md +72 -72
- package/skills/science/sci-data-analysis/LICENSE +21 -21
- package/skills/science/sci-data-analysis/SKILL.md +87 -87
- package/skills/science/sci-environmental-science/LICENSE +21 -21
- package/skills/science/sci-environmental-science/SKILL.md +69 -69
- package/skills/science/sci-geology/LICENSE +21 -21
- package/skills/science/sci-geology/SKILL.md +56 -56
- package/skills/science/sci-method/LICENSE +21 -21
- package/skills/science/sci-method/SKILL.md +77 -77
- package/skills/science/sci-neuroscience/LICENSE +21 -21
- package/skills/science/sci-neuroscience/SKILL.md +79 -79
- package/skills/science/sci-physics/LICENSE +21 -21
- package/skills/science/sci-physics/SKILL.md +78 -78
- package/skills/science/sci-research-methods/LICENSE +21 -21
- package/skills/science/sci-research-methods/SKILL.md +83 -83
- package/skills/science/sci-statistics/LICENSE +21 -21
- package/skills/science/sci-statistics/SKILL.md +249 -249
- package/skills/session-logs/SKILL.md +155 -155
- package/skills/sherpa-onnx-tts/SKILL.md +113 -113
- package/skills/skill-creator/SKILL.md +81 -81
- package/skills/skill-creator/license.txt +202 -202
- package/skills/skill-creator/scripts/init_skill.py +378 -378
- package/skills/skill-creator/scripts/package_skill.py +144 -144
- package/skills/skill-creator/scripts/quick_validate.py +169 -169
- package/skills/skill-creator/scripts/test_init_skill.py +51 -51
- package/skills/skill-creator/scripts/test_package_skill.py +199 -199
- package/skills/skill-creator/scripts/test_quick_validate.py +116 -116
- package/skills/slack/SKILL.md +82 -82
- package/skills/slack-gif-creator/LICENSE +21 -21
- package/skills/slack-gif-creator/SKILL.md +293 -293
- package/skills/slack-gif-creator/requirements.txt +3 -3
- package/skills/social-sciences/social-anthropology/LICENSE +21 -21
- package/skills/social-sciences/social-anthropology/SKILL.md +62 -62
- package/skills/social-sciences/social-economics/LICENSE +21 -21
- package/skills/social-sciences/social-economics/SKILL.md +88 -88
- package/skills/social-sciences/social-geography/LICENSE +21 -21
- package/skills/social-sciences/social-geography/SKILL.md +61 -61
- package/skills/social-sciences/social-international-dev/LICENSE +21 -21
- package/skills/social-sciences/social-international-dev/SKILL.md +76 -76
- package/skills/social-sciences/social-political-science/LICENSE +21 -21
- package/skills/social-sciences/social-political-science/SKILL.md +70 -70
- package/skills/social-sciences/social-public-policy/LICENSE +21 -21
- package/skills/social-sciences/social-public-policy/SKILL.md +73 -73
- package/skills/social-sciences/social-sociology/LICENSE +21 -21
- package/skills/social-sciences/social-sociology/SKILL.md +78 -78
- package/skills/songsee/SKILL.md +53 -53
- package/skills/sonoscli/SKILL.md +69 -69
- package/skills/spike/SKILL.md +55 -55
- package/skills/spotify-player/SKILL.md +68 -68
- package/skills/summarize/SKILL.md +90 -90
- package/skills/taskflow/SKILL.md +153 -153
- package/skills/taskflow/examples/inbox-triage.lobster +33 -33
- package/skills/taskflow/examples/pr-intake.lobster +32 -32
- package/skills/taskflow-inbox-triage/SKILL.md +123 -123
- package/skills/technical/ai-ethics/LICENSE +21 -21
- package/skills/technical/ai-ethics/SKILL.md +92 -92
- package/skills/technical/ai-product-builder/LICENSE +21 -21
- package/skills/technical/ai-product-builder/SKILL.md +180 -180
- package/skills/technical/analytics-setup/LICENSE +21 -21
- package/skills/technical/analytics-setup/SKILL.md +125 -125
- package/skills/technical/api-builder/LICENSE +21 -21
- package/skills/technical/api-builder/SKILL.md +202 -202
- package/skills/technical/architecture-decisions/LICENSE +21 -21
- package/skills/technical/architecture-decisions/SKILL.md +120 -120
- package/skills/technical/auth-security/LICENSE +21 -21
- package/skills/technical/auth-security/SKILL.md +209 -209
- package/skills/technical/blockchain-web3/LICENSE +21 -21
- package/skills/technical/blockchain-web3/SKILL.md +84 -84
- package/skills/technical/cloud-architecture/LICENSE +21 -21
- package/skills/technical/cloud-architecture/SKILL.md +85 -85
- package/skills/technical/content-platform/LICENSE +21 -21
- package/skills/technical/content-platform/SKILL.md +134 -134
- package/skills/technical/cybersecurity-advanced/LICENSE +21 -21
- package/skills/technical/cybersecurity-advanced/SKILL.md +99 -99
- package/skills/technical/data-engineering/LICENSE +21 -21
- package/skills/technical/data-engineering/SKILL.md +117 -117
- package/skills/technical/database-design/LICENSE +21 -21
- package/skills/technical/database-design/SKILL.md +185 -185
- package/skills/technical/devops-cicd/LICENSE +21 -21
- package/skills/technical/devops-cicd/SKILL.md +181 -181
- package/skills/technical/ecommerce-builder/LICENSE +21 -21
- package/skills/technical/ecommerce-builder/SKILL.md +123 -123
- package/skills/technical/email-marketing/LICENSE +21 -21
- package/skills/technical/email-marketing/SKILL.md +128 -128
- package/skills/technical/fintech-builder/LICENSE +21 -21
- package/skills/technical/fintech-builder/SKILL.md +141 -141
- package/skills/technical/full-stack-web/LICENSE +21 -21
- package/skills/technical/full-stack-web/SKILL.md +173 -173
- package/skills/technical/gdpr-basics/LICENSE +21 -21
- package/skills/technical/gdpr-basics/SKILL.md +145 -145
- package/skills/technical/launch-playbook/LICENSE +21 -21
- package/skills/technical/launch-playbook/SKILL.md +95 -95
- package/skills/technical/marketing-copy/LICENSE +21 -21
- package/skills/technical/marketing-copy/SKILL.md +126 -126
- package/skills/technical/marketplace-builder/LICENSE +21 -21
- package/skills/technical/marketplace-builder/SKILL.md +105 -105
- package/skills/technical/mobile-pwa/LICENSE +21 -21
- package/skills/technical/mobile-pwa/SKILL.md +191 -191
- package/skills/technical/no-code-tools/LICENSE +21 -21
- package/skills/technical/no-code-tools/SKILL.md +80 -80
- package/skills/technical/open-source/LICENSE +21 -21
- package/skills/technical/open-source/SKILL.md +71 -71
- package/skills/technical/performance-optimization/LICENSE +21 -21
- package/skills/technical/performance-optimization/SKILL.md +155 -155
- package/skills/technical/pricing-design/LICENSE +21 -21
- package/skills/technical/pricing-design/SKILL.md +87 -87
- package/skills/technical/product-management/LICENSE +21 -21
- package/skills/technical/product-management/SKILL.md +94 -94
- package/skills/technical/saas-builder/LICENSE +21 -21
- package/skills/technical/saas-builder/SKILL.md +138 -138
- package/skills/technical/scope-estimation/LICENSE +21 -21
- package/skills/technical/scope-estimation/SKILL.md +99 -99
- package/skills/technical/secrets-management/LICENSE +21 -21
- package/skills/technical/secrets-management/SKILL.md +135 -135
- package/skills/technical/seo-technical/LICENSE +21 -21
- package/skills/technical/seo-technical/SKILL.md +136 -136
- package/skills/technical/technical-writing/LICENSE +21 -21
- package/skills/technical/technical-writing/SKILL.md +149 -149
- package/skills/technical/ux-research-tools/LICENSE +21 -21
- package/skills/technical/ux-research-tools/SKILL.md +54 -54
- package/skills/theme-factory/LICENSE +21 -21
- package/skills/theme-factory/SKILL.md +65 -65
- package/skills/theme-factory/themes/arctic-frost.md +19 -19
- package/skills/theme-factory/themes/botanical-garden.md +19 -19
- package/skills/theme-factory/themes/desert-rose.md +19 -19
- package/skills/theme-factory/themes/forest-canopy.md +19 -19
- package/skills/theme-factory/themes/golden-hour.md +19 -19
- package/skills/theme-factory/themes/midnight-galaxy.md +19 -19
- package/skills/theme-factory/themes/modern-minimalist.md +19 -19
- package/skills/theme-factory/themes/ocean-depths.md +19 -19
- package/skills/theme-factory/themes/sunset-boulevard.md +19 -19
- package/skills/theme-factory/themes/tech-innovation.md +19 -19
- package/skills/things-mac/SKILL.md +90 -90
- package/skills/tmux/SKILL.md +95 -95
- package/skills/tmux/scripts/find-sessions.sh +112 -112
- package/skills/tmux/scripts/wait-for-text.sh +83 -83
- package/skills/trades/trades-agriculture/LICENSE +21 -21
- package/skills/trades/trades-agriculture/SKILL.md +80 -80
- package/skills/trades/trades-automotive/LICENSE +21 -21
- package/skills/trades/trades-automotive/SKILL.md +84 -84
- package/skills/trades/trades-carpentry/LICENSE +21 -21
- package/skills/trades/trades-carpentry/SKILL.md +71 -71
- package/skills/trades/trades-cooking-pro/LICENSE +21 -21
- package/skills/trades/trades-cooking-pro/SKILL.md +90 -90
- package/skills/trades/trades-electrical/LICENSE +21 -21
- package/skills/trades/trades-electrical/SKILL.md +146 -146
- package/skills/trades/trades-hvac/LICENSE +21 -21
- package/skills/trades/trades-hvac/SKILL.md +80 -80
- package/skills/trades/trades-landscaping/LICENSE +21 -21
- package/skills/trades/trades-landscaping/SKILL.md +60 -60
- package/skills/trades/trades-metalworking/LICENSE +21 -21
- package/skills/trades/trades-metalworking/SKILL.md +64 -64
- package/skills/trades/trades-painting/LICENSE +21 -21
- package/skills/trades/trades-painting/SKILL.md +70 -70
- package/skills/trades/trades-plumbing/LICENSE +21 -21
- package/skills/trades/trades-plumbing/SKILL.md +160 -160
- package/skills/trades/trades-welding/LICENSE +21 -21
- package/skills/trades/trades-welding/SKILL.md +82 -82
- package/skills/trello/SKILL.md +112 -112
- package/skills/uipm-ui-styling/SKILL.md +328 -328
- package/skills/video-frames/SKILL.md +50 -50
- package/skills/video-frames/scripts/frame.sh +81 -81
- package/skills/voice-call/SKILL.md +49 -49
- package/skills/wacli/SKILL.md +76 -76
- package/skills/weather/SKILL.md +91 -91
- package/skills/web-artifacts-builder/LICENSE +21 -21
- package/skills/web-artifacts-builder/SKILL.md +82 -82
- package/skills/web-artifacts-builder/scripts/bundle-artifact.sh +53 -53
- package/skills/web-artifacts-builder/scripts/init-artifact.sh +322 -322
- package/skills/xurl/SKILL.md +124 -124
- package/skills/graphify/SKILL.md +0 -619
- package/skills/graphify/__init__.py +0 -28
- package/skills/graphify/__main__.py +0 -4582
- package/skills/graphify/affected.py +0 -154
- package/skills/graphify/always_on/agents-md.md +0 -12
- package/skills/graphify/always_on/antigravity-rules.md +0 -14
- package/skills/graphify/always_on/claude-md.md +0 -9
- package/skills/graphify/always_on/gemini-md.md +0 -9
- package/skills/graphify/always_on/kiro-steering.md +0 -5
- package/skills/graphify/always_on/vscode-instructions.md +0 -17
- package/skills/graphify/analyze.py +0 -724
- package/skills/graphify/benchmark.py +0 -155
- package/skills/graphify/build.py +0 -487
- package/skills/graphify/cache.py +0 -417
- package/skills/graphify/callflow_html.py +0 -2020
- package/skills/graphify/cluster.py +0 -272
- package/skills/graphify/command-kilo.md +0 -15
- package/skills/graphify/dedup.py +0 -429
- package/skills/graphify/detect.py +0 -1379
- package/skills/graphify/diagnostics.py +0 -390
- package/skills/graphify/export.py +0 -1408
- package/skills/graphify/extract.py +0 -11570
- package/skills/graphify/global_graph.py +0 -159
- package/skills/graphify/google_workspace.py +0 -223
- package/skills/graphify/hooks.py +0 -457
- package/skills/graphify/ingest.py +0 -331
- package/skills/graphify/llm.py +0 -1896
- package/skills/graphify/manifest.py +0 -4
- package/skills/graphify/mcp_ingest.py +0 -392
- package/skills/graphify/multigraph_compat.py +0 -212
- package/skills/graphify/pg_introspect.py +0 -142
- package/skills/graphify/prs.py +0 -748
- package/skills/graphify/querylog.py +0 -70
- package/skills/graphify/report.py +0 -218
- package/skills/graphify/scip_ingest.py +0 -363
- package/skills/graphify/security.py +0 -336
- package/skills/graphify/semantic_cleanup.py +0 -319
- package/skills/graphify/serve.py +0 -1309
- package/skills/graphify/skill-aider.md +0 -1246
- package/skills/graphify/skill-amp.md +0 -613
- package/skills/graphify/skill-claw.md +0 -616
- package/skills/graphify/skill-codex.md +0 -613
- package/skills/graphify/skill-copilot.md +0 -616
- package/skills/graphify/skill-devin.md +0 -1372
- package/skills/graphify/skill-droid.md +0 -613
- package/skills/graphify/skill-kilo.md +0 -625
- package/skills/graphify/skill-kiro.md +0 -615
- package/skills/graphify/skill-opencode.md +0 -608
- package/skills/graphify/skill-pi.md +0 -615
- package/skills/graphify/skill-trae.md +0 -614
- package/skills/graphify/skill-vscode.md +0 -612
- package/skills/graphify/skill-windows.md +0 -651
- package/skills/graphify/skills/amp/references/add-watch.md +0 -56
- package/skills/graphify/skills/amp/references/exports.md +0 -71
- package/skills/graphify/skills/amp/references/extraction-spec.md +0 -68
- package/skills/graphify/skills/amp/references/github-and-merge.md +0 -46
- package/skills/graphify/skills/amp/references/hooks.md +0 -33
- package/skills/graphify/skills/amp/references/query.md +0 -249
- package/skills/graphify/skills/amp/references/transcribe.md +0 -48
- package/skills/graphify/skills/amp/references/update.md +0 -179
- package/skills/graphify/skills/claude/references/add-watch.md +0 -56
- package/skills/graphify/skills/claude/references/exports.md +0 -71
- package/skills/graphify/skills/claude/references/extraction-spec.md +0 -68
- package/skills/graphify/skills/claude/references/github-and-merge.md +0 -46
- package/skills/graphify/skills/claude/references/hooks.md +0 -33
- package/skills/graphify/skills/claude/references/query.md +0 -103
- package/skills/graphify/skills/claude/references/transcribe.md +0 -48
- package/skills/graphify/skills/claude/references/update.md +0 -179
- package/skills/graphify/skills/claw/references/add-watch.md +0 -56
- package/skills/graphify/skills/claw/references/exports.md +0 -71
- package/skills/graphify/skills/claw/references/extraction-spec.md +0 -29
- package/skills/graphify/skills/claw/references/github-and-merge.md +0 -46
- package/skills/graphify/skills/claw/references/hooks.md +0 -33
- package/skills/graphify/skills/claw/references/query.md +0 -249
- package/skills/graphify/skills/claw/references/transcribe.md +0 -48
- package/skills/graphify/skills/claw/references/update.md +0 -179
- package/skills/graphify/skills/codex/references/add-watch.md +0 -56
- package/skills/graphify/skills/codex/references/exports.md +0 -71
- package/skills/graphify/skills/codex/references/extraction-spec.md +0 -29
- package/skills/graphify/skills/codex/references/github-and-merge.md +0 -46
- package/skills/graphify/skills/codex/references/hooks.md +0 -33
- package/skills/graphify/skills/codex/references/query.md +0 -249
- package/skills/graphify/skills/codex/references/transcribe.md +0 -48
- package/skills/graphify/skills/codex/references/update.md +0 -179
- package/skills/graphify/skills/copilot/references/add-watch.md +0 -56
- package/skills/graphify/skills/copilot/references/exports.md +0 -71
- package/skills/graphify/skills/copilot/references/extraction-spec.md +0 -68
- package/skills/graphify/skills/copilot/references/github-and-merge.md +0 -46
- package/skills/graphify/skills/copilot/references/hooks.md +0 -33
- package/skills/graphify/skills/copilot/references/query.md +0 -249
- package/skills/graphify/skills/copilot/references/transcribe.md +0 -48
- package/skills/graphify/skills/copilot/references/update.md +0 -179
- package/skills/graphify/skills/droid/references/add-watch.md +0 -56
- package/skills/graphify/skills/droid/references/exports.md +0 -71
- package/skills/graphify/skills/droid/references/extraction-spec.md +0 -68
- package/skills/graphify/skills/droid/references/github-and-merge.md +0 -46
- package/skills/graphify/skills/droid/references/hooks.md +0 -33
- package/skills/graphify/skills/droid/references/query.md +0 -249
- package/skills/graphify/skills/droid/references/transcribe.md +0 -48
- package/skills/graphify/skills/droid/references/update.md +0 -179
- package/skills/graphify/skills/kilo/references/add-watch.md +0 -56
- package/skills/graphify/skills/kilo/references/exports.md +0 -71
- package/skills/graphify/skills/kilo/references/extraction-spec.md +0 -68
- package/skills/graphify/skills/kilo/references/github-and-merge.md +0 -46
- package/skills/graphify/skills/kilo/references/hooks.md +0 -33
- package/skills/graphify/skills/kilo/references/query.md +0 -249
- package/skills/graphify/skills/kilo/references/transcribe.md +0 -48
- package/skills/graphify/skills/kilo/references/update.md +0 -179
- package/skills/graphify/skills/kiro/references/add-watch.md +0 -56
- package/skills/graphify/skills/kiro/references/exports.md +0 -71
- package/skills/graphify/skills/kiro/references/extraction-spec.md +0 -29
- package/skills/graphify/skills/kiro/references/github-and-merge.md +0 -46
- package/skills/graphify/skills/kiro/references/hooks.md +0 -33
- package/skills/graphify/skills/kiro/references/query.md +0 -249
- package/skills/graphify/skills/kiro/references/transcribe.md +0 -48
- package/skills/graphify/skills/kiro/references/update.md +0 -179
- package/skills/graphify/skills/opencode/references/add-watch.md +0 -56
- package/skills/graphify/skills/opencode/references/exports.md +0 -71
- package/skills/graphify/skills/opencode/references/extraction-spec.md +0 -68
- package/skills/graphify/skills/opencode/references/github-and-merge.md +0 -46
- package/skills/graphify/skills/opencode/references/hooks.md +0 -33
- package/skills/graphify/skills/opencode/references/query.md +0 -249
- package/skills/graphify/skills/opencode/references/transcribe.md +0 -48
- package/skills/graphify/skills/opencode/references/update.md +0 -179
- package/skills/graphify/skills/pi/references/add-watch.md +0 -56
- package/skills/graphify/skills/pi/references/exports.md +0 -71
- package/skills/graphify/skills/pi/references/extraction-spec.md +0 -29
- package/skills/graphify/skills/pi/references/github-and-merge.md +0 -46
- package/skills/graphify/skills/pi/references/hooks.md +0 -33
- package/skills/graphify/skills/pi/references/query.md +0 -249
- package/skills/graphify/skills/pi/references/transcribe.md +0 -48
- package/skills/graphify/skills/pi/references/update.md +0 -179
- package/skills/graphify/skills/trae/references/add-watch.md +0 -56
- package/skills/graphify/skills/trae/references/exports.md +0 -71
- package/skills/graphify/skills/trae/references/extraction-spec.md +0 -68
- package/skills/graphify/skills/trae/references/github-and-merge.md +0 -46
- package/skills/graphify/skills/trae/references/hooks.md +0 -35
- package/skills/graphify/skills/trae/references/query.md +0 -249
- package/skills/graphify/skills/trae/references/transcribe.md +0 -48
- package/skills/graphify/skills/trae/references/update.md +0 -179
- package/skills/graphify/skills/vscode/references/add-watch.md +0 -56
- package/skills/graphify/skills/vscode/references/exports.md +0 -71
- package/skills/graphify/skills/vscode/references/extraction-spec.md +0 -68
- package/skills/graphify/skills/vscode/references/github-and-merge.md +0 -46
- package/skills/graphify/skills/vscode/references/hooks.md +0 -33
- package/skills/graphify/skills/vscode/references/query.md +0 -249
- package/skills/graphify/skills/vscode/references/transcribe.md +0 -48
- package/skills/graphify/skills/vscode/references/update.md +0 -179
- package/skills/graphify/skills/windows/references/add-watch.md +0 -56
- package/skills/graphify/skills/windows/references/exports.md +0 -71
- package/skills/graphify/skills/windows/references/extraction-spec.md +0 -68
- package/skills/graphify/skills/windows/references/github-and-merge.md +0 -46
- package/skills/graphify/skills/windows/references/hooks.md +0 -33
- package/skills/graphify/skills/windows/references/query.md +0 -249
- package/skills/graphify/skills/windows/references/transcribe.md +0 -48
- package/skills/graphify/skills/windows/references/update.md +0 -179
- package/skills/graphify/symbol_resolution.py +0 -538
- package/skills/graphify/transcribe.py +0 -184
- package/skills/graphify/tree_html.py +0 -582
- package/skills/graphify/validate.py +0 -72
- package/skills/graphify/watch.py +0 -898
- package/skills/graphify/wiki.py +0 -282
package/skills/graphify/watch.py
DELETED
|
@@ -1,898 +0,0 @@
|
|
|
1
|
-
# monitor a folder and auto-trigger --update when files change
|
|
2
|
-
from __future__ import annotations
|
|
3
|
-
import contextlib
|
|
4
|
-
import json
|
|
5
|
-
import os
|
|
6
|
-
import re
|
|
7
|
-
import sys
|
|
8
|
-
import time
|
|
9
|
-
from pathlib import Path
|
|
10
|
-
|
|
11
|
-
_GRAPHIFY_OUT = os.environ.get("GRAPHIFY_OUT", "graphify-out")
|
|
12
|
-
_PENDING_FILENAME = ".pending_changes"
|
|
13
|
-
_PENDING_DRAIN_MAX_PASSES = 20
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
def _queue_pending(out_dir: Path, changed_paths: list[Path]) -> None:
|
|
17
|
-
"""Append ``changed_paths`` to ``out_dir/.pending_changes`` (one per line).
|
|
18
|
-
|
|
19
|
-
Used by a post-commit hook process that cannot acquire ``_rebuild_lock``
|
|
20
|
-
so its change set is not silently dropped (#1059). The lock-holding
|
|
21
|
-
process drains this file before and after its rebuild and merges the
|
|
22
|
-
contents with its own change set.
|
|
23
|
-
|
|
24
|
-
Opened in append mode so concurrent writers do not clobber each other on
|
|
25
|
-
POSIX; each ``write()`` of a small payload is effectively atomic. A
|
|
26
|
-
trailing newline is always written so partial-line corruption stays
|
|
27
|
-
confined to the offending entry and is skipped on drain.
|
|
28
|
-
"""
|
|
29
|
-
if not changed_paths:
|
|
30
|
-
return
|
|
31
|
-
out_dir.mkdir(parents=True, exist_ok=True)
|
|
32
|
-
pending = out_dir / _PENDING_FILENAME
|
|
33
|
-
payload = "".join(f"{os.fspath(p)}\n" for p in changed_paths)
|
|
34
|
-
with open(pending, "a", encoding="utf-8") as fh:
|
|
35
|
-
fh.write(payload)
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
def _drain_pending(out_dir: Path) -> list[Path]:
|
|
39
|
-
"""Read + unlink ``out_dir/.pending_changes`` and return deduplicated paths.
|
|
40
|
-
|
|
41
|
-
Returns an empty list if the file does not exist. Empty/whitespace lines
|
|
42
|
-
are silently skipped so a partial concurrent write that left only a
|
|
43
|
-
fragment cannot poison the merge.
|
|
44
|
-
"""
|
|
45
|
-
pending = out_dir / _PENDING_FILENAME
|
|
46
|
-
if not pending.exists():
|
|
47
|
-
return []
|
|
48
|
-
try:
|
|
49
|
-
raw = pending.read_text(encoding="utf-8")
|
|
50
|
-
except OSError:
|
|
51
|
-
return []
|
|
52
|
-
# Unlink BEFORE returning so a crash between read and process retains the
|
|
53
|
-
# data in the next caller's view via the lines we are about to return —
|
|
54
|
-
# i.e. losing the file after reading is fine, losing it before would be a
|
|
55
|
-
# bug. Use missing_ok to tolerate a racing drain on platforms where
|
|
56
|
-
# rename/unlink may interleave.
|
|
57
|
-
with contextlib.suppress(FileNotFoundError):
|
|
58
|
-
pending.unlink()
|
|
59
|
-
seen: set[str] = set()
|
|
60
|
-
out: list[Path] = []
|
|
61
|
-
for line in raw.splitlines():
|
|
62
|
-
s = line.strip()
|
|
63
|
-
if not s or s in seen:
|
|
64
|
-
continue
|
|
65
|
-
seen.add(s)
|
|
66
|
-
out.append(Path(s))
|
|
67
|
-
return out
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
def _merge_changed_paths(*sources: "list[Path] | None") -> list[Path]:
|
|
71
|
-
"""Concatenate path lists, preserving order and dropping duplicates.
|
|
72
|
-
|
|
73
|
-
Used to combine a hook process's own ``changed_paths`` with the drained
|
|
74
|
-
contents of ``.pending_changes`` so the lock-holding rebuild covers
|
|
75
|
-
every queued commit's worth of files (#1059).
|
|
76
|
-
"""
|
|
77
|
-
seen: set[str] = set()
|
|
78
|
-
out: list[Path] = []
|
|
79
|
-
for src in sources:
|
|
80
|
-
if not src:
|
|
81
|
-
continue
|
|
82
|
-
for p in src:
|
|
83
|
-
key = os.fspath(p)
|
|
84
|
-
if key in seen:
|
|
85
|
-
continue
|
|
86
|
-
seen.add(key)
|
|
87
|
-
out.append(p)
|
|
88
|
-
return out
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
@contextlib.contextmanager
|
|
92
|
-
def _rebuild_lock(out_dir: Path, *, blocking: bool = False):
|
|
93
|
-
"""Per-repo advisory lock around a rebuild.
|
|
94
|
-
|
|
95
|
-
Yields True if acquired, False if another rebuild is already running and
|
|
96
|
-
``blocking`` is False. Uses fcntl.flock so the lock is released
|
|
97
|
-
automatically if the process is killed (no stale-lock cleanup needed).
|
|
98
|
-
|
|
99
|
-
While the lock is held, ``.rebuild.lock`` contains the owning PID followed
|
|
100
|
-
by a newline so external pollers (publish scripts, etc.) can read it.
|
|
101
|
-
On successful release the file is unlinked so downstream tooling that
|
|
102
|
-
waits for the lock to clear by polling for its absence unblocks promptly.
|
|
103
|
-
|
|
104
|
-
Falls back to a no-op yield(True) on platforms without fcntl (Windows).
|
|
105
|
-
"""
|
|
106
|
-
try:
|
|
107
|
-
import fcntl
|
|
108
|
-
except ImportError:
|
|
109
|
-
yield True
|
|
110
|
-
return
|
|
111
|
-
|
|
112
|
-
out_dir.mkdir(parents=True, exist_ok=True)
|
|
113
|
-
lock_path = out_dir / ".rebuild.lock"
|
|
114
|
-
# "a+" creates the file if missing without truncating an existing holder's
|
|
115
|
-
# PID payload — important because another process may have already written
|
|
116
|
-
# its PID before we attempt the flock.
|
|
117
|
-
fh = open(lock_path, "a+", encoding="utf-8")
|
|
118
|
-
acquired = False
|
|
119
|
-
try:
|
|
120
|
-
flags = fcntl.LOCK_EX if blocking else (fcntl.LOCK_EX | fcntl.LOCK_NB)
|
|
121
|
-
try:
|
|
122
|
-
fcntl.flock(fh.fileno(), flags)
|
|
123
|
-
except BlockingIOError:
|
|
124
|
-
yield False
|
|
125
|
-
return
|
|
126
|
-
acquired = True
|
|
127
|
-
# Replace any prior owner's PID with ours so external readers see a
|
|
128
|
-
# single parseable line, not a digit-concatenation across rebuilds.
|
|
129
|
-
try:
|
|
130
|
-
fh.seek(0)
|
|
131
|
-
fh.truncate()
|
|
132
|
-
fh.write(f"{os.getpid()}\n")
|
|
133
|
-
fh.flush()
|
|
134
|
-
except OSError:
|
|
135
|
-
pass
|
|
136
|
-
yield True
|
|
137
|
-
finally:
|
|
138
|
-
if acquired:
|
|
139
|
-
try:
|
|
140
|
-
fcntl.flock(fh.fileno(), fcntl.LOCK_UN)
|
|
141
|
-
except OSError:
|
|
142
|
-
pass
|
|
143
|
-
fh.close()
|
|
144
|
-
# Signal "rebuild done" by removing the lock file. Only the holder
|
|
145
|
-
# unlinks; a non-acquiring caller leaves the existing lock in place.
|
|
146
|
-
if acquired:
|
|
147
|
-
with contextlib.suppress(OSError):
|
|
148
|
-
lock_path.unlink()
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
def _apply_resource_limits() -> None:
|
|
152
|
-
"""Best-effort nice + memory cap. Called from inline hook scripts.
|
|
153
|
-
|
|
154
|
-
GRAPHIFY_REBUILD_MEMORY_LIMIT_MB caps RSS-ish memory. Uses RLIMIT_DATA on
|
|
155
|
-
macOS (RLIMIT_AS is unreliable under Apple's libmalloc) and RLIMIT_AS on
|
|
156
|
-
Linux. Silently skips if the platform doesn't support it.
|
|
157
|
-
"""
|
|
158
|
-
try:
|
|
159
|
-
os.nice(10)
|
|
160
|
-
except (OSError, AttributeError):
|
|
161
|
-
pass
|
|
162
|
-
mb = os.environ.get("GRAPHIFY_REBUILD_MEMORY_LIMIT_MB", "").strip()
|
|
163
|
-
if not mb:
|
|
164
|
-
return
|
|
165
|
-
try:
|
|
166
|
-
limit = int(mb) * 1024 * 1024
|
|
167
|
-
except ValueError:
|
|
168
|
-
return
|
|
169
|
-
try:
|
|
170
|
-
import resource
|
|
171
|
-
which = resource.RLIMIT_DATA if sys.platform == "darwin" else resource.RLIMIT_AS
|
|
172
|
-
soft, hard = resource.getrlimit(which)
|
|
173
|
-
new_hard = hard if hard != resource.RLIM_INFINITY and hard < limit else limit
|
|
174
|
-
resource.setrlimit(which, (limit, new_hard))
|
|
175
|
-
except (ImportError, ValueError, OSError):
|
|
176
|
-
pass
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
def _git_head() -> str | None:
|
|
180
|
-
"""Return current git HEAD commit hash, or None outside a repo."""
|
|
181
|
-
import subprocess as _sp
|
|
182
|
-
try:
|
|
183
|
-
r = _sp.run(["git", "rev-parse", "HEAD"], capture_output=True, text=True, timeout=3)
|
|
184
|
-
return r.stdout.strip() if r.returncode == 0 else None
|
|
185
|
-
except Exception:
|
|
186
|
-
return None
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
from graphify.detect import (
|
|
190
|
-
CODE_EXTENSIONS,
|
|
191
|
-
DOC_EXTENSIONS,
|
|
192
|
-
PAPER_EXTENSIONS,
|
|
193
|
-
IMAGE_EXTENSIONS,
|
|
194
|
-
_load_graphifyignore,
|
|
195
|
-
_is_ignored,
|
|
196
|
-
)
|
|
197
|
-
|
|
198
|
-
_WATCHED_EXTENSIONS = CODE_EXTENSIONS | DOC_EXTENSIONS | PAPER_EXTENSIONS | IMAGE_EXTENSIONS
|
|
199
|
-
_CODE_EXTENSIONS = CODE_EXTENSIONS
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
def _report_root_label(watch_path: Path) -> str:
|
|
203
|
-
if watch_path.is_absolute():
|
|
204
|
-
return watch_path.name or str(watch_path)
|
|
205
|
-
return Path.cwd().name if watch_path == Path(".") else str(watch_path)
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
def _relativize_source_files(payload: dict, root: Path) -> None:
|
|
209
|
-
for bucket in ("nodes", "edges", "hyperedges"):
|
|
210
|
-
for item in payload.get(bucket, []):
|
|
211
|
-
source = item.get("source_file")
|
|
212
|
-
if not source:
|
|
213
|
-
continue
|
|
214
|
-
source_path = Path(source)
|
|
215
|
-
if not source_path.is_absolute():
|
|
216
|
-
continue
|
|
217
|
-
try:
|
|
218
|
-
item["source_file"] = source_path.resolve().relative_to(root).as_posix()
|
|
219
|
-
except ValueError:
|
|
220
|
-
continue
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
def _node_community_map(graph_data: dict) -> dict[str, int]:
|
|
224
|
-
out: dict[str, int] = {}
|
|
225
|
-
for node in graph_data.get("nodes", []):
|
|
226
|
-
node_id = node.get("id")
|
|
227
|
-
cid = node.get("community")
|
|
228
|
-
if node_id is None or cid is None:
|
|
229
|
-
continue
|
|
230
|
-
try:
|
|
231
|
-
out[str(node_id)] = int(cid)
|
|
232
|
-
except (TypeError, ValueError):
|
|
233
|
-
print(
|
|
234
|
-
f"[graphify watch] Skipping node with invalid community id: "
|
|
235
|
-
f"node_id={node_id!r} community={cid!r}",
|
|
236
|
-
file=sys.stderr,
|
|
237
|
-
)
|
|
238
|
-
continue
|
|
239
|
-
return out
|
|
240
|
-
|
|
241
|
-
|
|
242
|
-
def _canonical_graph_for_compare(graph_data: dict) -> dict:
|
|
243
|
-
canonical = dict(graph_data)
|
|
244
|
-
canonical.pop("built_at_commit", None)
|
|
245
|
-
for key in ("nodes", "links", "edges", "hyperedges"):
|
|
246
|
-
if key in canonical and isinstance(canonical[key], list):
|
|
247
|
-
canonical[key] = sorted(
|
|
248
|
-
canonical[key],
|
|
249
|
-
key=lambda item: json.dumps(item, sort_keys=True, ensure_ascii=False, default=str),
|
|
250
|
-
)
|
|
251
|
-
return canonical
|
|
252
|
-
|
|
253
|
-
|
|
254
|
-
def _canonical_topology_for_compare(graph_data: dict) -> dict:
|
|
255
|
-
canonical = dict(graph_data)
|
|
256
|
-
canonical.pop("built_at_commit", None)
|
|
257
|
-
|
|
258
|
-
nodes = canonical.get("nodes")
|
|
259
|
-
if isinstance(nodes, list):
|
|
260
|
-
norm_nodes = []
|
|
261
|
-
for node in nodes:
|
|
262
|
-
if not isinstance(node, dict):
|
|
263
|
-
continue
|
|
264
|
-
n = dict(node)
|
|
265
|
-
n.pop("community", None)
|
|
266
|
-
n.pop("norm_label", None)
|
|
267
|
-
norm_nodes.append(n)
|
|
268
|
-
canonical["nodes"] = sorted(
|
|
269
|
-
norm_nodes,
|
|
270
|
-
key=lambda item: json.dumps(item, sort_keys=True, ensure_ascii=False, default=str),
|
|
271
|
-
)
|
|
272
|
-
|
|
273
|
-
for key in ("links", "edges"):
|
|
274
|
-
items = canonical.get(key)
|
|
275
|
-
if not isinstance(items, list):
|
|
276
|
-
continue
|
|
277
|
-
norm_edges = []
|
|
278
|
-
for edge in items:
|
|
279
|
-
if not isinstance(edge, dict):
|
|
280
|
-
continue
|
|
281
|
-
e = dict(edge)
|
|
282
|
-
# to_json writes _src/_tgt as the canonical directed endpoints and
|
|
283
|
-
# overwrites source/target with them before serialising, so the
|
|
284
|
-
# on-disk graph has no _src/_tgt. The candidate topology (fresh from
|
|
285
|
-
# node_link_data) still has them. Popping and reassigning here makes
|
|
286
|
-
# both sides comparable: existing gets no-op pops (None), candidate
|
|
287
|
-
# gets source/target overwritten from _src/_tgt — same result.
|
|
288
|
-
true_src = e.pop("_src", None)
|
|
289
|
-
true_tgt = e.pop("_tgt", None)
|
|
290
|
-
if true_src is not None and true_tgt is not None:
|
|
291
|
-
e["source"] = true_src
|
|
292
|
-
e["target"] = true_tgt
|
|
293
|
-
e.pop("confidence_score", None)
|
|
294
|
-
norm_edges.append(e)
|
|
295
|
-
canonical[key] = sorted(
|
|
296
|
-
norm_edges,
|
|
297
|
-
key=lambda item: json.dumps(item, sort_keys=True, ensure_ascii=False, default=str),
|
|
298
|
-
)
|
|
299
|
-
|
|
300
|
-
hyperedges = canonical.get("hyperedges")
|
|
301
|
-
if isinstance(hyperedges, list):
|
|
302
|
-
canonical["hyperedges"] = sorted(
|
|
303
|
-
hyperedges,
|
|
304
|
-
key=lambda item: json.dumps(item, sort_keys=True, ensure_ascii=False, default=str),
|
|
305
|
-
)
|
|
306
|
-
|
|
307
|
-
return canonical
|
|
308
|
-
|
|
309
|
-
|
|
310
|
-
def _topology_from_graph(G) -> dict:
|
|
311
|
-
from networkx.readwrite import json_graph
|
|
312
|
-
try:
|
|
313
|
-
data = json_graph.node_link_data(G, edges="links")
|
|
314
|
-
except TypeError:
|
|
315
|
-
data = json_graph.node_link_data(G)
|
|
316
|
-
data["hyperedges"] = getattr(G, "graph", {}).get("hyperedges", [])
|
|
317
|
-
return data
|
|
318
|
-
|
|
319
|
-
|
|
320
|
-
def _check_shrink(
|
|
321
|
-
force: bool,
|
|
322
|
-
existing_data: dict,
|
|
323
|
-
new_data: dict,
|
|
324
|
-
tmp: "Path | None" = None,
|
|
325
|
-
*,
|
|
326
|
-
had_explicit_deletions: bool = False,
|
|
327
|
-
) -> bool:
|
|
328
|
-
"""Return True (ok to proceed) or False (shrink refused).
|
|
329
|
-
|
|
330
|
-
When False, cleans up *tmp* if provided and prints a warning to stderr.
|
|
331
|
-
|
|
332
|
-
The shrink-guard exists to catch SILENT shrinkage from failed extraction
|
|
333
|
-
chunks (a half-written semantic pass leaving thousands of nodes
|
|
334
|
-
unaccounted for). When ``had_explicit_deletions`` is True, the caller
|
|
335
|
-
has declared which files were removed (e.g. the post-commit hook saw
|
|
336
|
-
a ``D`` in ``git diff --name-only``) and a smaller graph is the expected
|
|
337
|
-
outcome — skip the guard so legitimate refactors don't require ``--force``.
|
|
338
|
-
"""
|
|
339
|
-
if force or not existing_data or had_explicit_deletions:
|
|
340
|
-
return True
|
|
341
|
-
existing_n = len(existing_data.get("nodes", []))
|
|
342
|
-
new_n = len(new_data.get("nodes", []))
|
|
343
|
-
if new_n < existing_n:
|
|
344
|
-
if tmp is not None:
|
|
345
|
-
tmp.unlink(missing_ok=True)
|
|
346
|
-
print(
|
|
347
|
-
f"[graphify] WARNING: new graph has {new_n} nodes but existing "
|
|
348
|
-
f"graph.json has {existing_n}. Refusing to overwrite — you may be "
|
|
349
|
-
f"missing chunk files from a previous session. "
|
|
350
|
-
f"Pass --force to override.",
|
|
351
|
-
file=sys.stderr,
|
|
352
|
-
)
|
|
353
|
-
return False
|
|
354
|
-
return True
|
|
355
|
-
|
|
356
|
-
|
|
357
|
-
def _report_for_compare(report_text: str) -> str:
|
|
358
|
-
return re.sub(r"^- Built from commit: `[^`]+`\n?", "", report_text, flags=re.MULTILINE)
|
|
359
|
-
|
|
360
|
-
|
|
361
|
-
def _json_text(data: dict) -> str:
|
|
362
|
-
return json.dumps(data, indent=2, ensure_ascii=False) + "\n"
|
|
363
|
-
|
|
364
|
-
|
|
365
|
-
def _rebuild_code(
|
|
366
|
-
watch_path: Path,
|
|
367
|
-
*,
|
|
368
|
-
changed_paths: list[Path] | None = None,
|
|
369
|
-
follow_symlinks: bool = False,
|
|
370
|
-
force: bool = False,
|
|
371
|
-
no_cluster: bool = False,
|
|
372
|
-
acquire_lock: bool = True,
|
|
373
|
-
block_on_lock: bool = False,
|
|
374
|
-
) -> bool:
|
|
375
|
-
"""Re-run AST extraction + build + optional cluster + report for code files. No LLM needed.
|
|
376
|
-
|
|
377
|
-
When ``force`` is True the node-count safety check in ``to_json`` is bypassed
|
|
378
|
-
so the rebuilt graph overwrites graph.json even if it has fewer nodes.
|
|
379
|
-
Use this after refactors that legitimately delete code.
|
|
380
|
-
|
|
381
|
-
When ``changed_paths`` is provided, only those files are re-extracted; nodes
|
|
382
|
-
for unchanged files are preserved from the existing graph. Deleted paths
|
|
383
|
-
in ``changed_paths`` (paths that no longer exist on disk) are dropped from
|
|
384
|
-
the preserved set. When ``changed_paths`` is None the full code corpus is
|
|
385
|
-
re-extracted (used by the watcher and post-checkout hook).
|
|
386
|
-
|
|
387
|
-
``acquire_lock`` (default True) takes a non-blocking per-repo flock around
|
|
388
|
-
the rebuild so concurrent post-commit hooks across multiple repos do not
|
|
389
|
-
pile up. Returns False with a log line if the lock is held. Pass
|
|
390
|
-
``block_on_lock=True`` to wait instead of skip (used by the interactive
|
|
391
|
-
``graphify update`` CLI).
|
|
392
|
-
|
|
393
|
-
``no_cluster`` skips community detection and writes raw merged extraction
|
|
394
|
-
JSON to graphify-out/graph.json (mirrors ``extract --no-cluster``).
|
|
395
|
-
|
|
396
|
-
Returns True on success, False on error or skipped-due-to-lock.
|
|
397
|
-
"""
|
|
398
|
-
out = watch_path / _GRAPHIFY_OUT
|
|
399
|
-
if acquire_lock:
|
|
400
|
-
# #1059: incremental (changed_paths is not None) hooks must not drop
|
|
401
|
-
# their change set when another rebuild is already running. Queue
|
|
402
|
-
# before attempting the lock so a non-blocking failure still records
|
|
403
|
-
# the work; the lock-holder drains the queue and merges it in. Full-
|
|
404
|
-
# corpus rebuilds skip the queue entirely — they already cover every
|
|
405
|
-
# file, so there is nothing to merge.
|
|
406
|
-
if changed_paths is not None and not block_on_lock:
|
|
407
|
-
_queue_pending(out, list(changed_paths))
|
|
408
|
-
with _rebuild_lock(out, blocking=block_on_lock) as got:
|
|
409
|
-
if not got:
|
|
410
|
-
print("[graphify watch] Rebuild already in progress for "
|
|
411
|
-
f"{watch_path.resolve()} - changes queued.")
|
|
412
|
-
return False
|
|
413
|
-
# Lock acquired. Drain anything queued by earlier contenders
|
|
414
|
-
# (including, importantly, the paths we just queued ourselves)
|
|
415
|
-
# and merge with our own change set so a single rebuild covers
|
|
416
|
-
# everything outstanding.
|
|
417
|
-
if changed_paths is not None:
|
|
418
|
-
merged = _merge_changed_paths(changed_paths, _drain_pending(out))
|
|
419
|
-
else:
|
|
420
|
-
# Full-corpus rebuild supersedes any queued incremental work.
|
|
421
|
-
_drain_pending(out)
|
|
422
|
-
merged = None
|
|
423
|
-
ok = _rebuild_code(
|
|
424
|
-
watch_path,
|
|
425
|
-
changed_paths=merged,
|
|
426
|
-
follow_symlinks=follow_symlinks,
|
|
427
|
-
force=force,
|
|
428
|
-
no_cluster=no_cluster,
|
|
429
|
-
acquire_lock=False,
|
|
430
|
-
)
|
|
431
|
-
# Late-arrival drain: another hook may have queued work while we
|
|
432
|
-
# were rebuilding. Loop up to _PENDING_DRAIN_MAX_PASSES times so a
|
|
433
|
-
# storm of commits eventually quiesces without livelocking. A full
|
|
434
|
-
# rebuild already saw everything, so skip this for changed_paths is None.
|
|
435
|
-
if merged is not None:
|
|
436
|
-
for _ in range(_PENDING_DRAIN_MAX_PASSES):
|
|
437
|
-
late = _drain_pending(out)
|
|
438
|
-
if not late:
|
|
439
|
-
break
|
|
440
|
-
ok = _rebuild_code(
|
|
441
|
-
watch_path,
|
|
442
|
-
changed_paths=late,
|
|
443
|
-
follow_symlinks=follow_symlinks,
|
|
444
|
-
force=force,
|
|
445
|
-
no_cluster=no_cluster,
|
|
446
|
-
acquire_lock=False,
|
|
447
|
-
) and ok
|
|
448
|
-
return ok
|
|
449
|
-
|
|
450
|
-
watch_root = watch_path.resolve()
|
|
451
|
-
project_root = Path.cwd().resolve() if not watch_path.is_absolute() else watch_root
|
|
452
|
-
report_root = _report_root_label(watch_path)
|
|
453
|
-
try:
|
|
454
|
-
from graphify.extract import extract, _get_extractor
|
|
455
|
-
from graphify.detect import detect
|
|
456
|
-
from graphify.build import build_from_json, _norm_source_file as _nsf
|
|
457
|
-
from graphify.cluster import cluster, remap_communities_to_previous, score_all
|
|
458
|
-
from graphify.analyze import god_nodes, surprising_connections, suggest_questions
|
|
459
|
-
from graphify.report import generate
|
|
460
|
-
from graphify.export import to_json, to_html
|
|
461
|
-
from graphify.security import check_graph_file_size_cap
|
|
462
|
-
|
|
463
|
-
detected = detect(watch_path, follow_symlinks=follow_symlinks)
|
|
464
|
-
code_files = [Path(f) for f in detected['files']['code']]
|
|
465
|
-
|
|
466
|
-
# Include document files that have AST extractors (e.g. .md, .mdx, .qmd)
|
|
467
|
-
for doc_file in detected['files'].get('document', []):
|
|
468
|
-
p = Path(doc_file)
|
|
469
|
-
if _get_extractor(p) is not None:
|
|
470
|
-
code_files.append(p)
|
|
471
|
-
|
|
472
|
-
if not code_files:
|
|
473
|
-
print("[graphify watch] No code files found - nothing to rebuild.")
|
|
474
|
-
return False
|
|
475
|
-
|
|
476
|
-
# Incremental path: when the caller passed an explicit change list,
|
|
477
|
-
# extract only changed-and-still-existing files. Deleted paths are
|
|
478
|
-
# tracked separately so their stale nodes can be evicted below.
|
|
479
|
-
deleted_paths: set[str] = set()
|
|
480
|
-
if changed_paths is not None:
|
|
481
|
-
code_set = {p.resolve() for p in code_files}
|
|
482
|
-
wanted: list[Path] = []
|
|
483
|
-
for raw in changed_paths:
|
|
484
|
-
cand = (watch_root / raw).resolve() if not raw.is_absolute() else raw.resolve()
|
|
485
|
-
if cand.exists() and cand in code_set:
|
|
486
|
-
wanted.append(cand)
|
|
487
|
-
else:
|
|
488
|
-
# File was deleted, renamed away, or filtered out by detect
|
|
489
|
-
# (e.g. .gitignore, vendored). Either way, evict any
|
|
490
|
-
# preserved nodes that still claim this source path.
|
|
491
|
-
deleted_paths.add(_nsf(str(cand), str(project_root)) or str(cand))
|
|
492
|
-
if not wanted and not deleted_paths:
|
|
493
|
-
print("[graphify watch] No tracked code files in change set - skipping rebuild.")
|
|
494
|
-
return True
|
|
495
|
-
extract_targets = wanted
|
|
496
|
-
else:
|
|
497
|
-
extract_targets = code_files
|
|
498
|
-
|
|
499
|
-
commit = _git_head()
|
|
500
|
-
result = extract(extract_targets, cache_root=watch_root) if extract_targets else {
|
|
501
|
-
"nodes": [], "edges": [], "hyperedges": [],
|
|
502
|
-
"input_tokens": 0, "output_tokens": 0,
|
|
503
|
-
}
|
|
504
|
-
|
|
505
|
-
# Preserve semantic nodes/edges from a previous full run.
|
|
506
|
-
# AST-only rebuild replaces nodes for changed files; everything else is kept.
|
|
507
|
-
# Filter by node ID membership in the new AST output, not by file_type —
|
|
508
|
-
# INFERRED/AMBIGUOUS nodes extracted from code files also carry file_type="code"
|
|
509
|
-
# and would be wrongly dropped by a file_type-based filter.
|
|
510
|
-
# When the caller supplied changed_paths, also evict preserved nodes whose
|
|
511
|
-
# source_file matches a path that was changed (re-extracted) or deleted —
|
|
512
|
-
# otherwise the old nodes for those files would survive forever.
|
|
513
|
-
existing_graph = out / "graph.json"
|
|
514
|
-
existing_graph_data: dict = {}
|
|
515
|
-
if existing_graph.exists():
|
|
516
|
-
try:
|
|
517
|
-
check_graph_file_size_cap(existing_graph)
|
|
518
|
-
existing = json.loads(existing_graph.read_text(encoding="utf-8"))
|
|
519
|
-
existing_graph_data = existing
|
|
520
|
-
new_ast_ids = {n["id"] for n in result["nodes"]}
|
|
521
|
-
_relativize_source_files(existing, project_root)
|
|
522
|
-
evict_sources: set[str] = set(deleted_paths)
|
|
523
|
-
if changed_paths is not None:
|
|
524
|
-
for p in extract_targets:
|
|
525
|
-
evict_sources.add(_nsf(str(p), str(project_root)) or str(p))
|
|
526
|
-
else:
|
|
527
|
-
# Full re-extraction: reconcile against current code files to
|
|
528
|
-
# evict nodes from files deleted since the last run (#1007).
|
|
529
|
-
_root_str = str(project_root)
|
|
530
|
-
current_sources = {
|
|
531
|
-
_nsf(str(p.relative_to(project_root)), _root_str)
|
|
532
|
-
for p in code_files
|
|
533
|
-
if p.is_relative_to(project_root)
|
|
534
|
-
}
|
|
535
|
-
for n in existing.get("nodes", []):
|
|
536
|
-
sf = n.get("source_file")
|
|
537
|
-
if not sf:
|
|
538
|
-
continue
|
|
539
|
-
if Path(sf).suffix.lower() not in _CODE_EXTENSIONS:
|
|
540
|
-
continue
|
|
541
|
-
norm = _nsf(sf, _root_str)
|
|
542
|
-
if norm not in current_sources:
|
|
543
|
-
evict_sources.add(sf)
|
|
544
|
-
evict_sources.add(norm)
|
|
545
|
-
deleted_paths.add(norm)
|
|
546
|
-
# On a full re-extraction every code file is re-extracted, so
|
|
547
|
-
# new_ast_ids is the complete current AST set. Any AST-marked node
|
|
548
|
-
# missing from it is stale and must be dropped even if its source
|
|
549
|
-
# file still exists (a symbol removed from a surviving file, #1116).
|
|
550
|
-
# Gate on full_rebuild: in incremental mode an AST node from an
|
|
551
|
-
# unchanged file is legitimately absent from new_ast_ids. Semantic
|
|
552
|
-
# nodes lack the "_origin" marker, so they are never dropped here —
|
|
553
|
-
# only by the deleted-file eviction in evict_sources above.
|
|
554
|
-
full_rebuild = changed_paths is None
|
|
555
|
-
preserved_nodes = [
|
|
556
|
-
n for n in existing.get("nodes", [])
|
|
557
|
-
if n["id"] not in new_ast_ids
|
|
558
|
-
and not (full_rebuild and n.get("_origin") == "ast")
|
|
559
|
-
and (not evict_sources or n.get("source_file") not in evict_sources)
|
|
560
|
-
]
|
|
561
|
-
all_ids = new_ast_ids | {n["id"] for n in preserved_nodes}
|
|
562
|
-
preserved_edges = [
|
|
563
|
-
e for e in existing.get("links", existing.get("edges", []))
|
|
564
|
-
if e.get("source") in all_ids and e.get("target") in all_ids
|
|
565
|
-
]
|
|
566
|
-
result = {
|
|
567
|
-
"nodes": result["nodes"] + preserved_nodes,
|
|
568
|
-
"edges": result["edges"] + preserved_edges,
|
|
569
|
-
"hyperedges": existing.get("hyperedges", []),
|
|
570
|
-
"input_tokens": 0,
|
|
571
|
-
"output_tokens": 0,
|
|
572
|
-
}
|
|
573
|
-
except Exception:
|
|
574
|
-
pass # corrupt graph.json - proceed with AST-only
|
|
575
|
-
|
|
576
|
-
_relativize_source_files(result, project_root)
|
|
577
|
-
out.mkdir(exist_ok=True)
|
|
578
|
-
# Write the user-supplied path rather than the resolved absolute form
|
|
579
|
-
# so a committed ``graphify-out/.graphify_root`` is portable across
|
|
580
|
-
# clones and CI runners (#777). When ``watch_path`` is ``.`` (the
|
|
581
|
-
# common case for ``graphify update``), this writes ``.`` and the
|
|
582
|
-
# subsequent re-run resolves it against the caller's CWD.
|
|
583
|
-
(out / ".graphify_root").write_text(str(watch_path), encoding="utf-8")
|
|
584
|
-
|
|
585
|
-
if no_cluster:
|
|
586
|
-
# Normalise to "links" key so schema is consistent with the full clustered path.
|
|
587
|
-
candidate_graph_data = {
|
|
588
|
-
**{k: v for k, v in result.items() if k != "edges"},
|
|
589
|
-
"links": result.get("edges", []),
|
|
590
|
-
}
|
|
591
|
-
candidate_graph_text = _json_text(candidate_graph_data)
|
|
592
|
-
same_graph = False
|
|
593
|
-
if existing_graph.exists():
|
|
594
|
-
try:
|
|
595
|
-
check_graph_file_size_cap(existing_graph)
|
|
596
|
-
existing_payload = json.loads(existing_graph.read_text(encoding="utf-8"))
|
|
597
|
-
same_graph = (
|
|
598
|
-
json.dumps(_canonical_graph_for_compare(existing_payload), sort_keys=True, ensure_ascii=False)
|
|
599
|
-
== json.dumps(_canonical_graph_for_compare(candidate_graph_data), sort_keys=True, ensure_ascii=False)
|
|
600
|
-
)
|
|
601
|
-
except Exception:
|
|
602
|
-
same_graph = False
|
|
603
|
-
if not same_graph:
|
|
604
|
-
if not _check_shrink(
|
|
605
|
-
force, existing_graph_data, candidate_graph_data,
|
|
606
|
-
had_explicit_deletions=bool(deleted_paths),
|
|
607
|
-
):
|
|
608
|
-
return False
|
|
609
|
-
existing_graph.write_text(candidate_graph_text, encoding="utf-8")
|
|
610
|
-
|
|
611
|
-
try:
|
|
612
|
-
from graphify.detect import save_manifest
|
|
613
|
-
save_manifest(detected["files"], kind="ast", root=project_root)
|
|
614
|
-
except Exception:
|
|
615
|
-
pass
|
|
616
|
-
|
|
617
|
-
# clear stale needs_update flag if present
|
|
618
|
-
flag = out / "needs_update"
|
|
619
|
-
if flag.exists():
|
|
620
|
-
flag.unlink()
|
|
621
|
-
|
|
622
|
-
if same_graph:
|
|
623
|
-
print("[graphify watch] No code-graph changes detected (--no-cluster); outputs left untouched.")
|
|
624
|
-
else:
|
|
625
|
-
print(
|
|
626
|
-
"[graphify watch] Rebuilt (no clustering): "
|
|
627
|
-
f"{len(result.get('nodes', []))} nodes, {len(result.get('edges', []))} edges"
|
|
628
|
-
)
|
|
629
|
-
print(f"[graphify watch] graph.json updated in {out}")
|
|
630
|
-
return True
|
|
631
|
-
|
|
632
|
-
detection = {
|
|
633
|
-
"files": {"code": [str(f) for f in code_files], "document": [], "paper": [], "image": []},
|
|
634
|
-
"total_files": len(code_files),
|
|
635
|
-
"total_words": detected.get("total_words", 0),
|
|
636
|
-
}
|
|
637
|
-
|
|
638
|
-
G = build_from_json(result)
|
|
639
|
-
candidate_topology = _topology_from_graph(G)
|
|
640
|
-
if existing_graph_data:
|
|
641
|
-
try:
|
|
642
|
-
same_topology = (
|
|
643
|
-
json.dumps(_canonical_topology_for_compare(existing_graph_data), sort_keys=True, ensure_ascii=False)
|
|
644
|
-
== json.dumps(_canonical_topology_for_compare(candidate_topology), sort_keys=True, ensure_ascii=False)
|
|
645
|
-
)
|
|
646
|
-
except Exception:
|
|
647
|
-
same_topology = False
|
|
648
|
-
if same_topology:
|
|
649
|
-
try:
|
|
650
|
-
from graphify.detect import save_manifest
|
|
651
|
-
save_manifest(detected["files"], kind="ast", root=project_root)
|
|
652
|
-
except Exception:
|
|
653
|
-
pass
|
|
654
|
-
flag = out / "needs_update"
|
|
655
|
-
if flag.exists():
|
|
656
|
-
flag.unlink()
|
|
657
|
-
print("[graphify watch] No code-graph topology changes detected; outputs left untouched.")
|
|
658
|
-
return True
|
|
659
|
-
|
|
660
|
-
communities = cluster(G)
|
|
661
|
-
previous_node_community = _node_community_map(existing_graph_data)
|
|
662
|
-
if previous_node_community:
|
|
663
|
-
communities = remap_communities_to_previous(communities, previous_node_community)
|
|
664
|
-
cohesion = score_all(G, communities)
|
|
665
|
-
gods = god_nodes(G)
|
|
666
|
-
surprises = surprising_connections(G, communities)
|
|
667
|
-
labels_file = out / ".graphify_labels.json"
|
|
668
|
-
try:
|
|
669
|
-
raw = json.loads(labels_file.read_text(encoding="utf-8")) if labels_file.exists() else {}
|
|
670
|
-
labels = {int(k): v for k, v in raw.items() if int(k) in communities}
|
|
671
|
-
except Exception:
|
|
672
|
-
raw = {}
|
|
673
|
-
labels = {}
|
|
674
|
-
for cid in communities:
|
|
675
|
-
if cid not in labels:
|
|
676
|
-
labels[cid] = "Community " + str(cid)
|
|
677
|
-
questions = suggest_questions(G, communities, labels)
|
|
678
|
-
report = generate(G, communities, cohesion, labels, gods, surprises, detection,
|
|
679
|
-
{"input": 0, "output": 0}, report_root, suggested_questions=questions,
|
|
680
|
-
built_at_commit=commit)
|
|
681
|
-
report_path = out / "GRAPH_REPORT.md"
|
|
682
|
-
labels_json = json.dumps({str(k): v for k, v in sorted(labels.items())}, ensure_ascii=False, indent=2) + "\n"
|
|
683
|
-
graph_tmp = out / ".graph.tmp.json"
|
|
684
|
-
json_written = to_json(G, communities, str(graph_tmp), force=True, built_at_commit=commit)
|
|
685
|
-
if not json_written:
|
|
686
|
-
return False
|
|
687
|
-
candidate_graph_data = json.loads(graph_tmp.read_text(encoding="utf-8"))
|
|
688
|
-
same_graph = False
|
|
689
|
-
same_report = False
|
|
690
|
-
if existing_graph.exists():
|
|
691
|
-
try:
|
|
692
|
-
check_graph_file_size_cap(existing_graph)
|
|
693
|
-
existing_payload = json.loads(existing_graph.read_text(encoding="utf-8"))
|
|
694
|
-
same_graph = (
|
|
695
|
-
json.dumps(_canonical_graph_for_compare(existing_payload), sort_keys=True, ensure_ascii=False)
|
|
696
|
-
== json.dumps(_canonical_graph_for_compare(candidate_graph_data), sort_keys=True, ensure_ascii=False)
|
|
697
|
-
)
|
|
698
|
-
except Exception:
|
|
699
|
-
same_graph = False
|
|
700
|
-
if report_path.exists():
|
|
701
|
-
old_report = report_path.read_text(encoding="utf-8")
|
|
702
|
-
same_report = _report_for_compare(old_report) == _report_for_compare(report)
|
|
703
|
-
no_change = same_graph and same_report
|
|
704
|
-
if no_change:
|
|
705
|
-
graph_tmp.unlink(missing_ok=True)
|
|
706
|
-
print("[graphify watch] No code-graph changes detected; graph.json/GRAPH_REPORT.md left untouched.")
|
|
707
|
-
else:
|
|
708
|
-
if not _check_shrink(
|
|
709
|
-
force, existing_graph_data, candidate_graph_data,
|
|
710
|
-
tmp=graph_tmp,
|
|
711
|
-
had_explicit_deletions=bool(deleted_paths),
|
|
712
|
-
):
|
|
713
|
-
return False
|
|
714
|
-
from graphify.export import backup_if_protected as _backup
|
|
715
|
-
_backup(out)
|
|
716
|
-
graph_tmp.replace(existing_graph)
|
|
717
|
-
report_path.write_text(report, encoding="utf-8")
|
|
718
|
-
labels_file.write_text(labels_json, encoding="utf-8")
|
|
719
|
-
|
|
720
|
-
try:
|
|
721
|
-
from graphify.detect import save_manifest
|
|
722
|
-
save_manifest(detected["files"], kind="ast", root=project_root)
|
|
723
|
-
except Exception:
|
|
724
|
-
pass
|
|
725
|
-
|
|
726
|
-
# to_html raises ValueError for graphs > MAX_NODES_FOR_VIZ (5000).
|
|
727
|
-
# Wrap so core outputs (graph.json + GRAPH_REPORT.md) always land.
|
|
728
|
-
html_written = False
|
|
729
|
-
if not no_change:
|
|
730
|
-
try:
|
|
731
|
-
to_html(G, communities, str(out / "graph.html"), community_labels=labels or None)
|
|
732
|
-
html_written = True
|
|
733
|
-
except ValueError as viz_err:
|
|
734
|
-
print(f"[graphify watch] Skipped graph.html: {viz_err}")
|
|
735
|
-
stale = out / "graph.html"
|
|
736
|
-
if stale.exists():
|
|
737
|
-
stale.unlink()
|
|
738
|
-
|
|
739
|
-
# Regenerate callflow HTML if the user previously generated one —
|
|
740
|
-
# opt-in by existence so users who never ran callflow-html aren't affected.
|
|
741
|
-
callflow_files = list(out.glob("*-callflow.html"))
|
|
742
|
-
if callflow_files and not no_change:
|
|
743
|
-
try:
|
|
744
|
-
from graphify.callflow_html import write_callflow_html
|
|
745
|
-
for cf in callflow_files:
|
|
746
|
-
write_callflow_html(
|
|
747
|
-
graph=out / "graph.json",
|
|
748
|
-
report=out / "GRAPH_REPORT.md",
|
|
749
|
-
labels=out / ".graphify_labels.json",
|
|
750
|
-
output=cf,
|
|
751
|
-
verbose=False,
|
|
752
|
-
)
|
|
753
|
-
except Exception as cf_err:
|
|
754
|
-
print(f"[graphify watch] callflow HTML update skipped: {cf_err}")
|
|
755
|
-
|
|
756
|
-
# clear stale needs_update flag if present
|
|
757
|
-
flag = out / "needs_update"
|
|
758
|
-
if flag.exists():
|
|
759
|
-
flag.unlink()
|
|
760
|
-
|
|
761
|
-
if not no_change:
|
|
762
|
-
print(f"[graphify watch] Rebuilt: {G.number_of_nodes()} nodes, "
|
|
763
|
-
f"{G.number_of_edges()} edges, {len(communities)} communities")
|
|
764
|
-
products = "graph.json" + (", graph.html" if html_written else "") + " and GRAPH_REPORT.md"
|
|
765
|
-
if callflow_files:
|
|
766
|
-
products += f", {len(callflow_files)} callflow HTML"
|
|
767
|
-
print(f"[graphify watch] {products} updated in {out}")
|
|
768
|
-
return True
|
|
769
|
-
|
|
770
|
-
except Exception as exc:
|
|
771
|
-
print(f"[graphify watch] Rebuild failed: {exc}")
|
|
772
|
-
return False
|
|
773
|
-
|
|
774
|
-
|
|
775
|
-
def check_update(watch_path: Path) -> bool:
|
|
776
|
-
"""Check for pending semantic update flag and notify the user if set.
|
|
777
|
-
|
|
778
|
-
Cron-safe: always returns True so cron jobs do not alarm.
|
|
779
|
-
Non-code file changes (docs, papers, images) require LLM-backed
|
|
780
|
-
re-extraction via `/graphify --update` — this function only signals
|
|
781
|
-
that the update is needed.
|
|
782
|
-
"""
|
|
783
|
-
flag = Path(watch_path) / _GRAPHIFY_OUT / "needs_update"
|
|
784
|
-
if flag.exists():
|
|
785
|
-
print(f"[graphify check-update] Pending non-code changes in {watch_path}.")
|
|
786
|
-
print("[graphify check-update] Run `/graphify --update` to apply semantic re-extraction.")
|
|
787
|
-
return True
|
|
788
|
-
|
|
789
|
-
|
|
790
|
-
def _notify_only(watch_path: Path) -> None:
|
|
791
|
-
"""Write a flag file and print a notification (fallback for non-code-only corpora)."""
|
|
792
|
-
flag = watch_path / _GRAPHIFY_OUT / "needs_update"
|
|
793
|
-
flag.parent.mkdir(parents=True, exist_ok=True)
|
|
794
|
-
flag.write_text("1", encoding="utf-8")
|
|
795
|
-
print(f"\n[graphify watch] New or changed files detected in {watch_path}")
|
|
796
|
-
print("[graphify watch] Non-code files changed - semantic re-extraction requires LLM.")
|
|
797
|
-
print("[graphify watch] Run `/graphify --update` in Claude Code to update the graph.")
|
|
798
|
-
print(f"[graphify watch] Flag written to {flag}")
|
|
799
|
-
|
|
800
|
-
|
|
801
|
-
def _has_non_code(changed_paths: list[Path]) -> bool:
|
|
802
|
-
return any(p.suffix.lower() not in _CODE_EXTENSIONS for p in changed_paths)
|
|
803
|
-
|
|
804
|
-
|
|
805
|
-
def watch(watch_path: Path, debounce: float = 3.0) -> None:
|
|
806
|
-
"""
|
|
807
|
-
Watch watch_path for new or modified files and auto-update the graph.
|
|
808
|
-
|
|
809
|
-
For code-only changes: re-runs AST extraction + rebuild immediately (no LLM).
|
|
810
|
-
For doc/paper/image changes: writes a needs_update flag and notifies the user
|
|
811
|
-
to run /graphify --update (LLM extraction required).
|
|
812
|
-
|
|
813
|
-
debounce: seconds to wait after the last change before triggering (avoids
|
|
814
|
-
running on every keystroke when many files are saved at once).
|
|
815
|
-
"""
|
|
816
|
-
try:
|
|
817
|
-
from watchdog.observers import Observer
|
|
818
|
-
from watchdog.observers.polling import PollingObserver
|
|
819
|
-
from watchdog.events import FileSystemEventHandler
|
|
820
|
-
except ImportError as e:
|
|
821
|
-
raise ImportError("watchdog not installed. Run: pip install watchdog") from e
|
|
822
|
-
|
|
823
|
-
last_trigger: float = 0.0
|
|
824
|
-
pending: bool = False
|
|
825
|
-
changed: set[Path] = set()
|
|
826
|
-
|
|
827
|
-
# Load .graphifyignore patterns ONCE at startup so the handler does not
|
|
828
|
-
# re-parse the file on every filesystem event. Watchdog's handler runs on
|
|
829
|
-
# the observer thread and is invoked for every event the OS delivers
|
|
830
|
-
# (Time Machine writes, Docker/Colima VM I/O, Spotlight indexing, …) —
|
|
831
|
-
# without this short-circuit a busy volume can saturate a CPU core
|
|
832
|
-
# discarding events one extension at a time. (gh-928)
|
|
833
|
-
watch_root_for_ignore = watch_path.resolve()
|
|
834
|
-
ignore_patterns = _load_graphifyignore(watch_root_for_ignore)
|
|
835
|
-
|
|
836
|
-
class Handler(FileSystemEventHandler):
|
|
837
|
-
def on_any_event(self, event):
|
|
838
|
-
nonlocal last_trigger, pending
|
|
839
|
-
if event.is_directory:
|
|
840
|
-
return
|
|
841
|
-
path = Path(event.src_path)
|
|
842
|
-
# Check .graphifyignore BEFORE the extension/dotfile/out filters so
|
|
843
|
-
# the cheapest short-circuit for users with broad ignore patterns
|
|
844
|
-
# (node_modules/, .venv/, build/, …) fires first. _is_ignored
|
|
845
|
-
# tolerates absolute paths outside watch_root via its internal
|
|
846
|
-
# relative_to guard, so a stray symlinked event won't raise.
|
|
847
|
-
if ignore_patterns and _is_ignored(path, watch_root_for_ignore, ignore_patterns):
|
|
848
|
-
return
|
|
849
|
-
if path.suffix.lower() not in _WATCHED_EXTENSIONS:
|
|
850
|
-
return
|
|
851
|
-
if any(part.startswith(".") for part in path.parts):
|
|
852
|
-
return
|
|
853
|
-
if _GRAPHIFY_OUT in path.parts:
|
|
854
|
-
return
|
|
855
|
-
last_trigger = time.monotonic()
|
|
856
|
-
pending = True
|
|
857
|
-
changed.add(path)
|
|
858
|
-
|
|
859
|
-
handler = Handler()
|
|
860
|
-
# Use polling observer on macOS — FSEvents can miss rapid saves in some editors
|
|
861
|
-
observer = PollingObserver() if sys.platform == "darwin" else Observer()
|
|
862
|
-
observer.schedule(handler, str(watch_path), recursive=True)
|
|
863
|
-
observer.start()
|
|
864
|
-
|
|
865
|
-
print(f"[graphify watch] Watching {watch_path.resolve()} - press Ctrl+C to stop")
|
|
866
|
-
print(f"[graphify watch] Code changes rebuild graph automatically. "
|
|
867
|
-
f"Doc/image changes require /graphify --update.")
|
|
868
|
-
print(f"[graphify watch] Debounce: {debounce}s")
|
|
869
|
-
|
|
870
|
-
try:
|
|
871
|
-
while True:
|
|
872
|
-
time.sleep(0.5)
|
|
873
|
-
if pending and (time.monotonic() - last_trigger) >= debounce:
|
|
874
|
-
pending = False
|
|
875
|
-
batch = list(changed)
|
|
876
|
-
changed.clear()
|
|
877
|
-
print(f"\n[graphify watch] {len(batch)} file(s) changed")
|
|
878
|
-
has_non_code = _has_non_code(batch)
|
|
879
|
-
has_code = any(p.suffix.lower() in _CODE_EXTENSIONS for p in batch)
|
|
880
|
-
if has_code:
|
|
881
|
-
_rebuild_code(watch_path)
|
|
882
|
-
if has_non_code:
|
|
883
|
-
_notify_only(watch_path)
|
|
884
|
-
except KeyboardInterrupt:
|
|
885
|
-
print("\n[graphify watch] Stopped.")
|
|
886
|
-
finally:
|
|
887
|
-
observer.stop()
|
|
888
|
-
observer.join()
|
|
889
|
-
|
|
890
|
-
|
|
891
|
-
if __name__ == "__main__":
|
|
892
|
-
import argparse
|
|
893
|
-
parser = argparse.ArgumentParser(description="Watch a folder and auto-update the graphify graph")
|
|
894
|
-
parser.add_argument("path", nargs="?", default=".", help="Folder to watch (default: .)")
|
|
895
|
-
parser.add_argument("--debounce", type=float, default=3.0,
|
|
896
|
-
help="Seconds to wait after last change before updating (default: 3)")
|
|
897
|
-
args = parser.parse_args()
|
|
898
|
-
watch(Path(args.path), debounce=args.debounce)
|