@k2works/claude-code-booster 2.7.1 → 3.1.0

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 (527) hide show
  1. package/lib/assets/docs/article/functional-desgin-ppp/all/01-immutability-and-data-transformation.md +475 -0
  2. package/lib/assets/docs/article/functional-desgin-ppp/all/02-function-composition.md +519 -0
  3. package/lib/assets/docs/article/functional-desgin-ppp/all/03-polymorphism.md +537 -0
  4. package/lib/assets/docs/article/functional-desgin-ppp/all/04-data-validation.md +300 -0
  5. package/lib/assets/docs/article/functional-desgin-ppp/all/05-property-based-testing.md +320 -0
  6. package/lib/assets/docs/article/functional-desgin-ppp/all/06-tdd-and-functional.md +498 -0
  7. package/lib/assets/docs/article/functional-desgin-ppp/all/07-composite-pattern.md +298 -0
  8. package/lib/assets/docs/article/functional-desgin-ppp/all/08-decorator-pattern.md +291 -0
  9. package/lib/assets/docs/article/functional-desgin-ppp/all/09-adapter-pattern.md +336 -0
  10. package/lib/assets/docs/article/functional-desgin-ppp/all/10-strategy-pattern.md +303 -0
  11. package/lib/assets/docs/article/functional-desgin-ppp/all/11-command-pattern.md +286 -0
  12. package/lib/assets/docs/article/functional-desgin-ppp/all/12-visitor-pattern.md +322 -0
  13. package/lib/assets/docs/article/functional-desgin-ppp/all/13-abstract-factory-pattern.md +319 -0
  14. package/lib/assets/docs/article/functional-desgin-ppp/all/14-abstract-server-pattern.md +365 -0
  15. package/lib/assets/docs/article/functional-desgin-ppp/all/15-gossiping-bus-drivers.md +156 -0
  16. package/lib/assets/docs/article/functional-desgin-ppp/all/16-payroll-system.md +178 -0
  17. package/lib/assets/docs/article/functional-desgin-ppp/all/17-video-rental-system.md +312 -0
  18. package/lib/assets/docs/article/functional-desgin-ppp/all/18-concurrency-system.md +287 -0
  19. package/lib/assets/docs/article/functional-desgin-ppp/all/19-wa-tor-simulation.md +286 -0
  20. package/lib/assets/docs/article/functional-desgin-ppp/all/20-pattern-interactions.md +274 -0
  21. package/lib/assets/docs/article/functional-desgin-ppp/all/21-best-practices.md +294 -0
  22. package/lib/assets/docs/article/functional-desgin-ppp/all/22-oo-to-fp-migration.md +337 -0
  23. package/lib/assets/docs/article/functional-desgin-ppp/all/index.md +388 -0
  24. package/lib/assets/docs/article/functional-desgin-ppp/clojure/01-immutability-and-data-transformation.md +271 -0
  25. package/lib/assets/docs/article/functional-desgin-ppp/clojure/02-function-composition.md +380 -0
  26. package/lib/assets/docs/article/functional-desgin-ppp/clojure/03-polymorphism.md +384 -0
  27. package/lib/assets/docs/article/functional-desgin-ppp/clojure/04-clojure-spec.md +350 -0
  28. package/lib/assets/docs/article/functional-desgin-ppp/clojure/05-property-based-testing.md +352 -0
  29. package/lib/assets/docs/article/functional-desgin-ppp/clojure/06-tdd-in-functional.md +383 -0
  30. package/lib/assets/docs/article/functional-desgin-ppp/clojure/07-composite-pattern.md +529 -0
  31. package/lib/assets/docs/article/functional-desgin-ppp/clojure/08-decorator-pattern.md +395 -0
  32. package/lib/assets/docs/article/functional-desgin-ppp/clojure/09-adapter-pattern.md +399 -0
  33. package/lib/assets/docs/article/functional-desgin-ppp/clojure/10-strategy-pattern.md +485 -0
  34. package/lib/assets/docs/article/functional-desgin-ppp/clojure/11-command-pattern.md +566 -0
  35. package/lib/assets/docs/article/functional-desgin-ppp/clojure/12-visitor-pattern.md +567 -0
  36. package/lib/assets/docs/article/functional-desgin-ppp/clojure/13-abstract-factory-pattern.md +475 -0
  37. package/lib/assets/docs/article/functional-desgin-ppp/clojure/14-abstract-server-pattern.md +462 -0
  38. package/lib/assets/docs/article/functional-desgin-ppp/clojure/15-gossiping-bus-drivers.md +323 -0
  39. package/lib/assets/docs/article/functional-desgin-ppp/clojure/16-payroll-system.md +401 -0
  40. package/lib/assets/docs/article/functional-desgin-ppp/clojure/17-video-rental-system.md +450 -0
  41. package/lib/assets/docs/article/functional-desgin-ppp/clojure/18-concurrency-system.md +475 -0
  42. package/lib/assets/docs/article/functional-desgin-ppp/clojure/19-wator-simulation.md +739 -0
  43. package/lib/assets/docs/article/functional-desgin-ppp/clojure/20-pattern-interactions.md +562 -0
  44. package/lib/assets/docs/article/functional-desgin-ppp/clojure/21-best-practices.md +506 -0
  45. package/lib/assets/docs/article/functional-desgin-ppp/clojure/22-oo-to-fp-migration.md +526 -0
  46. package/lib/assets/docs/article/functional-desgin-ppp/clojure/index.md +197 -0
  47. package/lib/assets/docs/article/functional-desgin-ppp/elixir/01-immutability-and-data-transformation.md +381 -0
  48. package/lib/assets/docs/article/functional-desgin-ppp/elixir/02-function-composition.md +374 -0
  49. package/lib/assets/docs/article/functional-desgin-ppp/elixir/03-polymorphism.md +375 -0
  50. package/lib/assets/docs/article/functional-desgin-ppp/elixir/04-data-validation.md +195 -0
  51. package/lib/assets/docs/article/functional-desgin-ppp/elixir/05-property-based-testing.md +268 -0
  52. package/lib/assets/docs/article/functional-desgin-ppp/elixir/06-tdd-and-fp.md +294 -0
  53. package/lib/assets/docs/article/functional-desgin-ppp/elixir/07-effects-and-pure-functions.md +164 -0
  54. package/lib/assets/docs/article/functional-desgin-ppp/elixir/08-error-handling-strategies.md +168 -0
  55. package/lib/assets/docs/article/functional-desgin-ppp/elixir/09-io-and-external-systems.md +254 -0
  56. package/lib/assets/docs/article/functional-desgin-ppp/elixir/10-concurrency-patterns.md +269 -0
  57. package/lib/assets/docs/article/functional-desgin-ppp/elixir/11-command-pattern.md +148 -0
  58. package/lib/assets/docs/article/functional-desgin-ppp/elixir/12-visitor-pattern.md +176 -0
  59. package/lib/assets/docs/article/functional-desgin-ppp/elixir/13-abstract-factory-pattern.md +604 -0
  60. package/lib/assets/docs/article/functional-desgin-ppp/elixir/14-abstract-server-pattern.md +729 -0
  61. package/lib/assets/docs/article/functional-desgin-ppp/elixir/15-gossiping-bus-drivers.md +291 -0
  62. package/lib/assets/docs/article/functional-desgin-ppp/elixir/16-payroll-system.md +420 -0
  63. package/lib/assets/docs/article/functional-desgin-ppp/elixir/17-video-rental-system.md +319 -0
  64. package/lib/assets/docs/article/functional-desgin-ppp/elixir/18-concurrency-system.md +466 -0
  65. package/lib/assets/docs/article/functional-desgin-ppp/elixir/19-wator-simulation.md +523 -0
  66. package/lib/assets/docs/article/functional-desgin-ppp/elixir/20-pattern-interactions.md +287 -0
  67. package/lib/assets/docs/article/functional-desgin-ppp/elixir/21-best-practices.md +340 -0
  68. package/lib/assets/docs/article/functional-desgin-ppp/elixir/22-oo-to-fp-migration.md +395 -0
  69. package/lib/assets/docs/article/functional-desgin-ppp/elixir/index.md +204 -0
  70. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/01-immutability-and-data-transformation.md +382 -0
  71. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/02-function-composition.md +452 -0
  72. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/03-polymorphism.md +495 -0
  73. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/04-data-validation.md +416 -0
  74. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/05-property-based-testing.md +382 -0
  75. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/06-tdd-functional.md +687 -0
  76. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/07-composite-pattern.md +442 -0
  77. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/08-decorator-pattern.md +479 -0
  78. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/09-adapter-pattern.md +479 -0
  79. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/10-strategy-pattern.md +427 -0
  80. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/11-command-pattern.md +428 -0
  81. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/12-visitor-pattern.md +339 -0
  82. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/13-abstract-factory-pattern.md +309 -0
  83. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/14-abstract-server-pattern.md +596 -0
  84. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/15-gossiping-bus-drivers.md +353 -0
  85. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/16-payroll-system.md +350 -0
  86. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/17-video-rental-system.md +412 -0
  87. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/18-concurrency-system.md +367 -0
  88. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/19-wator-simulation.md +401 -0
  89. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/20-pattern-interactions.md +291 -0
  90. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/21-best-practices.md +320 -0
  91. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/22-oo-to-fp-migration.md +322 -0
  92. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/index.md +230 -0
  93. package/lib/assets/docs/article/functional-desgin-ppp/haskell/01-immutability-and-data-transformation.md +298 -0
  94. package/lib/assets/docs/article/functional-desgin-ppp/haskell/02-function-composition.md +304 -0
  95. package/lib/assets/docs/article/functional-desgin-ppp/haskell/03-polymorphism.md +362 -0
  96. package/lib/assets/docs/article/functional-desgin-ppp/haskell/04-data-validation.md +257 -0
  97. package/lib/assets/docs/article/functional-desgin-ppp/haskell/05-property-based-testing.md +254 -0
  98. package/lib/assets/docs/article/functional-desgin-ppp/haskell/06-tdd-functional.md +283 -0
  99. package/lib/assets/docs/article/functional-desgin-ppp/haskell/07-composite-pattern.md +395 -0
  100. package/lib/assets/docs/article/functional-desgin-ppp/haskell/08-decorator-pattern.md +319 -0
  101. package/lib/assets/docs/article/functional-desgin-ppp/haskell/09-adapter-pattern.md +382 -0
  102. package/lib/assets/docs/article/functional-desgin-ppp/haskell/10-strategy-pattern.md +287 -0
  103. package/lib/assets/docs/article/functional-desgin-ppp/haskell/11-command-pattern.md +303 -0
  104. package/lib/assets/docs/article/functional-desgin-ppp/haskell/12-visitor-pattern.md +326 -0
  105. package/lib/assets/docs/article/functional-desgin-ppp/haskell/13-abstract-factory-pattern.md +332 -0
  106. package/lib/assets/docs/article/functional-desgin-ppp/haskell/14-abstract-server-pattern.md +379 -0
  107. package/lib/assets/docs/article/functional-desgin-ppp/haskell/15-gossiping-bus-drivers.md +175 -0
  108. package/lib/assets/docs/article/functional-desgin-ppp/haskell/16-payroll-system.md +219 -0
  109. package/lib/assets/docs/article/functional-desgin-ppp/haskell/17-video-rental-system.md +244 -0
  110. package/lib/assets/docs/article/functional-desgin-ppp/haskell/18-concurrency-system.md +363 -0
  111. package/lib/assets/docs/article/functional-desgin-ppp/haskell/19-wator-simulation.md +438 -0
  112. package/lib/assets/docs/article/functional-desgin-ppp/haskell/20-pattern-interactions.md +323 -0
  113. package/lib/assets/docs/article/functional-desgin-ppp/haskell/21-best-practices.md +403 -0
  114. package/lib/assets/docs/article/functional-desgin-ppp/haskell/22-oo-to-fp-migration.md +469 -0
  115. package/lib/assets/docs/article/functional-desgin-ppp/haskell/index.md +174 -0
  116. package/lib/assets/docs/article/functional-desgin-ppp/index.md +90 -0
  117. package/lib/assets/docs/article/functional-desgin-ppp/rust/01-immutability-and-data-transformation.md +448 -0
  118. package/lib/assets/docs/article/functional-desgin-ppp/rust/02-function-composition.md +463 -0
  119. package/lib/assets/docs/article/functional-desgin-ppp/rust/03-polymorphism.md +425 -0
  120. package/lib/assets/docs/article/functional-desgin-ppp/rust/04-data-validation.md +273 -0
  121. package/lib/assets/docs/article/functional-desgin-ppp/rust/05-property-based-testing.md +247 -0
  122. package/lib/assets/docs/article/functional-desgin-ppp/rust/06-tdd-and-functional.md +841 -0
  123. package/lib/assets/docs/article/functional-desgin-ppp/rust/07-composite-pattern.md +384 -0
  124. package/lib/assets/docs/article/functional-desgin-ppp/rust/08-decorator-pattern.md +383 -0
  125. package/lib/assets/docs/article/functional-desgin-ppp/rust/09-adapter-pattern.md +339 -0
  126. package/lib/assets/docs/article/functional-desgin-ppp/rust/10-strategy-pattern.md +331 -0
  127. package/lib/assets/docs/article/functional-desgin-ppp/rust/11-command-pattern.md +356 -0
  128. package/lib/assets/docs/article/functional-desgin-ppp/rust/12-visitor-pattern.md +379 -0
  129. package/lib/assets/docs/article/functional-desgin-ppp/rust/13-abstract-factory-pattern.md +361 -0
  130. package/lib/assets/docs/article/functional-desgin-ppp/rust/14-abstract-server-pattern.md +392 -0
  131. package/lib/assets/docs/article/functional-desgin-ppp/rust/15-gossiping-bus-drivers.md +300 -0
  132. package/lib/assets/docs/article/functional-desgin-ppp/rust/16-payroll-system.md +297 -0
  133. package/lib/assets/docs/article/functional-desgin-ppp/rust/17-video-rental-system.md +304 -0
  134. package/lib/assets/docs/article/functional-desgin-ppp/rust/18-concurrency-system.md +315 -0
  135. package/lib/assets/docs/article/functional-desgin-ppp/rust/19-wator-simulation.md +311 -0
  136. package/lib/assets/docs/article/functional-desgin-ppp/rust/20-pattern-interactions.md +304 -0
  137. package/lib/assets/docs/article/functional-desgin-ppp/rust/21-best-practices.md +336 -0
  138. package/lib/assets/docs/article/functional-desgin-ppp/rust/22-oo-to-fp-migration.md +349 -0
  139. package/lib/assets/docs/article/functional-desgin-ppp/rust/index.md +199 -0
  140. package/lib/assets/docs/article/functional-desgin-ppp/scala/01-immutability-and-data-transformation.md +326 -0
  141. package/lib/assets/docs/article/functional-desgin-ppp/scala/02-function-composition.md +348 -0
  142. package/lib/assets/docs/article/functional-desgin-ppp/scala/03-polymorphism.md +357 -0
  143. package/lib/assets/docs/article/functional-desgin-ppp/scala/04-data-validation.md +364 -0
  144. package/lib/assets/docs/article/functional-desgin-ppp/scala/05-property-based-testing.md +515 -0
  145. package/lib/assets/docs/article/functional-desgin-ppp/scala/06-tdd-functional.md +557 -0
  146. package/lib/assets/docs/article/functional-desgin-ppp/scala/07-composite-pattern.md +363 -0
  147. package/lib/assets/docs/article/functional-desgin-ppp/scala/08-decorator-pattern.md +327 -0
  148. package/lib/assets/docs/article/functional-desgin-ppp/scala/09-adapter-pattern.md +517 -0
  149. package/lib/assets/docs/article/functional-desgin-ppp/scala/10-strategy-pattern.md +441 -0
  150. package/lib/assets/docs/article/functional-desgin-ppp/scala/11-command-pattern.md +407 -0
  151. package/lib/assets/docs/article/functional-desgin-ppp/scala/12-visitor-pattern.md +379 -0
  152. package/lib/assets/docs/article/functional-desgin-ppp/scala/13-abstract-factory-pattern.md +398 -0
  153. package/lib/assets/docs/article/functional-desgin-ppp/scala/14-abstract-server-pattern.md +476 -0
  154. package/lib/assets/docs/article/functional-desgin-ppp/scala/15-gossiping-bus-drivers.md +389 -0
  155. package/lib/assets/docs/article/functional-desgin-ppp/scala/16-payroll-system.md +342 -0
  156. package/lib/assets/docs/article/functional-desgin-ppp/scala/17-video-rental-system.md +324 -0
  157. package/lib/assets/docs/article/functional-desgin-ppp/scala/18-concurrency-system.md +730 -0
  158. package/lib/assets/docs/article/functional-desgin-ppp/scala/19-wator-simulation.md +624 -0
  159. package/lib/assets/docs/article/functional-desgin-ppp/scala/20-pattern-interactions.md +512 -0
  160. package/lib/assets/docs/article/functional-desgin-ppp/scala/21-best-practices.md +427 -0
  161. package/lib/assets/docs/article/functional-desgin-ppp/scala/22-oo-to-fp-migration.md +682 -0
  162. package/lib/assets/docs/article/functional-desgin-ppp/scala/index.md +199 -0
  163. package/lib/assets/docs/article/getting-start-tdd/clojure/01-todo-list-and-first-test.md +166 -0
  164. package/lib/assets/docs/article/getting-start-tdd/clojure/02-fake-it-and-triangulation.md +162 -0
  165. package/lib/assets/docs/article/getting-start-tdd/clojure/03-obvious-implementation-and-refactoring.md +135 -0
  166. package/lib/assets/docs/article/getting-start-tdd/clojure/04-version-control-and-conventional-commits.md +88 -0
  167. package/lib/assets/docs/article/getting-start-tdd/clojure/05-package-management-and-static-analysis.md +299 -0
  168. package/lib/assets/docs/article/getting-start-tdd/clojure/06-task-runner-and-ci-cd.md +241 -0
  169. package/lib/assets/docs/article/getting-start-tdd/clojure/07-protocols-and-records.md +131 -0
  170. package/lib/assets/docs/article/getting-start-tdd/clojure/08-multimethods-and-design-patterns.md +130 -0
  171. package/lib/assets/docs/article/getting-start-tdd/clojure/09-namespaces-and-module-design.md +127 -0
  172. package/lib/assets/docs/article/getting-start-tdd/clojure/10-higher-order-functions-and-composition.md +114 -0
  173. package/lib/assets/docs/article/getting-start-tdd/clojure/11-persistent-data-and-pipeline.md +138 -0
  174. package/lib/assets/docs/article/getting-start-tdd/clojure/12-error-handling-and-spec.md +161 -0
  175. package/lib/assets/docs/article/getting-start-tdd/clojure/index.md +65 -0
  176. package/lib/assets/docs/article/getting-start-tdd/csharp/chapter01.md +232 -0
  177. package/lib/assets/docs/article/getting-start-tdd/csharp/chapter02.md +244 -0
  178. package/lib/assets/docs/article/getting-start-tdd/csharp/chapter03.md +202 -0
  179. package/lib/assets/docs/article/getting-start-tdd/csharp/chapter04.md +92 -0
  180. package/lib/assets/docs/article/getting-start-tdd/csharp/chapter05.md +256 -0
  181. package/lib/assets/docs/article/getting-start-tdd/csharp/chapter06.md +195 -0
  182. package/lib/assets/docs/article/getting-start-tdd/csharp/chapter07.md +214 -0
  183. package/lib/assets/docs/article/getting-start-tdd/csharp/chapter08.md +249 -0
  184. package/lib/assets/docs/article/getting-start-tdd/csharp/chapter09.md +174 -0
  185. package/lib/assets/docs/article/getting-start-tdd/csharp/chapter10.md +166 -0
  186. package/lib/assets/docs/article/getting-start-tdd/csharp/chapter11.md +192 -0
  187. package/lib/assets/docs/article/getting-start-tdd/csharp/chapter12.md +211 -0
  188. package/lib/assets/docs/article/getting-start-tdd/csharp/index.md +83 -0
  189. package/lib/assets/docs/article/getting-start-tdd/elixir/01-todo-list-and-first-test.md +87 -0
  190. package/lib/assets/docs/article/getting-start-tdd/elixir/02-fake-it-and-triangulation.md +95 -0
  191. package/lib/assets/docs/article/getting-start-tdd/elixir/03-obvious-implementation-and-refactoring.md +109 -0
  192. package/lib/assets/docs/article/getting-start-tdd/elixir/04-version-control-and-conventional-commits.md +96 -0
  193. package/lib/assets/docs/article/getting-start-tdd/elixir/05-package-management-and-static-analysis.md +88 -0
  194. package/lib/assets/docs/article/getting-start-tdd/elixir/06-task-runner-and-ci-cd.md +71 -0
  195. package/lib/assets/docs/article/getting-start-tdd/elixir/07-structs-and-protocols.md +110 -0
  196. package/lib/assets/docs/article/getting-start-tdd/elixir/08-pattern-matching-and-guards.md +108 -0
  197. package/lib/assets/docs/article/getting-start-tdd/elixir/09-module-design-and-behaviours.md +104 -0
  198. package/lib/assets/docs/article/getting-start-tdd/elixir/10-higher-order-functions-and-pipeline.md +178 -0
  199. package/lib/assets/docs/article/getting-start-tdd/elixir/11-stream-and-lazy-evaluation.md +142 -0
  200. package/lib/assets/docs/article/getting-start-tdd/elixir/12-error-handling-and-with.md +145 -0
  201. package/lib/assets/docs/article/getting-start-tdd/elixir/index.md +35 -0
  202. package/lib/assets/docs/article/getting-start-tdd/fsharp/chapter01.md +202 -0
  203. package/lib/assets/docs/article/getting-start-tdd/fsharp/chapter02.md +246 -0
  204. package/lib/assets/docs/article/getting-start-tdd/fsharp/chapter03.md +218 -0
  205. package/lib/assets/docs/article/getting-start-tdd/fsharp/chapter04.md +179 -0
  206. package/lib/assets/docs/article/getting-start-tdd/fsharp/chapter05.md +267 -0
  207. package/lib/assets/docs/article/getting-start-tdd/fsharp/chapter06.md +190 -0
  208. package/lib/assets/docs/article/getting-start-tdd/fsharp/chapter07.md +161 -0
  209. package/lib/assets/docs/article/getting-start-tdd/fsharp/chapter08.md +175 -0
  210. package/lib/assets/docs/article/getting-start-tdd/fsharp/chapter09.md +222 -0
  211. package/lib/assets/docs/article/getting-start-tdd/fsharp/chapter10.md +189 -0
  212. package/lib/assets/docs/article/getting-start-tdd/fsharp/chapter11.md +212 -0
  213. package/lib/assets/docs/article/getting-start-tdd/fsharp/chapter12.md +215 -0
  214. package/lib/assets/docs/article/getting-start-tdd/fsharp/index.md +71 -0
  215. package/lib/assets/docs/article/getting-start-tdd/go/01-todo-list-and-first-test.md +213 -0
  216. package/lib/assets/docs/article/getting-start-tdd/go/02-fake-it-and-triangulation.md +302 -0
  217. package/lib/assets/docs/article/getting-start-tdd/go/03-obvious-implementation-and-refactoring.md +339 -0
  218. package/lib/assets/docs/article/getting-start-tdd/go/04-version-control-and-conventional-commits.md +112 -0
  219. package/lib/assets/docs/article/getting-start-tdd/go/05-package-management-and-static-analysis.md +272 -0
  220. package/lib/assets/docs/article/getting-start-tdd/go/06-task-runner-and-ci-cd.md +233 -0
  221. package/lib/assets/docs/article/getting-start-tdd/go/07-encapsulation-and-polymorphism.md +394 -0
  222. package/lib/assets/docs/article/getting-start-tdd/go/08-design-patterns.md +422 -0
  223. package/lib/assets/docs/article/getting-start-tdd/go/09-solid-principles-and-module-design.md +400 -0
  224. package/lib/assets/docs/article/getting-start-tdd/go/10-higher-order-functions-and-composition.md +226 -0
  225. package/lib/assets/docs/article/getting-start-tdd/go/11-immutable-data-and-pipeline.md +296 -0
  226. package/lib/assets/docs/article/getting-start-tdd/go/12-error-handling-and-type-safety.md +411 -0
  227. package/lib/assets/docs/article/getting-start-tdd/go/index.md +83 -0
  228. package/lib/assets/docs/article/getting-start-tdd/haskell/01-todo-list-and-first-test.md +279 -0
  229. package/lib/assets/docs/article/getting-start-tdd/haskell/02-fake-it-and-triangulation.md +337 -0
  230. package/lib/assets/docs/article/getting-start-tdd/haskell/03-obvious-implementation-and-refactoring.md +257 -0
  231. package/lib/assets/docs/article/getting-start-tdd/haskell/04-version-control-and-conventional-commits.md +182 -0
  232. package/lib/assets/docs/article/getting-start-tdd/haskell/05-package-management-and-static-analysis.md +313 -0
  233. package/lib/assets/docs/article/getting-start-tdd/haskell/06-task-runner-and-ci-cd.md +309 -0
  234. package/lib/assets/docs/article/getting-start-tdd/haskell/07-algebraic-data-types-and-type-classes.md +412 -0
  235. package/lib/assets/docs/article/getting-start-tdd/haskell/08-pattern-matching-and-guards.md +390 -0
  236. package/lib/assets/docs/article/getting-start-tdd/haskell/09-module-design-and-smart-constructors.md +461 -0
  237. package/lib/assets/docs/article/getting-start-tdd/haskell/10-higher-order-functions-and-currying.md +434 -0
  238. package/lib/assets/docs/article/getting-start-tdd/haskell/11-function-composition-and-point-free.md +392 -0
  239. package/lib/assets/docs/article/getting-start-tdd/haskell/12-monad-and-error-handling.md +631 -0
  240. package/lib/assets/docs/article/getting-start-tdd/haskell/index.md +49 -0
  241. package/lib/assets/docs/article/getting-start-tdd/index.md +93 -0
  242. package/lib/assets/docs/article/getting-start-tdd/integration/01-language-overview.md +375 -0
  243. package/lib/assets/docs/article/getting-start-tdd/integration/02-test-framework-comparison.md +349 -0
  244. package/lib/assets/docs/article/getting-start-tdd/integration/03-tdd-pattern-comparison.md +445 -0
  245. package/lib/assets/docs/article/getting-start-tdd/integration/04-type-system-comparison.md +405 -0
  246. package/lib/assets/docs/article/getting-start-tdd/integration/05-dev-environment-comparison.md +330 -0
  247. package/lib/assets/docs/article/getting-start-tdd/integration/06-learning-roadmap.md +274 -0
  248. package/lib/assets/docs/article/getting-start-tdd/integration/index.md +69 -0
  249. package/lib/assets/docs/article/getting-start-tdd/java/01-todo-list-and-first-test.md +234 -0
  250. package/lib/assets/docs/article/getting-start-tdd/java/02-fake-it-and-triangulation.md +261 -0
  251. package/lib/assets/docs/article/getting-start-tdd/java/03-obvious-implementation-and-refactoring.md +185 -0
  252. package/lib/assets/docs/article/getting-start-tdd/java/04-version-control-and-conventional-commits.md +115 -0
  253. package/lib/assets/docs/article/getting-start-tdd/java/05-package-management-and-static-analysis.md +382 -0
  254. package/lib/assets/docs/article/getting-start-tdd/java/06-task-runner-and-ci-cd.md +272 -0
  255. package/lib/assets/docs/article/getting-start-tdd/java/07-encapsulation-and-polymorphism.md +626 -0
  256. package/lib/assets/docs/article/getting-start-tdd/java/08-design-patterns.md +393 -0
  257. package/lib/assets/docs/article/getting-start-tdd/java/09-solid-principles-and-module-design.md +310 -0
  258. package/lib/assets/docs/article/getting-start-tdd/java/10-higher-order-functions-and-composition.md +188 -0
  259. package/lib/assets/docs/article/getting-start-tdd/java/11-immutable-data-and-pipeline.md +167 -0
  260. package/lib/assets/docs/article/getting-start-tdd/java/12-error-handling-and-type-safety.md +205 -0
  261. package/lib/assets/docs/article/getting-start-tdd/java/index.md +61 -0
  262. package/lib/assets/docs/article/getting-start-tdd/node/01-todo-list-and-first-test.md +244 -0
  263. package/lib/assets/docs/article/getting-start-tdd/node/02-fake-it-and-triangulation.md +262 -0
  264. package/lib/assets/docs/article/getting-start-tdd/node/03-obvious-implementation-and-refactoring.md +169 -0
  265. package/lib/assets/docs/article/getting-start-tdd/node/04-version-control-and-conventional-commits.md +112 -0
  266. package/lib/assets/docs/article/getting-start-tdd/node/05-package-management-and-static-analysis.md +314 -0
  267. package/lib/assets/docs/article/getting-start-tdd/node/06-task-runner-and-ci-cd.md +235 -0
  268. package/lib/assets/docs/article/getting-start-tdd/node/07-encapsulation-and-polymorphism.md +327 -0
  269. package/lib/assets/docs/article/getting-start-tdd/node/08-design-patterns.md +322 -0
  270. package/lib/assets/docs/article/getting-start-tdd/node/09-solid-principles-and-module-design.md +285 -0
  271. package/lib/assets/docs/article/getting-start-tdd/node/10-higher-order-functions-and-composition.md +199 -0
  272. package/lib/assets/docs/article/getting-start-tdd/node/11-immutable-data-and-pipeline.md +207 -0
  273. package/lib/assets/docs/article/getting-start-tdd/node/12-error-handling-and-type-safety.md +295 -0
  274. package/lib/assets/docs/article/getting-start-tdd/node/index.md +56 -0
  275. package/lib/assets/docs/article/getting-start-tdd/php/01-todo-list-and-first-test.md +259 -0
  276. package/lib/assets/docs/article/getting-start-tdd/php/02-fake-it-and-triangulation.md +200 -0
  277. package/lib/assets/docs/article/getting-start-tdd/php/03-obvious-implementation-and-refactoring.md +248 -0
  278. package/lib/assets/docs/article/getting-start-tdd/php/04-version-control-and-conventional-commits.md +141 -0
  279. package/lib/assets/docs/article/getting-start-tdd/php/05-package-management-and-static-analysis.md +410 -0
  280. package/lib/assets/docs/article/getting-start-tdd/php/06-task-runner-and-ci-cd.md +321 -0
  281. package/lib/assets/docs/article/getting-start-tdd/php/07-encapsulation-and-polymorphism.md +372 -0
  282. package/lib/assets/docs/article/getting-start-tdd/php/08-design-patterns.md +453 -0
  283. package/lib/assets/docs/article/getting-start-tdd/php/09-solid-principles-and-module-design.md +460 -0
  284. package/lib/assets/docs/article/getting-start-tdd/php/10-higher-order-functions-and-composition.md +182 -0
  285. package/lib/assets/docs/article/getting-start-tdd/php/11-immutable-data-and-pipeline.md +266 -0
  286. package/lib/assets/docs/article/getting-start-tdd/php/12-error-handling-and-type-safety.md +308 -0
  287. package/lib/assets/docs/article/getting-start-tdd/php/index.md +84 -0
  288. package/lib/assets/docs/article/getting-start-tdd/python/01-todo-list-and-first-test.md +201 -0
  289. package/lib/assets/docs/article/getting-start-tdd/python/02-fake-it-and-triangulation.md +247 -0
  290. package/lib/assets/docs/article/getting-start-tdd/python/03-obvious-implementation-and-refactoring.md +199 -0
  291. package/lib/assets/docs/article/getting-start-tdd/python/04-version-control-and-conventional-commits.md +87 -0
  292. package/lib/assets/docs/article/getting-start-tdd/python/05-package-management-and-static-analysis.md +274 -0
  293. package/lib/assets/docs/article/getting-start-tdd/python/06-task-runner-and-ci-cd.md +190 -0
  294. package/lib/assets/docs/article/getting-start-tdd/python/07-encapsulation-and-polymorphism.md +208 -0
  295. package/lib/assets/docs/article/getting-start-tdd/python/08-design-patterns.md +172 -0
  296. package/lib/assets/docs/article/getting-start-tdd/python/09-solid-principles-and-module-design.md +130 -0
  297. package/lib/assets/docs/article/getting-start-tdd/python/10-higher-order-functions-and-composition.md +122 -0
  298. package/lib/assets/docs/article/getting-start-tdd/python/11-immutable-data-and-pipeline.md +116 -0
  299. package/lib/assets/docs/article/getting-start-tdd/python/12-error-handling-and-type-safety.md +126 -0
  300. package/lib/assets/docs/article/getting-start-tdd/python/index.md +55 -0
  301. package/lib/assets/docs/article/getting-start-tdd/ruby/01-todo-list-and-first-test.md +231 -0
  302. package/lib/assets/docs/article/getting-start-tdd/ruby/02-fake-it-and-triangulation.md +238 -0
  303. package/lib/assets/docs/article/getting-start-tdd/ruby/03-obvious-implementation-and-refactoring.md +228 -0
  304. package/lib/assets/docs/article/getting-start-tdd/ruby/04-version-control-and-conventional-commits.md +112 -0
  305. package/lib/assets/docs/article/getting-start-tdd/ruby/05-package-management-and-static-analysis.md +287 -0
  306. package/lib/assets/docs/article/getting-start-tdd/ruby/06-task-runner-and-ci-cd.md +248 -0
  307. package/lib/assets/docs/article/getting-start-tdd/ruby/07-encapsulation-and-polymorphism.md +279 -0
  308. package/lib/assets/docs/article/getting-start-tdd/ruby/08-design-patterns.md +329 -0
  309. package/lib/assets/docs/article/getting-start-tdd/ruby/09-solid-principles-and-module-design.md +196 -0
  310. package/lib/assets/docs/article/getting-start-tdd/ruby/10-higher-order-functions-and-composition.md +175 -0
  311. package/lib/assets/docs/article/getting-start-tdd/ruby/11-immutable-data-and-pipeline.md +233 -0
  312. package/lib/assets/docs/article/getting-start-tdd/ruby/12-error-handling-and-type-safety.md +398 -0
  313. package/lib/assets/docs/article/getting-start-tdd/ruby/index.md +83 -0
  314. package/lib/assets/docs/article/getting-start-tdd/rust/01-todo-list-and-first-test.md +211 -0
  315. package/lib/assets/docs/article/getting-start-tdd/rust/02-fake-it-and-triangulation.md +264 -0
  316. package/lib/assets/docs/article/getting-start-tdd/rust/03-obvious-implementation-and-refactoring.md +233 -0
  317. package/lib/assets/docs/article/getting-start-tdd/rust/04-version-control-and-conventional-commits.md +92 -0
  318. package/lib/assets/docs/article/getting-start-tdd/rust/05-package-management-and-static-analysis.md +212 -0
  319. package/lib/assets/docs/article/getting-start-tdd/rust/06-task-runner-and-ci-cd.md +164 -0
  320. package/lib/assets/docs/article/getting-start-tdd/rust/07-encapsulation-and-polymorphism.md +142 -0
  321. package/lib/assets/docs/article/getting-start-tdd/rust/08-design-patterns.md +145 -0
  322. package/lib/assets/docs/article/getting-start-tdd/rust/09-solid-principles-and-module-design.md +110 -0
  323. package/lib/assets/docs/article/getting-start-tdd/rust/10-higher-order-functions-and-composition.md +94 -0
  324. package/lib/assets/docs/article/getting-start-tdd/rust/11-immutable-data-and-pipeline.md +105 -0
  325. package/lib/assets/docs/article/getting-start-tdd/rust/12-error-handling-and-type-safety.md +112 -0
  326. package/lib/assets/docs/article/getting-start-tdd/rust/index.md +83 -0
  327. package/lib/assets/docs/article/getting-start-tdd/scala/01-todo-list-and-first-test.md +111 -0
  328. package/lib/assets/docs/article/getting-start-tdd/scala/02-fake-it-and-triangulation.md +107 -0
  329. package/lib/assets/docs/article/getting-start-tdd/scala/03-obvious-implementation-and-refactoring.md +99 -0
  330. package/lib/assets/docs/article/getting-start-tdd/scala/04-version-control-and-conventional-commits.md +123 -0
  331. package/lib/assets/docs/article/getting-start-tdd/scala/05-package-management-and-static-analysis.md +196 -0
  332. package/lib/assets/docs/article/getting-start-tdd/scala/06-task-runner-and-ci-cd.md +186 -0
  333. package/lib/assets/docs/article/getting-start-tdd/scala/07-case-classes-and-traits.md +139 -0
  334. package/lib/assets/docs/article/getting-start-tdd/scala/08-pattern-matching-and-sealed-traits.md +106 -0
  335. package/lib/assets/docs/article/getting-start-tdd/scala/09-packages-and-module-design.md +75 -0
  336. package/lib/assets/docs/article/getting-start-tdd/scala/10-higher-order-functions-and-composition.md +104 -0
  337. package/lib/assets/docs/article/getting-start-tdd/scala/11-collections-and-lazy-evaluation.md +94 -0
  338. package/lib/assets/docs/article/getting-start-tdd/scala/12-error-handling-and-type-safety.md +92 -0
  339. package/lib/assets/docs/article/getting-start-tdd/scala/index.md +65 -0
  340. package/lib/assets/docs/article/grokking-concurrency/all/index.md +404 -0
  341. package/lib/assets/docs/article/grokking-concurrency/all/part-1-ch02-sequential.md +554 -0
  342. package/lib/assets/docs/article/grokking-concurrency/all/part-2-ch04-05-threads.md +469 -0
  343. package/lib/assets/docs/article/grokking-concurrency/all/part-3-ch06-multitasking.md +520 -0
  344. package/lib/assets/docs/article/grokking-concurrency/all/part-4-ch07-parallel-patterns.md +420 -0
  345. package/lib/assets/docs/article/grokking-concurrency/all/part-5-ch08-09-synchronization.md +510 -0
  346. package/lib/assets/docs/article/grokking-concurrency/all/part-6-ch10-11-nonblocking-io.md +435 -0
  347. package/lib/assets/docs/article/grokking-concurrency/all/part-7-ch12-async.md +465 -0
  348. package/lib/assets/docs/article/grokking-concurrency/all/part-8-ch13-mapreduce.md +377 -0
  349. package/lib/assets/docs/article/grokking-concurrency/clojure/index.md +116 -0
  350. package/lib/assets/docs/article/grokking-concurrency/clojure/part-1.md +108 -0
  351. package/lib/assets/docs/article/grokking-concurrency/clojure/part-2.md +101 -0
  352. package/lib/assets/docs/article/grokking-concurrency/clojure/part-3.md +122 -0
  353. package/lib/assets/docs/article/grokking-concurrency/clojure/part-4.md +123 -0
  354. package/lib/assets/docs/article/grokking-concurrency/clojure/part-5.md +118 -0
  355. package/lib/assets/docs/article/grokking-concurrency/clojure/part-6.md +89 -0
  356. package/lib/assets/docs/article/grokking-concurrency/clojure/part-7.md +100 -0
  357. package/lib/assets/docs/article/grokking-concurrency/clojure/part-8.md +120 -0
  358. package/lib/assets/docs/article/grokking-concurrency/csharp/index.md +101 -0
  359. package/lib/assets/docs/article/grokking-concurrency/csharp/part-1.md +97 -0
  360. package/lib/assets/docs/article/grokking-concurrency/csharp/part-2.md +123 -0
  361. package/lib/assets/docs/article/grokking-concurrency/csharp/part-3.md +101 -0
  362. package/lib/assets/docs/article/grokking-concurrency/csharp/part-4.md +112 -0
  363. package/lib/assets/docs/article/grokking-concurrency/csharp/part-5.md +99 -0
  364. package/lib/assets/docs/article/grokking-concurrency/csharp/part-6.md +61 -0
  365. package/lib/assets/docs/article/grokking-concurrency/csharp/part-7.md +84 -0
  366. package/lib/assets/docs/article/grokking-concurrency/csharp/part-8.md +92 -0
  367. package/lib/assets/docs/article/grokking-concurrency/fsharp/index.md +65 -0
  368. package/lib/assets/docs/article/grokking-concurrency/fsharp/part-1.md +80 -0
  369. package/lib/assets/docs/article/grokking-concurrency/fsharp/part-2.md +103 -0
  370. package/lib/assets/docs/article/grokking-concurrency/fsharp/part-3.md +94 -0
  371. package/lib/assets/docs/article/grokking-concurrency/fsharp/part-4.md +110 -0
  372. package/lib/assets/docs/article/grokking-concurrency/fsharp/part-5.md +104 -0
  373. package/lib/assets/docs/article/grokking-concurrency/fsharp/part-6.md +93 -0
  374. package/lib/assets/docs/article/grokking-concurrency/fsharp/part-7.md +121 -0
  375. package/lib/assets/docs/article/grokking-concurrency/fsharp/part-8.md +107 -0
  376. package/lib/assets/docs/article/grokking-concurrency/haskell/index.md +248 -0
  377. package/lib/assets/docs/article/grokking-concurrency/haskell/part-1.md +96 -0
  378. package/lib/assets/docs/article/grokking-concurrency/haskell/part-2.md +96 -0
  379. package/lib/assets/docs/article/grokking-concurrency/haskell/part-3.md +91 -0
  380. package/lib/assets/docs/article/grokking-concurrency/haskell/part-4.md +106 -0
  381. package/lib/assets/docs/article/grokking-concurrency/haskell/part-5.md +99 -0
  382. package/lib/assets/docs/article/grokking-concurrency/haskell/part-6.md +95 -0
  383. package/lib/assets/docs/article/grokking-concurrency/haskell/part-7.md +111 -0
  384. package/lib/assets/docs/article/grokking-concurrency/haskell/part-8.md +118 -0
  385. package/lib/assets/docs/article/grokking-concurrency/index.md +66 -0
  386. package/lib/assets/docs/article/grokking-concurrency/java/index.md +102 -0
  387. package/lib/assets/docs/article/grokking-concurrency/java/part-1.md +308 -0
  388. package/lib/assets/docs/article/grokking-concurrency/java/part-2.md +334 -0
  389. package/lib/assets/docs/article/grokking-concurrency/java/part-3.md +221 -0
  390. package/lib/assets/docs/article/grokking-concurrency/java/part-4.md +213 -0
  391. package/lib/assets/docs/article/grokking-concurrency/java/part-5.md +112 -0
  392. package/lib/assets/docs/article/grokking-concurrency/java/part-6.md +69 -0
  393. package/lib/assets/docs/article/grokking-concurrency/java/part-7.md +101 -0
  394. package/lib/assets/docs/article/grokking-concurrency/java/part-8.md +101 -0
  395. package/lib/assets/docs/article/grokking-concurrency/python/index.md +313 -0
  396. package/lib/assets/docs/article/grokking-concurrency/python/part-1.md +239 -0
  397. package/lib/assets/docs/article/grokking-concurrency/python/part-2.md +418 -0
  398. package/lib/assets/docs/article/grokking-concurrency/python/part-3.md +227 -0
  399. package/lib/assets/docs/article/grokking-concurrency/python/part-4.md +299 -0
  400. package/lib/assets/docs/article/grokking-concurrency/python/part-5.md +315 -0
  401. package/lib/assets/docs/article/grokking-concurrency/python/part-6.md +297 -0
  402. package/lib/assets/docs/article/grokking-concurrency/python/part-7.md +314 -0
  403. package/lib/assets/docs/article/grokking-concurrency/python/part-8.md +360 -0
  404. package/lib/assets/docs/article/grokking-concurrency/rust/index.md +270 -0
  405. package/lib/assets/docs/article/grokking-concurrency/rust/part-1.md +108 -0
  406. package/lib/assets/docs/article/grokking-concurrency/rust/part-2.md +120 -0
  407. package/lib/assets/docs/article/grokking-concurrency/rust/part-3.md +126 -0
  408. package/lib/assets/docs/article/grokking-concurrency/rust/part-4.md +175 -0
  409. package/lib/assets/docs/article/grokking-concurrency/rust/part-5.md +158 -0
  410. package/lib/assets/docs/article/grokking-concurrency/rust/part-6.md +94 -0
  411. package/lib/assets/docs/article/grokking-concurrency/rust/part-7.md +133 -0
  412. package/lib/assets/docs/article/grokking-concurrency/rust/part-8.md +155 -0
  413. package/lib/assets/docs/article/grokking-concurrency/scala/index.md +69 -0
  414. package/lib/assets/docs/article/grokking-concurrency/scala/part-1.md +78 -0
  415. package/lib/assets/docs/article/grokking-concurrency/scala/part-2.md +112 -0
  416. package/lib/assets/docs/article/grokking-concurrency/scala/part-3.md +93 -0
  417. package/lib/assets/docs/article/grokking-concurrency/scala/part-4.md +110 -0
  418. package/lib/assets/docs/article/grokking-concurrency/scala/part-5.md +119 -0
  419. package/lib/assets/docs/article/grokking-concurrency/scala/part-6.md +83 -0
  420. package/lib/assets/docs/article/grokking-concurrency/scala/part-7.md +131 -0
  421. package/lib/assets/docs/article/grokking-concurrency/scala/part-8.md +129 -0
  422. package/lib/assets/docs/article/grokkingfp/all/index.md +368 -0
  423. package/lib/assets/docs/article/grokkingfp/all/part-1-ch01-fp-introduction.md +530 -0
  424. package/lib/assets/docs/article/grokkingfp/all/part-1-ch02-pure-functions.md +923 -0
  425. package/lib/assets/docs/article/grokkingfp/all/part-2-ch03-immutable-data.md +1122 -0
  426. package/lib/assets/docs/article/grokkingfp/all/part-2-ch04-higher-order-functions.md +1104 -0
  427. package/lib/assets/docs/article/grokkingfp/all/part-2-ch05-flatmap.md +1026 -0
  428. package/lib/assets/docs/article/grokkingfp/all/part-3-ch06-option.md +777 -0
  429. package/lib/assets/docs/article/grokkingfp/all/part-3-ch07-either-adt.md +871 -0
  430. package/lib/assets/docs/article/grokkingfp/all/part-4-ch08-io-monad.md +972 -0
  431. package/lib/assets/docs/article/grokkingfp/all/part-4-ch09-streams.md +926 -0
  432. package/lib/assets/docs/article/grokkingfp/all/part-5-ch10-concurrency.md +870 -0
  433. package/lib/assets/docs/article/grokkingfp/all/part-6-ch11-application.md +715 -0
  434. package/lib/assets/docs/article/grokkingfp/all/part-6-ch12-testing.md +626 -0
  435. package/lib/assets/docs/article/grokkingfp/all/writing-plan.md +696 -0
  436. package/lib/assets/docs/article/grokkingfp/clojure/index.md +276 -0
  437. package/lib/assets/docs/article/grokkingfp/clojure/part-1.md +667 -0
  438. package/lib/assets/docs/article/grokkingfp/clojure/part-2.md +643 -0
  439. package/lib/assets/docs/article/grokkingfp/clojure/part-3.md +620 -0
  440. package/lib/assets/docs/article/grokkingfp/clojure/part-4.md +697 -0
  441. package/lib/assets/docs/article/grokkingfp/clojure/part-5.md +751 -0
  442. package/lib/assets/docs/article/grokkingfp/clojure/part-6.md +721 -0
  443. package/lib/assets/docs/article/grokkingfp/csharp/index.md +246 -0
  444. package/lib/assets/docs/article/grokkingfp/csharp/part-1.md +811 -0
  445. package/lib/assets/docs/article/grokkingfp/csharp/part-2.md +971 -0
  446. package/lib/assets/docs/article/grokkingfp/csharp/part-3.md +981 -0
  447. package/lib/assets/docs/article/grokkingfp/csharp/part-4.md +949 -0
  448. package/lib/assets/docs/article/grokkingfp/csharp/part-5.md +947 -0
  449. package/lib/assets/docs/article/grokkingfp/csharp/part-6.md +739 -0
  450. package/lib/assets/docs/article/grokkingfp/elixir/index.md +203 -0
  451. package/lib/assets/docs/article/grokkingfp/elixir/part-1.md +710 -0
  452. package/lib/assets/docs/article/grokkingfp/elixir/part-2.md +838 -0
  453. package/lib/assets/docs/article/grokkingfp/elixir/part-3.md +985 -0
  454. package/lib/assets/docs/article/grokkingfp/elixir/part-4.md +974 -0
  455. package/lib/assets/docs/article/grokkingfp/elixir/part-5.md +1284 -0
  456. package/lib/assets/docs/article/grokkingfp/elixir/part-6.md +1047 -0
  457. package/lib/assets/docs/article/grokkingfp/fsharp/index.md +210 -0
  458. package/lib/assets/docs/article/grokkingfp/fsharp/part-1.md +714 -0
  459. package/lib/assets/docs/article/grokkingfp/fsharp/part-2.md +961 -0
  460. package/lib/assets/docs/article/grokkingfp/fsharp/part-3.md +972 -0
  461. package/lib/assets/docs/article/grokkingfp/fsharp/part-4.md +832 -0
  462. package/lib/assets/docs/article/grokkingfp/fsharp/part-5.md +911 -0
  463. package/lib/assets/docs/article/grokkingfp/fsharp/part-6.md +920 -0
  464. package/lib/assets/docs/article/grokkingfp/haskell/index.md +234 -0
  465. package/lib/assets/docs/article/grokkingfp/haskell/part-1.md +591 -0
  466. package/lib/assets/docs/article/grokkingfp/haskell/part-2.md +866 -0
  467. package/lib/assets/docs/article/grokkingfp/haskell/part-3.md +915 -0
  468. package/lib/assets/docs/article/grokkingfp/haskell/part-4.md +876 -0
  469. package/lib/assets/docs/article/grokkingfp/haskell/part-5.md +845 -0
  470. package/lib/assets/docs/article/grokkingfp/haskell/part-6.md +842 -0
  471. package/lib/assets/docs/article/grokkingfp/index.md +143 -0
  472. package/lib/assets/docs/article/grokkingfp/java/index.md +211 -0
  473. package/lib/assets/docs/article/grokkingfp/java/part-1.md +646 -0
  474. package/lib/assets/docs/article/grokkingfp/java/part-2.md +667 -0
  475. package/lib/assets/docs/article/grokkingfp/java/part-3.md +672 -0
  476. package/lib/assets/docs/article/grokkingfp/java/part-4.md +771 -0
  477. package/lib/assets/docs/article/grokkingfp/java/part-5.md +959 -0
  478. package/lib/assets/docs/article/grokkingfp/java/part-6.md +1324 -0
  479. package/lib/assets/docs/article/grokkingfp/python/index.md +258 -0
  480. package/lib/assets/docs/article/grokkingfp/python/part-1.md +437 -0
  481. package/lib/assets/docs/article/grokkingfp/python/part-2.md +958 -0
  482. package/lib/assets/docs/article/grokkingfp/python/part-3.md +1004 -0
  483. package/lib/assets/docs/article/grokkingfp/python/part-4.md +765 -0
  484. package/lib/assets/docs/article/grokkingfp/python/part-5.md +747 -0
  485. package/lib/assets/docs/article/grokkingfp/python/part-6.md +861 -0
  486. package/lib/assets/docs/article/grokkingfp/ruby/index.md +330 -0
  487. package/lib/assets/docs/article/grokkingfp/ruby/part-1.md +753 -0
  488. package/lib/assets/docs/article/grokkingfp/ruby/part-2.md +938 -0
  489. package/lib/assets/docs/article/grokkingfp/ruby/part-3.md +946 -0
  490. package/lib/assets/docs/article/grokkingfp/ruby/part-4.md +921 -0
  491. package/lib/assets/docs/article/grokkingfp/ruby/part-5.md +908 -0
  492. package/lib/assets/docs/article/grokkingfp/ruby/part-6.md +1410 -0
  493. package/lib/assets/docs/article/grokkingfp/rust/index.md +242 -0
  494. package/lib/assets/docs/article/grokkingfp/rust/part-1.md +634 -0
  495. package/lib/assets/docs/article/grokkingfp/rust/part-2.md +1060 -0
  496. package/lib/assets/docs/article/grokkingfp/rust/part-3.md +994 -0
  497. package/lib/assets/docs/article/grokkingfp/rust/part-4.md +571 -0
  498. package/lib/assets/docs/article/grokkingfp/rust/part-5.md +705 -0
  499. package/lib/assets/docs/article/grokkingfp/rust/part-6.md +508 -0
  500. package/lib/assets/docs/article/grokkingfp/scala/index.md +171 -0
  501. package/lib/assets/docs/article/grokkingfp/scala/part-1.md +541 -0
  502. package/lib/assets/docs/article/grokkingfp/scala/part-2.md +946 -0
  503. package/lib/assets/docs/article/grokkingfp/scala/part-3.md +917 -0
  504. package/lib/assets/docs/article/grokkingfp/scala/part-4.md +742 -0
  505. package/lib/assets/docs/article/grokkingfp/scala/part-5.md +722 -0
  506. package/lib/assets/docs/article/grokkingfp/scala/part-6.md +865 -0
  507. package/lib/assets/docs/article/grokkingfp/typescript/index.md +273 -0
  508. package/lib/assets/docs/article/grokkingfp/typescript/part-1.md +559 -0
  509. package/lib/assets/docs/article/grokkingfp/typescript/part-2.md +1129 -0
  510. package/lib/assets/docs/article/grokkingfp/typescript/part-3.md +842 -0
  511. package/lib/assets/docs/article/grokkingfp/typescript/part-4.md +1085 -0
  512. package/lib/assets/docs/article/grokkingfp/typescript/part-5.md +717 -0
  513. package/lib/assets/docs/article/grokkingfp/typescript/part-6.md +980 -0
  514. package/lib/assets/docs/article/index.md +36 -0
  515. package/lib/assets/docs/design/index.md +39 -27
  516. package/lib/assets/docs/development/index.md +11 -1
  517. package/lib/assets/docs/index.md +33 -103
  518. package/lib/assets/docs/operation/index.md +16 -6
  519. package/lib/assets/docs/reference/index.md +5 -4
  520. package/lib/assets/docs/requirements/index.md +13 -6
  521. package/lib/assets/docs/review/index.md +5 -0
  522. package/lib/assets/docs/strategy/index.md +15 -0
  523. package/lib/assets/docs/template/index.md +9 -5
  524. package/lib/assets/mkdocs.yml +33 -19
  525. package/package.json +1 -1
  526. package/lib/assets/docs/analysis/index.md +0 -8
  527. /package/lib/assets/docs/{analysis → strategy}/slide/.gitkeep +0 -0
@@ -0,0 +1,508 @@
1
+ # Rust で学ぶ関数型プログラミング Part VI: 実践的アプリケーション構築
2
+
3
+ ## はじめに
4
+
5
+ Part V では並行処理(Arc、Mutex、チャネル)を学びました。Part VI では、これまで学んだ FP の概念を総動員して**実践的なアプリケーション**を構築します。
6
+
7
+ Scala では trait による抽象化、Resource によるリソース管理、そしてテスト戦略を学びますが、Rust でも同様のパターンを async-trait、RAII パターン、proptest を使って実現します。
8
+
9
+ ## 第12章: 実践的なアプリケーション構築
10
+
11
+ ### 12.1 ドメインモデルの定義
12
+
13
+ 実際のアプリケーション開発では、ドメインモデルを適切に定義することが重要です。TravelGuide アプリケーションを例に見ていきます。
14
+
15
+ ```rust
16
+ /// Newtype パターンで型安全な ID を定義
17
+ #[derive(Debug, Clone, PartialEq, Eq, Hash)]
18
+ pub struct LocationId(pub String);
19
+
20
+ impl LocationId {
21
+ pub fn new(id: &str) -> Self {
22
+ Self(id.to_string())
23
+ }
24
+ }
25
+
26
+ /// ロケーション
27
+ #[derive(Debug, Clone, PartialEq, Eq)]
28
+ pub struct Location {
29
+ pub id: LocationId,
30
+ pub name: String,
31
+ pub population: i32,
32
+ }
33
+
34
+ /// アトラクション(観光地)
35
+ #[derive(Debug, Clone, PartialEq, Eq)]
36
+ pub struct Attraction {
37
+ pub name: String,
38
+ pub description: Option<String>,
39
+ pub location: Location,
40
+ }
41
+
42
+ /// 旅行ガイド - 最終的な出力モデル
43
+ #[derive(Debug, Clone, PartialEq, Eq)]
44
+ pub struct TravelGuide {
45
+ pub attraction: Attraction,
46
+ pub subjects: Vec<String>, // 関連するアーティストや映画
47
+ pub search_report: SearchReport, // 検索メタデータ
48
+ }
49
+ ```
50
+
51
+ Scala と比較すると:
52
+
53
+ | Scala | Rust |
54
+ |-------|------|
55
+ | `case class LocationId(value: String)` | `struct LocationId(pub String)` |
56
+ | `Option[String]` | `Option<String>` |
57
+ | `List[String]` | `Vec<String>` |
58
+
59
+ ### 12.2 DataAccess トレイト - 依存性の抽象化
60
+
61
+ 外部データソースへのアクセスをトレイトで抽象化します。これにより、テスト時にスタブ実装に差し替えることができます。
62
+
63
+ ```rust
64
+ use async_trait::async_trait;
65
+
66
+ /// データアクセス層のトレイト
67
+ #[async_trait]
68
+ pub trait DataAccess: Send + Sync {
69
+ /// アトラクションを検索
70
+ async fn find_attractions(
71
+ &self,
72
+ name: &str,
73
+ ordering: AttractionOrdering,
74
+ limit: usize,
75
+ ) -> Vec<Attraction>;
76
+
77
+ /// ロケーションからアーティストを検索
78
+ async fn find_artists_from_location(
79
+ &self,
80
+ location_id: &LocationId,
81
+ limit: usize,
82
+ ) -> Result<Vec<MusicArtist>, String>;
83
+
84
+ /// ロケーションに関する映画を検索
85
+ async fn find_movies_about_location(
86
+ &self,
87
+ location_id: &LocationId,
88
+ limit: usize,
89
+ ) -> Result<Vec<Movie>, String>;
90
+ }
91
+ ```
92
+
93
+ Scala の trait と比較:
94
+
95
+ | Scala | Rust |
96
+ |-------|------|
97
+ | `trait DataAccess[F[_]]` | `#[async_trait] trait DataAccess` |
98
+ | `def findAttractions(...): F[List[Attraction]]` | `async fn find_attractions(...) -> Vec<Attraction>` |
99
+ | `F[Either[String, List[A]]]` | `Result<Vec<A>, String>` |
100
+
101
+ ### 12.3 テスト用スタブ実装
102
+
103
+ Builder パターンを使って柔軟にテストデータを設定できるスタブ実装を作成します。
104
+
105
+ ```rust
106
+ pub struct StubDataAccess {
107
+ attractions: Vec<Attraction>,
108
+ artists: HashMap<LocationId, Vec<MusicArtist>>,
109
+ movies: HashMap<LocationId, Vec<Movie>>,
110
+ artists_error: Option<String>,
111
+ movies_error: Option<String>,
112
+ }
113
+
114
+ impl StubDataAccess {
115
+ pub fn new() -> Self {
116
+ Self {
117
+ attractions: vec![],
118
+ artists: HashMap::new(),
119
+ movies: HashMap::new(),
120
+ artists_error: None,
121
+ movies_error: None,
122
+ }
123
+ }
124
+
125
+ // Builder パターンでメソッドチェーン
126
+ pub fn with_attractions(mut self, attractions: Vec<Attraction>) -> Self {
127
+ self.attractions = attractions;
128
+ self
129
+ }
130
+
131
+ pub fn with_artists(mut self, location_id: LocationId, artists: Vec<MusicArtist>) -> Self {
132
+ self.artists.insert(location_id, artists);
133
+ self
134
+ }
135
+
136
+ pub fn with_artists_error(mut self, error: &str) -> Self {
137
+ self.artists_error = Some(error.to_string());
138
+ self
139
+ }
140
+ }
141
+ ```
142
+
143
+ 使用例:
144
+
145
+ ```rust
146
+ #[tokio::test]
147
+ async fn test_travel_guide_with_error() {
148
+ let data = Arc::new(
149
+ StubDataAccess::new()
150
+ .with_attractions(vec![create_test_attraction()])
151
+ .with_artists_error("Artist service unavailable")
152
+ );
153
+
154
+ let guide = travel_guide(data.as_ref(), "Test").await;
155
+
156
+ assert!(guide.is_some());
157
+ assert!(!guide.unwrap().search_report.errors.is_empty());
158
+ }
159
+ ```
160
+
161
+ ### 12.4 キャッシュ付き DataAccess
162
+
163
+ デコレーターパターンを使って、既存の DataAccess にキャッシュ機能を追加します。
164
+
165
+ ```rust
166
+ pub struct CachedDataAccess<D: DataAccess> {
167
+ inner: Arc<D>,
168
+ attractions_cache: Arc<RwLock<HashMap<String, Vec<Attraction>>>>,
169
+ }
170
+
171
+ impl<D: DataAccess> CachedDataAccess<D> {
172
+ pub fn new(inner: Arc<D>) -> Self {
173
+ Self {
174
+ inner,
175
+ attractions_cache: Arc::new(RwLock::new(HashMap::new())),
176
+ }
177
+ }
178
+
179
+ fn cache_key(name: &str, ordering: AttractionOrdering, limit: usize) -> String {
180
+ format!("{}-{:?}-{}", name, ordering, limit)
181
+ }
182
+ }
183
+
184
+ #[async_trait]
185
+ impl<D: DataAccess + 'static> DataAccess for CachedDataAccess<D> {
186
+ async fn find_attractions(
187
+ &self,
188
+ name: &str,
189
+ ordering: AttractionOrdering,
190
+ limit: usize,
191
+ ) -> Vec<Attraction> {
192
+ let key = Self::cache_key(name, ordering, limit);
193
+
194
+ // キャッシュを確認(読み取りロック)
195
+ {
196
+ let cache = self.attractions_cache.read().await;
197
+ if let Some(cached) = cache.get(&key) {
198
+ return cached.clone();
199
+ }
200
+ }
201
+
202
+ // キャッシュにない場合は取得
203
+ let result = self.inner.find_attractions(name, ordering, limit).await;
204
+
205
+ // キャッシュに保存(書き込みロック)
206
+ {
207
+ let mut cache = self.attractions_cache.write().await;
208
+ cache.insert(key, result.clone());
209
+ }
210
+
211
+ result
212
+ }
213
+
214
+ // 他のメソッドは inner に委譲
215
+ }
216
+ ```
217
+
218
+ ### 12.5 TravelGuide アプリケーション
219
+
220
+ トレイトを使った依存性注入により、ビジネスロジックをテスト可能な形で実装します。
221
+
222
+ ```rust
223
+ /// 旅行ガイドを生成
224
+ pub async fn travel_guide(
225
+ data: &dyn DataAccess,
226
+ attraction_name: &str,
227
+ ) -> Option<TravelGuide> {
228
+ // アトラクションを検索
229
+ let attractions = data
230
+ .find_attractions(attraction_name, AttractionOrdering::ByLocationPopulation, 1)
231
+ .await;
232
+
233
+ let attraction = attractions.into_iter().next()?;
234
+
235
+ // 関連情報を並行して取得
236
+ let artists_result = data
237
+ .find_artists_from_location(&attraction.location.id, 2)
238
+ .await;
239
+ let movies_result = data
240
+ .find_movies_about_location(&attraction.location.id, 2)
241
+ .await;
242
+
243
+ // エラーを収集(失敗しても継続)
244
+ let mut errors = Vec::new();
245
+ if let Err(e) = &artists_result {
246
+ errors.push(e.clone());
247
+ }
248
+ if let Err(e) = &movies_result {
249
+ errors.push(e.clone());
250
+ }
251
+
252
+ // 成功した結果を結合
253
+ let artists = artists_result.unwrap_or_default();
254
+ let movies = movies_result.unwrap_or_default();
255
+
256
+ let subjects: Vec<String> = artists
257
+ .into_iter()
258
+ .map(|a| a.name)
259
+ .chain(movies.into_iter().map(|m| m.name))
260
+ .collect();
261
+
262
+ Some(TravelGuide::new(
263
+ attraction,
264
+ subjects,
265
+ SearchReport::new(1, errors),
266
+ ))
267
+ }
268
+ ```
269
+
270
+ ### 12.6 純粋関数ユーティリティ
271
+
272
+ 副作用のない純粋関数は、単体テストが容易で再利用性が高いです。
273
+
274
+ ```rust
275
+ /// 人口でロケーションをフィルタリング
276
+ pub fn filter_popular_locations(locations: Vec<Location>, min_population: i32) -> Vec<Location> {
277
+ locations
278
+ .into_iter()
279
+ .filter(|loc| loc.population >= min_population)
280
+ .collect()
281
+ }
282
+
283
+ /// 人口順でソート
284
+ pub fn sort_by_population(mut locations: Vec<Location>) -> Vec<Location> {
285
+ locations.sort_by(|a, b| b.population.cmp(&a.population));
286
+ locations
287
+ }
288
+
289
+ /// 複数のサブジェクトを結合
290
+ pub fn combine_subjects(subjects_list: Vec<Vec<String>>) -> Vec<String> {
291
+ subjects_list.into_iter().flatten().collect()
292
+ }
293
+
294
+ /// 複数の SearchReport を集約
295
+ pub fn aggregate_reports(reports: Vec<SearchReport>) -> SearchReport {
296
+ let total_searched = reports.iter().map(|r| r.attractions_searched).sum();
297
+ let all_errors: Vec<String> = reports.into_iter().flat_map(|r| r.errors).collect();
298
+ SearchReport::new(total_searched, all_errors)
299
+ }
300
+ ```
301
+
302
+ ### 12.7 リソース管理パターン
303
+
304
+ Scala の Resource に相当する概念を Rust で実装します。
305
+
306
+ ```rust
307
+ /// リソース管理のトレイト
308
+ pub trait Resource {
309
+ type Item;
310
+
311
+ fn use_resource<F, R>(&self, f: F) -> R
312
+ where
313
+ F: FnOnce(&Self::Item) -> R;
314
+ }
315
+
316
+ /// ファイルリソース
317
+ pub struct FileResource {
318
+ path: String,
319
+ }
320
+
321
+ impl Resource for FileResource {
322
+ type Item = Result<String, std::io::Error>;
323
+
324
+ fn use_resource<F, R>(&self, f: F) -> R
325
+ where
326
+ F: FnOnce(&Self::Item) -> R,
327
+ {
328
+ let content = std::fs::read_to_string(&self.path);
329
+ f(&content)
330
+ }
331
+ }
332
+ ```
333
+
334
+ Rust の強みは、RAII(Resource Acquisition Is Initialization)パターンにより、リソースの解放が自動的に行われることです。
335
+
336
+ ### 12.8 バリデーション
337
+
338
+ 独自のバリデーション型を定義して、型安全なバリデーションを実装します。
339
+
340
+ ```rust
341
+ #[derive(Debug, Clone, PartialEq, Eq)]
342
+ pub enum Validation<T> {
343
+ Valid(T),
344
+ Invalid(Vec<String>),
345
+ }
346
+
347
+ impl<T> Validation<T> {
348
+ pub fn valid(value: T) -> Self {
349
+ Validation::Valid(value)
350
+ }
351
+
352
+ pub fn invalid(errors: Vec<String>) -> Self {
353
+ Validation::Invalid(errors)
354
+ }
355
+
356
+ pub fn is_valid(&self) -> bool {
357
+ matches!(self, Validation::Valid(_))
358
+ }
359
+
360
+ pub fn map<U, F>(self, f: F) -> Validation<U>
361
+ where
362
+ F: FnOnce(T) -> U,
363
+ {
364
+ match self {
365
+ Validation::Valid(v) => Validation::Valid(f(v)),
366
+ Validation::Invalid(e) => Validation::Invalid(e),
367
+ }
368
+ }
369
+
370
+ pub fn and_then<U, F>(self, f: F) -> Validation<U>
371
+ where
372
+ F: FnOnce(T) -> Validation<U>,
373
+ {
374
+ match self {
375
+ Validation::Valid(v) => f(v),
376
+ Validation::Invalid(e) => Validation::Invalid(e),
377
+ }
378
+ }
379
+ }
380
+
381
+ /// Location のバリデーション
382
+ pub fn validate_location(location: Location) -> Validation<Location> {
383
+ let mut errors = Vec::new();
384
+
385
+ if location.name.trim().is_empty() {
386
+ errors.push("Name cannot be empty".to_string());
387
+ }
388
+ if location.population < 0 {
389
+ errors.push("Population cannot be negative".to_string());
390
+ }
391
+
392
+ if errors.is_empty() {
393
+ Validation::valid(location)
394
+ } else {
395
+ Validation::invalid(errors)
396
+ }
397
+ }
398
+ ```
399
+
400
+ ### 12.9 プロパティベーステスト
401
+
402
+ proptest を使って、ランダムな入力に対する不変条件をテストします。
403
+
404
+ ```rust
405
+ use proptest::prelude::*;
406
+
407
+ proptest! {
408
+ /// ソートは要素を保持する
409
+ #[test]
410
+ fn sort_by_population_preserves_elements(
411
+ populations in prop::collection::vec(0i32..10_000_000, 0..10)
412
+ ) {
413
+ let locations: Vec<Location> = populations
414
+ .iter()
415
+ .enumerate()
416
+ .map(|(i, &pop)| Location::new(
417
+ LocationId::new(&format!("loc{}", i)),
418
+ &format!("City{}", i),
419
+ pop,
420
+ ))
421
+ .collect();
422
+
423
+ let sorted = sort_by_population(locations.clone());
424
+
425
+ prop_assert_eq!(sorted.len(), locations.len());
426
+ }
427
+
428
+ /// ソート結果は降順
429
+ #[test]
430
+ fn sort_by_population_is_sorted(
431
+ populations in prop::collection::vec(0i32..10_000_000, 0..10)
432
+ ) {
433
+ let locations: Vec<Location> = populations
434
+ .iter()
435
+ .enumerate()
436
+ .map(|(i, &pop)| Location::new(
437
+ LocationId::new(&format!("loc{}", i)),
438
+ &format!("City{}", i),
439
+ pop,
440
+ ))
441
+ .collect();
442
+
443
+ let sorted = sort_by_population(locations);
444
+
445
+ for window in sorted.windows(2) {
446
+ prop_assert!(window[0].population >= window[1].population);
447
+ }
448
+ }
449
+
450
+ /// 空の名前は無効
451
+ #[test]
452
+ fn validate_location_empty_name_is_invalid(
453
+ population in 0i32..10_000_000
454
+ ) {
455
+ let location = Location::new(LocationId::new("test"), "", population);
456
+ let result = validate_location(location);
457
+ prop_assert!(!result.is_valid());
458
+ }
459
+
460
+ /// 負の人口は無効
461
+ #[test]
462
+ fn validate_location_negative_population_is_invalid(
463
+ name in "[a-zA-Z]+",
464
+ population in i32::MIN..-1i32
465
+ ) {
466
+ let location = Location::new(LocationId::new("test"), &name, population);
467
+ let result = validate_location(location);
468
+ prop_assert!(!result.is_valid());
469
+ }
470
+ }
471
+ ```
472
+
473
+ Scala の ScalaCheck と比較:
474
+
475
+ | ScalaCheck | proptest |
476
+ |------------|----------|
477
+ | `forAll { (n: Int) => ... }` | `proptest! { fn test(n in any::<i32>()) { ... } }` |
478
+ | `Gen.choose(0, 100)` | `0i32..100` |
479
+ | `Gen.listOfN(10, gen)` | `prop::collection::vec(gen, 0..10)` |
480
+ | `Prop.passed` | `prop_assert!(true)` |
481
+
482
+ ## まとめ
483
+
484
+ Part VI で学んだ重要なポイント:
485
+
486
+ 1. **ドメインモデル**: Newtype パターンで型安全性を確保
487
+ 2. **トレイト抽象化**: `async_trait` で非同期メソッドを持つトレイトを定義
488
+ 3. **依存性注入**: トレイトオブジェクト (`&dyn DataAccess`) で実装を差し替え可能に
489
+ 4. **デコレーターパターン**: キャッシュなどの横断的関心事を分離
490
+ 5. **純粋関数**: テスタブルで再利用可能なユーティリティ
491
+ 6. **バリデーション**: 独自型でエラーを収集
492
+ 7. **プロパティベーステスト**: ランダム入力で不変条件を検証
493
+
494
+ Scala と Rust の対応表:
495
+
496
+ | 概念 | Scala | Rust |
497
+ |------|-------|------|
498
+ | 非同期トレイト | `trait DataAccess[F[_]]` | `#[async_trait] trait DataAccess` |
499
+ | テストスタブ | `Stub extends DataAccess` | `impl DataAccess for StubDataAccess` |
500
+ | リソース管理 | `Resource[IO, A]` | `trait Resource` / RAII |
501
+ | バリデーション | `Validated[E, A]` | `enum Validation<T>` |
502
+ | プロパティテスト | ScalaCheck | proptest |
503
+
504
+ ## 参考リンク
505
+
506
+ - [async-trait crate](https://docs.rs/async-trait/)
507
+ - [proptest crate](https://docs.rs/proptest/)
508
+ - [Rust Design Patterns](https://rust-unofficial.github.io/patterns/)
@@ -0,0 +1,171 @@
1
+ # Grokking Functional Programming 日本語解説
2
+
3
+ 本シリーズは「Grokking Functional Programming」(Michał Płachta 著)の学習コンパニオンとして、関数型プログラミングの概念を日本語で解説します。
4
+
5
+ ---
6
+
7
+ ## 対象読者
8
+
9
+ - Java や OOP の経験があり、関数型プログラミングに興味がある開発者
10
+ - Scala を学びたいが、FP の概念から理解したい方
11
+ - 実践的な FP の適用方法を知りたいエンジニア
12
+
13
+ ---
14
+
15
+ ## 記事一覧
16
+
17
+ ### [Part I: 関数型プログラミングの基礎](part-1.md)
18
+
19
+ 関数型プログラミングの基本概念を学びます。
20
+
21
+ | 章 | トピック |
22
+ |----|----------|
23
+ | 第1章 | 命令型 vs 関数型、Scala 基本構文 |
24
+ | 第2章 | 純粋関数、副作用の排除、テストの容易さ |
25
+
26
+ **キーワード**: 純粋関数、参照透過性、副作用
27
+
28
+ ---
29
+
30
+ ### [Part II: 関数型スタイルのプログラミング](part-2.md)
31
+
32
+ イミュータブルなデータ操作と高階関数を学びます。
33
+
34
+ | 章 | トピック |
35
+ |----|----------|
36
+ | 第3章 | イミュータブルデータ、List 操作 |
37
+ | 第4章 | 高階関数、map/filter/foldLeft |
38
+ | 第5章 | flatMap、for 内包表記 |
39
+
40
+ **キーワード**: イミュータブル、高階関数、flatMap、for 内包表記
41
+
42
+ ---
43
+
44
+ ### [Part III: エラーハンドリングと Option/Either](part-3.md)
45
+
46
+ 型安全なエラーハンドリングを学びます。
47
+
48
+ | 章 | トピック |
49
+ |----|----------|
50
+ | 第6章 | Option 型、Some/None |
51
+ | 第7章 | Either 型、ADT、パターンマッチング |
52
+
53
+ **キーワード**: Option、Either、代数的データ型(ADT)
54
+
55
+ ---
56
+
57
+ ### [Part IV: IO と副作用の管理](part-4.md)
58
+
59
+ IO モナドとストリーム処理を学びます。
60
+
61
+ | 章 | トピック |
62
+ |----|----------|
63
+ | 第8章 | IO モナド、cats-effect |
64
+ | 第9章 | fs2 Stream、無限ストリーム |
65
+
66
+ **キーワード**: IO モナド、遅延評価、ストリーム処理
67
+
68
+ ---
69
+
70
+ ### [Part V: 並行処理](part-5.md)
71
+
72
+ 関数型プログラミングにおける並行処理を学びます。
73
+
74
+ | 章 | トピック |
75
+ |----|----------|
76
+ | 第10章 | Ref、Fiber、parSequence |
77
+
78
+ **キーワード**: 並行処理、Ref、Fiber、軽量スレッド
79
+
80
+ ---
81
+
82
+ ### [Part VI: 実践的なアプリケーション構築とテスト](part-6.md)
83
+
84
+ 実践的なアプリケーション構築とテスト戦略を学びます。
85
+
86
+ | 章 | トピック |
87
+ |----|----------|
88
+ | 第11章 | TravelGuide アプリ、Resource、キャッシュ |
89
+ | 第12章 | テスト戦略、プロパティベーステスト |
90
+
91
+ **キーワード**: Resource、DataAccess 抽象化、ScalaCheck
92
+
93
+ ---
94
+
95
+ ## 学習パス
96
+
97
+ ```plantuml
98
+ @startuml
99
+ !theme plain
100
+ left to right direction
101
+
102
+ rectangle "学習の流れ" {
103
+ card "Part I\n基礎" as p1
104
+ card "Part II\nイミュータブル操作" as p2
105
+ card "Part III\n型による安全性" as p3
106
+ card "Part IV\nIO/Stream" as p4
107
+ card "Part V\n並行処理" as p5
108
+ card "Part VI\n実践" as p6
109
+ }
110
+
111
+ p1 --> p2
112
+ p2 --> p3
113
+ p3 --> p4
114
+ p4 --> p5
115
+ p5 --> p6
116
+
117
+ @enduml
118
+ ```
119
+
120
+ ---
121
+
122
+ ## 使用ライブラリ
123
+
124
+ | ライブラリ | 用途 | 対応章 |
125
+ |------------|------|--------|
126
+ | Scala 3 | 言語 | 全章 |
127
+ | cats-effect | IO モナド | Part IV-VI |
128
+ | fs2 | ストリーム処理 | Part IV-V |
129
+ | ScalaCheck | プロパティベーステスト | Part VI |
130
+
131
+ ---
132
+
133
+ ## リポジトリ構成
134
+
135
+ ```
136
+ grokkingfp-examples/
137
+ ├── app/scala/src/main/scala/ # Scala のサンプルコード
138
+ ├── app/java/src/main/java/ # Java の比較用コード
139
+ ├── src/test/scala/ # テストコード
140
+ ├── docs/journal/ # 開発履歴
141
+ └── docs/article/ # 解説記事(本ディレクトリ)
142
+ ├── index.md # この記事
143
+ ├── outline.md # アウトライン
144
+ ├── part-1.md # Part I
145
+ ├── part-2.md # Part II
146
+ ├── part-3.md # Part III
147
+ ├── part-4.md # Part IV
148
+ ├── part-5.md # Part V
149
+ └── part-6.md # Part VI
150
+ ```
151
+
152
+ ---
153
+
154
+ ## 関数型プログラミングの利点
155
+
156
+ 本シリーズを通じて、以下の利点を実感できます:
157
+
158
+ 1. **予測可能性** - 純粋関数は同じ入力に対して常に同じ出力
159
+ 2. **テスト容易性** - 副作用がないためテストが簡単
160
+ 3. **合成可能性** - 小さな関数を組み合わせて複雑な処理を構築
161
+ 4. **並行安全性** - イミュータブルデータは競合状態を防ぐ
162
+ 5. **型安全性** - Option、Either で null や例外を型で表現
163
+
164
+ ---
165
+
166
+ ## 参考資料
167
+
168
+ - [Grokking Functional Programming](https://www.manning.com/books/grokking-functional-programming) - 原著
169
+ - [Scala 公式ドキュメント](https://docs.scala-lang.org/)
170
+ - [cats-effect ドキュメント](https://typelevel.org/cats-effect/)
171
+ - [fs2 ドキュメント](https://fs2.io/)