@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,1060 @@
1
+ # Part II: 関数型スタイルのプログラミング
2
+
3
+ 本章では、関数型プログラミングの核心となるテクニックを学びます。イミュータブルなデータ操作、高階関数、そして `flat_map` による複雑なデータ変換を習得します。
4
+
5
+ ---
6
+
7
+ ## 第3章: イミュータブルなデータ操作
8
+
9
+ ### 3.1 イミュータブルとは
10
+
11
+ Rust ではデフォルトで変数は不変(イミュータブル)です。これは関数型プログラミングの重要な原則と一致しています。
12
+
13
+ **ソースファイル**: `app/rust/src/ch03_immutable_data.rs`
14
+
15
+ ```plantuml
16
+ @startuml
17
+ !theme plain
18
+
19
+ rectangle "ミュータブル(可変)" as mut {
20
+ card "let mut list = vec![A, B]" as m1
21
+ card "list.push(C)" as m2
22
+ card "list = [A, B, C]" as m3
23
+ m1 --> m2 : 変更
24
+ m2 --> m3 : 同じリストが変わる
25
+ }
26
+
27
+ rectangle "イミュータブル(不変)" as immut {
28
+ card "let list1 = vec![A, B]" as i1
29
+ card "let list2 = appended(&list1, C)" as i2
30
+ card "list1 = [A, B]\nlist2 = [A, B, C]" as i3
31
+ i1 --> i2 : 新規作成
32
+ i2 --> i3 : 両方が存在
33
+ }
34
+
35
+ @enduml
36
+ ```
37
+
38
+ ```rust
39
+ let list = vec!["Apple", "Book"];
40
+ // list.push("Mango"); // コンパイルエラー!不変だから
41
+
42
+ // 新しい Vec を作成する
43
+ let mut new_list = list.clone();
44
+ new_list.push("Mango");
45
+
46
+ assert_eq!(list.len(), 2); // 元のリストは変わらない
47
+ assert_eq!(new_list.len(), 3); // 新しいリストに追加された
48
+ ```
49
+
50
+ ### 3.2 Vec の基本操作
51
+
52
+ #### appended - 要素の追加
53
+
54
+ 元の Vec を変更せず、新しい Vec を返す関数を作成します。
55
+
56
+ ```rust
57
+ pub fn appended<T: Clone>(list: &[T], element: T) -> Vec<T> {
58
+ let mut result = list.to_vec();
59
+ result.push(element);
60
+ result
61
+ }
62
+
63
+ let apple_book = vec!["Apple", "Book"];
64
+ let apple_book_mango = appended(&apple_book, "Mango");
65
+
66
+ assert_eq!(apple_book.len(), 2); // 元のリストは変わらない
67
+ assert_eq!(apple_book_mango.len(), 3);
68
+ assert_eq!(apple_book_mango, vec!["Apple", "Book", "Mango"]);
69
+ ```
70
+
71
+ #### slice - リストの切り出し
72
+
73
+ Rust のスライスを使って部分的なデータを取得します。
74
+
75
+ ```rust
76
+ pub fn first_two<T: Clone>(list: &[T]) -> Vec<T> {
77
+ list.iter().take(2).cloned().collect()
78
+ }
79
+
80
+ pub fn last_two<T: Clone>(list: &[T]) -> Vec<T> {
81
+ let len = list.len();
82
+ if len <= 2 {
83
+ list.to_vec()
84
+ } else {
85
+ list[len - 2..].to_vec()
86
+ }
87
+ }
88
+
89
+ assert_eq!(first_two(&["a", "b", "c"]), vec!["a", "b"]);
90
+ assert_eq!(last_two(&["a", "b", "c"]), vec!["b", "c"]);
91
+ ```
92
+
93
+ ```plantuml
94
+ @startuml
95
+ !theme plain
96
+
97
+ rectangle "スライス操作" {
98
+ card "vec![\"a\", \"b\", \"c\", \"d\"]" as orig
99
+ card "&list[1..3]" as op
100
+ card "[\"b\", \"c\"]" as result
101
+
102
+ orig --> op
103
+ op --> result
104
+ }
105
+
106
+ note bottom of result
107
+ インデックス 1 から 3 の手前まで
108
+ (end は含まない)
109
+ end note
110
+
111
+ @enduml
112
+ ```
113
+
114
+ ### 3.3 リストの変換例
115
+
116
+ ```rust
117
+ /// 最初の2要素を末尾に移動
118
+ pub fn move_first_two_to_end<T: Clone>(list: &[T]) -> Vec<T> {
119
+ if list.len() <= 2 {
120
+ return list.to_vec();
121
+ }
122
+ let first_two = &list[..2];
123
+ let without_first_two = &list[2..];
124
+ appended_all(without_first_two, first_two)
125
+ }
126
+
127
+ assert_eq!(
128
+ move_first_two_to_end(&["a", "b", "c"]),
129
+ vec!["c", "a", "b"]
130
+ );
131
+
132
+ /// 最後の要素の前に新しい要素を挿入
133
+ pub fn insert_before_last<T: Clone>(list: &[T], element: T) -> Vec<T> {
134
+ if list.is_empty() {
135
+ return vec![element];
136
+ }
137
+ let len = list.len();
138
+ let without_last = &list[..len - 1];
139
+ let last = &list[len - 1..];
140
+ let mut result = without_last.to_vec();
141
+ result.push(element);
142
+ result.extend_from_slice(last);
143
+ result
144
+ }
145
+
146
+ assert_eq!(insert_before_last(&["a", "b"], "c"), vec!["a", "c", "b"]);
147
+ ```
148
+
149
+ ### 3.4 旅程の再計画
150
+
151
+ 旅行の計画変更をイミュータブルに行う例です。
152
+
153
+ ```rust
154
+ pub fn replan<'a>(plan: &[&'a str], new_city: &'a str, before_city: &str) -> Vec<&'a str> {
155
+ let before_city_index = plan.iter().position(|&c| c == before_city);
156
+
157
+ match before_city_index {
158
+ Some(index) => {
159
+ let cities_before = &plan[..index];
160
+ let cities_after = &plan[index..];
161
+ let mut result = cities_before.to_vec();
162
+ result.push(new_city);
163
+ result.extend_from_slice(cities_after);
164
+ result
165
+ }
166
+ None => {
167
+ let mut result = plan.to_vec();
168
+ result.push(new_city);
169
+ result
170
+ }
171
+ }
172
+ }
173
+
174
+ let plan_a = vec!["Paris", "Berlin", "Kraków"];
175
+ let plan_b = replan(&plan_a, "Vienna", "Kraków");
176
+
177
+ assert_eq!(plan_b, vec!["Paris", "Berlin", "Vienna", "Kraków"]);
178
+ assert_eq!(plan_a, vec!["Paris", "Berlin", "Kraków"]); // 元の計画は変わらない!
179
+ ```
180
+
181
+ ```plantuml
182
+ @startuml
183
+ !theme plain
184
+
185
+ rectangle "旅程の再計画" {
186
+ card "Plan A:\nParis → Berlin → Kraków" as planA
187
+ card "replan(&plan_a, \"Vienna\", \"Kraków\")" as op
188
+ card "Plan B:\nParis → Berlin → Vienna → Kraków" as planB
189
+
190
+ planA --> op
191
+ op --> planB
192
+ }
193
+
194
+ note right of planA
195
+ Plan A は変更されない
196
+ (イミュータブル)
197
+ end note
198
+
199
+ @enduml
200
+ ```
201
+
202
+ ### 3.5 String とスライスの類似性
203
+
204
+ Rust の `&str` と `&[T]` は似た操作ができます。
205
+
206
+ | 操作 | Vec/スライス | String/&str |
207
+ |------|-------------|-------------|
208
+ | 結合 | `extend_from_slice` | `push_str`, `+` |
209
+ | 切り出し | `&list[start..end]` | `&s[start..end]` |
210
+ | サイズ | `len()` | `len()` |
211
+
212
+ ```rust
213
+ pub fn abbreviate(name: &str) -> String {
214
+ if let Some(space_index) = name.find(' ') {
215
+ let initial = &name[..1];
216
+ let last_name = &name[space_index + 1..];
217
+ format!("{}. {}", initial, last_name)
218
+ } else {
219
+ name.to_string()
220
+ }
221
+ }
222
+
223
+ assert_eq!(abbreviate("Alonzo Church"), "A. Church");
224
+ assert_eq!(abbreviate("Alan Turing"), "A. Turing");
225
+ ```
226
+
227
+ ---
228
+
229
+ ## 第4章: 関数を値として扱う
230
+
231
+ ### 4.1 高階関数とは
232
+
233
+ 高階関数(Higher-Order Function)とは、以下のいずれかを満たす関数です:
234
+
235
+ 1. 関数を引数として受け取る
236
+ 2. 関数を戻り値として返す
237
+
238
+ **ソースファイル**: `app/rust/src/ch04_higher_order.rs`
239
+
240
+ ```plantuml
241
+ @startuml
242
+ !theme plain
243
+
244
+ rectangle "高階関数" {
245
+ rectangle "関数を引数に取る" as arg {
246
+ card "sort_by(key_fn)" as sortBy
247
+ card "map(transform)" as map
248
+ card "filter(predicate)" as filter
249
+ }
250
+
251
+ rectangle "関数を返す" as ret {
252
+ card "larger_than(n)" as larger
253
+ card "divisible_by(n)" as divisible
254
+ }
255
+ }
256
+
257
+ @enduml
258
+ ```
259
+
260
+ ### 4.2 関数を引数として渡す
261
+
262
+ #### sort_by - ソート基準を関数で指定
263
+
264
+ ```rust
265
+ pub fn score(word: &str) -> usize {
266
+ word.chars().filter(|&c| c != 'a').count()
267
+ }
268
+
269
+ pub fn sort_by_score<T, F, K>(list: &[T], key_fn: F) -> Vec<T>
270
+ where
271
+ T: Clone,
272
+ F: Fn(&T) -> K,
273
+ K: Ord,
274
+ {
275
+ let mut result = list.to_vec();
276
+ result.sort_by_key(|item| key_fn(item));
277
+ result
278
+ }
279
+
280
+ let words = vec!["rust", "java"];
281
+ let sorted = sort_by_score(&words, |w| score(w));
282
+
283
+ assert_eq!(sorted, vec!["java", "rust"]);
284
+ // java: 2文字 (j, v), rust: 4文字 (r, u, s, t)
285
+ ```
286
+
287
+ #### map - 各要素を変換
288
+
289
+ Rust のイテレータには `map` メソッドが組み込まれています。
290
+
291
+ ```rust
292
+ let lengths: Vec<usize> = vec!["scala", "rust", "ada"]
293
+ .iter()
294
+ .map(|s| s.len())
295
+ .collect();
296
+ assert_eq!(lengths, vec![5, 4, 3]);
297
+
298
+ let doubles: Vec<i32> = vec![5, 1, 2, 4, 0]
299
+ .iter()
300
+ .map(|&i| i * 2)
301
+ .collect();
302
+ assert_eq!(doubles, vec![10, 2, 4, 8, 0]);
303
+ ```
304
+
305
+ ```plantuml
306
+ @startuml
307
+ !theme plain
308
+
309
+ rectangle "map の動作" {
310
+ card "[\"scala\", \"rust\", \"ada\"]" as input
311
+ card "len() を各要素に適用" as op
312
+ card "[5, 4, 3]" as output
313
+
314
+ input --> op
315
+ op --> output
316
+ }
317
+
318
+ @enduml
319
+ ```
320
+
321
+ #### filter - 条件に合う要素を抽出
322
+
323
+ ```rust
324
+ let odds: Vec<i32> = vec![5, 1, 2, 4, 0]
325
+ .iter()
326
+ .filter(|&&i| i % 2 == 1)
327
+ .cloned()
328
+ .collect();
329
+ assert_eq!(odds, vec![5, 1]);
330
+
331
+ let large: Vec<i32> = vec![5, 1, 2, 4, 0]
332
+ .iter()
333
+ .filter(|&&i| i > 4)
334
+ .cloned()
335
+ .collect();
336
+ assert_eq!(large, vec![5]);
337
+ ```
338
+
339
+ #### fold - 畳み込み
340
+
341
+ Rust では `fold` メソッドを使います(Scala の `foldLeft` 相当)。
342
+
343
+ ```rust
344
+ let sum = vec![5, 1, 2, 4, 100]
345
+ .iter()
346
+ .fold(0, |acc, &i| acc + i);
347
+ assert_eq!(sum, 112);
348
+
349
+ let max = vec![5, 1, 2, 4, 15]
350
+ .iter()
351
+ .fold(i32::MIN, |max, &i| if i > max { i } else { max });
352
+ assert_eq!(max, 15);
353
+ ```
354
+
355
+ ```plantuml
356
+ @startuml
357
+ !theme plain
358
+
359
+ rectangle "fold の動作" {
360
+ card "初期値: 0" as init
361
+ card "0 + 5 = 5" as s1
362
+ card "5 + 1 = 6" as s2
363
+ card "6 + 2 = 8" as s3
364
+ card "8 + 4 = 12" as s4
365
+ card "12 + 100 = 112" as s5
366
+
367
+ init --> s1
368
+ s1 --> s2
369
+ s2 --> s3
370
+ s3 --> s4
371
+ s4 --> s5
372
+ }
373
+
374
+ @enduml
375
+ ```
376
+
377
+ ### 4.3 構造体とパターン
378
+
379
+ ```rust
380
+ #[derive(Debug, Clone, PartialEq)]
381
+ pub struct ProgrammingLanguage {
382
+ pub name: String,
383
+ pub year: i32,
384
+ }
385
+
386
+ impl ProgrammingLanguage {
387
+ pub fn new(name: &str, year: i32) -> Self {
388
+ Self {
389
+ name: name.to_string(),
390
+ year,
391
+ }
392
+ }
393
+ }
394
+
395
+ let java = ProgrammingLanguage::new("Java", 1995);
396
+ let scala = ProgrammingLanguage::new("Scala", 2004);
397
+ let languages = vec![java.clone(), scala.clone()];
398
+
399
+ // フィールドにアクセス
400
+ let names: Vec<String> = languages.iter().map(|lang| lang.name.clone()).collect();
401
+ assert_eq!(names, vec!["Java", "Scala"]);
402
+
403
+ // 条件でフィルタ
404
+ let young: Vec<_> = languages.iter().filter(|lang| lang.year > 2000).collect();
405
+ assert_eq!(young.len(), 1);
406
+ ```
407
+
408
+ ### 4.4 関数を返す関数
409
+
410
+ Rust ではクロージャを返すことで、関数を返す関数を実現します。
411
+
412
+ ```rust
413
+ pub fn larger_than(n: i32) -> impl Fn(i32) -> bool {
414
+ move |i| i > n
415
+ }
416
+
417
+ let larger_than_4 = larger_than(4);
418
+ assert!(larger_than_4(5));
419
+ assert!(!larger_than_4(4));
420
+
421
+ // filter で使う場合
422
+ let large: Vec<i32> = vec![5, 1, 2, 4, 0]
423
+ .into_iter()
424
+ .filter(|&x| larger_than(4)(x))
425
+ .collect();
426
+ assert_eq!(large, vec![5]);
427
+ ```
428
+
429
+ ```plantuml
430
+ @startuml
431
+ !theme plain
432
+
433
+ rectangle "関数を返す関数" {
434
+ card "larger_than(4)" as call
435
+ card "move |i| i > 4" as fn
436
+ card "filter に渡す" as filter
437
+
438
+ call --> fn : クロージャを生成
439
+ fn --> filter : 生成されたクロージャを使用
440
+ }
441
+
442
+ note bottom
443
+ larger_than(4) は
444
+ 「4より大きいか判定するクロージャ」を返す
445
+ end note
446
+
447
+ @enduml
448
+ ```
449
+
450
+ ### 4.5 カリー化
451
+
452
+ カリー化(Currying)は、複数の引数を取る関数を、引数を1つずつ取る関数のチェーンに変換する技法です。
453
+
454
+ ```rust
455
+ // カリー化された関数
456
+ pub fn curried_add(a: i32) -> impl Fn(i32) -> i32 {
457
+ move |b| a + b
458
+ }
459
+
460
+ let add_10 = curried_add(10);
461
+ assert_eq!(add_10(5), 15);
462
+ assert_eq!(add_10(20), 30);
463
+ ```
464
+
465
+ ```plantuml
466
+ @startuml
467
+ !theme plain
468
+
469
+ rectangle "カリー化" {
470
+ rectangle "通常の関数" as normal {
471
+ card "fn add(a: i32, b: i32) -> i32" as n1
472
+ }
473
+
474
+ rectangle "カリー化された関数" as curried {
475
+ card "fn curried_add(a: i32) -> impl Fn(i32) -> i32" as c1
476
+ }
477
+
478
+ normal --> curried : カリー化
479
+ }
480
+
481
+ note bottom of curried
482
+ 部分適用が可能
483
+ curried_add(10) → 「10を足す関数」を返す
484
+ end note
485
+
486
+ @enduml
487
+ ```
488
+
489
+ ### 4.6 ワードスコアリングの例
490
+
491
+ 複数のスコアリングロジックを組み合わせる例です。
492
+
493
+ ```rust
494
+ pub fn score(word: &str) -> usize {
495
+ word.chars().filter(|&c| c != 'a').count()
496
+ }
497
+
498
+ pub fn bonus(word: &str) -> i32 {
499
+ if word.contains('c') { 5 } else { 0 }
500
+ }
501
+
502
+ pub fn penalty(word: &str) -> i32 {
503
+ if word.contains('s') { 7 } else { 0 }
504
+ }
505
+
506
+ pub fn ranked_words<'a, F>(words: &[&'a str], word_score: F) -> Vec<&'a str>
507
+ where
508
+ F: Fn(&str) -> i32,
509
+ {
510
+ let mut result: Vec<&'a str> = words.to_vec();
511
+ result.sort_by(|a, b| word_score(b).cmp(&word_score(a))); // 降順
512
+ result
513
+ }
514
+
515
+ let words = vec!["ada", "haskell", "scala", "java", "rust"];
516
+
517
+ // 基本スコアでランキング
518
+ let ranking1 = ranked_words(&words, |w| score(w) as i32);
519
+ assert_eq!(ranking1, vec!["haskell", "rust", "scala", "java", "ada"]);
520
+
521
+ // ボーナス付きスコアでランキング
522
+ let ranking2 = ranked_words(&words, |w| score(w) as i32 + bonus(w));
523
+ assert_eq!(ranking2, vec!["scala", "haskell", "rust", "java", "ada"]);
524
+ ```
525
+
526
+ ---
527
+
528
+ ## 第5章: flat_map とネスト構造
529
+
530
+ ### 5.1 flatten と flat_map
531
+
532
+ **ソースファイル**: `app/rust/src/ch05_flatmap.rs`
533
+
534
+ #### flatten - ネストしたイテレータを平坦化
535
+
536
+ ```rust
537
+ #[derive(Debug, Clone, PartialEq)]
538
+ pub struct Book {
539
+ pub title: String,
540
+ pub authors: Vec<String>,
541
+ }
542
+
543
+ let books = vec![
544
+ Book::new("FP in Scala", vec!["Chiusano", "Bjarnason"]),
545
+ Book::new("The Hobbit", vec!["Tolkien"]),
546
+ ];
547
+
548
+ // map だけだとネストする
549
+ let author_lists: Vec<Vec<String>> = books.iter().map(|b| b.authors.clone()).collect();
550
+ // [["Chiusano", "Bjarnason"], ["Tolkien"]]
551
+
552
+ // flatten で平坦化
553
+ let authors: Vec<String> = author_lists.into_iter().flatten().collect();
554
+ // ["Chiusano", "Bjarnason", "Tolkien"]
555
+ ```
556
+
557
+ ```plantuml
558
+ @startuml
559
+ !theme plain
560
+
561
+ rectangle "flatten の動作" {
562
+ card "[[\"A\", \"B\"], [\"C\"]]" as nested
563
+ card "flatten()" as op
564
+ card "[\"A\", \"B\", \"C\"]" as flat
565
+
566
+ nested --> op
567
+ op --> flat
568
+ }
569
+
570
+ @enduml
571
+ ```
572
+
573
+ #### flat_map = map + flatten
574
+
575
+ ```rust
576
+ // flat_map で同じことを1行で
577
+ let authors: Vec<String> = books
578
+ .iter()
579
+ .flat_map(|book| book.authors.clone())
580
+ .collect();
581
+
582
+ assert_eq!(authors, vec!["Chiusano", "Bjarnason", "Tolkien"]);
583
+ ```
584
+
585
+ ### 5.2 flat_map によるリストサイズの変化
586
+
587
+ ```rust
588
+ // 要素数が増える
589
+ let expanded: Vec<i32> = vec![1, 2, 3]
590
+ .iter()
591
+ .flat_map(|&i| vec![i, i + 10])
592
+ .collect();
593
+ assert_eq!(expanded, vec![1, 11, 2, 12, 3, 13]);
594
+
595
+ // 要素数が同じ(map と同等)
596
+ let doubled: Vec<i32> = vec![1, 2, 3]
597
+ .iter()
598
+ .flat_map(|&i| vec![i * 2])
599
+ .collect();
600
+ assert_eq!(doubled, vec![2, 4, 6]);
601
+
602
+ // 要素数が減る(filter の代替)
603
+ let evens: Vec<i32> = vec![1, 2, 3]
604
+ .iter()
605
+ .flat_map(|&i| if i % 2 == 0 { vec![i] } else { vec![] })
606
+ .collect();
607
+ assert_eq!(evens, vec![2]);
608
+ ```
609
+
610
+ ```plantuml
611
+ @startuml
612
+ !theme plain
613
+
614
+ rectangle "flat_map とサイズの変化" {
615
+ rectangle "増加" as inc {
616
+ card "[1, 2, 3]" as i1
617
+ card "|&i| vec![i, i+10]" as f1
618
+ card "[1, 11, 2, 12, 3, 13]" as r1
619
+ i1 --> f1
620
+ f1 --> r1
621
+ }
622
+
623
+ rectangle "減少(フィルタ)" as dec {
624
+ card "[1, 2, 3]" as i2
625
+ card "|&i| if even vec![i] else vec![]" as f2
626
+ card "[2]" as r2
627
+ i2 --> f2
628
+ f2 --> r2
629
+ }
630
+ }
631
+
632
+ @enduml
633
+ ```
634
+
635
+ ### 5.3 ネストした flat_map
636
+
637
+ 複数のコレクションを組み合わせる場合、flat_map をネストします。
638
+
639
+ ```rust
640
+ #[derive(Debug, Clone, PartialEq)]
641
+ pub struct Movie {
642
+ pub title: String,
643
+ }
644
+
645
+ pub fn book_adaptations(author: &str) -> Vec<Movie> {
646
+ if author == "Tolkien" {
647
+ vec![
648
+ Movie::new("An Unexpected Journey"),
649
+ Movie::new("The Desolation of Smaug"),
650
+ ]
651
+ } else {
652
+ vec![]
653
+ }
654
+ }
655
+
656
+ let books = vec![
657
+ Book::new("FP in Scala", vec!["Chiusano", "Bjarnason"]),
658
+ Book::new("The Hobbit", vec!["Tolkien"]),
659
+ ];
660
+
661
+ // ネストした flat_map
662
+ let recommendations: Vec<String> = books
663
+ .iter()
664
+ .flat_map(|book| {
665
+ let book_title = book.title.clone();
666
+ book.authors.iter().flat_map(move |author| {
667
+ let author_name = author.clone();
668
+ let book_title_inner = book_title.clone();
669
+ book_adaptations(&author_name).into_iter().map(move |movie| {
670
+ format!(
671
+ "You may like {}, because you liked {}'s {}",
672
+ movie.title, author_name, book_title_inner
673
+ )
674
+ })
675
+ })
676
+ })
677
+ .collect();
678
+
679
+ // 結果:
680
+ // [
681
+ // "You may like An Unexpected Journey, because you liked Tolkien's The Hobbit",
682
+ // "You may like The Desolation of Smaug, because you liked Tolkien's The Hobbit"
683
+ // ]
684
+ ```
685
+
686
+ ```plantuml
687
+ @startuml
688
+ !theme plain
689
+
690
+ rectangle "ネストした flat_map のフロー" {
691
+ card "books" as books
692
+ card "book.authors" as authors
693
+ card "book_adaptations(author)" as movies
694
+ card "recommendation string" as result
695
+
696
+ books --> authors : flat_map
697
+ authors --> movies : flat_map
698
+ movies --> result : map
699
+ }
700
+
701
+ note bottom
702
+ 最後だけ map
703
+ 途中は flat_map
704
+ end note
705
+
706
+ @enduml
707
+ ```
708
+
709
+ ### 5.4 イテレータチェーン(Rust の for 内包表記相当)
710
+
711
+ Scala の for 内包表記に相当するものとして、Rust ではイテレータチェーンを使います。
712
+
713
+ ```rust
714
+ // 全組み合わせを生成
715
+ pub fn all_combinations(xs: &[i32], ys: &[i32]) -> Vec<i32> {
716
+ xs.iter()
717
+ .flat_map(|&x| ys.iter().map(move |&y| x + y))
718
+ .collect()
719
+ }
720
+
721
+ let result = all_combinations(&[1, 2], &[10, 20]);
722
+ assert_eq!(result, vec![11, 21, 12, 22]);
723
+
724
+ // 3つのリストの組み合わせ
725
+ pub fn three_way_combinations(xs: &[i32], ys: &[i32], zs: &[i32]) -> Vec<i32> {
726
+ xs.iter()
727
+ .flat_map(|&x| {
728
+ ys.iter()
729
+ .flat_map(move |&y| zs.iter().map(move |&z| x + y + z))
730
+ })
731
+ .collect()
732
+ }
733
+
734
+ let result = three_way_combinations(&[1, 2], &[10, 20], &[100, 200]);
735
+ assert_eq!(result, vec![111, 211, 121, 221, 112, 212, 122, 222]);
736
+ ```
737
+
738
+ ### 5.5 円内の点の判定
739
+
740
+ フィルタリングも含めた例です。
741
+
742
+ ```rust
743
+ #[derive(Debug, Clone, Copy, PartialEq)]
744
+ pub struct Point {
745
+ pub x: i32,
746
+ pub y: i32,
747
+ }
748
+
749
+ pub fn is_inside(point: &Point, radius: i32) -> bool {
750
+ radius * radius >= point.x * point.x + point.y * point.y
751
+ }
752
+
753
+ let points = vec![Point::new(5, 2), Point::new(1, 1)];
754
+ let radiuses = vec![2, 1];
755
+
756
+ // フィルタリングして円内の点のみを返す
757
+ let inside: Vec<String> = radiuses
758
+ .iter()
759
+ .flat_map(|&r| {
760
+ points
761
+ .iter()
762
+ .filter(move |point| is_inside(point, r))
763
+ .map(move |point| {
764
+ format!("Point({},{}) is within a radius of {}", point.x, point.y, r)
765
+ })
766
+ })
767
+ .collect();
768
+
769
+ assert_eq!(inside, vec!["Point(1,1) is within a radius of 2"]);
770
+ ```
771
+
772
+ #### flat_map でフィルタリング(filter の代替)
773
+
774
+ ```rust
775
+ // flat_map を使ったフィルタリング
776
+ let inside: Vec<String> = radiuses
777
+ .iter()
778
+ .flat_map(|&r| {
779
+ points.iter().flat_map(move |point| {
780
+ if is_inside(point, r) {
781
+ vec![format!(
782
+ "Point({},{}) is within a radius of {}",
783
+ point.x, point.y, r
784
+ )]
785
+ } else {
786
+ vec![]
787
+ }
788
+ })
789
+ })
790
+ .collect();
791
+ ```
792
+
793
+ ```plantuml
794
+ @startuml
795
+ !theme plain
796
+
797
+ rectangle "フィルタリングの3つの方法" {
798
+ rectangle "1. filter を使う" as m1 {
799
+ card "points.iter().filter(|p| is_inside(p, r))"
800
+ }
801
+
802
+ rectangle "2. flat_map を使う" as m3 {
803
+ card "flat_map で vec![] or vec![result] を返す"
804
+ }
805
+ }
806
+
807
+ @enduml
808
+ ```
809
+
810
+ ### 5.6 型の変化
811
+
812
+ イテレータの最初の型が結果の型を決定します。
813
+
814
+ ```rust
815
+ use std::collections::HashSet;
816
+
817
+ // Vec から始まると Vec が返る
818
+ let list_result: Vec<i32> = vec![1, 2]
819
+ .into_iter()
820
+ .flat_map(|a| vec![2, 1].into_iter().map(move |b| a * b))
821
+ .collect();
822
+ assert_eq!(list_result, vec![2, 1, 4, 2]); // 重複あり
823
+
824
+ // HashSet を使うと重複が除去される
825
+ let set_a: HashSet<i32> = [1, 2].into_iter().collect();
826
+ let list_b = vec![2, 1];
827
+
828
+ let set_result: HashSet<i32> = set_a
829
+ .into_iter()
830
+ .flat_map(|a| list_b.iter().map(move |&b| a * b))
831
+ .collect();
832
+ assert_eq!(set_result.len(), 3); // 重複なし: {1, 2, 4}
833
+ ```
834
+
835
+ ---
836
+
837
+ ## まとめ
838
+
839
+ ### Part II で学んだこと
840
+
841
+ ```plantuml
842
+ @startuml
843
+ !theme plain
844
+
845
+ rectangle "Part II: 関数型スタイルのプログラミング" {
846
+ rectangle "第3章" as ch3 {
847
+ card "イミュータブルデータ"
848
+ card "スライス操作"
849
+ card "データ変換パターン"
850
+ }
851
+
852
+ rectangle "第4章" as ch4 {
853
+ card "高階関数"
854
+ card "map / filter / fold"
855
+ card "クロージャを返す関数"
856
+ card "カリー化"
857
+ }
858
+
859
+ rectangle "第5章" as ch5 {
860
+ card "flatten / flat_map"
861
+ card "ネストした変換"
862
+ card "イテレータチェーン"
863
+ }
864
+ }
865
+
866
+ ch3 --> ch4
867
+ ch4 --> ch5
868
+
869
+ @enduml
870
+ ```
871
+
872
+ ### Scala との比較
873
+
874
+ | 概念 | Scala | Rust |
875
+ |------|-------|------|
876
+ | イミュータブル | `val` (デフォルト) | `let` (デフォルト) |
877
+ | リスト追加 | `list.appended(elem)` | 自作 `appended()` or `Vec::push` |
878
+ | スライス | `list.slice(start, end)` | `&list[start..end]` |
879
+ | 高階関数 | `list.map(f)` | `iter().map(f).collect()` |
880
+ | フィルタ | `list.filter(p)` | `iter().filter(p).collect()` |
881
+ | 畳み込み | `list.foldLeft(init)(f)` | `iter().fold(init, f)` |
882
+ | 関数を返す | `def f(x: Int): Int => Boolean` | `fn f(x: i32) -> impl Fn(i32) -> bool` |
883
+ | for 内包表記 | `for { ... } yield ...` | イテレータチェーン |
884
+ | flat_map | `list.flatMap(f)` | `iter().flat_map(f).collect()` |
885
+
886
+ ### キーポイント
887
+
888
+ | 章 | 主要概念 | キー操作 |
889
+ |----|----------|----------|
890
+ | 第3章 | イミュータブル | スライス `[..]`, `to_vec()`, `extend_from_slice` |
891
+ | 第4章 | 高階関数 | `map`, `filter`, `fold`, `sort_by_key` |
892
+ | 第5章 | 平坦化 | `flatten`, `flat_map`, イテレータチェーン |
893
+
894
+ ### 重要な法則
895
+
896
+ 1. **イミュータブルデータ**: Rust ではデフォルトで不変。新しいデータを作成する
897
+ 2. **関数は値**: クロージャを引数として渡したり、戻り値として返したりできる
898
+ 3. **flat_map パターン**: ネストした構造を平坦化しながら変換する
899
+ 4. **イテレータチェーン**: Scala の for 内包表記に相当する表現力を持つ
900
+
901
+ ### 次のステップ
902
+
903
+ Part III では、以下のトピックを学びます:
904
+
905
+ - `Option<T>` 型による安全な null ハンドリング
906
+ - `Result<T, E>` 型とエラー処理
907
+
908
+ ---
909
+
910
+ ## 演習問題
911
+
912
+ ### 問題 1: イミュータブルな操作
913
+
914
+ 以下の関数を実装してください。リストの中央に要素を挿入する関数です。
915
+
916
+ ```rust
917
+ fn insert_at_middle<T: Clone>(list: &[T], element: T) -> Vec<T> {
918
+ todo!()
919
+ }
920
+
921
+ // 期待される動作
922
+ assert_eq!(insert_at_middle(&["a", "b", "c", "d"], "X"), vec!["a", "b", "X", "c", "d"]);
923
+ assert_eq!(insert_at_middle(&["a", "b"], "X"), vec!["a", "X", "b"]);
924
+ ```
925
+
926
+ <details>
927
+ <summary>解答</summary>
928
+
929
+ ```rust
930
+ fn insert_at_middle<T: Clone>(list: &[T], element: T) -> Vec<T> {
931
+ let middle = list.len() / 2;
932
+ let before = &list[..middle];
933
+ let after = &list[middle..];
934
+ let mut result = before.to_vec();
935
+ result.push(element);
936
+ result.extend_from_slice(after);
937
+ result
938
+ }
939
+ ```
940
+
941
+ </details>
942
+
943
+ ### 問題 2: 高階関数
944
+
945
+ 以下の関数を実装してください。条件を満たす要素の数をカウントする関数です。
946
+
947
+ ```rust
948
+ fn count_where<T, F>(list: &[T], predicate: F) -> usize
949
+ where
950
+ F: Fn(&T) -> bool,
951
+ {
952
+ todo!()
953
+ }
954
+
955
+ // 期待される動作
956
+ assert_eq!(count_where(&[1, 2, 3, 4, 5], |&i| i > 3), 2);
957
+ assert_eq!(count_where(&["a", "bb", "ccc"], |s| s.len() > 1), 2);
958
+ ```
959
+
960
+ <details>
961
+ <summary>解答</summary>
962
+
963
+ ```rust
964
+ fn count_where<T, F>(list: &[T], predicate: F) -> usize
965
+ where
966
+ F: Fn(&T) -> bool,
967
+ {
968
+ list.iter().filter(|item| predicate(item)).count()
969
+ }
970
+
971
+ // または fold を使って
972
+ fn count_where2<T, F>(list: &[T], predicate: F) -> usize
973
+ where
974
+ F: Fn(&T) -> bool,
975
+ {
976
+ list.iter().fold(0, |count, elem| {
977
+ if predicate(elem) { count + 1 } else { count }
978
+ })
979
+ }
980
+ ```
981
+
982
+ </details>
983
+
984
+ ### 問題 3: イテレータチェーン
985
+
986
+ 以下のネストした flat_map を読みやすく整理してください。
987
+
988
+ ```rust
989
+ let result: Vec<i32> = vec![1, 2]
990
+ .iter()
991
+ .flat_map(|&x| {
992
+ vec![10, 20]
993
+ .iter()
994
+ .flat_map(move |&y| {
995
+ vec![100, 200]
996
+ .iter()
997
+ .map(move |&z| x + y + z)
998
+ })
999
+ })
1000
+ .collect();
1001
+ ```
1002
+
1003
+ <details>
1004
+ <summary>解答</summary>
1005
+
1006
+ ```rust
1007
+ // イテレータアダプタ iproduct を使う方法(itertools クレート)
1008
+ use itertools::iproduct;
1009
+
1010
+ let result: Vec<i32> = iproduct!(
1011
+ vec![1, 2],
1012
+ vec![10, 20],
1013
+ vec![100, 200]
1014
+ )
1015
+ .map(|(x, y, z)| x + y + z)
1016
+ .collect();
1017
+
1018
+ // または、ヘルパー関数を使う
1019
+ fn three_way_combinations(xs: &[i32], ys: &[i32], zs: &[i32]) -> Vec<i32> {
1020
+ xs.iter()
1021
+ .flat_map(|&x| {
1022
+ ys.iter()
1023
+ .flat_map(move |&y| zs.iter().map(move |&z| x + y + z))
1024
+ })
1025
+ .collect()
1026
+ }
1027
+
1028
+ let result = three_way_combinations(&[1, 2], &[10, 20], &[100, 200]);
1029
+ // 結果: [111, 211, 121, 221, 112, 212, 122, 222]
1030
+ ```
1031
+
1032
+ </details>
1033
+
1034
+ ### 問題 4: flat_map によるフィルタリング
1035
+
1036
+ flat_map だけで偶数のみを抽出するコードを書いてください。
1037
+
1038
+ ```rust
1039
+ let numbers = vec![1, 2, 3, 4, 5, 6];
1040
+ // 偶数のみを抽出: vec![2, 4, 6]
1041
+ ```
1042
+
1043
+ <details>
1044
+ <summary>解答</summary>
1045
+
1046
+ ```rust
1047
+ let even_numbers: Vec<i32> = numbers
1048
+ .iter()
1049
+ .flat_map(|&n| if n % 2 == 0 { vec![n] } else { vec![] })
1050
+ .collect();
1051
+
1052
+ // または関数に分離
1053
+ fn even_filter(n: &i32) -> Vec<i32> {
1054
+ if n % 2 == 0 { vec![*n] } else { vec![] }
1055
+ }
1056
+
1057
+ let even_numbers2: Vec<i32> = numbers.iter().flat_map(even_filter).collect();
1058
+ ```
1059
+
1060
+ </details>