@hivehub/rulebook 5.1.2 → 5.1.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (406) hide show
  1. package/.claude/commands/continue.md +33 -33
  2. package/.claude/commands/ralph-config.md +112 -112
  3. package/.claude/commands/ralph-history.md +110 -110
  4. package/.claude/commands/ralph-init.md +72 -72
  5. package/.claude/commands/ralph-pause-resume.md +105 -105
  6. package/.claude/commands/ralph-run.md +101 -101
  7. package/.claude/commands/ralph-status.md +76 -76
  8. package/.claude/commands/rulebook-decision-create.md +55 -55
  9. package/.claude/commands/rulebook-decision-list.md +15 -15
  10. package/.claude/commands/rulebook-knowledge-add.md +41 -41
  11. package/.claude/commands/rulebook-knowledge-list.md +15 -15
  12. package/.claude/commands/rulebook-learn-capture.md +48 -48
  13. package/.claude/commands/rulebook-learn-list.md +13 -13
  14. package/.claude/commands/rulebook-memory-save.md +48 -48
  15. package/.claude/commands/rulebook-memory-search.md +47 -47
  16. package/.claude/commands/rulebook-task-apply.md +67 -67
  17. package/.claude/commands/rulebook-task-archive.md +94 -94
  18. package/.claude/commands/rulebook-task-create.md +93 -93
  19. package/.claude/commands/rulebook-task-list.md +42 -42
  20. package/.claude/commands/rulebook-task-show.md +52 -52
  21. package/.claude/commands/rulebook-task-validate.md +53 -53
  22. package/.claude-plugin/marketplace.json +28 -28
  23. package/.claude-plugin/plugin.json +8 -8
  24. package/README.md +4 -0
  25. package/dist/cli/commands.d.ts.map +1 -1
  26. package/dist/cli/commands.js +39 -8
  27. package/dist/cli/commands.js.map +1 -1
  28. package/dist/core/agent-template-engine.d.ts.map +1 -1
  29. package/dist/core/agent-template-engine.js +36 -30
  30. package/dist/core/agent-template-engine.js.map +1 -1
  31. package/dist/core/complexity-detector.d.ts.map +1 -1
  32. package/dist/core/complexity-detector.js +109 -29
  33. package/dist/core/complexity-detector.js.map +1 -1
  34. package/dist/core/decision-manager.d.ts.map +1 -1
  35. package/dist/core/decision-manager.js +2 -7
  36. package/dist/core/decision-manager.js.map +1 -1
  37. package/dist/core/generator.d.ts.map +1 -1
  38. package/dist/core/generator.js +28 -28
  39. package/dist/core/generator.js.map +1 -1
  40. package/dist/core/indexer/background-indexer.d.ts +1 -0
  41. package/dist/core/indexer/background-indexer.d.ts.map +1 -1
  42. package/dist/core/indexer/background-indexer.js +107 -19
  43. package/dist/core/indexer/background-indexer.js.map +1 -1
  44. package/dist/core/indexer/indexer-types.d.ts +2 -0
  45. package/dist/core/indexer/indexer-types.d.ts.map +1 -1
  46. package/dist/core/knowledge-manager.d.ts.map +1 -1
  47. package/dist/core/knowledge-manager.js +1 -1
  48. package/dist/core/knowledge-manager.js.map +1 -1
  49. package/dist/core/learn-manager.d.ts.map +1 -1
  50. package/dist/core/learn-manager.js +1 -1
  51. package/dist/core/learn-manager.js.map +1 -1
  52. package/dist/core/rule-engine.d.ts.map +1 -1
  53. package/dist/core/rule-engine.js +1 -3
  54. package/dist/core/rule-engine.js.map +1 -1
  55. package/dist/core/task-manager.d.ts.map +1 -1
  56. package/dist/core/task-manager.js +24 -24
  57. package/dist/core/task-manager.js.map +1 -1
  58. package/dist/index.js +23 -7
  59. package/dist/index.js.map +1 -1
  60. package/dist/mcp/rulebook-server.d.ts.map +1 -1
  61. package/dist/mcp/rulebook-server.js +18 -6
  62. package/dist/mcp/rulebook-server.js.map +1 -1
  63. package/dist/memory/hnsw-index.d.ts.map +1 -1
  64. package/dist/memory/hnsw-index.js +12 -4
  65. package/dist/memory/hnsw-index.js.map +1 -1
  66. package/dist/memory/memory-store.d.ts.map +1 -1
  67. package/dist/memory/memory-store.js +136 -107
  68. package/dist/memory/memory-store.js.map +1 -1
  69. package/dist/types.d.ts +7 -0
  70. package/dist/types.d.ts.map +1 -1
  71. package/package.json +22 -21
  72. package/templates/agents/accessibility-reviewer.md +43 -43
  73. package/templates/agents/api-designer.md +42 -42
  74. package/templates/agents/architect.md +51 -51
  75. package/templates/agents/build-engineer.md +36 -36
  76. package/templates/agents/code-reviewer.md +47 -47
  77. package/templates/agents/compiler/codegen-debugger.md +34 -34
  78. package/templates/agents/compiler/stdlib-engineer.md +28 -28
  79. package/templates/agents/compiler/test-coverage-guardian.md +31 -31
  80. package/templates/agents/context-intelligence.md +52 -52
  81. package/templates/agents/database-architect.md +41 -41
  82. package/templates/agents/devops-engineer.md +42 -42
  83. package/templates/agents/docs-writer.md +38 -38
  84. package/templates/agents/game-engine/cpp-core-expert.md +35 -35
  85. package/templates/agents/game-engine/render-engineer.md +22 -22
  86. package/templates/agents/game-engine/shader-engineer.md +38 -38
  87. package/templates/agents/game-engine/systems-integration.md +43 -43
  88. package/templates/agents/generic/code-reviewer.md +41 -41
  89. package/templates/agents/generic/docs-writer.md +25 -25
  90. package/templates/agents/generic/project-manager.md +36 -36
  91. package/templates/agents/generic/researcher.md +34 -34
  92. package/templates/agents/generic/test-engineer.md +41 -41
  93. package/templates/agents/i18n-engineer.md +42 -42
  94. package/templates/agents/implementer.md +42 -42
  95. package/templates/agents/migration-engineer.md +42 -42
  96. package/templates/agents/mobile/platform-specialist.md +22 -22
  97. package/templates/agents/mobile/ui-engineer.md +22 -22
  98. package/templates/agents/performance-engineer.md +49 -49
  99. package/templates/agents/refactoring-agent.md +41 -41
  100. package/templates/agents/researcher.md +38 -38
  101. package/templates/agents/security-reviewer.md +40 -40
  102. package/templates/agents/team-lead.md +37 -37
  103. package/templates/agents/tester.md +48 -48
  104. package/templates/agents/ux-reviewer.md +43 -43
  105. package/templates/agents/web-app/api-designer.md +22 -22
  106. package/templates/agents/web-app/backend-engineer.md +30 -30
  107. package/templates/agents/web-app/database-engineer.md +22 -22
  108. package/templates/agents/web-app/frontend-engineer.md +29 -29
  109. package/templates/agents/web-app/security-reviewer.md +32 -32
  110. package/templates/ci/rulebook-review.yml +26 -26
  111. package/templates/cli/AIDER.md +49 -49
  112. package/templates/cli/AMAZON_Q.md +25 -25
  113. package/templates/cli/AUGGIE.md +32 -32
  114. package/templates/cli/CLAUDE.md +117 -117
  115. package/templates/cli/CLINE.md +99 -99
  116. package/templates/cli/CODEBUDDY.md +20 -20
  117. package/templates/cli/CODEIUM.md +20 -20
  118. package/templates/cli/CODEX.md +21 -21
  119. package/templates/cli/CONTINUE.md +34 -34
  120. package/templates/cli/CURSOR_CLI.md +62 -62
  121. package/templates/cli/FACTORY.md +18 -18
  122. package/templates/cli/GEMINI.md +35 -35
  123. package/templates/cli/KILOCODE.md +18 -18
  124. package/templates/cli/OPENCODE.md +18 -18
  125. package/templates/cli/_GENERIC_TEMPLATE.md +29 -29
  126. package/templates/commands/rulebook-decision-create.md +55 -55
  127. package/templates/commands/rulebook-decision-list.md +15 -15
  128. package/templates/commands/rulebook-knowledge-add.md +41 -41
  129. package/templates/commands/rulebook-knowledge-list.md +15 -15
  130. package/templates/commands/rulebook-learn-capture.md +48 -48
  131. package/templates/commands/rulebook-learn-list.md +13 -13
  132. package/templates/commands/rulebook-memory-save.md +48 -48
  133. package/templates/commands/rulebook-memory-search.md +47 -47
  134. package/templates/commands/rulebook-task-apply.md +67 -67
  135. package/templates/commands/rulebook-task-archive.md +94 -94
  136. package/templates/commands/rulebook-task-create.md +93 -93
  137. package/templates/commands/rulebook-task-list.md +42 -42
  138. package/templates/commands/rulebook-task-show.md +52 -52
  139. package/templates/commands/rulebook-task-validate.md +53 -53
  140. package/templates/core/AGENTS_LEAN.md +25 -25
  141. package/templates/core/AGENTS_OVERRIDE.md +16 -16
  142. package/templates/core/AGENT_AUTOMATION.md +296 -296
  143. package/templates/core/DAG.md +304 -304
  144. package/templates/core/DECISIONS.md +38 -38
  145. package/templates/core/DOCUMENTATION_RULES.md +36 -36
  146. package/templates/core/KNOWLEDGE.md +49 -49
  147. package/templates/core/MULTI_AGENT.md +74 -74
  148. package/templates/core/PLANS.md +28 -28
  149. package/templates/core/QUALITY_ENFORCEMENT.md +68 -68
  150. package/templates/core/RALPH.md +471 -471
  151. package/templates/core/RULEBOOK.md +1947 -1947
  152. package/templates/core/TIER1_PROHIBITIONS.md +154 -154
  153. package/templates/core/TOKEN_OPTIMIZATION.md +49 -49
  154. package/templates/frameworks/ANGULAR.md +36 -36
  155. package/templates/frameworks/DJANGO.md +83 -83
  156. package/templates/frameworks/ELECTRON.md +147 -147
  157. package/templates/frameworks/FLASK.md +38 -38
  158. package/templates/frameworks/FLUTTER.md +55 -55
  159. package/templates/frameworks/JQUERY.md +32 -32
  160. package/templates/frameworks/LARAVEL.md +38 -38
  161. package/templates/frameworks/NESTJS.md +43 -43
  162. package/templates/frameworks/NEXTJS.md +127 -127
  163. package/templates/frameworks/NUXT.md +40 -40
  164. package/templates/frameworks/RAILS.md +66 -66
  165. package/templates/frameworks/REACT.md +38 -38
  166. package/templates/frameworks/REACT_NATIVE.md +47 -47
  167. package/templates/frameworks/SPRING.md +39 -39
  168. package/templates/frameworks/SYMFONY.md +36 -36
  169. package/templates/frameworks/VUE.md +36 -36
  170. package/templates/frameworks/ZEND.md +35 -35
  171. package/templates/git/CI_CD_PATTERNS.md +661 -661
  172. package/templates/git/GITHUB_ACTIONS.md +728 -728
  173. package/templates/git/GITLAB_CI.md +730 -730
  174. package/templates/git/GIT_WORKFLOW.md +1192 -1192
  175. package/templates/git/SECRETS_MANAGEMENT.md +585 -585
  176. package/templates/hooks/COMMIT_MSG.md +530 -530
  177. package/templates/hooks/POST_CHECKOUT.md +546 -546
  178. package/templates/hooks/PREPARE_COMMIT_MSG.md +619 -619
  179. package/templates/hooks/PRE_COMMIT.md +414 -414
  180. package/templates/hooks/PRE_PUSH.md +601 -601
  181. package/templates/ides/CONTINUE_RULES.md +16 -16
  182. package/templates/ides/COPILOT.md +37 -37
  183. package/templates/ides/COPILOT_INSTRUCTIONS.md +23 -23
  184. package/templates/ides/CURSOR.md +43 -43
  185. package/templates/ides/GEMINI_RULES.md +17 -17
  186. package/templates/ides/JETBRAINS_AI.md +35 -35
  187. package/templates/ides/REPLIT.md +36 -36
  188. package/templates/ides/TABNINE.md +29 -29
  189. package/templates/ides/VSCODE.md +40 -40
  190. package/templates/ides/WINDSURF.md +36 -36
  191. package/templates/ides/WINDSURF_RULES.md +14 -14
  192. package/templates/ides/ZED.md +32 -32
  193. package/templates/ides/cursor-mdc/go.mdc +24 -24
  194. package/templates/ides/cursor-mdc/python.mdc +24 -24
  195. package/templates/ides/cursor-mdc/quality.mdc +25 -25
  196. package/templates/ides/cursor-mdc/ralph.mdc +39 -39
  197. package/templates/ides/cursor-mdc/rulebook.mdc +38 -38
  198. package/templates/ides/cursor-mdc/rust.mdc +24 -24
  199. package/templates/ides/cursor-mdc/typescript.mdc +25 -25
  200. package/templates/languages/C.md +333 -333
  201. package/templates/languages/CPP.md +743 -743
  202. package/templates/languages/CSHARP.md +417 -417
  203. package/templates/languages/ELIXIR.md +454 -454
  204. package/templates/languages/ERLANG.md +361 -361
  205. package/templates/languages/GO.md +645 -645
  206. package/templates/languages/HASKELL.md +177 -177
  207. package/templates/languages/JAVA.md +607 -607
  208. package/templates/languages/JAVASCRIPT.md +631 -631
  209. package/templates/languages/JULIA.md +97 -97
  210. package/templates/languages/KOTLIN.md +511 -511
  211. package/templates/languages/LISP.md +100 -100
  212. package/templates/languages/LUA.md +74 -74
  213. package/templates/languages/OBJECTIVEC.md +90 -90
  214. package/templates/languages/PHP.md +416 -416
  215. package/templates/languages/PYTHON.md +682 -682
  216. package/templates/languages/RUBY.md +421 -421
  217. package/templates/languages/RUST.md +477 -477
  218. package/templates/languages/SAS.md +73 -73
  219. package/templates/languages/SCALA.md +348 -348
  220. package/templates/languages/SOLIDITY.md +580 -580
  221. package/templates/languages/SQL.md +137 -137
  222. package/templates/languages/SWIFT.md +466 -466
  223. package/templates/languages/TYPESCRIPT.md +591 -591
  224. package/templates/languages/ZIG.md +265 -265
  225. package/templates/modules/ATLASSIAN.md +255 -255
  226. package/templates/modules/CONTEXT7.md +54 -54
  227. package/templates/modules/FIGMA.md +267 -267
  228. package/templates/modules/GITHUB_MCP.md +64 -64
  229. package/templates/modules/GRAFANA.md +328 -328
  230. package/templates/modules/MEMORY.md +126 -126
  231. package/templates/modules/NOTION.md +247 -247
  232. package/templates/modules/PLAYWRIGHT.md +90 -90
  233. package/templates/modules/RULEBOOK_MCP.md +156 -156
  234. package/templates/modules/SERENA.md +337 -337
  235. package/templates/modules/SUPABASE.md +223 -223
  236. package/templates/modules/SYNAP.md +69 -69
  237. package/templates/modules/VECTORIZER.md +63 -63
  238. package/templates/modules/sequential-thinking.md +42 -42
  239. package/templates/ralph/ralph-history.bat +4 -4
  240. package/templates/ralph/ralph-history.sh +5 -5
  241. package/templates/ralph/ralph-init.bat +5 -5
  242. package/templates/ralph/ralph-init.sh +5 -5
  243. package/templates/ralph/ralph-pause.bat +5 -5
  244. package/templates/ralph/ralph-pause.sh +5 -5
  245. package/templates/ralph/ralph-run.bat +5 -5
  246. package/templates/ralph/ralph-run.sh +5 -5
  247. package/templates/ralph/ralph-status.bat +4 -4
  248. package/templates/ralph/ralph-status.sh +5 -5
  249. package/templates/rules/follow-task-sequence.md +36 -36
  250. package/templates/rules/git-safety.md +29 -29
  251. package/templates/rules/incremental-tests.md +29 -29
  252. package/templates/rules/no-deferred.md +31 -31
  253. package/templates/rules/no-shortcuts.md +30 -30
  254. package/templates/rules/research-first.md +30 -30
  255. package/templates/rules/sequential-editing.md +21 -21
  256. package/templates/rules/session-workflow.md +24 -24
  257. package/templates/rules/task-decomposition.md +32 -32
  258. package/templates/services/AZURE_BLOB.md +184 -184
  259. package/templates/services/CASSANDRA.md +239 -239
  260. package/templates/services/DATADOG.md +26 -26
  261. package/templates/services/DOCKER.md +124 -124
  262. package/templates/services/DOCKER_COMPOSE.md +168 -168
  263. package/templates/services/DYNAMODB.md +308 -308
  264. package/templates/services/ELASTICSEARCH.md +347 -347
  265. package/templates/services/GCS.md +178 -178
  266. package/templates/services/HELM.md +194 -194
  267. package/templates/services/INFLUXDB.md +265 -265
  268. package/templates/services/KAFKA.md +341 -341
  269. package/templates/services/KUBERNETES.md +208 -208
  270. package/templates/services/MARIADB.md +183 -183
  271. package/templates/services/MEMCACHED.md +242 -242
  272. package/templates/services/MINIO.md +201 -201
  273. package/templates/services/MONGODB.md +268 -268
  274. package/templates/services/MYSQL.md +358 -358
  275. package/templates/services/NEO4J.md +247 -247
  276. package/templates/services/OPENTELEMETRY.md +25 -25
  277. package/templates/services/ORACLE.md +290 -290
  278. package/templates/services/PINO.md +24 -24
  279. package/templates/services/POSTGRESQL.md +326 -326
  280. package/templates/services/PROMETHEUS.md +33 -33
  281. package/templates/services/RABBITMQ.md +286 -286
  282. package/templates/services/REDIS.md +292 -292
  283. package/templates/services/S3.md +298 -298
  284. package/templates/services/SENTRY.md +23 -23
  285. package/templates/services/SQLITE.md +294 -294
  286. package/templates/services/SQLSERVER.md +294 -294
  287. package/templates/services/WINSTON.md +30 -30
  288. package/templates/skills/cli/aider/SKILL.md +59 -59
  289. package/templates/skills/cli/amazon-q/SKILL.md +35 -35
  290. package/templates/skills/cli/auggie/SKILL.md +42 -42
  291. package/templates/skills/cli/claude/SKILL.md +42 -42
  292. package/templates/skills/cli/cline/SKILL.md +42 -42
  293. package/templates/skills/cli/codebuddy/SKILL.md +30 -30
  294. package/templates/skills/cli/codeium/SKILL.md +30 -30
  295. package/templates/skills/cli/codex/SKILL.md +31 -31
  296. package/templates/skills/cli/continue/SKILL.md +44 -44
  297. package/templates/skills/cli/cursor-cli/SKILL.md +38 -38
  298. package/templates/skills/cli/factory/SKILL.md +28 -28
  299. package/templates/skills/cli/gemini/SKILL.md +45 -45
  300. package/templates/skills/cli/kilocode/SKILL.md +28 -28
  301. package/templates/skills/cli/opencode/SKILL.md +28 -28
  302. package/templates/skills/core/agent-automation/SKILL.md +194 -194
  303. package/templates/skills/core/dag/SKILL.md +314 -314
  304. package/templates/skills/core/documentation-rules/SKILL.md +46 -46
  305. package/templates/skills/core/quality-enforcement/SKILL.md +78 -78
  306. package/templates/skills/core/rulebook/SKILL.md +176 -176
  307. package/templates/skills/dev/accessibility/SKILL.md +17 -17
  308. package/templates/skills/dev/api-design/SKILL.md +15 -15
  309. package/templates/skills/dev/architect/SKILL.md +17 -17
  310. package/templates/skills/dev/build-fix/SKILL.md +17 -17
  311. package/templates/skills/dev/db-design/SKILL.md +15 -15
  312. package/templates/skills/dev/debug/SKILL.md +16 -16
  313. package/templates/skills/dev/deploy/SKILL.md +17 -17
  314. package/templates/skills/dev/docs/SKILL.md +17 -17
  315. package/templates/skills/dev/migrate/SKILL.md +15 -15
  316. package/templates/skills/dev/perf/SKILL.md +17 -17
  317. package/templates/skills/dev/refactor/SKILL.md +17 -17
  318. package/templates/skills/dev/research/SKILL.md +14 -14
  319. package/templates/skills/dev/review/SKILL.md +18 -18
  320. package/templates/skills/dev/security-audit/SKILL.md +17 -17
  321. package/templates/skills/frameworks/angular/SKILL.md +46 -46
  322. package/templates/skills/frameworks/django/SKILL.md +93 -93
  323. package/templates/skills/frameworks/electron/SKILL.md +157 -157
  324. package/templates/skills/frameworks/flask/SKILL.md +48 -48
  325. package/templates/skills/frameworks/flutter/SKILL.md +65 -65
  326. package/templates/skills/frameworks/jquery/SKILL.md +42 -42
  327. package/templates/skills/frameworks/laravel/SKILL.md +48 -48
  328. package/templates/skills/frameworks/nestjs/SKILL.md +53 -53
  329. package/templates/skills/frameworks/nextjs/SKILL.md +137 -137
  330. package/templates/skills/frameworks/nuxt/SKILL.md +50 -50
  331. package/templates/skills/frameworks/rails/SKILL.md +76 -76
  332. package/templates/skills/frameworks/react/SKILL.md +48 -48
  333. package/templates/skills/frameworks/react-native/SKILL.md +57 -57
  334. package/templates/skills/frameworks/spring/SKILL.md +49 -49
  335. package/templates/skills/frameworks/symfony/SKILL.md +46 -46
  336. package/templates/skills/frameworks/vue/SKILL.md +46 -46
  337. package/templates/skills/frameworks/zend/SKILL.md +45 -45
  338. package/templates/skills/ides/copilot/SKILL.md +47 -47
  339. package/templates/skills/ides/cursor/SKILL.md +53 -53
  340. package/templates/skills/ides/jetbrains-ai/SKILL.md +45 -45
  341. package/templates/skills/ides/replit/SKILL.md +46 -46
  342. package/templates/skills/ides/tabnine/SKILL.md +39 -39
  343. package/templates/skills/ides/vscode/SKILL.md +50 -50
  344. package/templates/skills/ides/windsurf/SKILL.md +46 -46
  345. package/templates/skills/ides/zed/SKILL.md +42 -42
  346. package/templates/skills/languages/c/SKILL.md +343 -343
  347. package/templates/skills/languages/cpp/SKILL.md +753 -753
  348. package/templates/skills/languages/csharp/SKILL.md +427 -427
  349. package/templates/skills/languages/elixir/SKILL.md +464 -464
  350. package/templates/skills/languages/erlang/SKILL.md +371 -371
  351. package/templates/skills/languages/go/SKILL.md +655 -655
  352. package/templates/skills/languages/haskell/SKILL.md +187 -187
  353. package/templates/skills/languages/java/SKILL.md +617 -617
  354. package/templates/skills/languages/javascript/SKILL.md +641 -641
  355. package/templates/skills/languages/julia/SKILL.md +107 -107
  356. package/templates/skills/languages/kotlin/SKILL.md +521 -521
  357. package/templates/skills/languages/lisp/SKILL.md +110 -110
  358. package/templates/skills/languages/lua/SKILL.md +84 -84
  359. package/templates/skills/languages/objectivec/SKILL.md +100 -100
  360. package/templates/skills/languages/php/SKILL.md +426 -426
  361. package/templates/skills/languages/python/SKILL.md +692 -692
  362. package/templates/skills/languages/ruby/SKILL.md +431 -431
  363. package/templates/skills/languages/rust/SKILL.md +487 -487
  364. package/templates/skills/languages/sas/SKILL.md +83 -83
  365. package/templates/skills/languages/scala/SKILL.md +358 -358
  366. package/templates/skills/languages/solidity/SKILL.md +590 -590
  367. package/templates/skills/languages/sql/SKILL.md +147 -147
  368. package/templates/skills/languages/swift/SKILL.md +476 -476
  369. package/templates/skills/languages/typescript/SKILL.md +302 -302
  370. package/templates/skills/languages/zig/SKILL.md +275 -275
  371. package/templates/skills/modules/atlassian/SKILL.md +265 -265
  372. package/templates/skills/modules/context7/SKILL.md +64 -64
  373. package/templates/skills/modules/figma/SKILL.md +277 -277
  374. package/templates/skills/modules/github-mcp/SKILL.md +74 -74
  375. package/templates/skills/modules/grafana/SKILL.md +338 -338
  376. package/templates/skills/modules/memory/SKILL.md +73 -73
  377. package/templates/skills/modules/notion/SKILL.md +257 -257
  378. package/templates/skills/modules/playwright/SKILL.md +100 -100
  379. package/templates/skills/modules/rulebook-mcp/SKILL.md +166 -166
  380. package/templates/skills/modules/serena/SKILL.md +347 -347
  381. package/templates/skills/modules/supabase/SKILL.md +233 -233
  382. package/templates/skills/modules/synap/SKILL.md +79 -79
  383. package/templates/skills/modules/vectorizer/SKILL.md +73 -73
  384. package/templates/skills/services/azure-blob/SKILL.md +194 -194
  385. package/templates/skills/services/cassandra/SKILL.md +249 -249
  386. package/templates/skills/services/dynamodb/SKILL.md +318 -318
  387. package/templates/skills/services/elasticsearch/SKILL.md +357 -357
  388. package/templates/skills/services/gcs/SKILL.md +188 -188
  389. package/templates/skills/services/influxdb/SKILL.md +275 -275
  390. package/templates/skills/services/kafka/SKILL.md +351 -351
  391. package/templates/skills/services/mariadb/SKILL.md +193 -193
  392. package/templates/skills/services/memcached/SKILL.md +252 -252
  393. package/templates/skills/services/minio/SKILL.md +211 -211
  394. package/templates/skills/services/mongodb/SKILL.md +278 -278
  395. package/templates/skills/services/mysql/SKILL.md +368 -368
  396. package/templates/skills/services/neo4j/SKILL.md +257 -257
  397. package/templates/skills/services/oracle/SKILL.md +300 -300
  398. package/templates/skills/services/postgresql/SKILL.md +336 -336
  399. package/templates/skills/services/rabbitmq/SKILL.md +296 -296
  400. package/templates/skills/services/redis/SKILL.md +302 -302
  401. package/templates/skills/services/s3/SKILL.md +308 -308
  402. package/templates/skills/services/sqlite/SKILL.md +304 -304
  403. package/templates/skills/services/sqlserver/SKILL.md +304 -304
  404. package/templates/skills/workflows/ralph/SKILL.md +309 -309
  405. package/templates/skills/workflows/ralph/install.sh +87 -87
  406. package/templates/skills/workflows/ralph/manifest.json +158 -158
@@ -1,421 +1,421 @@
1
- <!-- RUBY:START -->
2
- # Ruby Project Rules
3
-
4
- ## Agent Automation Commands
5
-
6
- **CRITICAL**: Execute these commands after EVERY implementation (see AGENT_AUTOMATION module for full workflow).
7
-
8
- ```bash
9
- # Complete quality check sequence:
10
- bundle exec rubocop # Linting and formatting
11
- bundle exec rspec # All tests (100% pass)
12
- bundle exec rspec --format documentation # Test coverage
13
-
14
- # Security audit:
15
- bundle audit # Vulnerability scan
16
- bundle outdated # Check outdated deps
17
- ```
18
-
19
- ## Ruby Configuration
20
-
21
- **CRITICAL**: Use Ruby 3.2+ with RuboCop and modern tooling.
22
-
23
- - **Version**: Ruby 3.2+
24
- - **Recommended**: Ruby 3.3+
25
- - **Style Guide**: Ruby Style Guide (RuboCop)
26
- - **Testing**: RSpec (recommended) or Minitest
27
- - **Type Checking**: RBS + Steep (optional but recommended)
28
-
29
- ### Gemfile Requirements
30
-
31
- ```ruby
32
- source 'https://rubygems.org'
33
-
34
- ruby '>= 3.2.0'
35
-
36
- # Production dependencies
37
- gem 'rake', '~> 13.0'
38
-
39
- # Development dependencies
40
- group :development do
41
- gem 'rubocop', '~> 1.60', require: false
42
- gem 'rubocop-performance', require: false
43
- gem 'rubocop-rspec', require: false
44
- end
45
-
46
- # Test dependencies
47
- group :test do
48
- gem 'rspec', '~> 3.12'
49
- gem 'simplecov', require: false
50
- gem 'simplecov-lcov', require: false
51
- end
52
-
53
- # Both development and test
54
- group :development, :test do
55
- gem 'pry'
56
- gem 'pry-byebug'
57
- end
58
- ```
59
-
60
- ### Gemspec Requirements (for gems)
61
-
62
- ```ruby
63
- Gem::Specification.new do |spec|
64
- spec.name = 'your_gem'
65
- spec.version = '0.1.0'
66
- spec.authors = ['Your Name']
67
- spec.email = ['you@example.com']
68
-
69
- spec.summary = 'Brief summary'
70
- spec.description = 'Longer description'
71
- spec.homepage = 'https://github.com/you/your_gem'
72
- spec.license = 'MIT'
73
- spec.required_ruby_version = '>= 3.2.0'
74
-
75
- spec.files = Dir.glob('{lib,bin}/**/*') + %w[README.md LICENSE.txt]
76
- spec.bindir = 'exe'
77
- spec.executables = spec.files.grep(%r{^exe/}) { |f| File.basename(f) }
78
- spec.require_paths = ['lib']
79
-
80
- spec.add_dependency 'rake', '~> 13.0'
81
-
82
- spec.add_development_dependency 'rspec', '~> 3.12'
83
- spec.add_development_dependency 'rubocop', '~> 1.60'
84
- end
85
- ```
86
-
87
- ## Code Quality Standards
88
-
89
- ### Mandatory Quality Checks
90
-
91
- **CRITICAL**: After implementing ANY feature, you MUST run these commands in order.
92
-
93
- **IMPORTANT**: These commands MUST match your GitHub Actions workflows to prevent CI/CD failures!
94
-
95
- ```bash
96
- # Pre-Commit Checklist (MUST match .github/workflows/*.yml)
97
-
98
- # 1. Lint (MUST pass with no warnings - matches workflow)
99
- bundle exec rubocop
100
-
101
- # 2. Run all tests (MUST pass 100% - matches workflow)
102
- bundle exec rspec
103
- # or: bundle exec rake test (for Minitest)
104
-
105
- # 3. Check coverage (MUST meet threshold - matches workflow)
106
- COVERAGE=true bundle exec rspec
107
-
108
- # 4. Security audit (matches workflow)
109
- bundle exec bundler-audit check --update
110
-
111
- # 5. Build gem (if gem project - matches workflow)
112
- gem build *.gemspec
113
-
114
- # If ANY fails: ❌ DO NOT COMMIT - Fix first!
115
- ```
116
-
117
- **If ANY of these fail, you MUST fix the issues before committing.**
118
-
119
- **Why This Matters:**
120
- - Running different commands locally than in CI causes "works on my machine" failures
121
- - CI/CD workflows will fail if commands don't match
122
- - Example: Using `rubocop -a` (auto-correct) locally but `rubocop` in CI = failure
123
- - Example: Missing security audit locally = CI catches vulnerabilities in dependencies
124
-
125
- ### Linting with RuboCop
126
-
127
- - Configuration in `.rubocop.yml`
128
- - Must pass with no offenses
129
- - Auto-correct safe offenses only
130
-
131
- Example `.rubocop.yml`:
132
- ```yaml
133
- require:
134
- - rubocop-performance
135
- - rubocop-rspec
136
-
137
- AllCops:
138
- TargetRubyVersion: 3.2
139
- NewCops: enable
140
- Exclude:
141
- - 'vendor/**/*'
142
- - 'tmp/**/*'
143
- - 'bin/**/*'
144
-
145
- Style/StringLiterals:
146
- EnforcedStyle: single_quotes
147
-
148
- Metrics/MethodLength:
149
- Max: 15
150
- Exclude:
151
- - 'spec/**/*'
152
-
153
- Metrics/BlockLength:
154
- Exclude:
155
- - 'spec/**/*'
156
- - '*.gemspec'
157
- ```
158
-
159
- ### Testing
160
-
161
- - **Framework**: RSpec (recommended) or Minitest
162
- - **Location**: `/spec` (RSpec) or `/test` (Minitest)
163
- - **Coverage**: SimpleCov (80%+ threshold)
164
- - **Focus**: Write descriptive specs
165
-
166
- Example RSpec test:
167
- ```ruby
168
- # spec/my_class_spec.rb
169
-
170
- RSpec.describe MyClass do
171
- let(:instance) { described_class.new(value: 'test') }
172
-
173
- describe '#process' do
174
- context 'with valid input' do
175
- it 'returns processed value' do
176
- result = instance.process('input')
177
- expect(result).to eq('PROCESSED: input')
178
- end
179
-
180
- it 'handles empty strings' do
181
- expect(instance.process('')).to be_nil
182
- end
183
- end
184
-
185
- context 'with invalid input' do
186
- it 'raises ArgumentError' do
187
- expect { instance.process(nil) }.to raise_error(ArgumentError)
188
- end
189
- end
190
- end
191
-
192
- describe '#validate' do
193
- it 'returns true for valid data' do
194
- expect(instance.validate('valid')).to be true
195
- end
196
-
197
- it 'returns false for invalid data' do
198
- expect(instance.validate('')).to be false
199
- end
200
- end
201
- end
202
- ```
203
-
204
- Example Minitest:
205
- ```ruby
206
- # test/my_class_test.rb
207
-
208
- require 'test_helper'
209
-
210
- class MyClassTest < Minitest::Test
211
- def setup
212
- @instance = MyClass.new(value: 'test')
213
- end
214
-
215
- def test_process_returns_expected_value
216
- result = @instance.process('input')
217
- assert_equal 'PROCESSED: input', result
218
- end
219
-
220
- def test_process_handles_empty_strings
221
- assert_nil @instance.process('')
222
- end
223
-
224
- def test_process_raises_on_nil
225
- assert_raises(ArgumentError) { @instance.process(nil) }
226
- end
227
- end
228
- ```
229
-
230
- ### Coverage Configuration
231
-
232
- Create `spec/spec_helper.rb`:
233
- ```ruby
234
- if ENV['COVERAGE']
235
- require 'simplecov'
236
- require 'simplecov-lcov'
237
-
238
- SimpleCov::Formatter::LcovFormatter.config.report_with_single_file = true
239
- SimpleCov.formatter = SimpleCov::Formatter::MultiFormatter.new([
240
- SimpleCov::Formatter::HTMLFormatter,
241
- SimpleCov::Formatter::LcovFormatter
242
- ])
243
-
244
- SimpleCov.start do
245
- add_filter '/spec/'
246
- add_filter '/test/'
247
-
248
- minimum_coverage 80
249
- minimum_coverage_by_file 70
250
- end
251
- end
252
-
253
- require 'your_gem'
254
-
255
- RSpec.configure do |config|
256
- config.expect_with :rspec do |expectations|
257
- expectations.include_chain_clauses_in_custom_matcher_descriptions = true
258
- end
259
-
260
- config.mock_with :rspec do |mocks|
261
- mocks.verify_partial_doubles = true
262
- end
263
-
264
- config.shared_context_metadata_behavior = :apply_to_host_groups
265
- config.filter_run_when_matching :focus
266
- config.example_status_persistence_file_path = 'spec/examples.txt'
267
- config.disable_monkey_patching!
268
- config.warnings = true
269
-
270
- config.default_formatter = 'doc' if config.files_to_run.one?
271
- config.profile_examples = 10
272
- config.order = :random
273
- Kernel.srand config.seed
274
- end
275
- ```
276
-
277
- ## Dependency Management
278
-
279
- ### Using Bundler
280
-
281
- ```bash
282
- # Install dependencies
283
- bundle install
284
-
285
- # Update dependencies
286
- bundle update
287
-
288
- # Check for outdated gems
289
- bundle outdated
290
-
291
- # Security audit
292
- bundle exec bundler-audit check --update
293
- ```
294
-
295
- ### Gemfile.lock
296
-
297
- - **MUST** commit Gemfile.lock for applications
298
- - For gems: Add to `.gitignore`
299
- - Ensures reproducible builds
300
-
301
- ## Best Practices
302
-
303
- ### DO's ✅
304
-
305
- - **USE** meaningful variable and method names
306
- - **FOLLOW** Ruby naming conventions (snake_case)
307
- - **WRITE** descriptive tests with context blocks
308
- - **HANDLE** exceptions explicitly
309
- - **VALIDATE** inputs
310
- - **DOCUMENT** public APIs
311
- - **USE** symbols for hash keys when possible
312
- - **FREEZE** string literals in Ruby 3+
313
-
314
- ### DON'Ts ❌
315
-
316
- - **NEVER** use global variables
317
- - **NEVER** monkey-patch core classes without extreme caution
318
- - **NEVER** skip tests
319
- - **NEVER** commit `.byebug_history` or debug files
320
- - **NEVER** use `eval` unless absolutely necessary
321
- - **NEVER** ignore RuboCop offenses without justification
322
- - **NEVER** commit with failing tests
323
-
324
- Example code style:
325
- ```ruby
326
- # ✅ GOOD: Clean Ruby code
327
- class DataProcessor
328
- def initialize(options = {})
329
- @threshold = options.fetch(:threshold, 0.5)
330
- @verbose = options.fetch(:verbose, false)
331
- end
332
-
333
- def process(data)
334
- validate_input!(data)
335
-
336
- log('Processing data...') if @verbose
337
-
338
- data.select { |item| item[:value] > @threshold }
339
- end
340
-
341
- private
342
-
343
- def validate_input!(data)
344
- raise ArgumentError, 'Data must be an array' unless data.is_a?(Array)
345
- raise ArgumentError, 'Data cannot be empty' if data.empty?
346
- end
347
-
348
- def log(message)
349
- puts "[#{Time.now.iso8601}] #{message}"
350
- end
351
- end
352
-
353
- # ❌ BAD: Poor practices
354
- class DataProcessor
355
- def process(data)
356
- $threshold = 0.5 # DON'T use globals!
357
-
358
- if data == nil # Use nil? method
359
- return false
360
- end
361
-
362
- result = []
363
- for item in data # Use .each or .map
364
- if item[:value] > $threshold
365
- result.push(item)
366
- end
367
- end
368
-
369
- puts result # DON'T print in library code
370
- result
371
- end
372
- end
373
- ```
374
-
375
- ## CI/CD Requirements
376
-
377
- Must include GitHub Actions workflows:
378
-
379
- 1. **Testing** (`ruby-test.yml`):
380
- - Test on ubuntu-latest, windows-latest, macos-latest
381
- - Ruby versions: 3.2, 3.3
382
- - Upload coverage to Codecov
383
-
384
- 2. **Linting** (`ruby-lint.yml`):
385
- - RuboCop checks
386
- - Bundler audit for security
387
-
388
- 3. **Build** (`ruby-build.yml`):
389
- - Build gem
390
- - Verify gem structure
391
-
392
- ## Publishing to RubyGems
393
-
394
- ### Prerequisites
395
-
396
- 1. Create account at https://rubygems.org
397
- 2. Get API key: `gem signin`
398
- 3. Add `RUBYGEMS_API_KEY` to GitHub secrets
399
-
400
- ### Publishing Workflow
401
-
402
- ```bash
403
- # 1. Update version in gemspec or version.rb
404
- # 2. Update CHANGELOG.md
405
- # 3. Run all quality checks
406
- bundle exec rubocop
407
- bundle exec rspec
408
- gem build *.gemspec
409
-
410
- # 4. Create git tag
411
- git tag -a v1.0.0 -m "Release version 1.0.0"
412
-
413
- # 5. Push (manual if SSH password)
414
- # git push origin main
415
- # git push origin v1.0.0
416
-
417
- # 6. Publish to RubyGems (or use GitHub Actions)
418
- gem push your_gem-1.0.0.gem
419
- ```
420
-
421
- <!-- RUBY:END -->
1
+ <!-- RUBY:START -->
2
+ # Ruby Project Rules
3
+
4
+ ## Agent Automation Commands
5
+
6
+ **CRITICAL**: Execute these commands after EVERY implementation (see AGENT_AUTOMATION module for full workflow).
7
+
8
+ ```bash
9
+ # Complete quality check sequence:
10
+ bundle exec rubocop # Linting and formatting
11
+ bundle exec rspec # All tests (100% pass)
12
+ bundle exec rspec --format documentation # Test coverage
13
+
14
+ # Security audit:
15
+ bundle audit # Vulnerability scan
16
+ bundle outdated # Check outdated deps
17
+ ```
18
+
19
+ ## Ruby Configuration
20
+
21
+ **CRITICAL**: Use Ruby 3.2+ with RuboCop and modern tooling.
22
+
23
+ - **Version**: Ruby 3.2+
24
+ - **Recommended**: Ruby 3.3+
25
+ - **Style Guide**: Ruby Style Guide (RuboCop)
26
+ - **Testing**: RSpec (recommended) or Minitest
27
+ - **Type Checking**: RBS + Steep (optional but recommended)
28
+
29
+ ### Gemfile Requirements
30
+
31
+ ```ruby
32
+ source 'https://rubygems.org'
33
+
34
+ ruby '>= 3.2.0'
35
+
36
+ # Production dependencies
37
+ gem 'rake', '~> 13.0'
38
+
39
+ # Development dependencies
40
+ group :development do
41
+ gem 'rubocop', '~> 1.60', require: false
42
+ gem 'rubocop-performance', require: false
43
+ gem 'rubocop-rspec', require: false
44
+ end
45
+
46
+ # Test dependencies
47
+ group :test do
48
+ gem 'rspec', '~> 3.12'
49
+ gem 'simplecov', require: false
50
+ gem 'simplecov-lcov', require: false
51
+ end
52
+
53
+ # Both development and test
54
+ group :development, :test do
55
+ gem 'pry'
56
+ gem 'pry-byebug'
57
+ end
58
+ ```
59
+
60
+ ### Gemspec Requirements (for gems)
61
+
62
+ ```ruby
63
+ Gem::Specification.new do |spec|
64
+ spec.name = 'your_gem'
65
+ spec.version = '0.1.0'
66
+ spec.authors = ['Your Name']
67
+ spec.email = ['you@example.com']
68
+
69
+ spec.summary = 'Brief summary'
70
+ spec.description = 'Longer description'
71
+ spec.homepage = 'https://github.com/you/your_gem'
72
+ spec.license = 'MIT'
73
+ spec.required_ruby_version = '>= 3.2.0'
74
+
75
+ spec.files = Dir.glob('{lib,bin}/**/*') + %w[README.md LICENSE.txt]
76
+ spec.bindir = 'exe'
77
+ spec.executables = spec.files.grep(%r{^exe/}) { |f| File.basename(f) }
78
+ spec.require_paths = ['lib']
79
+
80
+ spec.add_dependency 'rake', '~> 13.0'
81
+
82
+ spec.add_development_dependency 'rspec', '~> 3.12'
83
+ spec.add_development_dependency 'rubocop', '~> 1.60'
84
+ end
85
+ ```
86
+
87
+ ## Code Quality Standards
88
+
89
+ ### Mandatory Quality Checks
90
+
91
+ **CRITICAL**: After implementing ANY feature, you MUST run these commands in order.
92
+
93
+ **IMPORTANT**: These commands MUST match your GitHub Actions workflows to prevent CI/CD failures!
94
+
95
+ ```bash
96
+ # Pre-Commit Checklist (MUST match .github/workflows/*.yml)
97
+
98
+ # 1. Lint (MUST pass with no warnings - matches workflow)
99
+ bundle exec rubocop
100
+
101
+ # 2. Run all tests (MUST pass 100% - matches workflow)
102
+ bundle exec rspec
103
+ # or: bundle exec rake test (for Minitest)
104
+
105
+ # 3. Check coverage (MUST meet threshold - matches workflow)
106
+ COVERAGE=true bundle exec rspec
107
+
108
+ # 4. Security audit (matches workflow)
109
+ bundle exec bundler-audit check --update
110
+
111
+ # 5. Build gem (if gem project - matches workflow)
112
+ gem build *.gemspec
113
+
114
+ # If ANY fails: ❌ DO NOT COMMIT - Fix first!
115
+ ```
116
+
117
+ **If ANY of these fail, you MUST fix the issues before committing.**
118
+
119
+ **Why This Matters:**
120
+ - Running different commands locally than in CI causes "works on my machine" failures
121
+ - CI/CD workflows will fail if commands don't match
122
+ - Example: Using `rubocop -a` (auto-correct) locally but `rubocop` in CI = failure
123
+ - Example: Missing security audit locally = CI catches vulnerabilities in dependencies
124
+
125
+ ### Linting with RuboCop
126
+
127
+ - Configuration in `.rubocop.yml`
128
+ - Must pass with no offenses
129
+ - Auto-correct safe offenses only
130
+
131
+ Example `.rubocop.yml`:
132
+ ```yaml
133
+ require:
134
+ - rubocop-performance
135
+ - rubocop-rspec
136
+
137
+ AllCops:
138
+ TargetRubyVersion: 3.2
139
+ NewCops: enable
140
+ Exclude:
141
+ - 'vendor/**/*'
142
+ - 'tmp/**/*'
143
+ - 'bin/**/*'
144
+
145
+ Style/StringLiterals:
146
+ EnforcedStyle: single_quotes
147
+
148
+ Metrics/MethodLength:
149
+ Max: 15
150
+ Exclude:
151
+ - 'spec/**/*'
152
+
153
+ Metrics/BlockLength:
154
+ Exclude:
155
+ - 'spec/**/*'
156
+ - '*.gemspec'
157
+ ```
158
+
159
+ ### Testing
160
+
161
+ - **Framework**: RSpec (recommended) or Minitest
162
+ - **Location**: `/spec` (RSpec) or `/test` (Minitest)
163
+ - **Coverage**: SimpleCov (80%+ threshold)
164
+ - **Focus**: Write descriptive specs
165
+
166
+ Example RSpec test:
167
+ ```ruby
168
+ # spec/my_class_spec.rb
169
+
170
+ RSpec.describe MyClass do
171
+ let(:instance) { described_class.new(value: 'test') }
172
+
173
+ describe '#process' do
174
+ context 'with valid input' do
175
+ it 'returns processed value' do
176
+ result = instance.process('input')
177
+ expect(result).to eq('PROCESSED: input')
178
+ end
179
+
180
+ it 'handles empty strings' do
181
+ expect(instance.process('')).to be_nil
182
+ end
183
+ end
184
+
185
+ context 'with invalid input' do
186
+ it 'raises ArgumentError' do
187
+ expect { instance.process(nil) }.to raise_error(ArgumentError)
188
+ end
189
+ end
190
+ end
191
+
192
+ describe '#validate' do
193
+ it 'returns true for valid data' do
194
+ expect(instance.validate('valid')).to be true
195
+ end
196
+
197
+ it 'returns false for invalid data' do
198
+ expect(instance.validate('')).to be false
199
+ end
200
+ end
201
+ end
202
+ ```
203
+
204
+ Example Minitest:
205
+ ```ruby
206
+ # test/my_class_test.rb
207
+
208
+ require 'test_helper'
209
+
210
+ class MyClassTest < Minitest::Test
211
+ def setup
212
+ @instance = MyClass.new(value: 'test')
213
+ end
214
+
215
+ def test_process_returns_expected_value
216
+ result = @instance.process('input')
217
+ assert_equal 'PROCESSED: input', result
218
+ end
219
+
220
+ def test_process_handles_empty_strings
221
+ assert_nil @instance.process('')
222
+ end
223
+
224
+ def test_process_raises_on_nil
225
+ assert_raises(ArgumentError) { @instance.process(nil) }
226
+ end
227
+ end
228
+ ```
229
+
230
+ ### Coverage Configuration
231
+
232
+ Create `spec/spec_helper.rb`:
233
+ ```ruby
234
+ if ENV['COVERAGE']
235
+ require 'simplecov'
236
+ require 'simplecov-lcov'
237
+
238
+ SimpleCov::Formatter::LcovFormatter.config.report_with_single_file = true
239
+ SimpleCov.formatter = SimpleCov::Formatter::MultiFormatter.new([
240
+ SimpleCov::Formatter::HTMLFormatter,
241
+ SimpleCov::Formatter::LcovFormatter
242
+ ])
243
+
244
+ SimpleCov.start do
245
+ add_filter '/spec/'
246
+ add_filter '/test/'
247
+
248
+ minimum_coverage 80
249
+ minimum_coverage_by_file 70
250
+ end
251
+ end
252
+
253
+ require 'your_gem'
254
+
255
+ RSpec.configure do |config|
256
+ config.expect_with :rspec do |expectations|
257
+ expectations.include_chain_clauses_in_custom_matcher_descriptions = true
258
+ end
259
+
260
+ config.mock_with :rspec do |mocks|
261
+ mocks.verify_partial_doubles = true
262
+ end
263
+
264
+ config.shared_context_metadata_behavior = :apply_to_host_groups
265
+ config.filter_run_when_matching :focus
266
+ config.example_status_persistence_file_path = 'spec/examples.txt'
267
+ config.disable_monkey_patching!
268
+ config.warnings = true
269
+
270
+ config.default_formatter = 'doc' if config.files_to_run.one?
271
+ config.profile_examples = 10
272
+ config.order = :random
273
+ Kernel.srand config.seed
274
+ end
275
+ ```
276
+
277
+ ## Dependency Management
278
+
279
+ ### Using Bundler
280
+
281
+ ```bash
282
+ # Install dependencies
283
+ bundle install
284
+
285
+ # Update dependencies
286
+ bundle update
287
+
288
+ # Check for outdated gems
289
+ bundle outdated
290
+
291
+ # Security audit
292
+ bundle exec bundler-audit check --update
293
+ ```
294
+
295
+ ### Gemfile.lock
296
+
297
+ - **MUST** commit Gemfile.lock for applications
298
+ - For gems: Add to `.gitignore`
299
+ - Ensures reproducible builds
300
+
301
+ ## Best Practices
302
+
303
+ ### DO's ✅
304
+
305
+ - **USE** meaningful variable and method names
306
+ - **FOLLOW** Ruby naming conventions (snake_case)
307
+ - **WRITE** descriptive tests with context blocks
308
+ - **HANDLE** exceptions explicitly
309
+ - **VALIDATE** inputs
310
+ - **DOCUMENT** public APIs
311
+ - **USE** symbols for hash keys when possible
312
+ - **FREEZE** string literals in Ruby 3+
313
+
314
+ ### DON'Ts ❌
315
+
316
+ - **NEVER** use global variables
317
+ - **NEVER** monkey-patch core classes without extreme caution
318
+ - **NEVER** skip tests
319
+ - **NEVER** commit `.byebug_history` or debug files
320
+ - **NEVER** use `eval` unless absolutely necessary
321
+ - **NEVER** ignore RuboCop offenses without justification
322
+ - **NEVER** commit with failing tests
323
+
324
+ Example code style:
325
+ ```ruby
326
+ # ✅ GOOD: Clean Ruby code
327
+ class DataProcessor
328
+ def initialize(options = {})
329
+ @threshold = options.fetch(:threshold, 0.5)
330
+ @verbose = options.fetch(:verbose, false)
331
+ end
332
+
333
+ def process(data)
334
+ validate_input!(data)
335
+
336
+ log('Processing data...') if @verbose
337
+
338
+ data.select { |item| item[:value] > @threshold }
339
+ end
340
+
341
+ private
342
+
343
+ def validate_input!(data)
344
+ raise ArgumentError, 'Data must be an array' unless data.is_a?(Array)
345
+ raise ArgumentError, 'Data cannot be empty' if data.empty?
346
+ end
347
+
348
+ def log(message)
349
+ puts "[#{Time.now.iso8601}] #{message}"
350
+ end
351
+ end
352
+
353
+ # ❌ BAD: Poor practices
354
+ class DataProcessor
355
+ def process(data)
356
+ $threshold = 0.5 # DON'T use globals!
357
+
358
+ if data == nil # Use nil? method
359
+ return false
360
+ end
361
+
362
+ result = []
363
+ for item in data # Use .each or .map
364
+ if item[:value] > $threshold
365
+ result.push(item)
366
+ end
367
+ end
368
+
369
+ puts result # DON'T print in library code
370
+ result
371
+ end
372
+ end
373
+ ```
374
+
375
+ ## CI/CD Requirements
376
+
377
+ Must include GitHub Actions workflows:
378
+
379
+ 1. **Testing** (`ruby-test.yml`):
380
+ - Test on ubuntu-latest, windows-latest, macos-latest
381
+ - Ruby versions: 3.2, 3.3
382
+ - Upload coverage to Codecov
383
+
384
+ 2. **Linting** (`ruby-lint.yml`):
385
+ - RuboCop checks
386
+ - Bundler audit for security
387
+
388
+ 3. **Build** (`ruby-build.yml`):
389
+ - Build gem
390
+ - Verify gem structure
391
+
392
+ ## Publishing to RubyGems
393
+
394
+ ### Prerequisites
395
+
396
+ 1. Create account at https://rubygems.org
397
+ 2. Get API key: `gem signin`
398
+ 3. Add `RUBYGEMS_API_KEY` to GitHub secrets
399
+
400
+ ### Publishing Workflow
401
+
402
+ ```bash
403
+ # 1. Update version in gemspec or version.rb
404
+ # 2. Update CHANGELOG.md
405
+ # 3. Run all quality checks
406
+ bundle exec rubocop
407
+ bundle exec rspec
408
+ gem build *.gemspec
409
+
410
+ # 4. Create git tag
411
+ git tag -a v1.0.0 -m "Release version 1.0.0"
412
+
413
+ # 5. Push (manual if SSH password)
414
+ # git push origin main
415
+ # git push origin v1.0.0
416
+
417
+ # 6. Publish to RubyGems (or use GitHub Actions)
418
+ gem push your_gem-1.0.0.gem
419
+ ```
420
+
421
+ <!-- RUBY:END -->