@k2works/claude-code-booster 3.0.0 → 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 (524) 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 -106
  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/strategy/index.md +11 -4
  522. package/lib/assets/docs/template/index.md +9 -5
  523. package/lib/assets/mkdocs.yml +29 -17
  524. package/package.json +1 -1
@@ -0,0 +1,926 @@
1
+ # Part IV - 第 9 章:ストリーム処理
2
+
3
+ ## 9.1 はじめに:遅延評価と無限のデータ
4
+
5
+ リスト(配列)は全要素をメモリに保持する有限のデータ構造です。しかし、現実のプログラムでは「無限に続くデータ」を扱う場面があります:
6
+
7
+ - センサーからのリアルタイムデータ
8
+ - 為替レートの連続的な変動
9
+ - サイコロを何度も振る試行
10
+ - ログイベントの継続的な流れ
11
+
12
+ **ストリーム**は、遅延評価により「必要な時に必要な分だけ」要素を生成するデータ構造です。本章では、11 言語でのストリーム処理を横断的に比較し、以下を明らかにします:
13
+
14
+ - ストリームの実現方式の違い(言語組み込み遅延評価 vs ライブラリ vs ジェネレータ)
15
+ - 無限ストリームの生成パターン(repeat / iterate / unfold / cycle)
16
+ - スライディングウィンドウによるトレンド検出の実装差異
17
+
18
+ ```plantuml
19
+ @startuml
20
+ !theme plain
21
+
22
+ rectangle "List vs Stream" {
23
+ rectangle "List" as list {
24
+ card "全要素がメモリに存在"
25
+ card "有限"
26
+ card "即座に評価(正格)"
27
+ }
28
+
29
+ rectangle "Stream" as stream {
30
+ card "必要な時に要素を生成"
31
+ card "無限も可能"
32
+ card "遅延評価"
33
+ }
34
+ }
35
+
36
+ note bottom of stream
37
+ take(n) で有限個を取得
38
+ filter / map で変換
39
+ sliding(n) でウィンドウ分割
40
+ end note
41
+
42
+ @enduml
43
+ ```
44
+
45
+ ---
46
+
47
+ ## 9.2 共通の本質:遅延評価による無限シーケンス
48
+
49
+ 11 言語すべてに共通するストリームの原則は、**遅延評価によって無限のデータを有限のメモリで扱う**ことです:
50
+
51
+ 1. **遅延生成**: 要素は要求されるまで生成されない
52
+ 2. **変換の連鎖**: map / filter をストリームに適用しても即座に全要素を処理しない
53
+ 3. **実体化**: take / toList / collect で必要な分だけ取り出す
54
+
55
+ 3 つの言語グループから代表例を見てみましょう:
56
+
57
+ ```haskell
58
+ -- Haskell: リストがデフォルトで遅延評価
59
+ naturals :: [Integer]
60
+ naturals = [1..]
61
+
62
+ take 5 naturals -- [1, 2, 3, 4, 5]
63
+
64
+ -- フィボナッチ数列(自己参照的定義)
65
+ fibs :: [Integer]
66
+ fibs = 0 : 1 : zipWith (+) fibs (tail fibs)
67
+
68
+ take 10 fibs -- [0, 1, 1, 2, 3, 5, 8, 13, 21, 34]
69
+ ```
70
+
71
+ ```scala
72
+ // Scala: fs2 Stream ライブラリ
73
+ import fs2.{Pure, Stream}
74
+
75
+ val infinite123s: Stream[Pure, Int] = Stream(1, 2, 3).repeat
76
+ infinite123s.take(8).toList // List(1, 2, 3, 1, 2, 3, 1, 2)
77
+
78
+ // IO を含む無限ストリーム
79
+ val infiniteDieCasts: Stream[IO, Int] = Stream.eval(castTheDie()).repeat
80
+ infiniteDieCasts.take(3).compile.toList.unsafeRunSync() // List(4, 2, 6)
81
+ ```
82
+
83
+ ```python
84
+ # Python: ジェネレータで遅延評価
85
+ from itertools import count, islice
86
+
87
+ def cycle_stream(items):
88
+ while True:
89
+ yield from items
90
+
91
+ list(islice(cycle_stream([1, 2, 3]), 8)) # [1, 2, 3, 1, 2, 3, 1, 2]
92
+ ```
93
+
94
+ ---
95
+
96
+ ## 9.3 ストリームの実現方式
97
+
98
+ ### アプローチ 1: 言語組み込みの遅延評価
99
+
100
+ | 言語 | ストリーム型 | 特徴 |
101
+ |------|-----------|------|
102
+ | **Haskell** | `[a]`(リスト自体が遅延) | デフォルト遅延評価、特別な型不要 |
103
+ | **Clojure** | `lazy-seq` / `range` 等 | 遅延シーケンスが標準 |
104
+
105
+ ### アプローチ 2: ストリームライブラリ
106
+
107
+ | 言語 | ライブラリ | ストリーム型 | IO 統合 |
108
+ |------|-----------|-----------|--------|
109
+ | **Scala** | fs2 | `Stream[F, A]` | `Stream[IO, A]` で IO とストリームを統合 |
110
+ | **Rust** | futures | `Stream<Item = T>` | `then` / `buffered` で非同期処理 |
111
+
112
+ ### アプローチ 3: 言語の遅延評価プリミティブ
113
+
114
+ | 言語 | プリミティブ | 構文 |
115
+ |------|-----------|------|
116
+ | **F#** | `seq { }` | `Seq.take`, `Seq.windowed` |
117
+ | **C#** | `IEnumerable<T>` | `yield return`, LINQ |
118
+ | **Elixir** | `Stream` モジュール | `Stream.cycle`, `Stream.unfold` |
119
+
120
+ ### アプローチ 4: ジェネレータ / カスタム実装
121
+
122
+ | 言語 | プリミティブ | 構文 |
123
+ |------|-----------|------|
124
+ | **Python** | `Generator` | `yield` / `yield from` |
125
+ | **TypeScript** | `Generator` | `function*` / `yield` |
126
+ | **Java** | カスタム `LazyStream` | `Supplier<Option<Cons<A>>>` |
127
+ | **Ruby** | `Enumerator::Lazy` | `Enumerator.new` + `loop` |
128
+
129
+ ---
130
+
131
+ ## 9.4 無限ストリームの生成パターン
132
+
133
+ ### 4 つの基本パターン
134
+
135
+ | パターン | 説明 | 例 |
136
+ |---------|------|-----|
137
+ | **repeat** | 同じ値(列)を無限に繰り返す | `[1,2,3,1,2,3,...]` |
138
+ | **iterate** | 関数を繰り返し適用 | `[1,2,4,8,16,...]` |
139
+ | **unfold** | 状態から次の要素と新しい状態を生成 | フィボナッチ数列 |
140
+ | **generate** | 副作用のある関数を繰り返し呼ぶ | サイコロを振り続ける |
141
+
142
+ ### 全 11 言語の生成関数比較
143
+
144
+ | パターン | Haskell | Scala | Rust | F# | C# | TypeScript | Python | Java | Ruby | Clojure | Elixir |
145
+ |---------|---------|-------|------|-----|-----|-----------|--------|------|------|---------|--------|
146
+ | **repeat** | `repeat x` | `.repeat` | `stream::repeat` | `seq { while true }` | `yield return` loop | `while(true) yield` | `while True: yield` | カスタム | `Enumerator` + `loop` | `(repeat x)` | `Stream.cycle` |
147
+ | **iterate** | `iterate f x` | — | `stream::unfold` | `Seq.unfold` | カスタム | `function*` | `count` / カスタム | カスタム | `iterate` メソッド | `(iterate f x)` | `Stream.iterate` |
148
+ | **unfold** | `unfoldr f s` | `Stream.unfold` | `stream::unfold` | `Seq.unfold` | カスタム | `function*` | `function*` | カスタム | `Enumerator.new` | `lazy-seq` | `Stream.unfold` |
149
+ | **generate** | `sequence (repeat io)` | `Stream.eval(io).repeat` | `stream::repeat_with` | `seq { yield f() }` | `yield return f()` | `function*` | `while True: yield f()` | カスタム | `IOStream.repeat_eval` | `(repeatedly f)` | `Stream.repeatedly` |
150
+
151
+ ### 代表例:フィボナッチ数列
152
+
153
+ **Haskell**: 自己参照的定義(遅延評価の力)
154
+
155
+ ```haskell
156
+ fibs :: [Integer]
157
+ fibs = 0 : 1 : zipWith (+) fibs (tail fibs)
158
+
159
+ take 10 fibs -- [0, 1, 1, 2, 3, 5, 8, 13, 21, 34]
160
+ ```
161
+
162
+ **Rust**: `stream::unfold` で状態遷移
163
+
164
+ ```rust
165
+ pub fn fibonacci_stream() -> impl Stream<Item = u64> {
166
+ stream::unfold((0u64, 1u64), |(a, b)| async move {
167
+ Some((a, (b, a + b)))
168
+ })
169
+ }
170
+ ```
171
+
172
+ **TypeScript**: ジェネレータ関数
173
+
174
+ ```typescript
175
+ function* fibonacci(): LazyList<number> {
176
+ let [a, b] = [0, 1]
177
+ while (true) {
178
+ yield a
179
+ ;[a, b] = [b, a + b]
180
+ }
181
+ }
182
+ ```
183
+
184
+ ### 全 11 言語のフィボナッチ実装
185
+
186
+ <details>
187
+ <summary>関数型ファースト言語</summary>
188
+
189
+ **Haskell**:
190
+ ```haskell
191
+ fibs :: [Integer]
192
+ fibs = 0 : 1 : zipWith (+) fibs (tail fibs)
193
+ ```
194
+
195
+ **Clojure**:
196
+ ```clojure
197
+ (def fibs
198
+ ((fn fib [a b]
199
+ (lazy-seq (cons a (fib b (+ a b)))))
200
+ 0 1))
201
+
202
+ (take 10 fibs) ; => (0 1 1 2 3 5 8 13 21 34)
203
+ ```
204
+
205
+ **Elixir**:
206
+ ```elixir
207
+ def fibonacci do
208
+ Stream.unfold({0, 1}, fn {a, b} -> {a, {b, a + b}} end)
209
+ end
210
+
211
+ fibonacci() |> Enum.take(10) # [0, 1, 1, 2, 3, 5, 8, 13, 21, 34]
212
+ ```
213
+
214
+ **F#**:
215
+ ```fsharp
216
+ let fibonacci =
217
+ Seq.unfold (fun (a, b) -> Some(a, (b, a + b))) (0, 1)
218
+
219
+ fibonacci |> Seq.take 10 |> Seq.toList
220
+ // [0; 1; 1; 2; 3; 5; 8; 13; 21; 34]
221
+ ```
222
+
223
+ </details>
224
+
225
+ <details>
226
+ <summary>マルチパラダイム言語</summary>
227
+
228
+ **Scala**:
229
+ ```scala
230
+ val fibonacci: Stream[Pure, Long] =
231
+ Stream.unfold((0L, 1L)) { case (a, b) => Some((a, (b, a + b))) }
232
+
233
+ fibonacci.take(10).toList // List(0, 1, 1, 2, 3, 5, 8, 13, 21, 34)
234
+ ```
235
+
236
+ **Rust**:
237
+ ```rust
238
+ pub fn fibonacci_stream() -> impl Stream<Item = u64> {
239
+ stream::unfold((0u64, 1u64), |(a, b)| async move {
240
+ Some((a, (b, a + b)))
241
+ })
242
+ }
243
+ ```
244
+
245
+ **TypeScript**:
246
+ ```typescript
247
+ function* fibonacci(): LazyList<number> {
248
+ let [a, b] = [0, 1]
249
+ while (true) {
250
+ yield a
251
+ ;[a, b] = [b, a + b]
252
+ }
253
+ }
254
+ ```
255
+
256
+ </details>
257
+
258
+ <details>
259
+ <summary>OOP + FP ライブラリ言語</summary>
260
+
261
+ **Java**:
262
+ ```java
263
+ public static LazyStream<Long> fibonacci() {
264
+ return LazyStream.unfold(
265
+ new long[]{0, 1},
266
+ state -> Option.some(new Tuple2<>(state[0], new long[]{state[1], state[0] + state[1]}))
267
+ );
268
+ }
269
+ ```
270
+
271
+ **C#**:
272
+ ```csharp
273
+ public static IEnumerable<long> Fibonacci()
274
+ {
275
+ long a = 0, b = 1;
276
+ while (true)
277
+ {
278
+ yield return a;
279
+ (a, b) = (b, a + b);
280
+ }
281
+ }
282
+ ```
283
+
284
+ **Python**:
285
+ ```python
286
+ def fibonacci():
287
+ a, b = 0, 1
288
+ while True:
289
+ yield a
290
+ a, b = b, a + b
291
+ ```
292
+
293
+ **Ruby**:
294
+ ```ruby
295
+ def fibonacci
296
+ Enumerator.new do |yielder|
297
+ a, b = 0, 1
298
+ loop do
299
+ yielder << a
300
+ a, b = b, a + b
301
+ end
302
+ end.lazy
303
+ end
304
+ ```
305
+
306
+ </details>
307
+
308
+ ---
309
+
310
+ ## 9.5 ストリーム操作の比較
311
+
312
+ ### 主要操作の語彙比較
313
+
314
+ | 操作 | Haskell | Scala (fs2) | Rust | F# | C# | TypeScript | Python | Clojure | Elixir | Java | Ruby |
315
+ |------|---------|-------------|------|-----|-----|-----------|--------|---------|--------|------|------|
316
+ | 先頭 n 個 | `take n` | `.take(n)` | `.take(n)` | `Seq.take n` | `.Take(n)` | `take(s, n)` | `islice(s, n)` | `(take n s)` | `Enum.take(s, n)` | `.take(n)` | `.take(n)` |
317
+ | フィルタ | `filter p` | `.filter(p)` | `.filter(p)` | `Seq.filter p` | `.Where(p)` | `filterStream` | `filter` | `(filter p s)` | `Stream.filter(s, p)` | `.filter(p)` | `.filter(p)` |
318
+ | 変換 | `map f` | `.map(f)` | `.map(f)` | `Seq.map f` | `.Select(f)` | `mapStream` | `map(f, s)` | `(map f s)` | `Stream.map(s, f)` | `.map(f)` | `.fmap(f)` |
319
+ | 結合 | `++` | `.append(s)` | `.chain(s)` | `Seq.append` | `.Concat(s)` | `append` | `chain` | `(concat s1 s2)` | `Stream.concat` | `.append(s)` | `.append(s)` |
320
+ | ウィンドウ | `sliding n` | `.sliding(n)` | `.chunks(n)` | `Seq.windowed n` | `Sliding(n)` | `sliding` | `stream_sliding` | `(partition n 1)` | `Stream.chunk_every` | `.sliding(n)` | `.sliding(n)` |
321
+ | zip | `zip` | `.zip(s)` | `.zip(s)` | `Seq.zip` | `.Zip(s)` | `zipStream` | `zip` | `(map vector s1 s2)` | `Stream.zip(s1, s2)` | `.zip(s)` | `.zip(s)` |
322
+ | 畳み込み | `foldl` | `.fold` | `.fold` | `Seq.fold` | `.Aggregate` | `reduce` | `reduce` | `(reduce f s)` | `Enum.reduce` | `.fold` | `.reduce` |
323
+
324
+ ---
325
+
326
+ ## 9.6 スライディングウィンドウとトレンド検出
327
+
328
+ すべての言語で共通する実践的なパターンとして、為替レートの上昇トレンドを検出する例を比較します。
329
+
330
+ ### パターンの構造
331
+
332
+ ```plantuml
333
+ @startuml
334
+ !theme plain
335
+
336
+ rectangle "トレンド検出パイプライン" {
337
+ card "レートストリーム\n[0.81, 0.82, 0.85, 0.83, ...]" as rates
338
+ card "sliding(3)\n[[0.81, 0.82, 0.85],\n [0.82, 0.85, 0.83], ...]" as sliding
339
+ card "filter(trending)\n[[0.81, 0.82, 0.85]]" as filter
340
+ card "map(_.last)\n[0.85]" as extract
341
+ card "take(1)\n0.85" as take
342
+
343
+ rates --> sliding
344
+ sliding --> filter
345
+ filter --> extract
346
+ extract --> take
347
+ }
348
+
349
+ @enduml
350
+ ```
351
+
352
+ ### トレンド判定関数の比較
353
+
354
+ **Haskell**:
355
+
356
+ ```haskell
357
+ trending :: Ord a => [a] -> Bool
358
+ trending xs =
359
+ length xs > 1 &&
360
+ all (uncurry (<)) (zip xs (tail xs))
361
+ ```
362
+
363
+ **Scala**:
364
+
365
+ ```scala
366
+ def trending(rates: List[BigDecimal]): Boolean =
367
+ rates.size > 1 &&
368
+ rates.zip(rates.drop(1)).forall {
369
+ case (prev, rate) => rate > prev
370
+ }
371
+ ```
372
+
373
+ **Rust**:
374
+
375
+ ```rust
376
+ pub fn trending(rates: &[f64]) -> bool {
377
+ rates.len() > 1 &&
378
+ rates.windows(2).all(|w| w[1] > w[0])
379
+ }
380
+ ```
381
+
382
+ ### 全 11 言語の実装
383
+
384
+ #### 関数型ファースト言語
385
+
386
+ <details>
387
+ <summary>Haskell 実装</summary>
388
+
389
+ ```haskell
390
+ -- スライディングウィンドウ
391
+ sliding :: Int -> [a] -> [[a]]
392
+ sliding n xs
393
+ | length window < n = []
394
+ | otherwise = window : sliding n (tail xs)
395
+ where window = take n xs
396
+
397
+ -- トレンド判定
398
+ trending :: Ord a => [a] -> Bool
399
+ trending xs =
400
+ length xs > 1 &&
401
+ all (uncurry (<)) (zip xs (tail xs))
402
+
403
+ -- トレンド検出パイプライン
404
+ findTrending :: Ord a => Int -> [a] -> [[a]]
405
+ findTrending windowSize =
406
+ filter trending . sliding windowSize
407
+ ```
408
+
409
+ Haskell ではリストが遅延評価されるため、無限のレートストリームに対しても `findTrending` をそのまま適用できます。
410
+
411
+ </details>
412
+
413
+ <details>
414
+ <summary>Clojure 実装</summary>
415
+
416
+ ```clojure
417
+ ;; スライディングウィンドウ
418
+ (defn sliding-window [n coll]
419
+ (partition n 1 coll))
420
+
421
+ ;; トレンド判定
422
+ (defn trending? [rates]
423
+ (and (> (count rates) 1)
424
+ (every? (fn [[prev curr]] (< prev curr))
425
+ (partition 2 1 rates))))
426
+
427
+ ;; トレンド検出
428
+ (defn find-trending [window-size stream]
429
+ (->> stream
430
+ (sliding-window window-size)
431
+ (filter trending?)))
432
+ ```
433
+
434
+ Clojure の `partition` はステップ付きで呼ぶとスライディングウィンドウになります。
435
+
436
+ </details>
437
+
438
+ <details>
439
+ <summary>Elixir 実装</summary>
440
+
441
+ ```elixir
442
+ def trending?(rates) do
443
+ length(rates) > 1 &&
444
+ rates
445
+ |> Enum.chunk_every(2, 1, :discard)
446
+ |> Enum.all?(fn [prev, curr] -> curr > prev end)
447
+ end
448
+
449
+ # ストリームパイプライン
450
+ def find_trending(rates_stream, window_size) do
451
+ rates_stream
452
+ |> Stream.chunk_every(window_size, 1, :discard)
453
+ |> Stream.filter(&trending?/1)
454
+ end
455
+ ```
456
+
457
+ Elixir の `Stream.chunk_every/4` はステップ引数でスライディングウィンドウを実現します。
458
+
459
+ </details>
460
+
461
+ <details>
462
+ <summary>F# 実装</summary>
463
+
464
+ ```fsharp
465
+ let trending (rates: float list) =
466
+ rates.Length > 1 &&
467
+ List.pairwise rates |> List.forall (fun (prev, curr) -> curr > prev)
468
+
469
+ // ストリームパイプライン
470
+ let findTrending windowSize (rates: float seq) =
471
+ rates
472
+ |> Seq.windowed windowSize
473
+ |> Seq.filter (fun window -> trending (Array.toList window))
474
+ ```
475
+
476
+ F# の `Seq.windowed` はスライディングウィンドウを直接サポートしています。
477
+
478
+ </details>
479
+
480
+ #### マルチパラダイム言語
481
+
482
+ <details>
483
+ <summary>Scala 実装</summary>
484
+
485
+ ```scala
486
+ def trending(rates: List[BigDecimal]): Boolean =
487
+ rates.size > 1 &&
488
+ rates.zip(rates.drop(1)).forall { case (prev, rate) => rate > prev }
489
+
490
+ // fs2 ストリームパイプライン
491
+ def exchangeIfTrending(
492
+ amount: BigDecimal,
493
+ from: Currency,
494
+ to: Currency
495
+ ): IO[BigDecimal] =
496
+ rates(from, to)
497
+ .sliding(3)
498
+ .map(_.toList)
499
+ .filter(trending)
500
+ .map(_.last)
501
+ .take(1)
502
+ .compile
503
+ .lastOrError
504
+ .map(_ * amount)
505
+ ```
506
+
507
+ Scala の fs2 は `sliding` を標準で提供し、IO ストリームとシームレスに統合されます。
508
+
509
+ </details>
510
+
511
+ <details>
512
+ <summary>Rust 実装</summary>
513
+
514
+ ```rust
515
+ pub fn trending(rates: &[f64]) -> bool {
516
+ rates.len() > 1 && rates.windows(2).all(|w| w[1] > w[0])
517
+ }
518
+
519
+ // 移動平均ストリーム
520
+ pub fn moving_average<S>(stream: S, window_size: usize) -> impl Stream<Item = f64>
521
+ where
522
+ S: Stream<Item = f64> + Send + 'static,
523
+ {
524
+ stream::unfold(
525
+ (stream.boxed(), Vec::new(), window_size),
526
+ |(mut stream, mut window, size)| async move {
527
+ match stream.next().await {
528
+ Some(value) => {
529
+ window.push(value);
530
+ if window.len() > size { window.remove(0); }
531
+ let avg = window.iter().sum::<f64>() / window.len() as f64;
532
+ Some((avg, (stream, window, size)))
533
+ }
534
+ None => None,
535
+ }
536
+ },
537
+ )
538
+ }
539
+ ```
540
+
541
+ Rust の標準ライブラリには `windows` メソッドがスライスに対して存在しますが、`futures::Stream` でのスライディングウィンドウは `unfold` で自前実装が必要です。
542
+
543
+ </details>
544
+
545
+ <details>
546
+ <summary>TypeScript 実装</summary>
547
+
548
+ ```typescript
549
+ const trending = (rates: readonly number[]): boolean => {
550
+ if (rates.length <= 1) return false
551
+ return rates.slice(0, -1).every((prev, i) => rates[i + 1] > prev)
552
+ }
553
+
554
+ function* sliding<A>(gen: LazyList<A>, windowSize: number): LazyList<readonly A[]> {
555
+ const buffer: A[] = []
556
+ for (const item of gen) {
557
+ buffer.push(item)
558
+ if (buffer.length === windowSize) {
559
+ yield [...buffer]
560
+ buffer.shift()
561
+ }
562
+ }
563
+ }
564
+ ```
565
+
566
+ </details>
567
+
568
+ #### OOP + FP ライブラリ言語
569
+
570
+ <details>
571
+ <summary>Java 実装</summary>
572
+
573
+ ```java
574
+ public static boolean trending(List<BigDecimal> rates) {
575
+ return rates.size() > 1 &&
576
+ rates.zip(rates.drop(1))
577
+ .forAll(t -> t._2.compareTo(t._1) > 0);
578
+ }
579
+
580
+ // LazyStream でスライディングウィンドウ
581
+ public LazyStream<List<A>> sliding(int size) {
582
+ return LazyStream.unfold(this, stream -> {
583
+ List<A> window = stream.take(size).toList();
584
+ return window.size() == size
585
+ ? Option.some(new Tuple2<>(window, stream.drop(1)))
586
+ : Option.none();
587
+ });
588
+ }
589
+ ```
590
+
591
+ </details>
592
+
593
+ <details>
594
+ <summary>C# 実装</summary>
595
+
596
+ ```csharp
597
+ public static bool Trending(IEnumerable<decimal> rates)
598
+ {
599
+ var list = rates.ToList();
600
+ return list.Count > 1 &&
601
+ list.Zip(list.Skip(1), (prev, curr) => curr > prev).All(x => x);
602
+ }
603
+
604
+ // スライディングウィンドウ
605
+ public static IEnumerable<IReadOnlyList<T>> Sliding<T>(
606
+ this IEnumerable<T> source, int windowSize)
607
+ {
608
+ var window = new Queue<T>();
609
+ foreach (var item in source)
610
+ {
611
+ window.Enqueue(item);
612
+ if (window.Count == windowSize)
613
+ {
614
+ yield return window.ToList();
615
+ window.Dequeue();
616
+ }
617
+ }
618
+ }
619
+ ```
620
+
621
+ </details>
622
+
623
+ <details>
624
+ <summary>Python 実装</summary>
625
+
626
+ ```python
627
+ from collections import deque
628
+
629
+ def trending(rates: list[float]) -> bool:
630
+ return len(rates) > 1 and all(
631
+ curr > prev for prev, curr in zip(rates, rates[1:])
632
+ )
633
+
634
+ def stream_sliding(stream, window_size):
635
+ window = deque(maxlen=window_size)
636
+ for item in stream:
637
+ window.append(item)
638
+ if len(window) == window_size:
639
+ yield list(window)
640
+ ```
641
+
642
+ </details>
643
+
644
+ <details>
645
+ <summary>Ruby 実装</summary>
646
+
647
+ ```ruby
648
+ def trending?(rates)
649
+ return false if rates.size <= 1
650
+ rates.each_cons(2).all? { |prev, curr| curr > prev }
651
+ end
652
+
653
+ # LazyStream のスライディングウィンドウ
654
+ def sliding(n)
655
+ LazyStream.new(
656
+ Enumerator.new do |yielder|
657
+ buffer = []
658
+ @enumerator.each do |item|
659
+ buffer << item
660
+ if buffer.size == n
661
+ yielder << buffer.dup
662
+ buffer.shift
663
+ end
664
+ end
665
+ end
666
+ )
667
+ end
668
+ ```
669
+
670
+ </details>
671
+
672
+ ---
673
+
674
+ ## 9.7 IO ストリーム:副作用とストリームの統合
675
+
676
+ 前章の IO モナドとストリームを組み合わせると、「副作用を持つ無限ストリーム」を安全に扱えます。
677
+
678
+ ### 代表 3 言語の比較
679
+
680
+ **Scala** (fs2): `Stream[IO, A]` で IO とストリームを型レベルで統合
681
+
682
+ ```scala
683
+ // IO を含む無限ストリーム
684
+ val infiniteDieCasts: Stream[IO, Int] = Stream.eval(castTheDie()).repeat
685
+
686
+ // 最初の 3 回を取得
687
+ infiniteDieCasts.take(3).compile.toList.unsafeRunSync() // List(4, 2, 6)
688
+
689
+ // 6 が出るまで振り続ける
690
+ infiniteDieCasts.filter(_ == 6).take(1).compile.toList.unsafeRunSync() // List(6)
691
+
692
+ // レートストリーム + 時間制御
693
+ val ratesWithDelay = rates(from, to).zipLeft(Stream.fixedRate[IO](1.second))
694
+ ```
695
+
696
+ **Elixir**: `Stream.repeatedly` + パイプライン
697
+
698
+ ```elixir
699
+ # 無限にサイコロを振るストリーム
700
+ def die_casts do
701
+ Stream.repeatedly(fn -> :rand.uniform(6) end)
702
+ end
703
+
704
+ die_casts() |> Enum.take(3) # [4, 2, 6]
705
+
706
+ # 6 が出るまで振り続ける
707
+ die_casts()
708
+ |> Stream.take_while(fn x -> x != 6 end)
709
+ |> Enum.to_list()
710
+ ```
711
+
712
+ **Ruby**: IOStream クラス
713
+
714
+ ```ruby
715
+ # IO アクションから無限ストリームを作成
716
+ infinite_die_casts = IOStream.repeat_eval(cast_the_die)
717
+
718
+ # 最初の 3 回を取得
719
+ first_three = infinite_die_casts.take(3).compile_to_list
720
+ first_three.run! # [4, 2, 6]
721
+ ```
722
+
723
+ ### IO ストリームの統合度比較
724
+
725
+ | レベル | 言語 | 方式 | 特徴 |
726
+ |--------|------|------|------|
727
+ | **型レベル統合** | Scala (fs2) | `Stream[IO, A]` | エフェクトとストリームが同一型で統合 |
728
+ | **標準モジュール** | Elixir | `Stream` + `Task` | OTP のプロセスモデルと統合 |
729
+ | **非同期ストリーム** | C# | `IAsyncEnumerable<T>` | `await foreach` で非同期ストリーム |
730
+ | **非同期トレイト** | Rust | `futures::Stream` | `then` / `buffered` で非同期処理 |
731
+ | **カスタム** | Java, Python, Ruby, TypeScript | 自前の IOStream | IO ラッパーを手動実装 |
732
+ | **暗黙的** | Haskell | IO リスト | リストが遅延なので IO を含められる |
733
+ | **実用的** | Clojure | `lazy-seq` + `future` | 遅延シーケンスが副作用を自然に含む |
734
+
735
+ ---
736
+
737
+ ## 9.8 比較分析:3 つの発見
738
+
739
+ ### 発見 1: 遅延評価の実現方式は 3 系統に分かれる
740
+
741
+ ```plantuml
742
+ @startuml
743
+ !theme plain
744
+ left to right direction
745
+
746
+ rectangle "Level 1: デフォルト遅延評価" #LightGreen {
747
+ card "Haskell(リスト自体が遅延)" as h
748
+ card "Clojure(lazy-seq が標準)" as clj
749
+ }
750
+
751
+ rectangle "Level 2: 専用ストリーム型" #LightBlue {
752
+ card "Scala (fs2 Stream)" as sc
753
+ card "Rust (futures::Stream)" as rs
754
+ card "Elixir (Stream モジュール)" as ex
755
+ card "F# (Seq)" as fs
756
+ card "C# (IEnumerable)" as cs
757
+ }
758
+
759
+ rectangle "Level 3: ジェネレータ / カスタム" #LightYellow {
760
+ card "Python (Generator)" as py
761
+ card "TypeScript (Generator)" as ts
762
+ card "Java (LazyStream)" as jv
763
+ card "Ruby (Enumerator::Lazy)" as rb
764
+ }
765
+
766
+ @enduml
767
+ ```
768
+
769
+ **Level 1(Haskell, Clojure)** はリスト自体が遅延評価されるため、特別なストリーム型が不要です。`[1..]` で無限リストを定義できる Haskell と、`(range)` で無限シーケンスを生成できる Clojure が該当します。
770
+
771
+ **Level 2(Scala, Rust, Elixir, F#, C#)** は専用のストリーム型 / モジュールで遅延評価を実現します。特に Scala の fs2 は IO とストリームを型レベルで統合する最も表現力の高いライブラリです。
772
+
773
+ **Level 3(Python, TypeScript, Java, Ruby)** はジェネレータ構文やカスタムクラスで遅延評価を実装します。
774
+
775
+ ### 発見 2: スライディングウィンドウの提供方法は言語により異なる
776
+
777
+ | 方式 | 言語 | 関数/メソッド |
778
+ |------|------|-------------|
779
+ | **標準提供** | Scala (fs2), F#, Rust (スライス) | `.sliding(n)`, `Seq.windowed n`, `.windows(n)` |
780
+ | **ステップ付き分割** | Clojure, Elixir | `(partition n 1 coll)`, `Stream.chunk_every(n, 1)` |
781
+ | **隣接ペア** | Haskell, Ruby | カスタム `sliding`, `each_cons(n)` |
782
+ | **キューベース実装** | C#, Python, TypeScript, Java | `Queue` / `deque` ベースのカスタム |
783
+
784
+ ### 発見 3: Haskell のフィボナッチ定義は遅延評価の本質を表す
785
+
786
+ ```haskell
787
+ fibs = 0 : 1 : zipWith (+) fibs (tail fibs)
788
+ ```
789
+
790
+ この**自己参照的**な定義は、遅延評価がなければ無限再帰で停止しません。Haskell のデフォルト遅延評価だからこそ可能な表現であり、他の言語では `unfold` や `iterate` による明示的な状態遷移が必要です。
791
+
792
+ ---
793
+
794
+ ## 9.9 言語固有の特徴
795
+
796
+ ### Haskell: リスト自体が無限ストリーム
797
+
798
+ ```haskell
799
+ -- 自然数、偶数、奇数の無限リスト
800
+ naturals = [1..]
801
+ evens = [2,4..]
802
+ odds = [1,3..]
803
+
804
+ -- エラトステネスのふるい(無限の素数列)
805
+ primes :: [Integer]
806
+ primes = sieve [2..]
807
+ where sieve (p:xs) = p : sieve [x | x <- xs, x `mod` p /= 0]
808
+ ```
809
+
810
+ ### Scala (fs2): IO ストリームの型安全な合成
811
+
812
+ ```scala
813
+ // レートと時間制御の結合
814
+ val ratesWithDelay: Stream[IO, BigDecimal] =
815
+ rates(from, to).zipLeft(Stream.fixedRate[IO](1.second))
816
+
817
+ // エフェクトフルなストリームパイプライン
818
+ rates(from, to)
819
+ .sliding(3)
820
+ .map(_.toList)
821
+ .filter(trending)
822
+ .map(_.last * amount)
823
+ .take(1)
824
+ .compile
825
+ .lastOrError
826
+ ```
827
+
828
+ ### Clojure: トランスデューサーによる効率的な合成
829
+
830
+ ```clojure
831
+ ;; トランスデューサー: 中間コレクションを作らない
832
+ (def xf (comp
833
+ (partition-all 3 1)
834
+ (filter trending?)
835
+ (map last)))
836
+
837
+ (transduce xf conj [] rates)
838
+ ```
839
+
840
+ ### Python: ジェネレータの直感的な構文
841
+
842
+ ```python
843
+ # yield で素数のストリームを定義
844
+ def primes():
845
+ def sieve(numbers):
846
+ p = next(numbers)
847
+ yield p
848
+ yield from sieve(n for n in numbers if n % p != 0)
849
+ yield from sieve(count(2))
850
+ ```
851
+
852
+ ### Elixir: Stream + Enum のパイプライン
853
+
854
+ ```elixir
855
+ # パイプ演算子でストリーム処理を連鎖
856
+ Stream.iterate(1, &(&1 + 1))
857
+ |> Stream.filter(&(rem(&1, 2) == 0))
858
+ |> Stream.map(&(&1 * &1))
859
+ |> Enum.take(5)
860
+ # [4, 16, 36, 64, 100]
861
+ ```
862
+
863
+ ---
864
+
865
+ ## 9.10 実践的な選択指針
866
+
867
+ ### ストリーム処理の選択
868
+
869
+ | 要件 | 推奨言語 | 理由 |
870
+ |------|---------|------|
871
+ | 最も自然な無限ストリーム | Haskell | デフォルト遅延評価、特別な型不要 |
872
+ | IO + ストリームの型安全な統合 | Scala (fs2) | `Stream[IO, A]` による統合 |
873
+ | 高性能な非同期ストリーム | Rust | ゼロコスト抽象化、`buffered` で並行処理 |
874
+ | 分散ストリーム処理 | Elixir | OTP + Stream のパイプライン |
875
+ | データ分析パイプライン | Python | ジェネレータ + itertools の豊富なAPI |
876
+ | 関数合成の効率化 | Clojure | トランスデューサーで中間コレクション排除 |
877
+
878
+ ### プロジェクト規模別の推奨
879
+
880
+ | 規模 | 推奨アプローチ | 言語例 |
881
+ |------|-------------|-------|
882
+ | 小規模 | ジェネレータ / イテレータ | Python, TypeScript, Ruby |
883
+ | 中規模 | 標準ストリームモジュール | Elixir (Stream), F# (Seq), C# (IEnumerable) |
884
+ | 大規模 | エフェクトフルストリームライブラリ | Scala (fs2), Rust (futures::Stream) |
885
+
886
+ ---
887
+
888
+ ## 9.11 まとめ
889
+
890
+ 本章では、11 言語でのストリーム処理を比較し、以下を確認しました:
891
+
892
+ **共通の原則**:
893
+
894
+ - ストリーム = 遅延評価による無限シーケンス
895
+ - take / filter / map / sliding で変換を連鎖
896
+ - スライディングウィンドウによるパターン検出は全言語で実装可能
897
+
898
+ **言語間の差異**:
899
+
900
+ - 遅延評価の実現方式は 3 系統(デフォルト遅延 / 専用ストリーム型 / ジェネレータ)
901
+ - Haskell のリストはそのまま無限ストリームとして機能する唯一の言語
902
+ - IO とストリームの統合度は Scala (fs2) が最も高い
903
+
904
+ **学び**:
905
+
906
+ - 遅延評価により、無限のデータを有限のメモリで安全に扱える
907
+ - スライディングウィンドウ + トレンド判定は関数型のストリーム処理の典型パターン
908
+ - IO ストリームの統合は、リアルタイムアプリケーションの基盤となる
909
+
910
+ ---
911
+
912
+ ### 各言語の詳細記事
913
+
914
+ | 言語 | 記事リンク |
915
+ |------|-----------|
916
+ | Scala | [Part IV: IO と副作用の管理](../scala/part-4.md) |
917
+ | Java | [Part IV: IO と副作用の管理](../java/part-4.md) |
918
+ | F# | [Part IV: 非同期処理とストリーム](../fsharp/part-4.md) |
919
+ | C# | [Part IV: 非同期処理とストリーム](../csharp/part-4.md) |
920
+ | Haskell | [Part IV: IO と副作用の管理](../haskell/part-4.md) |
921
+ | Clojure | [Part IV: 状態管理とストリーム処理](../clojure/part-4.md) |
922
+ | Elixir | [Part IV: IO とストリーム処理](../elixir/part-4.md) |
923
+ | Rust | [Part IV: 非同期処理とストリーム](../rust/part-4.md) |
924
+ | Python | [Part IV: IO と副作用の管理](../python/part-4.md) |
925
+ | TypeScript | [Part IV: IO と副作用の管理](../typescript/part-4.md) |
926
+ | Ruby | [Part IV: IO と副作用の管理](../ruby/part-4.md) |