@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,971 @@
1
+ # Part II: 関数型スタイルのプログラミング
2
+
3
+ 本章では、関数型プログラミングの核心となるテクニックを学びます。イミュータブルなデータ操作、高階関数、そして `Bind`(flatMap 相当)による複雑なデータ変換を習得します。
4
+
5
+ ---
6
+
7
+ ## 第3章: イミュータブルなデータ操作
8
+
9
+ ### 3.1 イミュータブルとは
10
+
11
+ イミュータブル(不変)とは、一度作成されたデータが変更されないことを意味します。データを「変更」する代わりに、新しいデータを「作成」します。
12
+
13
+ ```plantuml
14
+ @startuml
15
+ !theme plain
16
+
17
+ rectangle "ミュータブル(可変)" as mut {
18
+ card "list = new List<string>{\"A\", \"B\"}" as m1
19
+ card "list.Add(\"C\")" as m2
20
+ card "list = [A, B, C]" as m3
21
+ m1 --> m2 : 変更
22
+ m2 --> m3 : 同じリストが変わる
23
+ }
24
+
25
+ rectangle "イミュータブル(不変)" as immut {
26
+ card "seq1 = Seq(\"A\", \"B\")" as i1
27
+ card "seq2 = seq1.Add(\"C\")" as i2
28
+ card "seq1 = [A; B]\nseq2 = [A; B; C]" as i3
29
+ i1 --> i2 : 新規作成
30
+ i2 --> i3 : 両方が存在
31
+ }
32
+
33
+ @enduml
34
+ ```
35
+
36
+ ### 3.2 Seq の基本操作
37
+
38
+ **ソースファイル**: `app/csharp/src/Ch03/ImmutableOperations.cs`
39
+
40
+ #### 要素の追加
41
+
42
+ LanguageExt の `Seq<T>` はデフォルトでイミュータブルです。要素を追加すると新しい Seq が作成されます。
43
+
44
+ ```csharp
45
+ using LanguageExt;
46
+ using static LanguageExt.Prelude;
47
+
48
+ var appleBook = Seq("Apple", "Book");
49
+ var appleBookMango = appleBook.Add("Mango");
50
+
51
+ // 元の Seq は変わらない
52
+ Debug.Assert(appleBook.Count == 2);
53
+ // 新しい Seq が作成される
54
+ Debug.Assert(appleBookMango.Count == 3);
55
+ Debug.Assert(appleBookMango.SequenceEqual(Seq("Apple", "Book", "Mango")));
56
+ ```
57
+
58
+ #### スライス操作
59
+
60
+ ```csharp
61
+ /// <summary>
62
+ /// Seq の先頭 n 個の要素を取得
63
+ /// </summary>
64
+ public static Seq<T> FirstN<T>(Seq<T> seq, int n) =>
65
+ seq.Take(n);
66
+
67
+ /// <summary>
68
+ /// Seq の末尾 n 個の要素を取得
69
+ /// </summary>
70
+ public static Seq<T> LastN<T>(Seq<T> seq, int n)
71
+ {
72
+ var skipCount = Math.Max(0, seq.Count - n);
73
+ return seq.Skip(skipCount);
74
+ }
75
+
76
+ /// <summary>
77
+ /// Seq の最初の 2 要素を取得
78
+ /// </summary>
79
+ public static Seq<T> FirstTwo<T>(Seq<T> seq) =>
80
+ FirstN(seq, 2);
81
+
82
+ /// <summary>
83
+ /// Seq の最後の 2 要素を取得
84
+ /// </summary>
85
+ public static Seq<T> LastTwo<T>(Seq<T> seq) =>
86
+ LastN(seq, 2);
87
+ ```
88
+
89
+ ```plantuml
90
+ @startuml
91
+ !theme plain
92
+
93
+ rectangle "Slice(start, end)" {
94
+ card "Seq(\"a\", \"b\", \"c\", \"d\")" as orig
95
+ card "Skip(1).Take(2)" as op
96
+ card "Seq(\"b\", \"c\")" as result
97
+
98
+ orig --> op
99
+ op --> result
100
+ }
101
+
102
+ note bottom of result
103
+ インデックス 1 から 2 要素を取得
104
+ end note
105
+
106
+ @enduml
107
+ ```
108
+
109
+ ### 3.3 Seq の変換例
110
+
111
+ ```csharp
112
+ /// <summary>
113
+ /// 最初の 2 要素を末尾に移動
114
+ /// </summary>
115
+ public static Seq<T> MoveFirstTwoToEnd<T>(Seq<T> seq)
116
+ {
117
+ var first = FirstTwo(seq);
118
+ var rest = seq.Skip(2);
119
+ return rest.Concat(first);
120
+ }
121
+
122
+ // 使用例
123
+ Debug.Assert(MoveFirstTwoToEnd(Seq("a", "b", "c")).SequenceEqual(Seq("c", "a", "b")));
124
+
125
+ /// <summary>
126
+ /// 最後の要素の前に新しい要素を挿入
127
+ /// </summary>
128
+ public static Seq<T> InsertBeforeLast<T>(Seq<T> seq, T element)
129
+ {
130
+ var withoutLast = seq.Take(seq.Count - 1);
131
+ var last = LastN(seq, 1);
132
+ return withoutLast.Add(element).Concat(last);
133
+ }
134
+
135
+ Debug.Assert(InsertBeforeLast(Seq("a", "b"), "c").SequenceEqual(Seq("a", "c", "b")));
136
+ ```
137
+
138
+ ### 3.4 旅程の再計画
139
+
140
+ 旅行の計画変更をイミュータブルに行う例です。
141
+
142
+ ```csharp
143
+ /// <summary>
144
+ /// 指定した都市の前に新しい都市を挿入
145
+ /// </summary>
146
+ public static Seq<string> Replan(Seq<string> plan, string newCity, string beforeCity)
147
+ {
148
+ var index = plan.ToList().FindIndex(c => c == beforeCity);
149
+ if (index < 0) index = plan.Count;
150
+
151
+ var citiesBefore = plan.Take(index);
152
+ var citiesAfter = plan.Skip(index);
153
+ return citiesBefore.Add(newCity).Concat(citiesAfter);
154
+ }
155
+
156
+ var planA = Seq("Paris", "Berlin", "Kraków");
157
+ var planB = Replan(planA, "Vienna", "Kraków");
158
+
159
+ Debug.Assert(planB.SequenceEqual(Seq("Paris", "Berlin", "Vienna", "Kraków")));
160
+ Debug.Assert(planA.SequenceEqual(Seq("Paris", "Berlin", "Kraków"))); // 元の計画は変わらない!
161
+ ```
162
+
163
+ ```plantuml
164
+ @startuml
165
+ !theme plain
166
+
167
+ rectangle "旅程の再計画" {
168
+ card "Plan A:\nParis → Berlin → Kraków" as planA
169
+ card "Replan(planA, \"Vienna\", \"Kraków\")" as op
170
+ card "Plan B:\nParis → Berlin → Vienna → Kraków" as planB
171
+
172
+ planA --> op
173
+ op --> planB
174
+ }
175
+
176
+ note right of planA
177
+ Plan A は変更されない
178
+ (イミュータブル)
179
+ end note
180
+
181
+ @enduml
182
+ ```
183
+
184
+ ### 3.5 String と Seq の類似性
185
+
186
+ String と Seq は似た操作ができます。
187
+
188
+ | 操作 | C# Seq | C# String |
189
+ |------|--------|-----------|
190
+ | 結合 | `Concat` または `Add` | `+` または `String.Concat` |
191
+ | 切り出し | `Skip`, `Take` | `Substring` |
192
+ | サイズ | `Count` | `Length` |
193
+
194
+ ```csharp
195
+ // Seq の操作
196
+ var abSeq = Seq("a", "b");
197
+ var cdSeq = Seq("c", "d");
198
+ var abcdSeq = abSeq.Concat(cdSeq);
199
+ Debug.Assert(abcdSeq.SequenceEqual(Seq("a", "b", "c", "d")));
200
+
201
+ // String の操作
202
+ var abStr = "ab";
203
+ var cdStr = "cd";
204
+ var abcdStr = abStr + cdStr;
205
+ Debug.Assert(abcdStr == "abcd");
206
+ ```
207
+
208
+ ### 3.6 名前の省略
209
+
210
+ ```csharp
211
+ /// <summary>
212
+ /// 名前を省略形に変換(例: "Alonzo Church" -> "A. Church")
213
+ /// </summary>
214
+ public static string Abbreviate(string name)
215
+ {
216
+ var initial = name.Substring(0, 1);
217
+ var separatorIndex = name.IndexOf(' ');
218
+ if (separatorIndex < 0)
219
+ return name;
220
+
221
+ var lastName = name.Substring(separatorIndex + 1);
222
+ return $"{initial}. {lastName}";
223
+ }
224
+
225
+ Debug.Assert(Abbreviate("Alonzo Church") == "A. Church");
226
+ Debug.Assert(Abbreviate("A. Church") == "A. Church");
227
+ ```
228
+
229
+ ---
230
+
231
+ ## 第4章: 関数を値として扱う
232
+
233
+ ### 4.1 高階関数とは
234
+
235
+ 高階関数(Higher-Order Function)とは、以下のいずれかを満たす関数です:
236
+
237
+ 1. 関数を引数として受け取る
238
+ 2. 関数を戻り値として返す
239
+
240
+ ```plantuml
241
+ @startuml
242
+ !theme plain
243
+
244
+ rectangle "高階関数" {
245
+ rectangle "関数を引数に取る" as arg {
246
+ card "OrderBy" as sortBy
247
+ card "Map" as map
248
+ card "Filter" as filter
249
+ }
250
+
251
+ rectangle "関数を返す" as ret {
252
+ card "LargerThan(n)" as larger
253
+ card "DivisibleBy(n)" as divisible
254
+ }
255
+ }
256
+
257
+ @enduml
258
+ ```
259
+
260
+ ### 4.2 関数を引数として渡す
261
+
262
+ **ソースファイル**: `app/csharp/src/Ch04/HigherOrderFunctions.cs`
263
+
264
+ #### OrderBy - ソート基準を関数で指定
265
+
266
+ ```csharp
267
+ public static int WordScore(string word) =>
268
+ word.Replace("a", "").Length;
269
+
270
+ var words = Seq("rust", "java");
271
+ var sortedWords = toSeq(words.OrderBy(WordScore));
272
+
273
+ Debug.Assert(sortedWords.SequenceEqual(Seq("java", "rust")));
274
+ // java: 2文字 (j, v), rust: 4文字 (r, u, s, t)
275
+ ```
276
+
277
+ ```plantuml
278
+ @startuml
279
+ !theme plain
280
+
281
+ rectangle "OrderBy の動作" {
282
+ card "Seq(\"rust\", \"java\")" as input
283
+ card "WordScore(\"rust\") = 4\nWordScore(\"java\") = 2" as scores
284
+ card "Seq(\"java\", \"rust\")" as output
285
+
286
+ input --> scores : WordScore 関数を適用
287
+ scores --> output : スコア順にソート
288
+ }
289
+
290
+ @enduml
291
+ ```
292
+
293
+ #### Map - 各要素を変換
294
+
295
+ ```csharp
296
+ public static int Len(string s) => s.Length;
297
+
298
+ var lengths = Seq("scala", "rust", "ada").Map(Len);
299
+ Debug.Assert(lengths.SequenceEqual(Seq(5, 4, 3)));
300
+
301
+ public static int Double(int i) => i * 2;
302
+ var doubles = Seq(5, 1, 2, 4, 0).Map(Double);
303
+ Debug.Assert(doubles.SequenceEqual(Seq(10, 2, 4, 8, 0)));
304
+ ```
305
+
306
+ ```plantuml
307
+ @startuml
308
+ !theme plain
309
+
310
+ rectangle "Map の動作" {
311
+ card "Seq(\"scala\", \"rust\", \"ada\")" as input
312
+ card "Len 関数を各要素に適用" as op
313
+ card "Seq(5, 4, 3)" as output
314
+
315
+ input --> op
316
+ op --> output
317
+ }
318
+
319
+ @enduml
320
+ ```
321
+
322
+ #### Filter - 条件に合う要素を抽出
323
+
324
+ ```csharp
325
+ public static bool IsOdd(int i) => i % 2 == 1;
326
+
327
+ var odds = Seq(5, 1, 2, 4, 0).Filter(IsOdd);
328
+ Debug.Assert(odds.SequenceEqual(Seq(5, 1)));
329
+
330
+ var large = Seq(5, 1, 2, 4, 0).Filter(i => i > 4);
331
+ Debug.Assert(large.SequenceEqual(Seq(5)));
332
+ ```
333
+
334
+ #### Fold - 畳み込み
335
+
336
+ ```csharp
337
+ var sum = Seq(5, 1, 2, 4, 100).Fold(0, (acc, i) => acc + i);
338
+ Debug.Assert(sum == 112);
339
+
340
+ var maximum = Seq(5, 1, 2, 4, 15).Fold(int.MinValue, (maxVal, i) =>
341
+ i > maxVal ? i : maxVal);
342
+ Debug.Assert(maximum == 15);
343
+ ```
344
+
345
+ ```plantuml
346
+ @startuml
347
+ !theme plain
348
+
349
+ rectangle "Fold の動作" {
350
+ card "初期値: 0" as init
351
+ card "0 + 5 = 5" as s1
352
+ card "5 + 1 = 6" as s2
353
+ card "6 + 2 = 8" as s3
354
+ card "8 + 4 = 12" as s4
355
+ card "12 + 100 = 112" as s5
356
+
357
+ init --> s1
358
+ s1 --> s2
359
+ s2 --> s3
360
+ s3 --> s4
361
+ s4 --> s5
362
+ }
363
+
364
+ @enduml
365
+ ```
366
+
367
+ ### 4.3 レコード型とパターン
368
+
369
+ **ソースファイル**: `app/csharp/src/Ch04/HigherOrderFunctions.cs`
370
+
371
+ ```csharp
372
+ /// <summary>
373
+ /// プログラミング言語を表すレコード型
374
+ /// </summary>
375
+ public record ProgrammingLanguage(string Name, int Year);
376
+
377
+ var javaLang = new ProgrammingLanguage("Java", 1995);
378
+ var scalaLang = new ProgrammingLanguage("Scala", 2004);
379
+
380
+ var languages = Seq(javaLang, scalaLang);
381
+
382
+ // フィールドにアクセス
383
+ var names = languages.Map(lang => lang.Name);
384
+ Debug.Assert(names.SequenceEqual(Seq("Java", "Scala")));
385
+
386
+ // 条件でフィルタ
387
+ var young = languages.Filter(lang => lang.Year > 2000);
388
+ Debug.Assert(young.SequenceEqual(Seq(scalaLang)));
389
+ ```
390
+
391
+ ### 4.4 関数を返す関数
392
+
393
+ ```csharp
394
+ /// <summary>
395
+ /// n より大きいかを判定する関数を返す
396
+ /// </summary>
397
+ public static Func<int, bool> LargerThan(int n) =>
398
+ i => i > n;
399
+
400
+ var large = Seq(5, 1, 2, 4, 0).Filter(LargerThan(4));
401
+ Debug.Assert(large.SequenceEqual(Seq(5)));
402
+
403
+ var medium = Seq(5, 1, 2, 4, 0).Filter(LargerThan(1));
404
+ Debug.Assert(medium.SequenceEqual(Seq(5, 2, 4)));
405
+ ```
406
+
407
+ ```plantuml
408
+ @startuml
409
+ !theme plain
410
+
411
+ rectangle "関数を返す関数" {
412
+ card "LargerThan(4)" as call
413
+ card "i => i > 4" as fn
414
+ card "Filter に渡す" as filter
415
+
416
+ call --> fn : 関数を生成
417
+ fn --> filter : 生成された関数を使用
418
+ }
419
+
420
+ note bottom
421
+ LargerThan(4) は
422
+ 「4より大きいか判定する関数」を返す
423
+ end note
424
+
425
+ @enduml
426
+ ```
427
+
428
+ ### 4.5 カリー化と部分適用
429
+
430
+ LanguageExt の `curry` 関数を使ってカリー化できます。
431
+
432
+ ```csharp
433
+ using static LanguageExt.Prelude;
434
+
435
+ // カリー化された加算関数
436
+ public static Func<int, Func<int, int>> AddCurried =>
437
+ curry<int, int, int>((a, b) => a + b);
438
+
439
+ // 部分適用: 5を足す関数
440
+ public static Func<int, int> AddFive => AddCurried(5);
441
+
442
+ Debug.Assert(AddFive(3) == 8);
443
+ Debug.Assert(AddFive(10) == 15);
444
+ ```
445
+
446
+ ```plantuml
447
+ @startuml
448
+ !theme plain
449
+
450
+ rectangle "部分適用" {
451
+ rectangle "元の関数" as normal {
452
+ card "(a, b) => a + b" as n1
453
+ }
454
+
455
+ rectangle "部分適用" as partial {
456
+ card "AddFive = AddCurried(5)" as p1
457
+ card "AddFive(y) = 5 + y" as p2
458
+ }
459
+
460
+ normal --> partial : 最初の引数を固定
461
+ }
462
+
463
+ note bottom of partial
464
+ AddFive(3) = AddCurried(5)(3) = 8
465
+ end note
466
+
467
+ @enduml
468
+ ```
469
+
470
+ ### 4.6 ワードスコアリングの例
471
+
472
+ 複数のスコアリングロジックを組み合わせる例です。
473
+
474
+ ```csharp
475
+ public static int WordScore(string word) => word.Replace("a", "").Length;
476
+ public static int Bonus(string word) => word.Contains('c') ? 5 : 0;
477
+ public static int Penalty(string word) => word.Contains('s') ? 7 : 0;
478
+
479
+ var words = Seq("ada", "haskell", "scala", "java", "rust");
480
+
481
+ /// <summary>
482
+ /// 指定したスコア関数でワードをランキング
483
+ /// </summary>
484
+ public static Seq<string> RankedWords(Seq<string> words, Func<string, int> scoreFn) =>
485
+ toSeq(words.OrderByDescending(scoreFn));
486
+
487
+ // 基本スコアでランキング
488
+ var ranking1 = RankedWords(words, WordScore);
489
+ Debug.Assert(ranking1.Head == "haskell");
490
+
491
+ // ボーナス付きスコアでランキング
492
+ var ranking2 = RankedWords(words, w => WordScore(w) + Bonus(w));
493
+ // scala: 3 + 5 = 8, haskell: 7 + 0 = 7
494
+ Debug.Assert(ranking2.Head == "scala");
495
+
496
+ // ボーナスとペナルティ付きスコアでランキング
497
+ var ranking3 = RankedWords(words, w => WordScore(w) + Bonus(w) - Penalty(w));
498
+ // java: 2, scala: 1, ada: 0, haskell: 0, rust: -3
499
+ Debug.Assert(ranking3.Head == "java");
500
+ ```
501
+
502
+ ---
503
+
504
+ ## 第5章: Bind とネスト構造
505
+
506
+ ### 5.1 Flatten と Bind
507
+
508
+ **ソースファイル**: `app/csharp/src/Ch05/FlatMapOperations.cs`
509
+
510
+ #### Bind - ネストした Seq を平坦化
511
+
512
+ ```csharp
513
+ public record Book(string Title, Seq<string> Authors);
514
+
515
+ var books = Seq(
516
+ new Book("FP in Scala", Seq("Chiusano", "Bjarnason")),
517
+ new Book("The Hobbit", Seq("Tolkien"))
518
+ );
519
+
520
+ // Map だけだとネストする
521
+ var authorSeqs = books.Map(b => b.Authors);
522
+ // Seq<Seq<string>>: [ ["Chiusano", "Bjarnason"], ["Tolkien"] ]
523
+
524
+ // Bind で平坦化しながら変換
525
+ var authors = books.Bind(b => b.Authors);
526
+ // Seq<string>: ["Chiusano", "Bjarnason", "Tolkien"]
527
+ ```
528
+
529
+ ```plantuml
530
+ @startuml
531
+ !theme plain
532
+
533
+ rectangle "Bind の動作" {
534
+ card "Seq(Seq(\"A\", \"B\"), Seq(\"C\"))" as nested
535
+ card "Bind(x => x)" as op
536
+ card "Seq(\"A\", \"B\", \"C\")" as flat
537
+
538
+ nested --> op
539
+ op --> flat
540
+ }
541
+
542
+ @enduml
543
+ ```
544
+
545
+ #### Bind = Map + Flatten
546
+
547
+ C# の LanguageExt における `Bind` は Scala の `flatMap` に相当します。
548
+
549
+ ```csharp
550
+ // Map して Flatten
551
+ var authors1 = books.Map(b => b.Authors).Bind(x => x);
552
+
553
+ // Bind で同じことを1行で
554
+ var authors2 = books.Bind(b => b.Authors);
555
+
556
+ Debug.Assert(authors1.SequenceEqual(authors2));
557
+ // ["Chiusano", "Bjarnason", "Tolkien"]
558
+ ```
559
+
560
+ ### 5.2 Bind によるリストサイズの変化
561
+
562
+ ```csharp
563
+ // 要素数が増える
564
+ var duplicate = Seq(1, 2, 3).Bind(i => Seq(i, i + 10));
565
+ // [1, 11, 2, 12, 3, 13] - 6要素
566
+
567
+ // 要素数が同じ
568
+ var doubled = Seq(1, 2, 3).Bind(i => Seq(i * 2));
569
+ // [2, 4, 6] - 3要素
570
+
571
+ // 要素数が減る(フィルタリング効果)
572
+ var evens = Seq(1, 2, 3).Bind(i =>
573
+ i % 2 == 0 ? Seq(i) : Empty);
574
+ // [2] - 1要素
575
+ ```
576
+
577
+ ```plantuml
578
+ @startuml
579
+ !theme plain
580
+
581
+ rectangle "Bind とサイズの変化" {
582
+ rectangle "増加" as inc {
583
+ card "Seq(1, 2, 3)" as i1
584
+ card "i => Seq(i, i+10)" as f1
585
+ card "Seq(1, 11, 2, 12, 3, 13)" as r1
586
+ i1 --> f1
587
+ f1 --> r1
588
+ }
589
+
590
+ rectangle "減少(フィルタ)" as dec {
591
+ card "Seq(1, 2, 3)" as i2
592
+ card "i => even ? Seq(i) : Empty" as f2
593
+ card "Seq(2)" as r2
594
+ i2 --> f2
595
+ f2 --> r2
596
+ }
597
+ }
598
+
599
+ @enduml
600
+ ```
601
+
602
+ ### 5.3 ネストした Bind
603
+
604
+ 複数の Seq を組み合わせる場合、Bind をネストします。
605
+
606
+ ```csharp
607
+ public record Movie(string Title);
608
+
609
+ public static Seq<Movie> BookAdaptations(string author) =>
610
+ author == "Tolkien"
611
+ ? Seq(new Movie("An Unexpected Journey"), new Movie("The Desolation of Smaug"))
612
+ : Empty;
613
+
614
+ var books = Seq(
615
+ new Book("FP in Scala", Seq("Chiusano", "Bjarnason")),
616
+ new Book("The Hobbit", Seq("Tolkien"))
617
+ );
618
+
619
+ // ネストした Bind
620
+ var recommendations = books.Bind(book =>
621
+ book.Authors.Bind(author =>
622
+ BookAdaptations(author).Map(movie =>
623
+ $"You may like {movie.Title}, because you liked {author}'s {book.Title}")));
624
+
625
+ // 結果:
626
+ // [ "You may like An Unexpected Journey, because you liked Tolkien's The Hobbit"
627
+ // "You may like The Desolation of Smaug, because you liked Tolkien's The Hobbit" ]
628
+ ```
629
+
630
+ ```plantuml
631
+ @startuml
632
+ !theme plain
633
+
634
+ rectangle "ネストした Bind のフロー" {
635
+ card "books" as books
636
+ card "book.Authors" as authors
637
+ card "BookAdaptations(author)" as movies
638
+ card "recommendation string" as result
639
+
640
+ books --> authors : Bind
641
+ authors --> movies : Bind
642
+ movies --> result : Map
643
+ }
644
+
645
+ note bottom
646
+ 最後だけ Map
647
+ 途中は Bind
648
+ end note
649
+
650
+ @enduml
651
+ ```
652
+
653
+ ### 5.4 LINQ クエリ式
654
+
655
+ C# の LINQ クエリ式は、ネストした Bind を読みやすく書けます。
656
+
657
+ ```csharp
658
+ // Bind/Map 版
659
+ var c1 = books.Bind(book =>
660
+ book.Authors.Bind(author =>
661
+ BookAdaptations(author).Map(movie =>
662
+ $"You may like {movie.Title}, because you liked {author}'s {book.Title}")));
663
+
664
+ // LINQ クエリ式版(等価)
665
+ var c2 = (from book in books
666
+ from author in book.Authors
667
+ from movie in BookAdaptations(author)
668
+ select $"You may like {movie.Title}, because you liked {author}'s {book.Title}").ToSeq();
669
+
670
+ Debug.Assert(c1.SequenceEqual(c2));
671
+ ```
672
+
673
+ ```plantuml
674
+ @startuml
675
+ !theme plain
676
+
677
+ rectangle "LINQ クエリ式の構造" {
678
+ card "from x in xs\nfrom y in ys\nfrom z in zs\nselect f(x, y, z)" as forComp
679
+
680
+ card "xs.Bind(x =>\n ys.Bind(y =>\n zs.Map(z =>\n f(x, y, z))))" as binds
681
+
682
+ forComp <--> binds : 等価
683
+ }
684
+
685
+ note bottom
686
+ LINQ クエリ式は
687
+ Bind/Map の糖衣構文
688
+ end note
689
+
690
+ @enduml
691
+ ```
692
+
693
+ ### 5.5 円内の点の判定
694
+
695
+ LINQ クエリ式でフィルタリングも行う例です。
696
+
697
+ ```csharp
698
+ public record Point(int X, int Y);
699
+
700
+ var points = Seq(new Point(5, 2), new Point(1, 1));
701
+ var radiuses = Seq(2, 1);
702
+
703
+ public static bool IsInside(Point point, int radius) =>
704
+ radius * radius >= point.X * point.X + point.Y * point.Y;
705
+
706
+ // 全組み合わせを生成
707
+ var allCombinations = (from r in radiuses
708
+ from point in points
709
+ select $"Point({point.X},{point.Y}) is within a radius of {r}: {IsInside(point, r)}").ToSeq();
710
+
711
+ // 結果:
712
+ // [ "Point(5,2) is within a radius of 2: false"
713
+ // "Point(1,1) is within a radius of 2: true"
714
+ // "Point(5,2) is within a radius of 1: false"
715
+ // "Point(1,1) is within a radius of 1: false" ]
716
+ ```
717
+
718
+ #### where によるフィルタリング
719
+
720
+ ```csharp
721
+ // where を使ったフィルタリング
722
+ var insidePoints = (from r in radiuses
723
+ from point in points
724
+ where IsInside(point, r)
725
+ select $"Point({point.X},{point.Y}) is within a radius of {r}").ToSeq();
726
+
727
+ // 結果: [ "Point(1,1) is within a radius of 2" ]
728
+ ```
729
+
730
+ ```plantuml
731
+ @startuml
732
+ !theme plain
733
+
734
+ rectangle "フィルタリングの3つの方法" {
735
+ rectangle "1. Filter を使う" as m1 {
736
+ card "points.Filter(p => IsInside(p, r))"
737
+ }
738
+
739
+ rectangle "2. LINQ クエリ式で where を使う" as m2 {
740
+ card "from ... where IsInside(...) select ..."
741
+ }
742
+
743
+ rectangle "3. Bind を使う" as m3 {
744
+ card "cond ? Seq(x) : Empty"
745
+ }
746
+ }
747
+
748
+ @enduml
749
+ ```
750
+
751
+ ### 5.6 LINQ の柔軟性
752
+
753
+ C# の LINQ クエリ式は、`Seq`、`IEnumerable`、その他の LINQ 対応型で使えます。
754
+
755
+ ```csharp
756
+ // Seq を使った LINQ
757
+ var seqResult = (from a in Seq(1, 2)
758
+ from b in Seq(2, 1)
759
+ select a * b).ToSeq();
760
+ // [2, 1, 4, 2] - 重複あり、順序あり
761
+
762
+ // HashSet への変換
763
+ var hashSetResult = new System.Collections.Generic.HashSet<int>(seqResult);
764
+ // {1, 2, 4} - 重複なし
765
+ ```
766
+
767
+ ---
768
+
769
+ ## まとめ
770
+
771
+ ### Part II で学んだこと
772
+
773
+ ```plantuml
774
+ @startuml
775
+ !theme plain
776
+
777
+ rectangle "Part II: 関数型スタイルのプログラミング" {
778
+ rectangle "第3章" as ch3 {
779
+ card "イミュータブルデータ"
780
+ card "Skip / Take"
781
+ card "データ変換パターン"
782
+ }
783
+
784
+ rectangle "第4章" as ch4 {
785
+ card "高階関数"
786
+ card "Map / Filter / Fold"
787
+ card "関数を返す関数"
788
+ card "カリー化と部分適用"
789
+ }
790
+
791
+ rectangle "第5章" as ch5 {
792
+ card "Flatten / Bind"
793
+ card "ネストした変換"
794
+ card "LINQ クエリ式"
795
+ card "where によるフィルタリング"
796
+ }
797
+ }
798
+
799
+ ch3 --> ch4
800
+ ch4 --> ch5
801
+
802
+ @enduml
803
+ ```
804
+
805
+ ### キーポイント
806
+
807
+ | 章 | 主要概念 | キー操作 |
808
+ |----|----------|----------|
809
+ | 第3章 | イミュータブル | `Concat`, `Add`, `Skip`, `Take` |
810
+ | 第4章 | 高階関数 | `Map`, `Filter`, `Fold`, `OrderBy` |
811
+ | 第5章 | 平坦化 | `Bind`, LINQ クエリ式 |
812
+
813
+ ### C#/LanguageExt と Scala/F# の対応
814
+
815
+ | 操作 | C# (LanguageExt) | Scala | F# |
816
+ |------|------------------|-------|-----|
817
+ | 平坦化 | `Bind(x => x)` | `flatten` | `List.concat` |
818
+ | flatMap | `Bind` | `flatMap` | `List.collect` |
819
+ | 内包表記 | LINQ `from ... select` | `for { x <- xs } yield ...` | `[ for x in xs do ... ]` |
820
+ | 畳み込み | `Fold` | `foldLeft` | `List.fold` |
821
+ | フィルタ | `Filter` | `filter` | `List.filter` |
822
+
823
+ ### 重要な法則
824
+
825
+ 1. **イミュータブルデータ**: 元のデータは変更せず、新しいデータを作成する
826
+ 2. **関数は値**: 関数を引数として渡したり、戻り値として返したりできる
827
+ 3. **Bind パターン**: ネストした構造を平坦化しながら変換する
828
+ 4. **LINQ クエリ式**: Bind/Map の糖衣構文として使える
829
+ 5. **メソッドチェーン**: `.` で関数を連鎖させて読みやすくする
830
+
831
+ ### 次のステップ
832
+
833
+ Part III では、以下のトピックを学びます:
834
+
835
+ - `Option<T>` 型による安全なエラーハンドリング
836
+ - `Either<L, R>` / `Result` 型と複合的なエラー処理
837
+
838
+ ---
839
+
840
+ ## 演習問題
841
+
842
+ ### 問題 1: イミュータブルな操作
843
+
844
+ 以下の関数を実装してください。Seq の中央に要素を挿入する関数です。
845
+
846
+ ```csharp
847
+ public static Seq<T> InsertAtMiddle<T>(Seq<T> seq, T element) => ???
848
+
849
+ // 期待される動作
850
+ Debug.Assert(InsertAtMiddle(Seq("a", "b", "c", "d"), "X").SequenceEqual(Seq("a", "b", "X", "c", "d")));
851
+ Debug.Assert(InsertAtMiddle(Seq("a", "b"), "X").SequenceEqual(Seq("a", "X", "b")));
852
+ ```
853
+
854
+ <details>
855
+ <summary>解答</summary>
856
+
857
+ ```csharp
858
+ public static Seq<T> InsertAtMiddle<T>(Seq<T> seq, T element)
859
+ {
860
+ var middle = seq.Count / 2;
861
+ var before = seq.Take(middle);
862
+ var after = seq.Skip(middle);
863
+ return before.Add(element).Concat(after);
864
+ }
865
+ ```
866
+
867
+ </details>
868
+
869
+ ### 問題 2: 高階関数
870
+
871
+ 以下の関数を実装してください。条件を満たす要素の数をカウントする関数です。
872
+
873
+ ```csharp
874
+ public static int CountWhere<T>(Seq<T> seq, Func<T, bool> predicate) => ???
875
+
876
+ // 期待される動作
877
+ Debug.Assert(CountWhere(Seq(1, 2, 3, 4, 5), i => i > 3) == 2);
878
+ Debug.Assert(CountWhere(Seq("a", "bb", "ccc"), s => s.Length > 1) == 2);
879
+ ```
880
+
881
+ <details>
882
+ <summary>解答</summary>
883
+
884
+ ```csharp
885
+ public static int CountWhere<T>(Seq<T> seq, Func<T, bool> predicate) =>
886
+ seq.Filter(predicate).Count;
887
+
888
+ // または Fold を使って
889
+ public static int CountWhere2<T>(Seq<T> seq, Func<T, bool> predicate) =>
890
+ seq.Fold(0, (count, elem) => predicate(elem) ? count + 1 : count);
891
+ ```
892
+
893
+ </details>
894
+
895
+ ### 問題 3: LINQ クエリ式
896
+
897
+ 以下のネストした Bind を LINQ クエリ式で書き換えてください。
898
+
899
+ ```csharp
900
+ var result = Seq(1, 2).Bind(x =>
901
+ Seq(10, 20).Bind(y =>
902
+ Seq(100, 200).Map(z =>
903
+ x + y + z)));
904
+ ```
905
+
906
+ <details>
907
+ <summary>解答</summary>
908
+
909
+ ```csharp
910
+ var result = (from x in Seq(1, 2)
911
+ from y in Seq(10, 20)
912
+ from z in Seq(100, 200)
913
+ select x + y + z).ToSeq();
914
+
915
+ // 結果: [111, 211, 121, 221, 112, 212, 122, 222]
916
+ ```
917
+
918
+ </details>
919
+
920
+ ### 問題 4: Bind によるフィルタリング
921
+
922
+ LINQ クエリ式の `where` を使わずに、Bind だけで偶数のみを抽出するコードを書いてください。
923
+
924
+ ```csharp
925
+ var numbers = Seq(1, 2, 3, 4, 5, 6);
926
+ // 偶数のみを抽出: Seq(2, 4, 6)
927
+ ```
928
+
929
+ <details>
930
+ <summary>解答</summary>
931
+
932
+ ```csharp
933
+ var evenNumbers = numbers.Bind(n =>
934
+ n % 2 == 0 ? Seq(n) : Empty);
935
+
936
+ // または関数に分離
937
+ Seq<int> EvenFilter(int n) =>
938
+ n % 2 == 0 ? Seq(n) : Empty;
939
+
940
+ var evenNumbers2 = numbers.Bind(EvenFilter);
941
+ ```
942
+
943
+ </details>
944
+
945
+ ### 問題 5: メソッドチェーンで書き換え
946
+
947
+ 以下のコードをメソッドチェーンを使って書き換えてください。
948
+
949
+ ```csharp
950
+ var result = CountWhere(
951
+ Filter(
952
+ Map(Seq(1, -2, 3, -4, 5), x => x * 2),
953
+ x => x > 0),
954
+ x => true);
955
+ ```
956
+
957
+ <details>
958
+ <summary>解答</summary>
959
+
960
+ ```csharp
961
+ var result = Seq(1, -2, 3, -4, 5)
962
+ .Map(x => x * 2)
963
+ .Filter(x => x > 0)
964
+ .Count;
965
+
966
+ // 結果: 3 (2, 6, 10 の3つ)
967
+ ```
968
+
969
+ メソッドチェーンを使うと、データの変換過程が上から下に読めるようになります。
970
+
971
+ </details>