trackler 2.2.1.128 → 2.2.1.129

Sign up to get free protection for your applications and to get access to all the features.
Files changed (308) hide show
  1. checksums.yaml +4 -4
  2. data/lib/trackler/version.rb +1 -1
  3. data/problem-specifications/exercises/bracket-push/canonical-data.json +9 -1
  4. data/tracks/bash/config.json +3 -3
  5. data/tracks/ceylon/exercises/bracket-push/source/bracketpush/BracketsTest.ceylon +3 -1
  6. data/tracks/crystal/exercises/difference-of-squares/spec/difference_of_squares_spec.cr +9 -9
  7. data/tracks/csharp/config.json +12 -0
  8. data/tracks/csharp/exercises/Exercises.sln +7 -1
  9. data/tracks/csharp/exercises/yacht/Example.cs +71 -0
  10. data/tracks/csharp/exercises/yacht/README.md +34 -0
  11. data/tracks/csharp/exercises/yacht/Yacht.cs +26 -0
  12. data/tracks/csharp/exercises/yacht/Yacht.csproj +18 -0
  13. data/tracks/csharp/exercises/yacht/YachtTest.cs +162 -0
  14. data/tracks/csharp/generators/Exercises/Yacht.cs +20 -0
  15. data/tracks/dart/exercises/leap/lib/example.dart +4 -8
  16. data/tracks/dart/exercises/leap/lib/leap.dart +1 -1
  17. data/tracks/dart/exercises/leap/test/leap_test.dart +14 -16
  18. data/tracks/delphi/config.json +11 -0
  19. data/tracks/delphi/exercises/bracket-push/BracketPush.dpr +60 -0
  20. data/tracks/delphi/exercises/bracket-push/README.md +31 -0
  21. data/tracks/delphi/exercises/bracket-push/uBracketPushExample.pas +40 -0
  22. data/tracks/delphi/exercises/bracket-push/uBracketPushTest.pas +158 -0
  23. data/tracks/fsharp/config.json +18 -6
  24. data/tracks/fsharp/exercises/Exercises.sln +7 -1
  25. data/tracks/fsharp/exercises/accumulate/Accumulate.fsproj +2 -2
  26. data/tracks/fsharp/exercises/acronym/Acronym.fsproj +2 -2
  27. data/tracks/fsharp/exercises/all-your-base/AllYourBase.fsproj +2 -2
  28. data/tracks/fsharp/exercises/allergies/Allergies.fsproj +2 -2
  29. data/tracks/fsharp/exercises/alphametics/Alphametics.fsproj +2 -2
  30. data/tracks/fsharp/exercises/anagram/Anagram.fsproj +2 -2
  31. data/tracks/fsharp/exercises/armstrong-numbers/ArmstrongNumbers.fsproj +2 -2
  32. data/tracks/fsharp/exercises/atbash-cipher/AtbashCipher.fsproj +2 -2
  33. data/tracks/fsharp/exercises/bank-account/BankAccount.fsproj +2 -2
  34. data/tracks/fsharp/exercises/beer-song/BeerSong.fsproj +2 -2
  35. data/tracks/fsharp/exercises/binary/Binary.fsproj +2 -2
  36. data/tracks/fsharp/exercises/binary-search/BinarySearch.fsproj +2 -2
  37. data/tracks/fsharp/exercises/binary-search-tree/BinarySearchTree.fsproj +2 -2
  38. data/tracks/fsharp/exercises/bob/Bob.fsproj +2 -2
  39. data/tracks/fsharp/exercises/book-store/BookStore.fsproj +2 -2
  40. data/tracks/fsharp/exercises/bowling/Bowling.fsproj +2 -2
  41. data/tracks/fsharp/exercises/bowling/BowlingTest.fs +15 -1
  42. data/tracks/fsharp/exercises/bracket-push/BracketPush.fsproj +2 -2
  43. data/tracks/fsharp/exercises/change/Change.fsproj +2 -2
  44. data/tracks/fsharp/exercises/circular-buffer/CircularBuffer.fsproj +2 -2
  45. data/tracks/fsharp/exercises/circular-buffer/CircularBufferTest.fs +1 -1
  46. data/tracks/fsharp/exercises/clock/Clock.fsproj +2 -2
  47. data/tracks/fsharp/exercises/collatz-conjecture/CollatzConjecture.fsproj +2 -2
  48. data/tracks/fsharp/exercises/complex-numbers/ComplexNumbers.fsproj +2 -2
  49. data/tracks/fsharp/exercises/connect/Connect.fsproj +2 -2
  50. data/tracks/fsharp/exercises/crypto-square/CryptoSquare.fsproj +2 -2
  51. data/tracks/fsharp/exercises/custom-set/CustomSet.fsproj +2 -2
  52. data/tracks/fsharp/exercises/diamond/Diamond.fsproj +2 -2
  53. data/tracks/fsharp/exercises/difference-of-squares/DifferenceOfSquares.fsproj +2 -2
  54. data/tracks/fsharp/exercises/diffie-hellman/DiffieHellman.fsproj +2 -2
  55. data/tracks/fsharp/exercises/dominoes/Dominoes.fsproj +2 -2
  56. data/tracks/fsharp/exercises/dot-dsl/DotDsl.fsproj +2 -2
  57. data/tracks/fsharp/exercises/error-handling/ErrorHandling.fsproj +2 -2
  58. data/tracks/fsharp/exercises/etl/Etl.fsproj +2 -2
  59. data/tracks/fsharp/exercises/food-chain/FoodChain.fsproj +2 -2
  60. data/tracks/fsharp/exercises/forth/Forth.fsproj +2 -2
  61. data/tracks/fsharp/exercises/forth/ForthTest.fs +1 -1
  62. data/tracks/fsharp/exercises/gigasecond/Gigasecond.fsproj +2 -2
  63. data/tracks/fsharp/exercises/go-counting/GoCounting.fsproj +2 -2
  64. data/tracks/fsharp/exercises/grade-school/GradeSchool.fsproj +2 -2
  65. data/tracks/fsharp/exercises/grains/Grains.fsproj +2 -2
  66. data/tracks/fsharp/exercises/grains/GrainsTest.fs +1 -1
  67. data/tracks/fsharp/exercises/grep/Grep.fsproj +2 -2
  68. data/tracks/fsharp/exercises/grep/GrepTest.fs +1 -1
  69. data/tracks/fsharp/exercises/hamming/Hamming.fsproj +2 -2
  70. data/tracks/fsharp/exercises/hangman/Hangman.fsproj +2 -2
  71. data/tracks/fsharp/exercises/hello-world/HelloWorld.fsproj +2 -2
  72. data/tracks/fsharp/exercises/hexadecimal/Hexadecimal.fsproj +2 -2
  73. data/tracks/fsharp/exercises/house/Example.fs +2 -2
  74. data/tracks/fsharp/exercises/house/House.fsproj +2 -2
  75. data/tracks/fsharp/exercises/house/HouseTest.fs +28 -211
  76. data/tracks/fsharp/exercises/isbn-verifier/IsbnVerifier.fsproj +2 -2
  77. data/tracks/fsharp/exercises/isbn-verifier/IsbnVerifierTest.fs +2 -2
  78. data/tracks/fsharp/exercises/isogram/Isogram.fsproj +2 -2
  79. data/tracks/fsharp/exercises/isogram/IsogramTest.fs +1 -1
  80. data/tracks/fsharp/exercises/kindergarten-garden/KindergartenGarden.fsproj +2 -2
  81. data/tracks/fsharp/exercises/largest-series-product/LargestSeriesProduct.fsproj +2 -2
  82. data/tracks/fsharp/exercises/leap/Leap.fsproj +2 -2
  83. data/tracks/fsharp/exercises/ledger/Ledger.fsproj +2 -2
  84. data/tracks/fsharp/exercises/lens-person/LensPerson.fsproj +2 -2
  85. data/tracks/fsharp/exercises/linked-list/LinkedList.fsproj +2 -2
  86. data/tracks/fsharp/exercises/list-ops/ListOps.fsproj +2 -2
  87. data/tracks/fsharp/exercises/list-ops/ListOpsTest.fs +1 -1
  88. data/tracks/fsharp/exercises/luhn/Luhn.fsproj +2 -2
  89. data/tracks/fsharp/exercises/markdown/Markdown.fsproj +2 -2
  90. data/tracks/fsharp/exercises/matrix/Matrix.fsproj +2 -2
  91. data/tracks/fsharp/exercises/meetup/Meetup.fsproj +2 -2
  92. data/tracks/fsharp/exercises/minesweeper/Minesweeper.fsproj +2 -2
  93. data/tracks/fsharp/exercises/nth-prime/NthPrime.fsproj +2 -2
  94. data/tracks/fsharp/exercises/nucleotide-count/NucleotideCount.fsproj +2 -2
  95. data/tracks/fsharp/exercises/ocr-numbers/OcrNumbers.fsproj +2 -2
  96. data/tracks/fsharp/exercises/octal/Octal.fsproj +2 -2
  97. data/tracks/fsharp/exercises/palindrome-products/PalindromeProducts.fsproj +2 -2
  98. data/tracks/fsharp/exercises/pangram/Pangram.fsproj +2 -2
  99. data/tracks/fsharp/exercises/parallel-letter-frequency/ParallelLetterFrequency.fsproj +2 -2
  100. data/tracks/fsharp/exercises/pascals-triangle/PascalsTriangle.fsproj +2 -2
  101. data/tracks/fsharp/exercises/perfect-numbers/PerfectNumbers.fsproj +2 -2
  102. data/tracks/fsharp/exercises/phone-number/PhoneNumber.fsproj +2 -2
  103. data/tracks/fsharp/exercises/pig-latin/PigLatin.fsproj +2 -2
  104. data/tracks/fsharp/exercises/poker/Poker.fsproj +2 -2
  105. data/tracks/fsharp/exercises/pov/Pov.fsproj +2 -2
  106. data/tracks/fsharp/exercises/pov/PovTest.fs +2 -2
  107. data/tracks/fsharp/exercises/prime-factors/PrimeFactors.fsproj +2 -2
  108. data/tracks/fsharp/exercises/protein-translation/ProteinTranslation.fsproj +2 -2
  109. data/tracks/fsharp/exercises/proverb/Proverb.fsproj +2 -2
  110. data/tracks/fsharp/exercises/pythagorean-triplet/PythagoreanTriplet.fsproj +2 -2
  111. data/tracks/fsharp/exercises/queen-attack/QueenAttack.fsproj +2 -2
  112. data/tracks/fsharp/exercises/rail-fence-cipher/RailFenceCipher.fsproj +2 -2
  113. data/tracks/fsharp/exercises/raindrops/Raindrops.fsproj +2 -2
  114. data/tracks/fsharp/exercises/rational-numbers/RationalNumbers.fsproj +2 -2
  115. data/tracks/fsharp/exercises/react/Example.fs +1 -1
  116. data/tracks/fsharp/exercises/react/React.fsproj +2 -2
  117. data/tracks/fsharp/exercises/react/ReactTest.fs +14 -1
  118. data/tracks/fsharp/exercises/rectangles/Rectangles.fsproj +2 -2
  119. data/tracks/fsharp/exercises/reverse-string/ReverseString.fsproj +2 -2
  120. data/tracks/fsharp/exercises/rna-transcription/RnaTranscription.fsproj +2 -2
  121. data/tracks/fsharp/exercises/robot-name/RobotName.fsproj +2 -2
  122. data/tracks/fsharp/exercises/robot-simulator/RobotSimulator.fsproj +2 -2
  123. data/tracks/fsharp/exercises/roman-numerals/RomanNumerals.fsproj +2 -2
  124. data/tracks/fsharp/exercises/rotational-cipher/RotationalCipher.fsproj +2 -2
  125. data/tracks/fsharp/exercises/run-length-encoding/RunLengthEncoding.fsproj +2 -2
  126. data/tracks/fsharp/exercises/saddle-points/SaddlePoints.fsproj +2 -2
  127. data/tracks/fsharp/exercises/say/Say.fsproj +2 -2
  128. data/tracks/fsharp/exercises/scale-generator/ScaleGenerator.fsproj +2 -2
  129. data/tracks/fsharp/exercises/scrabble-score/ScrabbleScore.fsproj +2 -2
  130. data/tracks/fsharp/exercises/secret-handshake/SecretHandshake.fsproj +2 -2
  131. data/tracks/fsharp/exercises/series/Series.fsproj +2 -2
  132. data/tracks/fsharp/exercises/sgf-parsing/SgfParsing.fsproj +2 -2
  133. data/tracks/fsharp/exercises/sieve/Sieve.fsproj +2 -2
  134. data/tracks/fsharp/exercises/simple-cipher/SimpleCipher.fsproj +2 -2
  135. data/tracks/fsharp/exercises/simple-linked-list/SimpleLinkedList.fsproj +2 -2
  136. data/tracks/fsharp/exercises/space-age/SpaceAge.fsproj +2 -2
  137. data/tracks/fsharp/exercises/spiral-matrix/SpiralMatrix.fsproj +2 -2
  138. data/tracks/fsharp/exercises/strain/Strain.fsproj +2 -2
  139. data/tracks/fsharp/exercises/sublist/Sublist.fsproj +2 -2
  140. data/tracks/fsharp/exercises/sum-of-multiples/SumOfMultiples.fsproj +2 -2
  141. data/tracks/fsharp/exercises/tournament/Tournament.fsproj +2 -2
  142. data/tracks/fsharp/exercises/transpose/Transpose.fsproj +2 -2
  143. data/tracks/fsharp/exercises/tree-building/TreeBuilding.fsproj +2 -2
  144. data/tracks/fsharp/exercises/triangle/Triangle.fsproj +2 -2
  145. data/tracks/fsharp/exercises/trinary/Trinary.fsproj +2 -2
  146. data/tracks/fsharp/exercises/twelve-days/TwelveDays.fsproj +2 -2
  147. data/tracks/fsharp/exercises/two-bucket/TwoBucket.fsproj +2 -2
  148. data/tracks/fsharp/exercises/two-fer/TwoFer.fsproj +2 -2
  149. data/tracks/fsharp/exercises/variable-length-quantity/VariableLengthQuantity.fsproj +2 -2
  150. data/tracks/fsharp/exercises/word-count/WordCount.fsproj +2 -2
  151. data/tracks/fsharp/exercises/word-search/WordSearch.fsproj +2 -2
  152. data/tracks/fsharp/exercises/word-search/WordSearchTest.fs +1 -1
  153. data/tracks/fsharp/exercises/wordy/Wordy.fsproj +2 -2
  154. data/tracks/fsharp/exercises/yacht/Example.fs +65 -0
  155. data/tracks/fsharp/exercises/yacht/Program.fs +1 -0
  156. data/tracks/fsharp/exercises/yacht/README.md +34 -0
  157. data/tracks/fsharp/exercises/yacht/Yacht.fs +17 -0
  158. data/tracks/fsharp/exercises/yacht/Yacht.fsproj +23 -0
  159. data/tracks/fsharp/exercises/yacht/YachtTest.fs +113 -0
  160. data/tracks/fsharp/exercises/zebra-puzzle/ZebraPuzzle.fsproj +2 -2
  161. data/tracks/fsharp/exercises/zipper/Zipper.fsproj +2 -2
  162. data/tracks/fsharp/generators/CanonicalData.fs +2 -20
  163. data/tracks/fsharp/generators/Common.fs +1 -1
  164. data/tracks/fsharp/generators/Generators.fs +24 -11
  165. data/tracks/fsharp/generators/Generators.fsproj +4 -4
  166. data/tracks/fsharp/generators/Options.fs +1 -1
  167. data/tracks/haskell/exercises/bracket-push/package.yaml +1 -1
  168. data/tracks/haskell/exercises/bracket-push/test/Tests.hs +4 -0
  169. data/tracks/java/config.json +13 -0
  170. data/tracks/java/exercises/dominoes/.meta/src/reference/java/ChainNotFoundException.java +5 -0
  171. data/tracks/java/exercises/dominoes/.meta/src/reference/java/Domino.java +30 -0
  172. data/tracks/java/exercises/dominoes/.meta/src/reference/java/Dominoes.java +67 -0
  173. data/tracks/java/exercises/dominoes/.meta/version +2 -0
  174. data/tracks/java/exercises/dominoes/README.md +29 -0
  175. data/tracks/java/exercises/dominoes/build.gradle +18 -0
  176. data/tracks/java/exercises/dominoes/src/main/java/ChainNotFoundException.java +5 -0
  177. data/tracks/java/exercises/dominoes/src/main/java/Domino.java +30 -0
  178. data/tracks/java/exercises/dominoes/src/test/java/DominoesTest.java +230 -0
  179. data/tracks/java/exercises/settings.gradle +1 -0
  180. data/tracks/javascript/.eslintignore +0 -1
  181. data/tracks/javascript/exercises/simple-cipher/example.js +4 -6
  182. data/tracks/javascript/exercises/simple-cipher/simple-cipher.spec.js +7 -3
  183. data/tracks/php/config.json +7 -7
  184. data/tracks/python/config.json +195 -188
  185. data/tracks/python/exercises/alphametics/alphametics_test.py +1 -0
  186. data/tracks/python/exercises/bank-account/README.md +20 -1
  187. data/tracks/python/exercises/go-counting/README.md +2 -0
  188. data/tracks/python/test/check-exercises.py +1 -1
  189. data/tracks/rust/_test/ensure-stubs-compile.sh +5 -0
  190. data/tracks/rust/config/exercise_readme.go.tmpl +1 -1
  191. data/tracks/rust/config.json +10 -0
  192. data/tracks/rust/exercises/accumulate/README.md +1 -1
  193. data/tracks/rust/exercises/acronym/README.md +1 -1
  194. data/tracks/rust/exercises/all-your-base/README.md +1 -1
  195. data/tracks/rust/exercises/all-your-base/example.rs +15 -5
  196. data/tracks/rust/exercises/all-your-base/src/lib.rs +8 -1
  197. data/tracks/rust/exercises/all-your-base/tests/all-your-base.rs +10 -5
  198. data/tracks/rust/exercises/allergies/README.md +1 -1
  199. data/tracks/rust/exercises/alphametics/README.md +1 -1
  200. data/tracks/rust/exercises/anagram/README.md +1 -1
  201. data/tracks/rust/exercises/armstrong-numbers/.gitignore +3 -0
  202. data/tracks/rust/exercises/armstrong-numbers/Cargo.toml +3 -0
  203. data/tracks/rust/exercises/armstrong-numbers/README.md +51 -0
  204. data/tracks/rust/exercises/armstrong-numbers/example.rs +7 -0
  205. data/tracks/rust/exercises/armstrong-numbers/src/lib.rs +3 -0
  206. data/tracks/rust/exercises/armstrong-numbers/tests/armstrong-numbers.rs +49 -0
  207. data/tracks/rust/exercises/atbash-cipher/README.md +1 -1
  208. data/tracks/rust/exercises/beer-song/README.md +1 -1
  209. data/tracks/rust/exercises/binary-search/README.md +1 -1
  210. data/tracks/rust/exercises/bob/README.md +1 -1
  211. data/tracks/rust/exercises/book-store/README.md +1 -1
  212. data/tracks/rust/exercises/bowling/README.md +1 -1
  213. data/tracks/rust/exercises/bowling/example.rs +13 -8
  214. data/tracks/rust/exercises/bowling/src/lib.rs +22 -0
  215. data/tracks/rust/exercises/bowling/tests/bowling.rs +31 -31
  216. data/tracks/rust/exercises/bracket-push/README.md +1 -1
  217. data/tracks/rust/exercises/circular-buffer/README.md +1 -1
  218. data/tracks/rust/exercises/clock/README.md +1 -1
  219. data/tracks/rust/exercises/collatz-conjecture/README.md +1 -1
  220. data/tracks/rust/exercises/crypto-square/README.md +1 -1
  221. data/tracks/rust/exercises/crypto-square/example.rs +11 -3
  222. data/tracks/rust/exercises/crypto-square/tests/crypto-square.rs +8 -16
  223. data/tracks/rust/exercises/custom-set/README.md +1 -1
  224. data/tracks/rust/exercises/custom-set/example.rs +17 -17
  225. data/tracks/rust/exercises/custom-set/tests/custom-set.rs +84 -84
  226. data/tracks/rust/exercises/decimal/README.md +1 -1
  227. data/tracks/rust/exercises/difference-of-squares/README.md +1 -1
  228. data/tracks/rust/exercises/diffie-hellman/README.md +1 -1
  229. data/tracks/rust/exercises/dominoes/README.md +1 -1
  230. data/tracks/rust/exercises/etl/README.md +1 -1
  231. data/tracks/rust/exercises/forth/README.md +1 -1
  232. data/tracks/rust/exercises/gigasecond/README.md +1 -1
  233. data/tracks/rust/exercises/grade-school/README.md +1 -1
  234. data/tracks/rust/exercises/grains/README.md +1 -1
  235. data/tracks/rust/exercises/hamming/README.md +1 -1
  236. data/tracks/rust/exercises/hello-world/README.md +1 -1
  237. data/tracks/rust/exercises/hexadecimal/README.md +1 -1
  238. data/tracks/rust/exercises/isbn-verifier/README.md +1 -1
  239. data/tracks/rust/exercises/isogram/README.md +1 -1
  240. data/tracks/rust/exercises/largest-series-product/README.md +1 -1
  241. data/tracks/rust/exercises/largest-series-product/example.rs +10 -4
  242. data/tracks/rust/exercises/largest-series-product/src/lib.rs +9 -0
  243. data/tracks/rust/exercises/largest-series-product/tests/largest-series-product.rs +3 -3
  244. data/tracks/rust/exercises/leap/README.md +1 -1
  245. data/tracks/rust/exercises/luhn/README.md +1 -1
  246. data/tracks/rust/exercises/luhn-from/README.md +1 -1
  247. data/tracks/rust/exercises/luhn-trait/README.md +1 -1
  248. data/tracks/rust/exercises/macros/.meta/ALLOWED_TO_NOT_COMPILE +2 -0
  249. data/tracks/rust/exercises/macros/README.md +1 -1
  250. data/tracks/rust/exercises/minesweeper/README.md +1 -1
  251. data/tracks/rust/exercises/nth-prime/README.md +1 -1
  252. data/tracks/rust/exercises/nucleotide-codons/README.md +1 -1
  253. data/tracks/rust/exercises/nucleotide-count/README.md +1 -1
  254. data/tracks/rust/exercises/ocr-numbers/README.md +1 -1
  255. data/tracks/rust/exercises/ocr-numbers/example.rs +14 -6
  256. data/tracks/rust/exercises/ocr-numbers/src/lib.rs +7 -1
  257. data/tracks/rust/exercises/ocr-numbers/tests/ocr-numbers.rs +2 -2
  258. data/tracks/rust/exercises/pangram/README.md +1 -1
  259. data/tracks/rust/exercises/parallel-letter-frequency/README.md +1 -1
  260. data/tracks/rust/exercises/pascals-triangle/README.md +1 -1
  261. data/tracks/rust/exercises/perfect-numbers/README.md +1 -1
  262. data/tracks/rust/exercises/phone-number/README.md +1 -1
  263. data/tracks/rust/exercises/pig-latin/README.md +1 -1
  264. data/tracks/rust/exercises/poker/README.md +1 -1
  265. data/tracks/rust/exercises/prime-factors/README.md +1 -1
  266. data/tracks/rust/exercises/protein-translation/README.md +1 -1
  267. data/tracks/rust/exercises/proverb/README.md +1 -1
  268. data/tracks/rust/exercises/pythagorean-triplet/README.md +1 -1
  269. data/tracks/rust/exercises/queen-attack/README.md +1 -1
  270. data/tracks/rust/exercises/raindrops/README.md +1 -1
  271. data/tracks/rust/exercises/react/README.md +1 -1
  272. data/tracks/rust/exercises/react/example.rs +27 -18
  273. data/tracks/rust/exercises/react/src/lib.rs +25 -10
  274. data/tracks/rust/exercises/react/tests/react.rs +113 -83
  275. data/tracks/rust/exercises/rectangles/README.md +1 -1
  276. data/tracks/rust/exercises/reverse-string/README.md +1 -1
  277. data/tracks/rust/exercises/rna-transcription/README.md +1 -1
  278. data/tracks/rust/exercises/robot-name/README.md +1 -1
  279. data/tracks/rust/exercises/robot-simulator/README.md +1 -1
  280. data/tracks/rust/exercises/roman-numerals/README.md +1 -1
  281. data/tracks/rust/exercises/rotational-cipher/README.md +1 -1
  282. data/tracks/rust/exercises/run-length-encoding/README.md +1 -1
  283. data/tracks/rust/exercises/saddle-points/README.md +1 -1
  284. data/tracks/rust/exercises/say/README.md +1 -1
  285. data/tracks/rust/exercises/scrabble-score/README.md +1 -1
  286. data/tracks/rust/exercises/series/README.md +1 -1
  287. data/tracks/rust/exercises/sieve/README.md +1 -1
  288. data/tracks/rust/exercises/simple-linked-list/README.md +1 -1
  289. data/tracks/rust/exercises/space-age/README.md +1 -1
  290. data/tracks/rust/exercises/sublist/README.md +1 -1
  291. data/tracks/rust/exercises/sum-of-multiples/README.md +1 -1
  292. data/tracks/rust/exercises/tournament/README.md +1 -1
  293. data/tracks/rust/exercises/triangle/README.md +1 -1
  294. data/tracks/rust/exercises/two-bucket/README.md +1 -1
  295. data/tracks/rust/exercises/variable-length-quantity/README.md +1 -1
  296. data/tracks/rust/exercises/word-count/README.md +1 -1
  297. data/tracks/rust/exercises/wordy/README.md +1 -1
  298. data/tracks/typescript/config.json +11 -0
  299. data/tracks/typescript/exercises/list-ops/README.md +35 -0
  300. data/tracks/typescript/exercises/list-ops/list-ops.example.ts +80 -0
  301. data/tracks/typescript/exercises/list-ops/list-ops.test.ts +117 -0
  302. data/tracks/typescript/exercises/list-ops/list-ops.ts +0 -0
  303. data/tracks/typescript/exercises/list-ops/package.json +36 -0
  304. data/tracks/typescript/exercises/list-ops/tsconfig.json +22 -0
  305. data/tracks/typescript/exercises/list-ops/tslint.json +127 -0
  306. data/tracks/typescript/exercises/list-ops/yarn.lock +2624 -0
  307. metadata +42 -3
  308. data/tracks/dart/exercises/leap/pubspec.lock +0 -293
@@ -13,10 +13,10 @@
13
13
  </ItemGroup>
14
14
 
15
15
  <ItemGroup>
16
- <PackageReference Include="Microsoft.NET.Test.Sdk" Version="15.5.0" />
16
+ <PackageReference Include="Microsoft.NET.Test.Sdk" Version="15.7.0" />
17
17
  <PackageReference Include="xunit" Version="2.3.1" />
18
18
  <PackageReference Include="xunit.runner.visualstudio" Version="2.3.1" />
19
- <PackageReference Include="FsUnit.xUnit" Version="3.0.0" />
19
+ <PackageReference Include="FsUnit.xUnit" Version="3.1.0" />
20
20
  <DotNetCliToolReference Include="dotnet-xunit" Version="2.3.1" />
21
21
  </ItemGroup>
22
22
 
@@ -13,10 +13,10 @@
13
13
  </ItemGroup>
14
14
 
15
15
  <ItemGroup>
16
- <PackageReference Include="Microsoft.NET.Test.Sdk" Version="15.5.0" />
16
+ <PackageReference Include="Microsoft.NET.Test.Sdk" Version="15.7.0" />
17
17
  <PackageReference Include="xunit" Version="2.3.1" />
18
18
  <PackageReference Include="xunit.runner.visualstudio" Version="2.3.1" />
19
- <PackageReference Include="FsUnit.xUnit" Version="3.0.0" />
19
+ <PackageReference Include="FsUnit.xUnit" Version="3.1.0" />
20
20
  <DotNetCliToolReference Include="dotnet-xunit" Version="2.3.1" />
21
21
  </ItemGroup>
22
22
 
@@ -13,10 +13,10 @@
13
13
  </ItemGroup>
14
14
 
15
15
  <ItemGroup>
16
- <PackageReference Include="Microsoft.NET.Test.Sdk" Version="15.5.0" />
16
+ <PackageReference Include="Microsoft.NET.Test.Sdk" Version="15.7.0" />
17
17
  <PackageReference Include="xunit" Version="2.3.1" />
18
18
  <PackageReference Include="xunit.runner.visualstudio" Version="2.3.1" />
19
- <PackageReference Include="FsUnit.xUnit" Version="3.0.0" />
19
+ <PackageReference Include="FsUnit.xUnit" Version="3.1.0" />
20
20
  <DotNetCliToolReference Include="dotnet-xunit" Version="2.3.1" />
21
21
  </ItemGroup>
22
22
 
@@ -13,10 +13,10 @@
13
13
  </ItemGroup>
14
14
 
15
15
  <ItemGroup>
16
- <PackageReference Include="Microsoft.NET.Test.Sdk" Version="15.5.0" />
16
+ <PackageReference Include="Microsoft.NET.Test.Sdk" Version="15.7.0" />
17
17
  <PackageReference Include="xunit" Version="2.3.1" />
18
18
  <PackageReference Include="xunit.runner.visualstudio" Version="2.3.1" />
19
- <PackageReference Include="FsUnit.xUnit" Version="3.0.0" />
19
+ <PackageReference Include="FsUnit.xUnit" Version="3.1.0" />
20
20
  <DotNetCliToolReference Include="dotnet-xunit" Version="2.3.1" />
21
21
  </ItemGroup>
22
22
 
@@ -13,10 +13,10 @@
13
13
  </ItemGroup>
14
14
 
15
15
  <ItemGroup>
16
- <PackageReference Include="Microsoft.NET.Test.Sdk" Version="15.5.0" />
16
+ <PackageReference Include="Microsoft.NET.Test.Sdk" Version="15.7.0" />
17
17
  <PackageReference Include="xunit" Version="2.3.1" />
18
18
  <PackageReference Include="xunit.runner.visualstudio" Version="2.3.1" />
19
- <PackageReference Include="FsUnit.xUnit" Version="3.0.0" />
19
+ <PackageReference Include="FsUnit.xUnit" Version="3.1.0" />
20
20
  <DotNetCliToolReference Include="dotnet-xunit" Version="2.3.1" />
21
21
  </ItemGroup>
22
22
 
@@ -13,10 +13,10 @@
13
13
  </ItemGroup>
14
14
 
15
15
  <ItemGroup>
16
- <PackageReference Include="Microsoft.NET.Test.Sdk" Version="15.5.0" />
16
+ <PackageReference Include="Microsoft.NET.Test.Sdk" Version="15.7.0" />
17
17
  <PackageReference Include="xunit" Version="2.3.1" />
18
18
  <PackageReference Include="xunit.runner.visualstudio" Version="2.3.1" />
19
- <PackageReference Include="FsUnit.xUnit" Version="3.0.0" />
19
+ <PackageReference Include="FsUnit.xUnit" Version="3.1.0" />
20
20
  <DotNetCliToolReference Include="dotnet-xunit" Version="2.3.1" />
21
21
  </ItemGroup>
22
22
 
@@ -13,10 +13,10 @@
13
13
  </ItemGroup>
14
14
 
15
15
  <ItemGroup>
16
- <PackageReference Include="Microsoft.NET.Test.Sdk" Version="15.5.0" />
16
+ <PackageReference Include="Microsoft.NET.Test.Sdk" Version="15.7.0" />
17
17
  <PackageReference Include="xunit" Version="2.3.1" />
18
18
  <PackageReference Include="xunit.runner.visualstudio" Version="2.3.1" />
19
- <PackageReference Include="FsUnit.xUnit" Version="3.0.0" />
19
+ <PackageReference Include="FsUnit.xUnit" Version="3.1.0" />
20
20
  <DotNetCliToolReference Include="dotnet-xunit" Version="2.3.1" />
21
21
  </ItemGroup>
22
22
 
@@ -13,10 +13,10 @@
13
13
  </ItemGroup>
14
14
 
15
15
  <ItemGroup>
16
- <PackageReference Include="Microsoft.NET.Test.Sdk" Version="15.5.0" />
16
+ <PackageReference Include="Microsoft.NET.Test.Sdk" Version="15.7.0" />
17
17
  <PackageReference Include="xunit" Version="2.3.1" />
18
18
  <PackageReference Include="xunit.runner.visualstudio" Version="2.3.1" />
19
- <PackageReference Include="FsUnit.xUnit" Version="3.0.0" />
19
+ <PackageReference Include="FsUnit.xUnit" Version="3.1.0" />
20
20
  <DotNetCliToolReference Include="dotnet-xunit" Version="2.3.1" />
21
21
  </ItemGroup>
22
22
 
@@ -13,10 +13,10 @@
13
13
  </ItemGroup>
14
14
 
15
15
  <ItemGroup>
16
- <PackageReference Include="Microsoft.NET.Test.Sdk" Version="15.5.0" />
16
+ <PackageReference Include="Microsoft.NET.Test.Sdk" Version="15.7.0" />
17
17
  <PackageReference Include="xunit" Version="2.3.1" />
18
18
  <PackageReference Include="xunit.runner.visualstudio" Version="2.3.1" />
19
- <PackageReference Include="FsUnit.xUnit" Version="3.0.0" />
19
+ <PackageReference Include="FsUnit.xUnit" Version="3.1.0" />
20
20
  <DotNetCliToolReference Include="dotnet-xunit" Version="2.3.1" />
21
21
  </ItemGroup>
22
22
 
@@ -13,10 +13,10 @@
13
13
  </ItemGroup>
14
14
 
15
15
  <ItemGroup>
16
- <PackageReference Include="Microsoft.NET.Test.Sdk" Version="15.5.0" />
16
+ <PackageReference Include="Microsoft.NET.Test.Sdk" Version="15.7.0" />
17
17
  <PackageReference Include="xunit" Version="2.3.1" />
18
18
  <PackageReference Include="xunit.runner.visualstudio" Version="2.3.1" />
19
- <PackageReference Include="FsUnit.xUnit" Version="3.0.0" />
19
+ <PackageReference Include="FsUnit.xUnit" Version="3.1.0" />
20
20
  <DotNetCliToolReference Include="dotnet-xunit" Version="2.3.1" />
21
21
  </ItemGroup>
22
22
 
@@ -1,4 +1,4 @@
1
- // This file was auto-generated based on version 1.1.0 of the canonical data.
1
+ // This file was auto-generated based on version 1.2.0 of the canonical data.
2
2
 
3
3
  module WordSearchTest
4
4
 
@@ -13,10 +13,10 @@
13
13
  </ItemGroup>
14
14
 
15
15
  <ItemGroup>
16
- <PackageReference Include="Microsoft.NET.Test.Sdk" Version="15.5.0" />
16
+ <PackageReference Include="Microsoft.NET.Test.Sdk" Version="15.7.0" />
17
17
  <PackageReference Include="xunit" Version="2.3.1" />
18
18
  <PackageReference Include="xunit.runner.visualstudio" Version="2.3.1" />
19
- <PackageReference Include="FsUnit.xUnit" Version="3.0.0" />
19
+ <PackageReference Include="FsUnit.xUnit" Version="3.1.0" />
20
20
  <DotNetCliToolReference Include="dotnet-xunit" Version="2.3.1" />
21
21
  </ItemGroup>
22
22
 
@@ -0,0 +1,65 @@
1
+ module Yacht
2
+
3
+ type Category =
4
+ | Ones
5
+ | Twos
6
+ | Threes
7
+ | Fours
8
+ | Fives
9
+ | Sixes
10
+ | FullHouse
11
+ | FourOfAKind
12
+ | LittleStraight
13
+ | BigStraight
14
+ | Choice
15
+ | Yacht
16
+
17
+ let private diceWithCount dice =
18
+ dice
19
+ |> List.countBy id
20
+ |> List.sortByDescending snd
21
+
22
+ let private valueScore value dice =
23
+ let count =
24
+ dice
25
+ |> List.filter ((=) value)
26
+ |> List.length
27
+ count * value
28
+
29
+ let private fullHouseScore dice =
30
+ match diceWithCount dice with
31
+ | [(_, 3); (_, 2)] -> List.sum dice
32
+ | _ -> 0
33
+
34
+ let private fourOfAKindScore dice =
35
+ match diceWithCount dice with
36
+ | [(value, 4); _] -> value * 4
37
+ | [(value, 5)] -> value * 4
38
+ | _ -> 0
39
+
40
+ let private littleStraightScore dice =
41
+ if List.sort dice = [1; 2; 3; 4; 5] then 30 else 0
42
+
43
+ let private bigStraightScore dice =
44
+ if List.sort dice = [2; 3; 4; 5; 6] then 30 else 0
45
+
46
+ let private choiceScore dice =
47
+ List.sum dice
48
+
49
+ let private yachtScore dice =
50
+ if dice |> List.distinct |> List.length = 1 then 50 else 0
51
+
52
+ let score category dice =
53
+ match category with
54
+ | Ones -> valueScore 1 dice
55
+ | Twos -> valueScore 2 dice
56
+ | Threes -> valueScore 3 dice
57
+ | Fours -> valueScore 4 dice
58
+ | Fives -> valueScore 5 dice
59
+ | Sixes -> valueScore 6 dice
60
+ | FullHouse -> fullHouseScore dice
61
+ | FourOfAKind -> fourOfAKindScore dice
62
+ | LittleStraight -> littleStraightScore dice
63
+ | BigStraight -> bigStraightScore dice
64
+ | Choice -> choiceScore dice
65
+ | Yacht -> yachtScore dice
@@ -0,0 +1 @@
1
+ module Program = let [<EntryPoint>] main _ = 0
@@ -0,0 +1,34 @@
1
+ # Score a single throw of dice in *Yacht*
2
+
3
+ The dice game [Yacht](https://en.wikipedia.org/wiki/Yacht_(dice_game)) is from
4
+ the same family as Poker Dice, Generala and particularly Yahtzee, of which it
5
+ is a precursor. In the game, five dice are rolled and the result can be entered
6
+ in any of twelve categories. The score of a throw of the dice depends on
7
+ category chosen.
8
+
9
+ ## Scores in Yacht
10
+
11
+ Category Score Example
12
+ Ones 1 × number of ones 1 1 1 4 5 scores 3
13
+ Twos 2 × number of twos 2 2 3 4 5 scores 4
14
+ Threes 3 × number of threes 3 3 3 3 3 scores 15
15
+ Fours 4 × number of fours 1 2 3 3 5 scores 0
16
+ Fives 5 × number of fives 5 1 5 2 5 scores 15
17
+ Sixes 6 × number of sixes 2 3 4 5 6 scores 6
18
+ Full House Total of the dice 3 3 3 5 5 scores 19
19
+ Four of a Kind Total of the four dice 4 4 4 4 6 scores 16
20
+ Little Straight 30 points 1 2 3 4 5 scores 30
21
+ Big Straight 30 points 2 3 4 5 6 scores 30
22
+ Choice Sum of the dice 2 3 3 4 6 scores 18
23
+ Yacht 50 points 4 4 4 4 4 scores 50
24
+
25
+ If the dice do not satisfy the requirements of a category, the score is zero.
26
+ If, for example, *Four Of A Kind* is entered in the *Yacht* category, zero
27
+ points are scored. A *Yacht* scores zero if entered in the *Full House* category.
28
+
29
+ ## Task
30
+ Given a list of values for five dice and a category, your solution should return
31
+ the score of the dice for that category. If the dice do not satisfy the requirements
32
+ of the category your solution should return 0. You can assume that five values
33
+ will always be presented, and the value of each will be between one and six
34
+ inclusively. You should not assume that the dice are ordered.
@@ -0,0 +1,17 @@
1
+ module Yacht
2
+
3
+ type Category =
4
+ | Ones
5
+ | Twos
6
+ | Threes
7
+ | Fours
8
+ | Fives
9
+ | Sixes
10
+ | FullHouse
11
+ | FourOfAKind
12
+ | LittleStraight
13
+ | BigStraight
14
+ | Choice
15
+ | Yacht
16
+
17
+ let score category dice = failwith "You need to implement this function."
@@ -0,0 +1,23 @@
1
+ <Project Sdk="Microsoft.NET.Sdk">
2
+
3
+ <PropertyGroup>
4
+ <TargetFramework>netcoreapp2.0</TargetFramework>
5
+
6
+ <IsPackable>false</IsPackable>
7
+ </PropertyGroup>
8
+
9
+ <ItemGroup>
10
+ <Compile Include="Yacht.fs" />
11
+ <Compile Include="YachtTest.fs" />
12
+ <Compile Include="Program.fs" />
13
+ </ItemGroup>
14
+
15
+ <ItemGroup>
16
+ <PackageReference Include="Microsoft.NET.Test.Sdk" Version="15.7.0" />
17
+ <PackageReference Include="xunit" Version="2.3.1" />
18
+ <PackageReference Include="xunit.runner.visualstudio" Version="2.3.1" />
19
+ <PackageReference Include="FsUnit.xUnit" Version="3.1.0" />
20
+ <DotNetCliToolReference Include="dotnet-xunit" Version="2.3.1" />
21
+ </ItemGroup>
22
+
23
+ </Project>
@@ -0,0 +1,113 @@
1
+ // This file was auto-generated based on version 1.0.0 of the canonical data.
2
+
3
+ module YachtTest
4
+
5
+ open FsUnit.Xunit
6
+ open Xunit
7
+
8
+ open Yacht
9
+
10
+ [<Fact>]
11
+ let ``Yacht`` () =
12
+ score Category.Yacht [5; 5; 5; 5; 5] |> should equal 50
13
+
14
+ [<Fact(Skip = "Remove to run test")>]
15
+ let ``Not Yacht`` () =
16
+ score Category.Yacht [1; 3; 3; 2; 5] |> should equal 0
17
+
18
+ [<Fact(Skip = "Remove to run test")>]
19
+ let ``Ones`` () =
20
+ score Category.Ones [1; 1; 1; 3; 5] |> should equal 3
21
+
22
+ [<Fact(Skip = "Remove to run test")>]
23
+ let ``Ones, out of order`` () =
24
+ score Category.Ones [3; 1; 1; 5; 1] |> should equal 3
25
+
26
+ [<Fact(Skip = "Remove to run test")>]
27
+ let ``No ones`` () =
28
+ score Category.Ones [4; 3; 6; 5; 5] |> should equal 0
29
+
30
+ [<Fact(Skip = "Remove to run test")>]
31
+ let ``Twos`` () =
32
+ score Category.Twos [2; 3; 4; 5; 6] |> should equal 2
33
+
34
+ [<Fact(Skip = "Remove to run test")>]
35
+ let ``Fours`` () =
36
+ score Category.Fours [1; 4; 1; 4; 1] |> should equal 8
37
+
38
+ [<Fact(Skip = "Remove to run test")>]
39
+ let ``Yacht counted as threes`` () =
40
+ score Category.Threes [3; 3; 3; 3; 3] |> should equal 15
41
+
42
+ [<Fact(Skip = "Remove to run test")>]
43
+ let ``Yacht of 3s counted as fives`` () =
44
+ score Category.Fives [3; 3; 3; 3; 3] |> should equal 0
45
+
46
+ [<Fact(Skip = "Remove to run test")>]
47
+ let ``Sixes`` () =
48
+ score Category.Sixes [2; 3; 4; 5; 6] |> should equal 6
49
+
50
+ [<Fact(Skip = "Remove to run test")>]
51
+ let ``Full house two small, three big`` () =
52
+ score Category.FullHouse [2; 2; 4; 4; 4] |> should equal 16
53
+
54
+ [<Fact(Skip = "Remove to run test")>]
55
+ let ``Full house three small, two big`` () =
56
+ score Category.FullHouse [5; 3; 3; 5; 3] |> should equal 19
57
+
58
+ [<Fact(Skip = "Remove to run test")>]
59
+ let ``Two pair is not a full house`` () =
60
+ score Category.FullHouse [2; 2; 4; 4; 5] |> should equal 0
61
+
62
+ [<Fact(Skip = "Remove to run test")>]
63
+ let ``Yacht is not a full house`` () =
64
+ score Category.FullHouse [2; 2; 2; 2; 2] |> should equal 0
65
+
66
+ [<Fact(Skip = "Remove to run test")>]
67
+ let ``Four of a Kind`` () =
68
+ score Category.FourOfAKind [6; 6; 4; 6; 6] |> should equal 24
69
+
70
+ [<Fact(Skip = "Remove to run test")>]
71
+ let ``Yacht can be scored as Four of a Kind`` () =
72
+ score Category.FourOfAKind [3; 3; 3; 3; 3] |> should equal 12
73
+
74
+ [<Fact(Skip = "Remove to run test")>]
75
+ let ``Full house is not Four of a Kind`` () =
76
+ score Category.FourOfAKind [3; 3; 3; 5; 5] |> should equal 0
77
+
78
+ [<Fact(Skip = "Remove to run test")>]
79
+ let ``Little Straight`` () =
80
+ score Category.LittleStraight [3; 5; 4; 1; 2] |> should equal 30
81
+
82
+ [<Fact(Skip = "Remove to run test")>]
83
+ let ``Little Straight as Big Straight`` () =
84
+ score Category.BigStraight [1; 2; 3; 4; 5] |> should equal 0
85
+
86
+ [<Fact(Skip = "Remove to run test")>]
87
+ let ``Four in order but not a little straight`` () =
88
+ score Category.LittleStraight [1; 1; 2; 3; 4] |> should equal 0
89
+
90
+ [<Fact(Skip = "Remove to run test")>]
91
+ let ``No pairs but not a little straight`` () =
92
+ score Category.LittleStraight [1; 2; 3; 4; 6] |> should equal 0
93
+
94
+ [<Fact(Skip = "Remove to run test")>]
95
+ let ``Minimum is 1, maximum is 5, but not a little straight`` () =
96
+ score Category.LittleStraight [1; 1; 3; 4; 5] |> should equal 0
97
+
98
+ [<Fact(Skip = "Remove to run test")>]
99
+ let ``Big Straight`` () =
100
+ score Category.BigStraight [4; 6; 2; 5; 3] |> should equal 30
101
+
102
+ [<Fact(Skip = "Remove to run test")>]
103
+ let ``Big Straight as little straight`` () =
104
+ score Category.LittleStraight [6; 5; 4; 3; 2] |> should equal 0
105
+
106
+ [<Fact(Skip = "Remove to run test")>]
107
+ let ``Choice`` () =
108
+ score Category.Choice [3; 3; 5; 6; 6] |> should equal 23
109
+
110
+ [<Fact(Skip = "Remove to run test")>]
111
+ let ``Yacht as choice`` () =
112
+ score Category.Choice [2; 2; 2; 2; 2] |> should equal 10
113
+
@@ -13,10 +13,10 @@
13
13
  </ItemGroup>
14
14
 
15
15
  <ItemGroup>
16
- <PackageReference Include="Microsoft.NET.Test.Sdk" Version="15.5.0" />
16
+ <PackageReference Include="Microsoft.NET.Test.Sdk" Version="15.7.0" />
17
17
  <PackageReference Include="xunit" Version="2.3.1" />
18
18
  <PackageReference Include="xunit.runner.visualstudio" Version="2.3.1" />
19
- <PackageReference Include="FsUnit.xUnit" Version="3.0.0" />
19
+ <PackageReference Include="FsUnit.xUnit" Version="3.1.0" />
20
20
  <DotNetCliToolReference Include="dotnet-xunit" Version="2.3.1" />
21
21
  </ItemGroup>
22
22
 
@@ -13,10 +13,10 @@
13
13
  </ItemGroup>
14
14
 
15
15
  <ItemGroup>
16
- <PackageReference Include="Microsoft.NET.Test.Sdk" Version="15.5.0" />
16
+ <PackageReference Include="Microsoft.NET.Test.Sdk" Version="15.7.0" />
17
17
  <PackageReference Include="xunit" Version="2.3.1" />
18
18
  <PackageReference Include="xunit.runner.visualstudio" Version="2.3.1" />
19
- <PackageReference Include="FsUnit.xUnit" Version="3.0.0" />
19
+ <PackageReference Include="FsUnit.xUnit" Version="3.1.0" />
20
20
  <DotNetCliToolReference Include="dotnet-xunit" Version="2.3.1" />
21
21
  </ItemGroup>
22
22
 
@@ -22,10 +22,6 @@ type CanonicalData =
22
22
  Version: string
23
23
  Cases: CanonicalDataCase list }
24
24
 
25
- type CanonicalDataFormat =
26
- | Old
27
- | New
28
-
29
25
  let [<Literal>] private ProblemSpecificationsGitUrl = "https://github.com/exercism/problem-specifications.git";
30
26
  let [<Literal>] private ProblemSpecificationsBranch = "master";
31
27
  let [<Literal>] private ProblemSpecificationsRemote = "origin";
@@ -77,23 +73,9 @@ type CanonicalDataConverter() =
77
73
  |> Json.parentsAndSelf
78
74
  |> List.choose descriptionFromJToken
79
75
 
80
- let createInputFromJTokenInNewFormat (properties: Map<string, obj>) =
81
- (properties.["input"] :?> JObject)
82
- |> jTokenToMap
83
-
84
- let createInputFromJTokenInOldFormat (properties: Map<string, obj>) =
85
- properties
86
- |> Map.filter (fun key _ -> List.contains key ["expected"; "property"; "description"; "comments"] |> not)
87
-
88
- let detectCanonicalDataFormatFromJToken (properties: Map<string, obj>) =
89
- match properties.ContainsKey "input" && properties.["input"] :? JObject with
90
- | true -> New
91
- | false -> Old
92
-
93
76
  let createInputFromJToken (properties: Map<string, obj>) =
94
- match detectCanonicalDataFormatFromJToken properties with
95
- | Old -> createInputFromJTokenInOldFormat properties
96
- | New -> createInputFromJTokenInNewFormat properties
77
+ properties.["input"] :?> JObject
78
+ |> jTokenToMap
97
79
 
98
80
  let createCanonicalDataCaseFromJToken (jToken: JToken) =
99
81
  let properties = jTokenToMap jToken
@@ -72,7 +72,7 @@ module String =
72
72
 
73
73
  let equals (x: string) (y: string) = String.Equals(x, y, StringComparison.OrdinalIgnoreCase)
74
74
 
75
- let humanize (str: string) = str.Humanize()
75
+ let dehumanize (str: string) = str.Dehumanize()
76
76
 
77
77
  let camelize (str: string) = str.Camelize()
78
78
 
@@ -24,7 +24,7 @@ type AllYourBase() =
24
24
  type Allergies() =
25
25
  inherit GeneratorExercise()
26
26
 
27
- let toAllergen (jToken: JToken) = sprintf "Allergen.%s" (jToken.ToString() |> String.humanize)
27
+ let toAllergen (jToken: JToken) = sprintf "Allergen.%s" (jToken.ToString() |> String.dehumanize)
28
28
 
29
29
  let renderAllergicToAssert canonicalDataCase (jToken: JToken) =
30
30
  let substance = jToken.["substance"] |> toAllergen
@@ -240,8 +240,8 @@ type CircularBuffer() =
240
240
 
241
241
  override this.RenderArrange canonicalDataCase =
242
242
  seq {
243
- yield sprintf "let buffer1 = mkCircularBuffer %i" (canonicalDataCase.Properties.["capacity"] :?> int64)
244
- let operations = (canonicalDataCase.Properties.["operations"] :?> JArray)
243
+ yield sprintf "let buffer1 = mkCircularBuffer %i" (canonicalDataCase.Input.["capacity"] :?> int64)
244
+ let operations = (canonicalDataCase.Input.["operations"] :?> JArray)
245
245
  let mutable ind = 2
246
246
  let lastInd = operations.Count + 1
247
247
  for op in operations do
@@ -609,7 +609,7 @@ type Isogram() =
609
609
  type KindergartenGarden() =
610
610
  inherit GeneratorExercise()
611
611
 
612
- let toPlant (jToken: JToken) = sprintf "Plant.%s" (jToken.ToString() |> String.humanize)
612
+ let toPlant (jToken: JToken) = sprintf "Plant.%s" (jToken.ToString() |> String.dehumanize)
613
613
 
614
614
  override __.RenderExpected (_, _, value) =
615
615
  value :?> JArray
@@ -822,7 +822,7 @@ type PascalsTriangle() =
822
822
  type PerfectNumbers() =
823
823
  inherit GeneratorExercise()
824
824
 
825
- let toClassification value = string value |> String.humanize
825
+ let toClassification value = string value |> String.dehumanize
826
826
 
827
827
  override __.RenderExpected (_, _, value) =
828
828
  value
@@ -854,7 +854,7 @@ type Pov() =
854
854
  let isNull x = match x with null -> true | _ -> false
855
855
 
856
856
  override __.RenderSetup _ =
857
- ["let rec graphToList graph = "
857
+ ["let rec graphToList (graph: Graph<'a>) = "
858
858
  " let right ="
859
859
  " graph.children"
860
860
  " |> List.sortBy (fun x -> x.value)"
@@ -883,7 +883,7 @@ type Pov() =
883
883
  override this.RenderArrange canonicalDataCase =
884
884
  seq {
885
885
  yield
886
- canonicalDataCase.Properties.["tree"]
886
+ canonicalDataCase.Input.["tree"]
887
887
  |> this.RenderNode
888
888
  |> sprintf "let tree = %s"
889
889
 
@@ -901,17 +901,17 @@ type Pov() =
901
901
  match canonicalDataCase.Property with
902
902
  | "fromPov" ->
903
903
  let from =
904
- canonicalDataCase.Properties.["from"]
904
+ canonicalDataCase.Input.["from"]
905
905
  |> formatValue
906
906
  match isNull canonicalDataCase.Expected with
907
907
  | false -> sprintf "fromPOV %s tree |> mapToList " from
908
908
  | true -> sprintf "fromPOV %s tree " from
909
909
  | "pathTo" ->
910
910
  let fromValue =
911
- canonicalDataCase.Properties.["from"]
911
+ canonicalDataCase.Input.["from"]
912
912
  |> formatValue
913
913
  let toValue =
914
- canonicalDataCase.Properties.["to"]
914
+ canonicalDataCase.Input.["to"]
915
915
  |> formatValue
916
916
  sprintf "tracePathBetween %s %s tree" fromValue toValue
917
917
  | _ -> ""
@@ -1047,8 +1047,13 @@ type React() =
1047
1047
  | "add_callback" -> seq {
1048
1048
  let callbackName = op.["name"].ToObject<string>()
1049
1049
  let cellName = op.["cell"].ToObject<string>()
1050
+ let callback =
1051
+ if canonicalDataCase.Description.Contains("do not report") then
1052
+ "[value]"
1053
+ else
1054
+ sprintf "%s @ [value]" callbackName
1050
1055
  yield sprintf "let mutable %s = []" callbackName
1051
- yield sprintf "let %sHandler = Handler<int>(fun _ value -> %s <- %s @ [value])" callbackName callbackName callbackName
1056
+ yield sprintf "let %sHandler = Handler<int>(fun _ value -> %s <- %s)" callbackName callbackName callback
1052
1057
  yield sprintf "%s.Changed.AddHandler %sHandler" cellName callbackName }
1053
1058
  | "expect_callback_values" -> seq {
1054
1059
  let callbackName = op.["callback"].ToObject<string>()
@@ -1442,6 +1447,14 @@ type Wordy() =
1442
1447
  override __.RenderExpected (_, _, value) =
1443
1448
  value |> Option.ofNonFalse |> formatValue |> parenthesizeOption
1444
1449
 
1450
+ type Yacht() =
1451
+ inherit GeneratorExercise()
1452
+
1453
+ override __.RenderInput (canonicalDataCase, key, value) =
1454
+ match key with
1455
+ | "category" -> sprintf "Category.%s" (value |> string |> String.dehumanize)
1456
+ | _ -> base.RenderInput (canonicalDataCase, key, value)
1457
+
1445
1458
  type ZebraPuzzle() =
1446
1459
  inherit GeneratorExercise()
1447
1460
 
@@ -18,17 +18,17 @@
18
18
  </ItemGroup>
19
19
 
20
20
  <ItemGroup>
21
- <PackageReference Include="CommandLineParser" Version="2.1.1-beta" />
22
- <PackageReference Include="DotLiquid" Version="2.0.232" />
21
+ <PackageReference Include="CommandLineParser" Version="2.2.1" />
22
+ <PackageReference Include="DotLiquid" Version="2.0.254" />
23
23
  <PackageReference Include="Humanizer" Version="2.2.0" />
24
24
  <PackageReference Include="LibGit2Sharp.Portable" Version="0.24.10" />
25
- <PackageReference Include="Newtonsoft.Json" Version="10.0.3" />
25
+ <PackageReference Include="Newtonsoft.Json" Version="11.0.2" />
26
26
  <PackageReference Include="serilog" Version="2.6.0" />
27
27
  <PackageReference Include="serilog.sinks.literate" Version="3.0.0" />
28
28
  </ItemGroup>
29
29
 
30
30
  <ItemGroup>
31
- <PackageReference Update="FSharp.Core" Version="4.2.3" />
31
+ <PackageReference Update="FSharp.Core" Version="4.3.4" />
32
32
  </ItemGroup>
33
33
 
34
34
  </Project>
@@ -28,7 +28,7 @@ type Options =
28
28
  CacheCanonicalData : bool }
29
29
 
30
30
  let private normalizeCanonicalDataDirectory canonicalDataDirectory =
31
- if canonicalDataDirectory <> "" then
31
+ if not (String.IsNullOrWhiteSpace(canonicalDataDirectory)) then
32
32
  canonicalDataDirectory
33
33
  else
34
34
  let appDataDirectory = Environment.GetFolderPath(Environment.SpecialFolder.ApplicationData)
@@ -1,5 +1,5 @@
1
1
  name: bracket-push
2
- version: 1.2.0.3
2
+ version: 1.3.0.4
3
3
 
4
4
  dependencies:
5
5
  - base