@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,431 +1,431 @@
1
- ---
2
- name: "Ruby"
3
- description: "Execute these commands after EVERY implementation (see AGENT_AUTOMATION module for full workflow)."
4
- version: "1.0.0"
5
- category: "languages"
6
- author: "Rulebook"
7
- tags: ["languages", "language"]
8
- dependencies: []
9
- conflicts: []
10
- ---
11
- <!-- RUBY:START -->
12
- # Ruby Project Rules
13
-
14
- ## Agent Automation Commands
15
-
16
- **CRITICAL**: Execute these commands after EVERY implementation (see AGENT_AUTOMATION module for full workflow).
17
-
18
- ```bash
19
- # Complete quality check sequence:
20
- bundle exec rubocop # Linting and formatting
21
- bundle exec rspec # All tests (100% pass)
22
- bundle exec rspec --format documentation # Test coverage
23
-
24
- # Security audit:
25
- bundle audit # Vulnerability scan
26
- bundle outdated # Check outdated deps
27
- ```
28
-
29
- ## Ruby Configuration
30
-
31
- **CRITICAL**: Use Ruby 3.2+ with RuboCop and modern tooling.
32
-
33
- - **Version**: Ruby 3.2+
34
- - **Recommended**: Ruby 3.3+
35
- - **Style Guide**: Ruby Style Guide (RuboCop)
36
- - **Testing**: RSpec (recommended) or Minitest
37
- - **Type Checking**: RBS + Steep (optional but recommended)
38
-
39
- ### Gemfile Requirements
40
-
41
- ```ruby
42
- source 'https://rubygems.org'
43
-
44
- ruby '>= 3.2.0'
45
-
46
- # Production dependencies
47
- gem 'rake', '~> 13.0'
48
-
49
- # Development dependencies
50
- group :development do
51
- gem 'rubocop', '~> 1.60', require: false
52
- gem 'rubocop-performance', require: false
53
- gem 'rubocop-rspec', require: false
54
- end
55
-
56
- # Test dependencies
57
- group :test do
58
- gem 'rspec', '~> 3.12'
59
- gem 'simplecov', require: false
60
- gem 'simplecov-lcov', require: false
61
- end
62
-
63
- # Both development and test
64
- group :development, :test do
65
- gem 'pry'
66
- gem 'pry-byebug'
67
- end
68
- ```
69
-
70
- ### Gemspec Requirements (for gems)
71
-
72
- ```ruby
73
- Gem::Specification.new do |spec|
74
- spec.name = 'your_gem'
75
- spec.version = '0.1.0'
76
- spec.authors = ['Your Name']
77
- spec.email = ['you@example.com']
78
-
79
- spec.summary = 'Brief summary'
80
- spec.description = 'Longer description'
81
- spec.homepage = 'https://github.com/you/your_gem'
82
- spec.license = 'MIT'
83
- spec.required_ruby_version = '>= 3.2.0'
84
-
85
- spec.files = Dir.glob('{lib,bin}/**/*') + %w[README.md LICENSE.txt]
86
- spec.bindir = 'exe'
87
- spec.executables = spec.files.grep(%r{^exe/}) { |f| File.basename(f) }
88
- spec.require_paths = ['lib']
89
-
90
- spec.add_dependency 'rake', '~> 13.0'
91
-
92
- spec.add_development_dependency 'rspec', '~> 3.12'
93
- spec.add_development_dependency 'rubocop', '~> 1.60'
94
- end
95
- ```
96
-
97
- ## Code Quality Standards
98
-
99
- ### Mandatory Quality Checks
100
-
101
- **CRITICAL**: After implementing ANY feature, you MUST run these commands in order.
102
-
103
- **IMPORTANT**: These commands MUST match your GitHub Actions workflows to prevent CI/CD failures!
104
-
105
- ```bash
106
- # Pre-Commit Checklist (MUST match .github/workflows/*.yml)
107
-
108
- # 1. Lint (MUST pass with no warnings - matches workflow)
109
- bundle exec rubocop
110
-
111
- # 2. Run all tests (MUST pass 100% - matches workflow)
112
- bundle exec rspec
113
- # or: bundle exec rake test (for Minitest)
114
-
115
- # 3. Check coverage (MUST meet threshold - matches workflow)
116
- COVERAGE=true bundle exec rspec
117
-
118
- # 4. Security audit (matches workflow)
119
- bundle exec bundler-audit check --update
120
-
121
- # 5. Build gem (if gem project - matches workflow)
122
- gem build *.gemspec
123
-
124
- # If ANY fails: ❌ DO NOT COMMIT - Fix first!
125
- ```
126
-
127
- **If ANY of these fail, you MUST fix the issues before committing.**
128
-
129
- **Why This Matters:**
130
- - Running different commands locally than in CI causes "works on my machine" failures
131
- - CI/CD workflows will fail if commands don't match
132
- - Example: Using `rubocop -a` (auto-correct) locally but `rubocop` in CI = failure
133
- - Example: Missing security audit locally = CI catches vulnerabilities in dependencies
134
-
135
- ### Linting with RuboCop
136
-
137
- - Configuration in `.rubocop.yml`
138
- - Must pass with no offenses
139
- - Auto-correct safe offenses only
140
-
141
- Example `.rubocop.yml`:
142
- ```yaml
143
- require:
144
- - rubocop-performance
145
- - rubocop-rspec
146
-
147
- AllCops:
148
- TargetRubyVersion: 3.2
149
- NewCops: enable
150
- Exclude:
151
- - 'vendor/**/*'
152
- - 'tmp/**/*'
153
- - 'bin/**/*'
154
-
155
- Style/StringLiterals:
156
- EnforcedStyle: single_quotes
157
-
158
- Metrics/MethodLength:
159
- Max: 15
160
- Exclude:
161
- - 'spec/**/*'
162
-
163
- Metrics/BlockLength:
164
- Exclude:
165
- - 'spec/**/*'
166
- - '*.gemspec'
167
- ```
168
-
169
- ### Testing
170
-
171
- - **Framework**: RSpec (recommended) or Minitest
172
- - **Location**: `/spec` (RSpec) or `/test` (Minitest)
173
- - **Coverage**: SimpleCov (80%+ threshold)
174
- - **Focus**: Write descriptive specs
175
-
176
- Example RSpec test:
177
- ```ruby
178
- # spec/my_class_spec.rb
179
-
180
- RSpec.describe MyClass do
181
- let(:instance) { described_class.new(value: 'test') }
182
-
183
- describe '#process' do
184
- context 'with valid input' do
185
- it 'returns processed value' do
186
- result = instance.process('input')
187
- expect(result).to eq('PROCESSED: input')
188
- end
189
-
190
- it 'handles empty strings' do
191
- expect(instance.process('')).to be_nil
192
- end
193
- end
194
-
195
- context 'with invalid input' do
196
- it 'raises ArgumentError' do
197
- expect { instance.process(nil) }.to raise_error(ArgumentError)
198
- end
199
- end
200
- end
201
-
202
- describe '#validate' do
203
- it 'returns true for valid data' do
204
- expect(instance.validate('valid')).to be true
205
- end
206
-
207
- it 'returns false for invalid data' do
208
- expect(instance.validate('')).to be false
209
- end
210
- end
211
- end
212
- ```
213
-
214
- Example Minitest:
215
- ```ruby
216
- # test/my_class_test.rb
217
-
218
- require 'test_helper'
219
-
220
- class MyClassTest < Minitest::Test
221
- def setup
222
- @instance = MyClass.new(value: 'test')
223
- end
224
-
225
- def test_process_returns_expected_value
226
- result = @instance.process('input')
227
- assert_equal 'PROCESSED: input', result
228
- end
229
-
230
- def test_process_handles_empty_strings
231
- assert_nil @instance.process('')
232
- end
233
-
234
- def test_process_raises_on_nil
235
- assert_raises(ArgumentError) { @instance.process(nil) }
236
- end
237
- end
238
- ```
239
-
240
- ### Coverage Configuration
241
-
242
- Create `spec/spec_helper.rb`:
243
- ```ruby
244
- if ENV['COVERAGE']
245
- require 'simplecov'
246
- require 'simplecov-lcov'
247
-
248
- SimpleCov::Formatter::LcovFormatter.config.report_with_single_file = true
249
- SimpleCov.formatter = SimpleCov::Formatter::MultiFormatter.new([
250
- SimpleCov::Formatter::HTMLFormatter,
251
- SimpleCov::Formatter::LcovFormatter
252
- ])
253
-
254
- SimpleCov.start do
255
- add_filter '/spec/'
256
- add_filter '/test/'
257
-
258
- minimum_coverage 80
259
- minimum_coverage_by_file 70
260
- end
261
- end
262
-
263
- require 'your_gem'
264
-
265
- RSpec.configure do |config|
266
- config.expect_with :rspec do |expectations|
267
- expectations.include_chain_clauses_in_custom_matcher_descriptions = true
268
- end
269
-
270
- config.mock_with :rspec do |mocks|
271
- mocks.verify_partial_doubles = true
272
- end
273
-
274
- config.shared_context_metadata_behavior = :apply_to_host_groups
275
- config.filter_run_when_matching :focus
276
- config.example_status_persistence_file_path = 'spec/examples.txt'
277
- config.disable_monkey_patching!
278
- config.warnings = true
279
-
280
- config.default_formatter = 'doc' if config.files_to_run.one?
281
- config.profile_examples = 10
282
- config.order = :random
283
- Kernel.srand config.seed
284
- end
285
- ```
286
-
287
- ## Dependency Management
288
-
289
- ### Using Bundler
290
-
291
- ```bash
292
- # Install dependencies
293
- bundle install
294
-
295
- # Update dependencies
296
- bundle update
297
-
298
- # Check for outdated gems
299
- bundle outdated
300
-
301
- # Security audit
302
- bundle exec bundler-audit check --update
303
- ```
304
-
305
- ### Gemfile.lock
306
-
307
- - **MUST** commit Gemfile.lock for applications
308
- - For gems: Add to `.gitignore`
309
- - Ensures reproducible builds
310
-
311
- ## Best Practices
312
-
313
- ### DO's ✅
314
-
315
- - **USE** meaningful variable and method names
316
- - **FOLLOW** Ruby naming conventions (snake_case)
317
- - **WRITE** descriptive tests with context blocks
318
- - **HANDLE** exceptions explicitly
319
- - **VALIDATE** inputs
320
- - **DOCUMENT** public APIs
321
- - **USE** symbols for hash keys when possible
322
- - **FREEZE** string literals in Ruby 3+
323
-
324
- ### DON'Ts ❌
325
-
326
- - **NEVER** use global variables
327
- - **NEVER** monkey-patch core classes without extreme caution
328
- - **NEVER** skip tests
329
- - **NEVER** commit `.byebug_history` or debug files
330
- - **NEVER** use `eval` unless absolutely necessary
331
- - **NEVER** ignore RuboCop offenses without justification
332
- - **NEVER** commit with failing tests
333
-
334
- Example code style:
335
- ```ruby
336
- # ✅ GOOD: Clean Ruby code
337
- class DataProcessor
338
- def initialize(options = {})
339
- @threshold = options.fetch(:threshold, 0.5)
340
- @verbose = options.fetch(:verbose, false)
341
- end
342
-
343
- def process(data)
344
- validate_input!(data)
345
-
346
- log('Processing data...') if @verbose
347
-
348
- data.select { |item| item[:value] > @threshold }
349
- end
350
-
351
- private
352
-
353
- def validate_input!(data)
354
- raise ArgumentError, 'Data must be an array' unless data.is_a?(Array)
355
- raise ArgumentError, 'Data cannot be empty' if data.empty?
356
- end
357
-
358
- def log(message)
359
- puts "[#{Time.now.iso8601}] #{message}"
360
- end
361
- end
362
-
363
- # ❌ BAD: Poor practices
364
- class DataProcessor
365
- def process(data)
366
- $threshold = 0.5 # DON'T use globals!
367
-
368
- if data == nil # Use nil? method
369
- return false
370
- end
371
-
372
- result = []
373
- for item in data # Use .each or .map
374
- if item[:value] > $threshold
375
- result.push(item)
376
- end
377
- end
378
-
379
- puts result # DON'T print in library code
380
- result
381
- end
382
- end
383
- ```
384
-
385
- ## CI/CD Requirements
386
-
387
- Must include GitHub Actions workflows:
388
-
389
- 1. **Testing** (`ruby-test.yml`):
390
- - Test on ubuntu-latest, windows-latest, macos-latest
391
- - Ruby versions: 3.2, 3.3
392
- - Upload coverage to Codecov
393
-
394
- 2. **Linting** (`ruby-lint.yml`):
395
- - RuboCop checks
396
- - Bundler audit for security
397
-
398
- 3. **Build** (`ruby-build.yml`):
399
- - Build gem
400
- - Verify gem structure
401
-
402
- ## Publishing to RubyGems
403
-
404
- ### Prerequisites
405
-
406
- 1. Create account at https://rubygems.org
407
- 2. Get API key: `gem signin`
408
- 3. Add `RUBYGEMS_API_KEY` to GitHub secrets
409
-
410
- ### Publishing Workflow
411
-
412
- ```bash
413
- # 1. Update version in gemspec or version.rb
414
- # 2. Update CHANGELOG.md
415
- # 3. Run all quality checks
416
- bundle exec rubocop
417
- bundle exec rspec
418
- gem build *.gemspec
419
-
420
- # 4. Create git tag
421
- git tag -a v1.0.0 -m "Release version 1.0.0"
422
-
423
- # 5. Push (manual if SSH password)
424
- # git push origin main
425
- # git push origin v1.0.0
426
-
427
- # 6. Publish to RubyGems (or use GitHub Actions)
428
- gem push your_gem-1.0.0.gem
429
- ```
430
-
431
- <!-- RUBY:END -->
1
+ ---
2
+ name: "Ruby"
3
+ description: "Execute these commands after EVERY implementation (see AGENT_AUTOMATION module for full workflow)."
4
+ version: "1.0.0"
5
+ category: "languages"
6
+ author: "Rulebook"
7
+ tags: ["languages", "language"]
8
+ dependencies: []
9
+ conflicts: []
10
+ ---
11
+ <!-- RUBY:START -->
12
+ # Ruby Project Rules
13
+
14
+ ## Agent Automation Commands
15
+
16
+ **CRITICAL**: Execute these commands after EVERY implementation (see AGENT_AUTOMATION module for full workflow).
17
+
18
+ ```bash
19
+ # Complete quality check sequence:
20
+ bundle exec rubocop # Linting and formatting
21
+ bundle exec rspec # All tests (100% pass)
22
+ bundle exec rspec --format documentation # Test coverage
23
+
24
+ # Security audit:
25
+ bundle audit # Vulnerability scan
26
+ bundle outdated # Check outdated deps
27
+ ```
28
+
29
+ ## Ruby Configuration
30
+
31
+ **CRITICAL**: Use Ruby 3.2+ with RuboCop and modern tooling.
32
+
33
+ - **Version**: Ruby 3.2+
34
+ - **Recommended**: Ruby 3.3+
35
+ - **Style Guide**: Ruby Style Guide (RuboCop)
36
+ - **Testing**: RSpec (recommended) or Minitest
37
+ - **Type Checking**: RBS + Steep (optional but recommended)
38
+
39
+ ### Gemfile Requirements
40
+
41
+ ```ruby
42
+ source 'https://rubygems.org'
43
+
44
+ ruby '>= 3.2.0'
45
+
46
+ # Production dependencies
47
+ gem 'rake', '~> 13.0'
48
+
49
+ # Development dependencies
50
+ group :development do
51
+ gem 'rubocop', '~> 1.60', require: false
52
+ gem 'rubocop-performance', require: false
53
+ gem 'rubocop-rspec', require: false
54
+ end
55
+
56
+ # Test dependencies
57
+ group :test do
58
+ gem 'rspec', '~> 3.12'
59
+ gem 'simplecov', require: false
60
+ gem 'simplecov-lcov', require: false
61
+ end
62
+
63
+ # Both development and test
64
+ group :development, :test do
65
+ gem 'pry'
66
+ gem 'pry-byebug'
67
+ end
68
+ ```
69
+
70
+ ### Gemspec Requirements (for gems)
71
+
72
+ ```ruby
73
+ Gem::Specification.new do |spec|
74
+ spec.name = 'your_gem'
75
+ spec.version = '0.1.0'
76
+ spec.authors = ['Your Name']
77
+ spec.email = ['you@example.com']
78
+
79
+ spec.summary = 'Brief summary'
80
+ spec.description = 'Longer description'
81
+ spec.homepage = 'https://github.com/you/your_gem'
82
+ spec.license = 'MIT'
83
+ spec.required_ruby_version = '>= 3.2.0'
84
+
85
+ spec.files = Dir.glob('{lib,bin}/**/*') + %w[README.md LICENSE.txt]
86
+ spec.bindir = 'exe'
87
+ spec.executables = spec.files.grep(%r{^exe/}) { |f| File.basename(f) }
88
+ spec.require_paths = ['lib']
89
+
90
+ spec.add_dependency 'rake', '~> 13.0'
91
+
92
+ spec.add_development_dependency 'rspec', '~> 3.12'
93
+ spec.add_development_dependency 'rubocop', '~> 1.60'
94
+ end
95
+ ```
96
+
97
+ ## Code Quality Standards
98
+
99
+ ### Mandatory Quality Checks
100
+
101
+ **CRITICAL**: After implementing ANY feature, you MUST run these commands in order.
102
+
103
+ **IMPORTANT**: These commands MUST match your GitHub Actions workflows to prevent CI/CD failures!
104
+
105
+ ```bash
106
+ # Pre-Commit Checklist (MUST match .github/workflows/*.yml)
107
+
108
+ # 1. Lint (MUST pass with no warnings - matches workflow)
109
+ bundle exec rubocop
110
+
111
+ # 2. Run all tests (MUST pass 100% - matches workflow)
112
+ bundle exec rspec
113
+ # or: bundle exec rake test (for Minitest)
114
+
115
+ # 3. Check coverage (MUST meet threshold - matches workflow)
116
+ COVERAGE=true bundle exec rspec
117
+
118
+ # 4. Security audit (matches workflow)
119
+ bundle exec bundler-audit check --update
120
+
121
+ # 5. Build gem (if gem project - matches workflow)
122
+ gem build *.gemspec
123
+
124
+ # If ANY fails: ❌ DO NOT COMMIT - Fix first!
125
+ ```
126
+
127
+ **If ANY of these fail, you MUST fix the issues before committing.**
128
+
129
+ **Why This Matters:**
130
+ - Running different commands locally than in CI causes "works on my machine" failures
131
+ - CI/CD workflows will fail if commands don't match
132
+ - Example: Using `rubocop -a` (auto-correct) locally but `rubocop` in CI = failure
133
+ - Example: Missing security audit locally = CI catches vulnerabilities in dependencies
134
+
135
+ ### Linting with RuboCop
136
+
137
+ - Configuration in `.rubocop.yml`
138
+ - Must pass with no offenses
139
+ - Auto-correct safe offenses only
140
+
141
+ Example `.rubocop.yml`:
142
+ ```yaml
143
+ require:
144
+ - rubocop-performance
145
+ - rubocop-rspec
146
+
147
+ AllCops:
148
+ TargetRubyVersion: 3.2
149
+ NewCops: enable
150
+ Exclude:
151
+ - 'vendor/**/*'
152
+ - 'tmp/**/*'
153
+ - 'bin/**/*'
154
+
155
+ Style/StringLiterals:
156
+ EnforcedStyle: single_quotes
157
+
158
+ Metrics/MethodLength:
159
+ Max: 15
160
+ Exclude:
161
+ - 'spec/**/*'
162
+
163
+ Metrics/BlockLength:
164
+ Exclude:
165
+ - 'spec/**/*'
166
+ - '*.gemspec'
167
+ ```
168
+
169
+ ### Testing
170
+
171
+ - **Framework**: RSpec (recommended) or Minitest
172
+ - **Location**: `/spec` (RSpec) or `/test` (Minitest)
173
+ - **Coverage**: SimpleCov (80%+ threshold)
174
+ - **Focus**: Write descriptive specs
175
+
176
+ Example RSpec test:
177
+ ```ruby
178
+ # spec/my_class_spec.rb
179
+
180
+ RSpec.describe MyClass do
181
+ let(:instance) { described_class.new(value: 'test') }
182
+
183
+ describe '#process' do
184
+ context 'with valid input' do
185
+ it 'returns processed value' do
186
+ result = instance.process('input')
187
+ expect(result).to eq('PROCESSED: input')
188
+ end
189
+
190
+ it 'handles empty strings' do
191
+ expect(instance.process('')).to be_nil
192
+ end
193
+ end
194
+
195
+ context 'with invalid input' do
196
+ it 'raises ArgumentError' do
197
+ expect { instance.process(nil) }.to raise_error(ArgumentError)
198
+ end
199
+ end
200
+ end
201
+
202
+ describe '#validate' do
203
+ it 'returns true for valid data' do
204
+ expect(instance.validate('valid')).to be true
205
+ end
206
+
207
+ it 'returns false for invalid data' do
208
+ expect(instance.validate('')).to be false
209
+ end
210
+ end
211
+ end
212
+ ```
213
+
214
+ Example Minitest:
215
+ ```ruby
216
+ # test/my_class_test.rb
217
+
218
+ require 'test_helper'
219
+
220
+ class MyClassTest < Minitest::Test
221
+ def setup
222
+ @instance = MyClass.new(value: 'test')
223
+ end
224
+
225
+ def test_process_returns_expected_value
226
+ result = @instance.process('input')
227
+ assert_equal 'PROCESSED: input', result
228
+ end
229
+
230
+ def test_process_handles_empty_strings
231
+ assert_nil @instance.process('')
232
+ end
233
+
234
+ def test_process_raises_on_nil
235
+ assert_raises(ArgumentError) { @instance.process(nil) }
236
+ end
237
+ end
238
+ ```
239
+
240
+ ### Coverage Configuration
241
+
242
+ Create `spec/spec_helper.rb`:
243
+ ```ruby
244
+ if ENV['COVERAGE']
245
+ require 'simplecov'
246
+ require 'simplecov-lcov'
247
+
248
+ SimpleCov::Formatter::LcovFormatter.config.report_with_single_file = true
249
+ SimpleCov.formatter = SimpleCov::Formatter::MultiFormatter.new([
250
+ SimpleCov::Formatter::HTMLFormatter,
251
+ SimpleCov::Formatter::LcovFormatter
252
+ ])
253
+
254
+ SimpleCov.start do
255
+ add_filter '/spec/'
256
+ add_filter '/test/'
257
+
258
+ minimum_coverage 80
259
+ minimum_coverage_by_file 70
260
+ end
261
+ end
262
+
263
+ require 'your_gem'
264
+
265
+ RSpec.configure do |config|
266
+ config.expect_with :rspec do |expectations|
267
+ expectations.include_chain_clauses_in_custom_matcher_descriptions = true
268
+ end
269
+
270
+ config.mock_with :rspec do |mocks|
271
+ mocks.verify_partial_doubles = true
272
+ end
273
+
274
+ config.shared_context_metadata_behavior = :apply_to_host_groups
275
+ config.filter_run_when_matching :focus
276
+ config.example_status_persistence_file_path = 'spec/examples.txt'
277
+ config.disable_monkey_patching!
278
+ config.warnings = true
279
+
280
+ config.default_formatter = 'doc' if config.files_to_run.one?
281
+ config.profile_examples = 10
282
+ config.order = :random
283
+ Kernel.srand config.seed
284
+ end
285
+ ```
286
+
287
+ ## Dependency Management
288
+
289
+ ### Using Bundler
290
+
291
+ ```bash
292
+ # Install dependencies
293
+ bundle install
294
+
295
+ # Update dependencies
296
+ bundle update
297
+
298
+ # Check for outdated gems
299
+ bundle outdated
300
+
301
+ # Security audit
302
+ bundle exec bundler-audit check --update
303
+ ```
304
+
305
+ ### Gemfile.lock
306
+
307
+ - **MUST** commit Gemfile.lock for applications
308
+ - For gems: Add to `.gitignore`
309
+ - Ensures reproducible builds
310
+
311
+ ## Best Practices
312
+
313
+ ### DO's ✅
314
+
315
+ - **USE** meaningful variable and method names
316
+ - **FOLLOW** Ruby naming conventions (snake_case)
317
+ - **WRITE** descriptive tests with context blocks
318
+ - **HANDLE** exceptions explicitly
319
+ - **VALIDATE** inputs
320
+ - **DOCUMENT** public APIs
321
+ - **USE** symbols for hash keys when possible
322
+ - **FREEZE** string literals in Ruby 3+
323
+
324
+ ### DON'Ts ❌
325
+
326
+ - **NEVER** use global variables
327
+ - **NEVER** monkey-patch core classes without extreme caution
328
+ - **NEVER** skip tests
329
+ - **NEVER** commit `.byebug_history` or debug files
330
+ - **NEVER** use `eval` unless absolutely necessary
331
+ - **NEVER** ignore RuboCop offenses without justification
332
+ - **NEVER** commit with failing tests
333
+
334
+ Example code style:
335
+ ```ruby
336
+ # ✅ GOOD: Clean Ruby code
337
+ class DataProcessor
338
+ def initialize(options = {})
339
+ @threshold = options.fetch(:threshold, 0.5)
340
+ @verbose = options.fetch(:verbose, false)
341
+ end
342
+
343
+ def process(data)
344
+ validate_input!(data)
345
+
346
+ log('Processing data...') if @verbose
347
+
348
+ data.select { |item| item[:value] > @threshold }
349
+ end
350
+
351
+ private
352
+
353
+ def validate_input!(data)
354
+ raise ArgumentError, 'Data must be an array' unless data.is_a?(Array)
355
+ raise ArgumentError, 'Data cannot be empty' if data.empty?
356
+ end
357
+
358
+ def log(message)
359
+ puts "[#{Time.now.iso8601}] #{message}"
360
+ end
361
+ end
362
+
363
+ # ❌ BAD: Poor practices
364
+ class DataProcessor
365
+ def process(data)
366
+ $threshold = 0.5 # DON'T use globals!
367
+
368
+ if data == nil # Use nil? method
369
+ return false
370
+ end
371
+
372
+ result = []
373
+ for item in data # Use .each or .map
374
+ if item[:value] > $threshold
375
+ result.push(item)
376
+ end
377
+ end
378
+
379
+ puts result # DON'T print in library code
380
+ result
381
+ end
382
+ end
383
+ ```
384
+
385
+ ## CI/CD Requirements
386
+
387
+ Must include GitHub Actions workflows:
388
+
389
+ 1. **Testing** (`ruby-test.yml`):
390
+ - Test on ubuntu-latest, windows-latest, macos-latest
391
+ - Ruby versions: 3.2, 3.3
392
+ - Upload coverage to Codecov
393
+
394
+ 2. **Linting** (`ruby-lint.yml`):
395
+ - RuboCop checks
396
+ - Bundler audit for security
397
+
398
+ 3. **Build** (`ruby-build.yml`):
399
+ - Build gem
400
+ - Verify gem structure
401
+
402
+ ## Publishing to RubyGems
403
+
404
+ ### Prerequisites
405
+
406
+ 1. Create account at https://rubygems.org
407
+ 2. Get API key: `gem signin`
408
+ 3. Add `RUBYGEMS_API_KEY` to GitHub secrets
409
+
410
+ ### Publishing Workflow
411
+
412
+ ```bash
413
+ # 1. Update version in gemspec or version.rb
414
+ # 2. Update CHANGELOG.md
415
+ # 3. Run all quality checks
416
+ bundle exec rubocop
417
+ bundle exec rspec
418
+ gem build *.gemspec
419
+
420
+ # 4. Create git tag
421
+ git tag -a v1.0.0 -m "Release version 1.0.0"
422
+
423
+ # 5. Push (manual if SSH password)
424
+ # git push origin main
425
+ # git push origin v1.0.0
426
+
427
+ # 6. Publish to RubyGems (or use GitHub Actions)
428
+ gem push your_gem-1.0.0.gem
429
+ ```
430
+
431
+ <!-- RUBY:END -->