trackler 2.2.1.45 → 2.2.1.46

Sign up to get free protection for your applications and to get access to all the features.
Files changed (508) hide show
  1. checksums.yaml +4 -4
  2. data/lib/trackler/version.rb +1 -1
  3. data/problem-specifications/exercises/complex-numbers/description.md +27 -0
  4. data/problem-specifications/exercises/crypto-square/canonical-data.json +39 -43
  5. data/problem-specifications/exercises/crypto-square/description.md +6 -4
  6. data/problem-specifications/exercises/hamming/canonical-data.json +5 -5
  7. data/problem-specifications/exercises/kindergarten-garden/description.md +10 -10
  8. data/problem-specifications/exercises/leap/canonical-data.json +2 -2
  9. data/problem-specifications/exercises/markdown/canonical-data.json +2 -2
  10. data/problem-specifications/exercises/nucleotide-count/canonical-data.json +12 -1
  11. data/problem-specifications/exercises/pangram/canonical-data.json +7 -1
  12. data/problem-specifications/exercises/queen-attack/canonical-data.json +83 -26
  13. data/problem-specifications/exercises/space-age/description.md +1 -2
  14. data/problem-specifications/exercises/zipper/canonical-data.json +671 -0
  15. data/tracks/bash/config.json +13 -1
  16. data/tracks/bash/exercises/atbash-cipher/README.md +45 -0
  17. data/tracks/bash/exercises/atbash-cipher/atbash_cipher_tests.sh +73 -0
  18. data/tracks/bash/exercises/atbash-cipher/example.sh +14 -0
  19. data/tracks/bash/exercises/gigasecond/.meta/hints.md +33 -0
  20. data/tracks/bash/exercises/two-fer/README.md +0 -22
  21. data/tracks/c/exercises/allergies/src/allergies.h +9 -9
  22. data/tracks/c/exercises/allergies/src/example.c +2 -2
  23. data/tracks/c/exercises/allergies/src/example.h +9 -9
  24. data/tracks/c/exercises/allergies/test/test_allergies.c +34 -34
  25. data/tracks/c/exercises/clock/test/test_clock.c +0 -52
  26. data/tracks/c/exercises/meetup/test/test_meetup.c +604 -114
  27. data/tracks/c/exercises/nucleotide-count/src/example.c +10 -10
  28. data/tracks/c/exercises/palindrome-products/src/example.c +8 -8
  29. data/tracks/c/exercises/palindrome-products/src/example.h +5 -5
  30. data/tracks/c/exercises/palindrome-products/test/test_palindrome_products.c +8 -6
  31. data/tracks/c/exercises/robot-simulator/src/example.c +19 -19
  32. data/tracks/c/exercises/robot-simulator/src/robot_simulator.h +24 -24
  33. data/tracks/c/exercises/robot-simulator/test/test_robot_simulator.c +35 -34
  34. data/tracks/c/exercises/series/src/example.c +10 -10
  35. data/tracks/c/exercises/series/src/series.h +5 -5
  36. data/tracks/c/exercises/series/test/test_series.c +77 -30
  37. data/tracks/c/exercises/sieve/src/example.c +17 -17
  38. data/tracks/c/exercises/sieve/src/sieve.h +2 -2
  39. data/tracks/c/exercises/sieve/test/test_sieve.c +6 -6
  40. data/tracks/c/exercises/space-age/src/example.c +1 -1
  41. data/tracks/c/exercises/space-age/src/example.h +3 -3
  42. data/tracks/c/exercises/space-age/test/test_space_age.c +2 -0
  43. data/tracks/c/exercises/sum-of-multiples/src/example.c +3 -1
  44. data/tracks/c/exercises/sum-of-multiples/test/test_sum_of_multiples.c +17 -0
  45. data/tracks/c/exercises/triangle/src/example.c +4 -4
  46. data/tracks/c/exercises/triangle/src/example.h +4 -4
  47. data/tracks/c/exercises/triangle/src/triangle.h +1 -1
  48. data/tracks/c/exercises/triangle/test/test_triangle.c +18 -16
  49. data/tracks/c/exercises/word-count/src/example.c +24 -24
  50. data/tracks/c/exercises/word-count/src/word_count.h +3 -3
  51. data/tracks/c/exercises/word-count/test/test_word_count.c +139 -139
  52. data/tracks/cfml/exercises/acronym/README.md +31 -0
  53. data/tracks/cfml/exercises/atbash-cipher/README.md +50 -0
  54. data/tracks/cfml/exercises/bob/README.md +34 -0
  55. data/tracks/cfml/exercises/diamond/README.md +75 -0
  56. data/tracks/cfml/exercises/difference-of-squares/README.md +35 -0
  57. data/tracks/cfml/exercises/flatten-array/README.md +34 -0
  58. data/tracks/cfml/exercises/gigasecond/README.md +27 -0
  59. data/tracks/cfml/exercises/grains/README.md +50 -0
  60. data/tracks/cfml/exercises/hamming/README.md +58 -0
  61. data/tracks/cfml/exercises/hello-world/README.md +37 -0
  62. data/tracks/cfml/exercises/isogram/README.md +35 -0
  63. data/tracks/cfml/exercises/largest-series-product/README.md +36 -0
  64. data/tracks/cfml/exercises/leap/README.md +16 -0
  65. data/tracks/cfml/exercises/luhn/README.md +87 -0
  66. data/tracks/cfml/exercises/markdown/README.md +34 -0
  67. data/tracks/cfml/exercises/nth-prime/README.md +31 -0
  68. data/tracks/cfml/exercises/pangram/README.md +31 -0
  69. data/tracks/cfml/exercises/pig-latin/README.md +40 -0
  70. data/tracks/cfml/exercises/raindrops/README.md +40 -0
  71. data/tracks/cfml/exercises/rna-transcription/README.md +41 -0
  72. data/tracks/cfml/exercises/saddle-points/README.md +49 -0
  73. data/tracks/cfml/exercises/scrabble-score/README.md +60 -0
  74. data/tracks/cfml/exercises/secret-handshake/README.md +51 -0
  75. data/tracks/cfml/exercises/space-age/README.md +41 -0
  76. data/tracks/cfml/exercises/sum-of-multiples/README.md +34 -0
  77. data/tracks/cfml/exercises/triangle/README.md +42 -0
  78. data/tracks/cfml/exercises/word-count/README.md +35 -0
  79. data/tracks/clojure/config.json +10 -0
  80. data/tracks/clojure/exercises/spiral-matrix/README.md +32 -0
  81. data/tracks/clojure/exercises/spiral-matrix/project.clj +4 -0
  82. data/tracks/clojure/exercises/spiral-matrix/src/example.clj +11 -0
  83. data/tracks/clojure/exercises/spiral-matrix/src/spiral_matrix.clj +3 -0
  84. data/tracks/clojure/exercises/spiral-matrix/test/spiral_matrix_test.clj +58 -0
  85. data/tracks/common-lisp/config.json +20 -0
  86. data/tracks/common-lisp/exercises/hello-world/README.md +68 -0
  87. data/tracks/common-lisp/exercises/hello-world/example.lisp +9 -0
  88. data/tracks/common-lisp/exercises/hello-world/hello-world-test.lisp +21 -0
  89. data/tracks/common-lisp/exercises/hello-world/hello-world.lisp +6 -0
  90. data/tracks/common-lisp/exercises/perfect-numbers/README.md +72 -0
  91. data/tracks/common-lisp/exercises/perfect-numbers/example.lisp +17 -0
  92. data/tracks/common-lisp/exercises/perfect-numbers/perfect-numbers-test.lisp +56 -0
  93. data/tracks/common-lisp/exercises/perfect-numbers/perfect-numbers.lisp +7 -0
  94. data/tracks/cpp/.travis.yml +34 -14
  95. data/tracks/cpp/docs/INSTALLATION.md +17 -28
  96. data/tracks/cpp/docs/TESTS.md +13 -21
  97. data/tracks/crystal/config.json +10 -0
  98. data/tracks/crystal/exercises/triangle/spec/triangle_spec.cr +60 -0
  99. data/tracks/crystal/exercises/triangle/src/example.cr +31 -0
  100. data/tracks/crystal/exercises/triangle/src/triangle.cr +1 -0
  101. data/tracks/crystal/generator/spec/remote_data_file_spec.cr +0 -1
  102. data/tracks/crystal/generator/src/generators/triangle.cr +38 -0
  103. data/tracks/crystal/generator/src/remote_data_file.cr +1 -1
  104. data/tracks/csharp/exercises/difference-of-squares/DifferenceOfSquares.cs +4 -4
  105. data/tracks/csharp/exercises/difference-of-squares/DifferenceOfSquaresTest.cs +22 -27
  106. data/tracks/csharp/exercises/difference-of-squares/Example.cs +5 -5
  107. data/tracks/csharp/exercises/error-handling/ErrorHandlingTest.cs +4 -4
  108. data/tracks/csharp/exercises/flatten-array/Example.cs +1 -1
  109. data/tracks/csharp/exercises/flatten-array/FlattenArray.cs +1 -1
  110. data/tracks/csharp/exercises/flatten-array/FlattenArrayTest.cs +106 -72
  111. data/tracks/csharp/exercises/largest-series-product/LargestSeriesProductTest.cs +24 -98
  112. data/tracks/csharp/exercises/minesweeper/Example.cs +3 -3
  113. data/tracks/csharp/exercises/minesweeper/Minesweeper.cs +1 -1
  114. data/tracks/csharp/exercises/minesweeper/MinesweeperTest.cs +155 -57
  115. data/tracks/csharp/generators/Exercises/DifferenceOfSquares.cs +25 -0
  116. data/tracks/csharp/generators/Exercises/FlattenArray.cs +36 -0
  117. data/tracks/csharp/generators/Exercises/LargestSeriesProduct.cs +18 -0
  118. data/tracks/csharp/generators/Exercises/Minesweeper.cs +32 -0
  119. data/tracks/d/docs/EXERCISE_README_INSERT.md +1 -1
  120. data/tracks/d/exercises/bob/README.md +1 -1
  121. data/tracks/d/exercises/circular-buffer/README.md +1 -1
  122. data/tracks/d/exercises/crypto-square/README.md +1 -1
  123. data/tracks/d/exercises/difference-of-squares/README.md +1 -1
  124. data/tracks/d/exercises/etl/README.md +1 -1
  125. data/tracks/d/exercises/gigasecond/README.md +1 -1
  126. data/tracks/d/exercises/hamming/README.md +1 -1
  127. data/tracks/d/exercises/hello-world/README.md +1 -1
  128. data/tracks/d/exercises/leap/README.md +1 -1
  129. data/tracks/d/exercises/nucleotide-count/README.md +1 -1
  130. data/tracks/d/exercises/pangram/README.md +1 -1
  131. data/tracks/d/exercises/raindrops/README.md +1 -1
  132. data/tracks/d/exercises/react/README.md +1 -1
  133. data/tracks/d/exercises/rna-transcription/README.md +1 -1
  134. data/tracks/d/exercises/robot-name/README.md +1 -1
  135. data/tracks/d/exercises/roman-numerals/README.md +1 -1
  136. data/tracks/d/exercises/series/README.md +1 -1
  137. data/tracks/d/exercises/triangle/README.md +1 -1
  138. data/tracks/dart/CONTRIBUTING.md +61 -0
  139. data/tracks/dart/README.md +10 -47
  140. data/tracks/dart/config.json +13 -1
  141. data/tracks/dart/exercises/anagram/README.md +10 -0
  142. data/tracks/dart/exercises/bob/README.md +11 -0
  143. data/tracks/dart/exercises/difference-of-squares/README.md +11 -0
  144. data/tracks/dart/exercises/gigasecond/README.md +11 -0
  145. data/tracks/dart/exercises/gigasecond/test/gigasecond_test.dart +56 -33
  146. data/tracks/dart/exercises/hamming/README.md +11 -0
  147. data/tracks/dart/exercises/hamming/lib/example.dart +2 -2
  148. data/tracks/dart/exercises/hamming/test/hamming_test.dart +41 -24
  149. data/tracks/dart/exercises/hello-world/README.md +11 -0
  150. data/tracks/dart/exercises/leap/README.md +12 -1
  151. data/tracks/dart/exercises/phone-number/README.md +56 -0
  152. data/tracks/dart/exercises/phone-number/lib/example.dart +45 -0
  153. data/tracks/dart/exercises/phone-number/lib/phone_number.dart +3 -0
  154. data/tracks/dart/exercises/phone-number/pubspec.lock +293 -0
  155. data/tracks/dart/exercises/phone-number/pubspec.yaml +3 -0
  156. data/tracks/dart/exercises/phone-number/test/phone_number_test.dart +66 -0
  157. data/tracks/dart/exercises/raindrops/README.md +35 -0
  158. data/tracks/dart/exercises/rna-transcription/README.md +11 -0
  159. data/tracks/dart/exercises/word-count/README.md +14 -3
  160. data/tracks/delphi/docs/RESOURCES.md +10 -11
  161. data/tracks/elixir/exercises/hello-world/hello_world.exs +1 -1
  162. data/tracks/elixir/exercises/secret-handshake/README.md +3 -5
  163. data/tracks/elm/exercises/isogram/Isogram.example.elm +4 -4
  164. data/tracks/erlang/config.json +10 -0
  165. data/tracks/erlang/exercises/sieve/README.md +88 -0
  166. data/tracks/erlang/exercises/sieve/include/exercism.hrl +11 -0
  167. data/tracks/erlang/exercises/sieve/rebar.config +30 -0
  168. data/tracks/erlang/exercises/sieve/src/example.erl +16 -0
  169. data/tracks/erlang/exercises/sieve/src/sieve.app.src +9 -0
  170. data/tracks/erlang/exercises/sieve/src/sieve.erl +8 -0
  171. data/tracks/erlang/exercises/sieve/test/sieve_tests.erl +38 -0
  172. data/tracks/fsharp/.gitignore +2 -1
  173. data/tracks/fsharp/exercises/crypto-square/CryptoSquareTest.fs +10 -6
  174. data/tracks/fsharp/exercises/leap/LeapTest.fs +2 -2
  175. data/tracks/fsharp/exercises/pangram/PangramTest.fs +5 -1
  176. data/tracks/fsharp/exercises/queen-attack/QueenAttackTest.fs +7 -7
  177. data/tracks/fsharp/exercises/run-length-encoding/Example.fs +2 -2
  178. data/tracks/fsharp/exercises/run-length-encoding/RunLengthEncodingTest.fs +42 -30
  179. data/tracks/fsharp/generators/Generators.fs +21 -8
  180. data/tracks/gnu-apl/test.apl +4 -4
  181. data/tracks/go/README.md +1 -2
  182. data/tracks/go/config/maintainers.json +5 -6
  183. data/tracks/groovy/config.json +23 -0
  184. data/tracks/groovy/exercises/binary-search/BinarySearch.groovy +14 -0
  185. data/tracks/groovy/exercises/binary-search/BinarySearchSpec.groovy +56 -0
  186. data/tracks/groovy/exercises/binary-search/Example.groovy +43 -0
  187. data/tracks/groovy/exercises/binary-search/README.md +59 -0
  188. data/tracks/groovy/exercises/triangle/Example.groovy +23 -0
  189. data/tracks/groovy/exercises/triangle/README.md +42 -0
  190. data/tracks/groovy/exercises/triangle/Triangle.groovy +15 -0
  191. data/tracks/groovy/exercises/triangle/TriangleSpec.groovy +66 -0
  192. data/tracks/haskell/config.json +9 -0
  193. data/tracks/haskell/exercises/all-your-base/package.yaml +1 -1
  194. data/tracks/haskell/exercises/all-your-base/test/Tests.hs +18 -18
  195. data/tracks/haskell/exercises/bowling/package.yaml +1 -1
  196. data/tracks/haskell/exercises/bowling/test/Tests.hs +9 -9
  197. data/tracks/haskell/exercises/change/package.yaml +1 -1
  198. data/tracks/haskell/exercises/change/test/Tests.hs +5 -0
  199. data/tracks/haskell/exercises/complex-numbers/README.md +92 -0
  200. data/tracks/haskell/exercises/complex-numbers/examples/success-standard/package.yaml +16 -0
  201. data/tracks/haskell/exercises/complex-numbers/examples/success-standard/src/ComplexNumbers.hs +50 -0
  202. data/tracks/haskell/exercises/complex-numbers/package.yaml +20 -0
  203. data/tracks/haskell/exercises/complex-numbers/src/ComplexNumbers.hs +45 -0
  204. data/tracks/haskell/exercises/complex-numbers/stack.yaml +1 -0
  205. data/tracks/haskell/exercises/complex-numbers/test/Tests.hs +194 -0
  206. data/tracks/haskell/exercises/crypto-square/package.yaml +1 -1
  207. data/tracks/haskell/exercises/crypto-square/test/Tests.hs +20 -12
  208. data/tracks/haskell/exercises/dominoes/package.yaml +1 -1
  209. data/tracks/haskell/exercises/forth/package.yaml +1 -1
  210. data/tracks/haskell/exercises/forth/test/Tests.hs +4 -3
  211. data/tracks/haskell/exercises/hamming/package.yaml +1 -1
  212. data/tracks/haskell/exercises/hamming/test/Tests.hs +6 -6
  213. data/tracks/haskell/exercises/isogram/package.yaml +1 -1
  214. data/tracks/haskell/exercises/isogram/test/Tests.hs +2 -2
  215. data/tracks/haskell/exercises/leap/package.yaml +1 -1
  216. data/tracks/haskell/exercises/leap/test/Tests.hs +1 -1
  217. data/tracks/haskell/exercises/pascals-triangle/package.yaml +1 -1
  218. data/tracks/haskell/exercises/pig-latin/examples/success-standard/src/PigLatin.hs +2 -0
  219. data/tracks/haskell/exercises/pig-latin/package.yaml +1 -1
  220. data/tracks/haskell/exercises/pig-latin/test/Tests.hs +8 -0
  221. data/tracks/haskell/exercises/queen-attack/package.yaml +1 -1
  222. data/tracks/haskell/exercises/rna-transcription/package.yaml +1 -1
  223. data/tracks/haskell/exercises/rna-transcription/test/Tests.hs +8 -8
  224. data/tracks/haskell/exercises/robot-simulator/package.yaml +1 -1
  225. data/tracks/haskell/exercises/secret-handshake/package.yaml +1 -1
  226. data/tracks/haskell/exercises/secret-handshake/test/Tests.hs +0 -3
  227. data/tracks/haskell/exercises/sum-of-multiples/package.yaml +1 -1
  228. data/tracks/haskell/exercises/sum-of-multiples/test/Tests.hs +4 -0
  229. data/tracks/haskell/exercises/zipper/package.yaml +1 -1
  230. data/tracks/haskell/exercises/zipper/test/Tests.hs +23 -0
  231. data/tracks/java/config.json +85 -13
  232. data/tracks/java/config/maintainers.json +1 -1
  233. data/tracks/java/exercises/accumulate/README.md +0 -3
  234. data/tracks/java/exercises/acronym/.meta/.version +1 -0
  235. data/tracks/java/exercises/acronym/README.md +0 -1
  236. data/tracks/java/exercises/acronym/src/test/java/AcronymTest.java +0 -3
  237. data/tracks/java/exercises/all-your-base/.meta/.version +1 -0
  238. data/tracks/java/exercises/all-your-base/README.md +1 -1
  239. data/tracks/java/exercises/all-your-base/src/test/java/BaseConverterTest.java +0 -3
  240. data/tracks/java/exercises/allergies/README.md +0 -1
  241. data/tracks/java/exercises/atbash-cipher/README.md +2 -1
  242. data/tracks/java/exercises/beer-song/README.md +1 -1
  243. data/tracks/java/exercises/binary/README.md +2 -0
  244. data/tracks/java/exercises/book-store/README.md +5 -5
  245. data/tracks/java/exercises/bowling/README.md +20 -6
  246. data/tracks/java/exercises/change/.meta/.version +1 -0
  247. data/tracks/java/exercises/change/README.md +1 -1
  248. data/tracks/java/exercises/change/src/test/java/ChangeCalculatorTest.java +0 -3
  249. data/tracks/java/exercises/circular-buffer/README.md +13 -6
  250. data/tracks/java/exercises/clock/.meta/.version +1 -0
  251. data/tracks/java/exercises/clock/src/test/java/ClockAddTest.java +0 -3
  252. data/tracks/java/exercises/clock/src/test/java/ClockCreationTest.java +0 -3
  253. data/tracks/java/exercises/clock/src/test/java/ClockEqualTest.java +0 -3
  254. data/tracks/java/exercises/collatz-conjecture/.meta/.version +1 -0
  255. data/tracks/java/exercises/collatz-conjecture/README.md +1 -1
  256. data/tracks/java/exercises/collatz-conjecture/src/test/java/CollatzCalculatorTest.java +0 -3
  257. data/tracks/java/exercises/complex-numbers/README.md +27 -0
  258. data/tracks/java/exercises/crypto-square/README.md +10 -8
  259. data/tracks/java/exercises/diamond/.meta/.version +1 -0
  260. data/tracks/java/exercises/diamond/README.md +6 -6
  261. data/tracks/java/exercises/diamond/src/test/java/DiamondPrinterTest.java +0 -3
  262. data/tracks/java/exercises/difference-of-squares/.meta/.version +1 -0
  263. data/tracks/java/exercises/difference-of-squares/src/test/java/DifferenceOfSquaresCalculatorTest.java +0 -3
  264. data/tracks/java/exercises/etl/README.md +2 -0
  265. data/tracks/java/exercises/flatten-array/.meta/.version +1 -0
  266. data/tracks/java/exercises/flatten-array/README.md +1 -2
  267. data/tracks/java/exercises/flatten-array/src/test/java/FlattenerTest.java +0 -3
  268. data/tracks/java/exercises/food-chain/README.md +1 -1
  269. data/tracks/java/exercises/forth/.meta/.version +1 -0
  270. data/tracks/java/exercises/forth/src/test/java/ForthEvaluatorTest.java +0 -3
  271. data/tracks/java/exercises/grade-school/README.md +0 -1
  272. data/tracks/java/exercises/hamming/.meta/.version +1 -0
  273. data/tracks/java/exercises/hamming/src/test/java/HammingTest.java +0 -3
  274. data/tracks/java/exercises/house/README.md +1 -2
  275. data/tracks/java/exercises/isogram/README.md +2 -1
  276. data/tracks/java/exercises/kindergarten-garden/README.md +13 -13
  277. data/tracks/java/exercises/linked-list/README.md +10 -10
  278. data/tracks/java/exercises/list-ops/.meta/.version +1 -0
  279. data/tracks/java/exercises/list-ops/README.md +4 -0
  280. data/tracks/java/exercises/list-ops/src/test/java/ListOpsTest.java +0 -3
  281. data/tracks/java/exercises/luhn/README.md +7 -7
  282. data/tracks/java/exercises/matrix/README.md +6 -4
  283. data/tracks/java/exercises/meetup/README.md +1 -2
  284. data/tracks/java/exercises/minesweeper/.meta/.version +1 -0
  285. data/tracks/java/exercises/minesweeper/src/test/java/MinesweeperBoardTest.java +0 -3
  286. data/tracks/java/exercises/nucleotide-count/README.md +8 -22
  287. data/tracks/java/exercises/ocr-numbers/README.md +5 -5
  288. data/tracks/java/exercises/octal/README.md +6 -2
  289. data/tracks/java/exercises/palindrome-products/README.md +15 -16
  290. data/tracks/java/exercises/pangram/.meta/.version +1 -0
  291. data/tracks/java/exercises/pangram/README.md +1 -1
  292. data/tracks/java/exercises/pangram/src/test/java/PangramCheckerTest.java +0 -3
  293. data/tracks/java/exercises/pascals-triangle/.meta/.version +1 -0
  294. data/tracks/java/exercises/pascals-triangle/README.md +1 -1
  295. data/tracks/java/exercises/pascals-triangle/src/test/java/PascalsTriangleGeneratorTest.java +0 -3
  296. data/tracks/java/exercises/perfect-numbers/.meta/.version +1 -0
  297. data/tracks/java/exercises/perfect-numbers/README.md +2 -2
  298. data/tracks/java/exercises/perfect-numbers/src/test/java/NaturalNumberTest.java +0 -3
  299. data/tracks/java/exercises/phone-number/README.md +3 -2
  300. data/tracks/java/exercises/pythagorean-triplet/README.md +3 -3
  301. data/tracks/java/exercises/queen-attack/README.md +1 -1
  302. data/tracks/java/exercises/rectangles/README.md +7 -7
  303. data/tracks/java/exercises/rna-transcription/.meta/.version +1 -0
  304. data/tracks/java/exercises/rna-transcription/src/test/java/RnaTranscriptionTest.java +0 -3
  305. data/tracks/java/exercises/roman-numerals/README.md +1 -1
  306. data/tracks/java/exercises/rotational-cipher/README.md +2 -1
  307. data/tracks/java/exercises/run-length-encoding/README.md +4 -4
  308. data/tracks/java/exercises/saddle-points/.meta/.version +1 -0
  309. data/tracks/java/exercises/saddle-points/README.md +1 -1
  310. data/tracks/java/exercises/saddle-points/src/test/java/MatrixTest.java +0 -3
  311. data/tracks/java/exercises/scrabble-score/.meta/.version +1 -0
  312. data/tracks/java/exercises/scrabble-score/README.md +3 -1
  313. data/tracks/java/exercises/scrabble-score/src/test/java/ScrabbleScoreTest.java +0 -3
  314. data/tracks/java/exercises/secret-handshake/README.md +1 -1
  315. data/tracks/java/exercises/simple-cipher/README.md +1 -1
  316. data/tracks/java/exercises/simple-linked-list/src/test/java/SimpleLinkedListTest.java +25 -25
  317. data/tracks/java/exercises/space-age/README.md +1 -1
  318. data/tracks/java/exercises/spiral-matrix/.meta/.version +1 -0
  319. data/tracks/java/exercises/spiral-matrix/README.md +2 -2
  320. data/tracks/java/exercises/spiral-matrix/src/test/java/SpiralMatrixBuilderTest.java +0 -3
  321. data/tracks/java/exercises/sum-of-multiples/README.md +0 -3
  322. data/tracks/java/exercises/tournament/README.md +6 -5
  323. data/tracks/java/exercises/transpose/README.md +7 -7
  324. data/tracks/java/exercises/triangle/README.md +9 -6
  325. data/tracks/java/exercises/trinary/README.md +1 -1
  326. data/tracks/java/exercises/twelve-days/README.md +1 -1
  327. data/tracks/java/exercises/two-fer/README.md +1 -2
  328. data/tracks/java/exercises/word-count/README.md +1 -2
  329. data/tracks/java/exercises/word-search/.meta/.version +1 -0
  330. data/tracks/java/exercises/word-search/README.md +1 -1
  331. data/tracks/java/exercises/word-search/src/test/java/WordSearcherTest.java +0 -3
  332. data/tracks/java/exercises/wordy/README.md +0 -5
  333. data/tracks/javascript/config.json +13 -0
  334. data/tracks/javascript/docs/TESTS.md +1 -1
  335. data/tracks/javascript/exercises/diffie-hellman/example.js +1 -1
  336. data/tracks/javascript/exercises/hello-world/example.js +2 -3
  337. data/tracks/javascript/exercises/meetup/example.js +24 -27
  338. data/tracks/javascript/exercises/meetup/meetup.spec.js +0 -6
  339. data/tracks/javascript/exercises/nucleotide-count/nucleotide-count.spec.js +1 -1
  340. data/tracks/javascript/exercises/protein-translation/README.md +73 -0
  341. data/tracks/javascript/exercises/protein-translation/example.js +68 -0
  342. data/tracks/javascript/exercises/protein-translation/protein-translation.spec.js +63 -0
  343. data/tracks/julia/README.md +1 -1
  344. data/tracks/kotlin/config.json +11 -0
  345. data/tracks/kotlin/exercises/acronym/README.md +0 -1
  346. data/tracks/kotlin/exercises/all-your-base/README.md +1 -1
  347. data/tracks/kotlin/exercises/allergies/README.md +0 -1
  348. data/tracks/kotlin/exercises/atbash-cipher/README.md +2 -1
  349. data/tracks/kotlin/exercises/beer-song/README.md +1 -1
  350. data/tracks/kotlin/exercises/binary/README.md +2 -0
  351. data/tracks/kotlin/exercises/change/README.md +1 -1
  352. data/tracks/kotlin/exercises/collatz-conjecture/README.md +1 -1
  353. data/tracks/kotlin/exercises/complex-numbers/README.md +27 -0
  354. data/tracks/kotlin/exercises/diamond/README.md +6 -6
  355. data/tracks/kotlin/exercises/etl/README.md +2 -0
  356. data/tracks/kotlin/exercises/flatten-array/README.md +1 -2
  357. data/tracks/kotlin/exercises/grade-school/README.md +0 -1
  358. data/tracks/kotlin/exercises/grains/README.md +0 -1
  359. data/tracks/kotlin/exercises/hello-world/.meta/hints.md +4 -0
  360. data/tracks/kotlin/exercises/hello-world/.meta/src/reference/kotlin/HelloWorld.kt +2 -2
  361. data/tracks/kotlin/exercises/hello-world/README.md +6 -0
  362. data/tracks/kotlin/exercises/hello-world/TUTORIAL.md +32 -434
  363. data/tracks/kotlin/exercises/hello-world/src/main/kotlin/HelloWorld.kt +1 -1
  364. data/tracks/kotlin/exercises/hello-world/src/test/kotlin/HelloWorldTest.kt +2 -21
  365. data/tracks/kotlin/exercises/isogram/README.md +2 -1
  366. data/tracks/kotlin/exercises/leap/README.md +1 -1
  367. data/tracks/kotlin/exercises/linked-list/README.md +10 -10
  368. data/tracks/kotlin/exercises/luhn/README.md +7 -7
  369. data/tracks/kotlin/exercises/meetup/README.md +1 -2
  370. data/tracks/kotlin/exercises/nucleotide-count/README.md +8 -22
  371. data/tracks/kotlin/exercises/pangram/README.md +1 -1
  372. data/tracks/kotlin/exercises/pascals-triangle/README.md +1 -1
  373. data/tracks/kotlin/exercises/perfect-numbers/README.md +2 -2
  374. data/tracks/kotlin/exercises/phone-number/README.md +3 -2
  375. data/tracks/kotlin/exercises/roman-numerals/README.md +1 -1
  376. data/tracks/kotlin/exercises/rotational-cipher/README.md +2 -1
  377. data/tracks/kotlin/exercises/saddle-points/README.md +1 -1
  378. data/tracks/kotlin/exercises/scrabble-score/README.md +3 -1
  379. data/tracks/kotlin/exercises/secret-handshake/README.md +1 -1
  380. data/tracks/kotlin/exercises/settings.gradle +1 -0
  381. data/tracks/kotlin/exercises/space-age/README.md +1 -2
  382. data/tracks/kotlin/exercises/spiral-matrix/README.md +2 -2
  383. data/tracks/kotlin/exercises/sum-of-multiples/README.md +0 -3
  384. data/tracks/kotlin/exercises/triangle/README.md +9 -6
  385. data/tracks/kotlin/exercises/two-fer/.meta/src/reference/kotlin/Twofer.kt +3 -0
  386. data/tracks/kotlin/exercises/two-fer/README.md +50 -0
  387. data/tracks/kotlin/exercises/two-fer/build.gradle +28 -0
  388. data/tracks/kotlin/exercises/two-fer/src/main/kotlin/.keep +0 -0
  389. data/tracks/kotlin/exercises/two-fer/src/test/kotlin/TwoferTest.kt +31 -0
  390. data/tracks/kotlin/exercises/word-count/README.md +1 -2
  391. data/tracks/ocaml/exercises/pangram/test.ml +3 -1
  392. data/tracks/perl5/.travis.yml +3 -1
  393. data/tracks/php/Makefile +2 -2
  394. data/tracks/php/README.md +4 -4
  395. data/tracks/php/config.json +15 -0
  396. data/tracks/php/exercises/transpose/example.php +30 -0
  397. data/tracks/php/exercises/transpose/transpose_test.php +116 -0
  398. data/tracks/php/{phpcs-xphp.xml → phpcs-php.xml} +0 -0
  399. data/tracks/python/.travis.yml +1 -1
  400. data/tracks/python/config.json +199 -39
  401. data/tracks/python/exercises/acronym/acronym_test.py +1 -1
  402. data/tracks/python/exercises/allergies/allergies_test.py +1 -1
  403. data/tracks/python/exercises/alphametics/alphametics_test.py +1 -1
  404. data/tracks/python/exercises/anagram/anagram_test.py +1 -1
  405. data/tracks/python/exercises/atbash-cipher/atbash_cipher_test.py +1 -1
  406. data/tracks/python/exercises/bob/bob.py +1 -1
  407. data/tracks/python/exercises/bob/bob_test.py +1 -1
  408. data/tracks/python/exercises/book-store/book_store_test.py +1 -1
  409. data/tracks/python/exercises/bracket-push/bracket_push.py +1 -1
  410. data/tracks/python/exercises/bracket-push/bracket_push_test.py +1 -1
  411. data/tracks/python/exercises/collatz-conjecture/collatz_conjecture_test.py +1 -1
  412. data/tracks/python/exercises/diamond/diamond_test.py +1 -1
  413. data/tracks/python/exercises/difference-of-squares/difference_of_squares_test.py +1 -1
  414. data/tracks/python/exercises/diffie-hellman/README.md +58 -0
  415. data/tracks/python/exercises/diffie-hellman/diffie_hellman.py +10 -0
  416. data/tracks/python/exercises/diffie-hellman/diffie_hellman_test.py +87 -0
  417. data/tracks/python/exercises/diffie-hellman/example.py +13 -0
  418. data/tracks/python/exercises/etl/etl_test.py +1 -1
  419. data/tracks/python/exercises/food-chain/README.md +81 -0
  420. data/tracks/python/exercises/food-chain/example.py +45 -0
  421. data/tracks/python/exercises/food-chain/food_chain.py +2 -0
  422. data/tracks/python/exercises/food-chain/food_chain_test.py +109 -0
  423. data/tracks/python/exercises/forth/README.md +43 -0
  424. data/tracks/python/exercises/forth/example.py +58 -0
  425. data/tracks/python/exercises/forth/forth.py +2 -0
  426. data/tracks/python/exercises/forth/forth_test.py +254 -0
  427. data/tracks/python/exercises/gigasecond/gigasecond_test.py +1 -1
  428. data/tracks/python/exercises/grep/grep_test.py +1 -1
  429. data/tracks/python/exercises/hello-world/hello_world_test.py +1 -1
  430. data/tracks/python/exercises/isogram/isogram_test.py +10 -10
  431. data/tracks/python/exercises/largest-series-product/largest_series_product_test.py +1 -1
  432. data/tracks/python/exercises/leap/leap_test.py +5 -5
  433. data/tracks/python/exercises/luhn/luhn_test.py +16 -16
  434. data/tracks/python/exercises/markdown/README.md +30 -0
  435. data/tracks/python/exercises/markdown/example.py +80 -0
  436. data/tracks/python/exercises/markdown/markdown.py +71 -0
  437. data/tracks/python/exercises/markdown/markdown_test.py +51 -0
  438. data/tracks/python/exercises/meetup/meetup_test.py +1 -1
  439. data/tracks/python/exercises/nth-prime/nth_prime_test.py +1 -1
  440. data/tracks/python/exercises/pascals-triangle/pascals_triangle_test.py +2 -2
  441. data/tracks/python/exercises/perfect-numbers/perfect_numbers_test.py +11 -11
  442. data/tracks/python/exercises/phone-number/phone_number_test.py +1 -1
  443. data/tracks/python/exercises/prime-factors/prime_factors_test.py +1 -1
  444. data/tracks/python/exercises/pythagorean-triplet/pythagorean_triplet_test.py +3 -3
  445. data/tracks/python/exercises/queen-attack/queen_attack_test.py +8 -8
  446. data/tracks/python/exercises/rail-fence-cipher/rail_fence_cipher_test.py +1 -1
  447. data/tracks/python/exercises/rectangles/rectangles_test.py +1 -1
  448. data/tracks/python/exercises/robot-simulator/robot_simulator.py +9 -1
  449. data/tracks/python/exercises/roman-numerals/roman_numerals_test.py +1 -1
  450. data/tracks/python/exercises/run-length-encoding/run_length_encoding_test.py +1 -1
  451. data/tracks/python/exercises/say/say_test.py +1 -1
  452. data/tracks/python/exercises/scrabble-score/scrabble_score_test.py +1 -1
  453. data/tracks/python/exercises/series/series.py +1 -1
  454. data/tracks/python/exercises/sieve/sieve_test.py +1 -1
  455. data/tracks/python/exercises/sublist/sublist_test.py +1 -1
  456. data/tracks/python/exercises/tournament/tournament_test.py +1 -1
  457. data/tracks/python/exercises/transpose/transpose_test.py +1 -1
  458. data/tracks/python/exercises/two-bucket/example.py +49 -54
  459. data/tracks/python/exercises/two-bucket/two_bucket_test.py +1 -1
  460. data/tracks/python/exercises/variable-length-quantity/variable_length_quantity_test.py +1 -1
  461. data/tracks/rust/config.json +24 -0
  462. data/tracks/rust/exercises/collatz-conjecture/Cargo.lock +4 -0
  463. data/tracks/rust/exercises/collatz-conjecture/Cargo.toml +3 -0
  464. data/tracks/rust/exercises/collatz-conjecture/README.md +65 -0
  465. data/tracks/rust/exercises/collatz-conjecture/example.rs +19 -0
  466. data/tracks/rust/exercises/collatz-conjecture/src/lib.rs +4 -0
  467. data/tracks/rust/exercises/collatz-conjecture/tests/collatz-conjecture.rs +32 -0
  468. data/tracks/rust/exercises/decimal/.gitignore +7 -0
  469. data/tracks/rust/exercises/decimal/.meta/description.md +19 -0
  470. data/tracks/rust/exercises/decimal/.meta/metadata.yml +3 -0
  471. data/tracks/rust/exercises/decimal/Cargo-example.toml +9 -0
  472. data/tracks/rust/exercises/decimal/Cargo.toml +6 -0
  473. data/tracks/rust/exercises/decimal/README.md +59 -0
  474. data/tracks/rust/exercises/decimal/example.rs +187 -0
  475. data/tracks/rust/exercises/decimal/src/lib.rs +10 -0
  476. data/tracks/rust/exercises/decimal/tests/decimal.rs +332 -0
  477. data/tracks/sml/exercises/accumulate/README.md +9 -1
  478. data/tracks/swift/exercises/luhn/Sources/LuhnExample.swift +17 -26
  479. data/tracks/swift/exercises/luhn/Tests/LinuxMain.swift +1 -1
  480. data/tracks/swift/exercises/luhn/Tests/LuhnTests/LuhnTests.swift +59 -35
  481. data/tracks/typescript/config.json +34 -0
  482. data/tracks/typescript/exercises/binary-search/README.md +67 -0
  483. data/tracks/typescript/exercises/binary-search/binary-search.example.ts +42 -0
  484. data/tracks/typescript/exercises/binary-search/binary-search.test.ts +27 -0
  485. data/tracks/typescript/exercises/binary-search/binary-search.ts +3 -0
  486. data/tracks/typescript/exercises/binary-search/package.json +36 -0
  487. data/tracks/typescript/exercises/binary-search/tsconfig.json +22 -0
  488. data/tracks/typescript/exercises/binary-search/tslint.json +127 -0
  489. data/tracks/typescript/exercises/binary-search/yarn.lock +2305 -0
  490. data/tracks/typescript/exercises/pascals-triangle/README.md +47 -0
  491. data/tracks/typescript/exercises/pascals-triangle/package.json +36 -0
  492. data/tracks/typescript/exercises/pascals-triangle/pascals-triangle.example.ts +32 -0
  493. data/tracks/typescript/exercises/pascals-triangle/pascals-triangle.test.ts +28 -0
  494. data/tracks/typescript/exercises/pascals-triangle/pascals-triangle.ts +2 -0
  495. data/tracks/typescript/exercises/pascals-triangle/tsconfig.json +22 -0
  496. data/tracks/typescript/exercises/pascals-triangle/tslint.json +127 -0
  497. data/tracks/typescript/exercises/pascals-triangle/yarn.lock +2305 -0
  498. data/tracks/typescript/exercises/rotational-cipher/README.md +63 -0
  499. data/tracks/typescript/exercises/rotational-cipher/package.json +36 -0
  500. data/tracks/typescript/exercises/rotational-cipher/rotational-cipher.example.ts +19 -0
  501. data/tracks/typescript/exercises/rotational-cipher/rotational-cipher.test.ts +56 -0
  502. data/tracks/typescript/exercises/rotational-cipher/rotational-cipher.ts +1 -0
  503. data/tracks/typescript/exercises/rotational-cipher/tsconfig.json +22 -0
  504. data/tracks/typescript/exercises/rotational-cipher/tslint.json +127 -0
  505. data/tracks/typescript/exercises/rotational-cipher/yarn.lock +2305 -0
  506. metadata +171 -5
  507. data/tracks/javascript/exercises/twelve-days/package.json +0 -69
  508. data/tracks/kotlin/exercises/hello-world/GETTING_STARTED.md +0 -50
@@ -5,6 +5,6 @@ typedef struct {
5
5
  double a;
6
6
  double b;
7
7
  double c;
8
- } Triangle_t;
8
+ } triangle_t;
9
9
 
10
10
  #endif
@@ -3,118 +3,119 @@
3
3
 
4
4
  void test_equilateral_is_true_if_all_sides_are_equal(void)
5
5
  {
6
- Triangle_t sides = { 2, 2, 2 };
6
+ triangle_t sides = { 2, 2, 2 };
7
7
  TEST_ASSERT_TRUE(is_equilateral(&sides));
8
8
  }
9
9
 
10
10
  void test_equilateral_is_false_if_any_side_is_unequal(void)
11
11
  {
12
12
  TEST_IGNORE(); // delete this line to run test
13
- Triangle_t sides = { 2, 3, 2 };
13
+ triangle_t sides = { 2, 3, 2 };
14
14
  TEST_ASSERT_FALSE(is_equilateral(&sides));
15
15
  }
16
16
 
17
17
  void test_equilateral_is_false_if_all_sides_zero(void)
18
18
  {
19
19
  TEST_IGNORE();
20
- Triangle_t sides = { 0, 0, 0 };
20
+ triangle_t sides = { 0, 0, 0 };
21
21
  TEST_ASSERT_FALSE(is_equilateral(&sides));
22
22
  }
23
23
 
24
24
  void test_equilateral_sides_may_be_floats(void)
25
25
  {
26
26
  TEST_IGNORE();
27
- Triangle_t sides = { 0.5, 0.5, 0.5 };
27
+ triangle_t sides = { 0.5, 0.5, 0.5 };
28
28
  TEST_ASSERT_TRUE(is_equilateral(&sides));
29
29
  }
30
30
 
31
31
  void test_isosceles_is_true_if_last_two_sides_are_equal(void)
32
32
  {
33
33
  TEST_IGNORE();
34
- Triangle_t sides = { 3, 4, 4 };
34
+ triangle_t sides = { 3, 4, 4 };
35
35
  TEST_ASSERT_TRUE(is_isosceles(&sides));
36
36
  }
37
37
 
38
38
  void test_isosceles_is_true_if_first_two_sides_are_equal(void)
39
39
  {
40
40
  TEST_IGNORE();
41
- Triangle_t sides = { 4, 4, 3 };
41
+ triangle_t sides = { 4, 4, 3 };
42
42
  TEST_ASSERT_TRUE(is_isosceles(&sides));
43
43
  }
44
44
 
45
45
  void test_isosceles_is_true_if_first_and_last_sides_are_equal(void)
46
46
  {
47
47
  TEST_IGNORE();
48
- Triangle_t sides = { 4, 3, 4 };
48
+ triangle_t sides = { 4, 3, 4 };
49
49
  TEST_ASSERT_TRUE(is_isosceles(&sides));
50
50
  }
51
51
 
52
52
  void test_equilateral_triangles_are_also_isosceles(void)
53
53
  {
54
54
  TEST_IGNORE();
55
- Triangle_t sides = { 4, 4, 4 };
55
+ triangle_t sides = { 4, 4, 4 };
56
56
  TEST_ASSERT_TRUE(is_isosceles(&sides));
57
57
  }
58
58
 
59
59
  void test_isosceles_is_false_if_no_sides_are_equal(void)
60
60
  {
61
61
  TEST_IGNORE();
62
- Triangle_t sides = { 2, 3, 4 };
62
+ triangle_t sides = { 2, 3, 4 };
63
63
  TEST_ASSERT_FALSE(is_isosceles(&sides));
64
64
  }
65
65
 
66
66
  void test_isosceles_is_false_if_two_sides_equal_and_violate_inequality(void)
67
67
  {
68
68
  TEST_IGNORE();
69
- Triangle_t sides = { 1, 1, 3 };
69
+ triangle_t sides = { 1, 1, 3 };
70
70
  TEST_ASSERT_FALSE(is_isosceles(&sides));
71
71
  }
72
72
 
73
73
  void test_isosceles_sides_may_be_floats(void)
74
74
  {
75
75
  TEST_IGNORE();
76
- Triangle_t sides = { 0.5, 0.4, 0.5 };
76
+ triangle_t sides = { 0.5, 0.4, 0.5 };
77
77
  TEST_ASSERT_TRUE(is_isosceles(&sides));
78
78
  }
79
79
 
80
80
  void test_scalene_is_true_if_no_sides_are_equal(void)
81
81
  {
82
82
  TEST_IGNORE();
83
- Triangle_t sides = { 5, 4, 6 };
83
+ triangle_t sides = { 5, 4, 6 };
84
84
  TEST_ASSERT_TRUE(is_scalene(&sides));
85
85
  }
86
86
 
87
87
  void test_scalene_is_false_if_all_sides_are_equal(void)
88
88
  {
89
89
  TEST_IGNORE();
90
- Triangle_t sides = { 4, 4, 4 };
90
+ triangle_t sides = { 4, 4, 4 };
91
91
  TEST_ASSERT_FALSE(is_scalene(&sides));
92
92
  }
93
93
 
94
94
  void test_scalene_is_false_if_two_sides_are_equal(void)
95
95
  {
96
96
  TEST_IGNORE();
97
- Triangle_t sides = { 4, 4, 3 };
97
+ triangle_t sides = { 4, 4, 3 };
98
98
  TEST_ASSERT_FALSE(is_scalene(&sides));
99
99
  }
100
100
 
101
101
  void test_scalene_is_false_if_no_sides_equal_and_violate_inequality(void)
102
102
  {
103
103
  TEST_IGNORE();
104
- Triangle_t sides = { 7, 3, 2 };
104
+ triangle_t sides = { 7, 3, 2 };
105
105
  TEST_ASSERT_FALSE(is_scalene(&sides));
106
106
  }
107
107
 
108
108
  void test_scalene_sides_may_be_floats(void)
109
109
  {
110
110
  TEST_IGNORE();
111
- Triangle_t sides = { 0.5, 0.4, 0.6 };
111
+ triangle_t sides = { 0.5, 0.4, 0.6 };
112
112
  TEST_ASSERT_TRUE(is_scalene(&sides));
113
113
  }
114
114
 
115
115
  int main(void)
116
116
  {
117
117
  UnityBegin("test/test_triangle.c");
118
+
118
119
  RUN_TEST(test_equilateral_is_true_if_all_sides_are_equal);
119
120
  RUN_TEST(test_equilateral_is_false_if_any_side_is_unequal);
120
121
  RUN_TEST(test_equilateral_is_false_if_all_sides_zero);
@@ -131,6 +132,7 @@ int main(void)
131
132
  RUN_TEST(test_scalene_is_false_if_two_sides_are_equal);
132
133
  RUN_TEST(test_scalene_is_false_if_no_sides_equal_and_violate_inequality);
133
134
  RUN_TEST(test_scalene_sides_may_be_floats);
135
+
134
136
  UnityEnd();
135
137
  return 0;
136
138
  }
@@ -7,59 +7,59 @@
7
7
  // if word counted already it returns index,
8
8
  // else returns -1
9
9
  static int word_match(char *testWord, int current_word_count,
10
- WordCount_Word_t words[MAX_WORDS])
10
+ word_count_word_t words[MAX_WORDS])
11
11
  {
12
- int matchIndex = -1;
12
+ int match_index = -1;
13
13
 
14
14
  for (int index = 0; index < current_word_count; index++) {
15
15
  if (!strcmp(testWord, words[index].text)) {
16
- matchIndex = index;
16
+ match_index = index;
17
17
  break;
18
18
  }
19
19
  }
20
- return matchIndex;
20
+ return match_index;
21
21
  }
22
22
 
23
- int word_count(char *input_text, WordCount_Word_t words[MAX_WORDS])
23
+ int word_count(char *input_text, word_count_word_t words[MAX_WORDS])
24
24
  {
25
25
  int index;
26
- int uniqueWords = 0;
27
- char *testWord;
28
- char *lowerCaseInputText; // hold lowercase copy of passed text
26
+ int unique_words = 0;
27
+ char *test_word;
28
+ char *lower_case_input_text; // hold lowercase copy of passed text
29
29
  const char *delimiters = " ,.-\n:!!&@$%^&\"";
30
30
 
31
31
  // convert the input text to lower case
32
- lowerCaseInputText = malloc(strlen(input_text) + 1);
32
+ lower_case_input_text = malloc(strlen(input_text) + 1);
33
33
  for (index = 0; input_text[index] != 0; index++) {
34
- lowerCaseInputText[index] = tolower(input_text[index]);
34
+ lower_case_input_text[index] = tolower(input_text[index]);
35
35
  }
36
- lowerCaseInputText[index] = '\0';
36
+ lower_case_input_text[index] = '\0';
37
37
 
38
38
  // start with known results...
39
- memset(words, 0, sizeof(WordCount_Word_t));
39
+ memset(words, 0, sizeof(word_count_word_t));
40
40
 
41
- testWord = strtok(lowerCaseInputText, delimiters);
42
- while (testWord != NULL) {
41
+ test_word = strtok(lower_case_input_text, delimiters);
42
+ while (test_word != NULL) {
43
43
  // account for leading/trailing single quote.
44
- if (('\'' == testWord[0]) && ('\'' == testWord[strlen(testWord) - 1])) {
45
- testWord[strlen(testWord) - 1] = '\0';
46
- testWord++;
44
+ if (('\'' == test_word[0]) && ('\'' == test_word[strlen(test_word) - 1])) {
45
+ test_word[strlen(test_word) - 1] = '\0';
46
+ test_word++;
47
47
  }
48
48
  // determine index of counted word.
49
- index = word_match(testWord, uniqueWords, words);
49
+ index = word_match(test_word, unique_words, words);
50
50
 
51
51
  // add if not yet counted else increment count.
52
52
  if (-1 == index) {
53
- words[uniqueWords].count = 1;
54
- strcpy(words[uniqueWords].text, testWord);
55
- uniqueWords++;
53
+ words[unique_words].count = 1;
54
+ strcpy(words[unique_words].text, test_word);
55
+ unique_words++;
56
56
  } else {
57
57
  words[index].count++;
58
58
  }
59
59
  // get next word in string
60
- testWord = strtok(NULL, delimiters);
60
+ test_word = strtok(NULL, delimiters);
61
61
  }
62
62
 
63
- free(lowerCaseInputText);
64
- return uniqueWords;
63
+ free(lower_case_input_text);
64
+ return unique_words;
65
65
  }
@@ -5,10 +5,10 @@
5
5
  #define MAX_WORD_LENGTH 50 // no individual word will exceed this length
6
6
 
7
7
  // results structure
8
- typedef struct WordCount_Word {
8
+ typedef struct word_count_word {
9
9
  char text[MAX_WORD_LENGTH];
10
10
  int count;
11
- } WordCount_Word_t;
11
+ } word_count_word_t;
12
12
 
13
13
  // word_count - routine to classify the unique words and their frequency in a test input string
14
14
  // inputs:
@@ -17,6 +17,6 @@ typedef struct WordCount_Word {
17
17
  //
18
18
  // outputs:
19
19
  // uniqueWords - number of words in the words structure
20
- int word_count(char *input_text, WordCount_Word_t words[MAX_WORDS]);
20
+ int word_count(char *input_text, word_count_word_t words[MAX_WORDS]);
21
21
 
22
22
  #endif
@@ -4,11 +4,11 @@
4
4
  #include "vendor/unity.h"
5
5
  #include "../src/word_count.h"
6
6
 
7
- WordCount_Word_t ActualSolution[MAX_WORDS];
7
+ word_count_word_t actual_solution[MAX_WORDS];
8
8
 
9
- static void test_solution(WordCount_Word_t * expected_solution,
9
+ static void test_solution(word_count_word_t * expected_solution,
10
10
  int expected_word_count,
11
- WordCount_Word_t * actual_solution,
11
+ word_count_word_t * actual_solution,
12
12
  int actual_word_count)
13
13
  {
14
14
  // All words counted?
@@ -25,7 +25,7 @@ static void test_solution(WordCount_Word_t * expected_solution,
25
25
 
26
26
  static void reset_actual_solution(void)
27
27
  {
28
- memset(ActualSolution, 0, sizeof(ActualSolution));
28
+ memset(actual_solution, 0, sizeof(actual_solution));
29
29
  }
30
30
 
31
31
  // Tests Start here
@@ -35,21 +35,21 @@ void test_word_count_one_word(void)
35
35
  int actual_word_count;
36
36
  char *input_text = "word";
37
37
  const int expected_word_count = 1;
38
- WordCount_Word_t ExpectedSolution[expected_word_count];
38
+ word_count_word_t expected_solution[expected_word_count];
39
39
 
40
40
  // build the expected solution
41
- memset(ExpectedSolution, 0, sizeof(ExpectedSolution)); // clear to start with a known value
41
+ memset(expected_solution, 0, sizeof(expected_solution)); // clear to start with a known value
42
42
 
43
43
  // fill in the expected words
44
- ExpectedSolution[index].count = 1;
45
- strncpy(ExpectedSolution[index++].text, "word", MAX_WORD_LENGTH);
44
+ expected_solution[index].count = 1;
45
+ strncpy(expected_solution[index++].text, "word", MAX_WORD_LENGTH);
46
46
 
47
47
  reset_actual_solution();
48
48
 
49
- actual_word_count = word_count(input_text, ActualSolution);
49
+ actual_word_count = word_count(input_text, actual_solution);
50
50
 
51
- test_solution(ExpectedSolution,
52
- expected_word_count, ActualSolution, actual_word_count);
51
+ test_solution(expected_solution,
52
+ expected_word_count, actual_solution, actual_word_count);
53
53
  }
54
54
 
55
55
  void test_word_count_one_of_each_word(void)
@@ -59,26 +59,26 @@ void test_word_count_one_of_each_word(void)
59
59
  int actual_word_count;
60
60
  char *input_text = "one of each";
61
61
  const int expected_word_count = 3;
62
- WordCount_Word_t ExpectedSolution[expected_word_count];
62
+ word_count_word_t expected_solution[expected_word_count];
63
63
 
64
64
  // build the expected solution
65
- memset(ExpectedSolution, 0, sizeof(ExpectedSolution)); // clear to start with a known value
65
+ memset(expected_solution, 0, sizeof(expected_solution)); // clear to start with a known value
66
66
 
67
67
  // fill in the expected words
68
- ExpectedSolution[index].count = 1;
69
- strncpy(ExpectedSolution[index++].text, "one", MAX_WORD_LENGTH);
68
+ expected_solution[index].count = 1;
69
+ strncpy(expected_solution[index++].text, "one", MAX_WORD_LENGTH);
70
70
 
71
- ExpectedSolution[index].count = 1;
72
- strncpy(ExpectedSolution[index++].text, "of", MAX_WORD_LENGTH);
71
+ expected_solution[index].count = 1;
72
+ strncpy(expected_solution[index++].text, "of", MAX_WORD_LENGTH);
73
73
 
74
- ExpectedSolution[index].count = 1;
75
- strncpy(ExpectedSolution[index++].text, "each", MAX_WORD_LENGTH);
74
+ expected_solution[index].count = 1;
75
+ strncpy(expected_solution[index++].text, "each", MAX_WORD_LENGTH);
76
76
 
77
77
  reset_actual_solution();
78
- actual_word_count = word_count(input_text, ActualSolution);
78
+ actual_word_count = word_count(input_text, actual_solution);
79
79
 
80
- test_solution(ExpectedSolution,
81
- expected_word_count, ActualSolution, actual_word_count);
80
+ test_solution(expected_solution,
81
+ expected_word_count, actual_solution, actual_word_count);
82
82
  }
83
83
 
84
84
  void test_word_count_multiple_occurrences_of_a_word(void)
@@ -88,31 +88,31 @@ void test_word_count_multiple_occurrences_of_a_word(void)
88
88
  int actual_word_count;
89
89
  char *input_text = "one fish two fish red fish blue fish";
90
90
  const int expected_word_count = 5;
91
- WordCount_Word_t ExpectedSolution[expected_word_count];
91
+ word_count_word_t expected_solution[expected_word_count];
92
92
 
93
93
  // build the expected solution
94
- memset(ExpectedSolution, 0, sizeof(ExpectedSolution)); // clear to start with a known value
94
+ memset(expected_solution, 0, sizeof(expected_solution)); // clear to start with a known value
95
95
 
96
- ExpectedSolution[index].count = 1;
97
- strncpy(ExpectedSolution[index++].text, "one", MAX_WORD_LENGTH);
96
+ expected_solution[index].count = 1;
97
+ strncpy(expected_solution[index++].text, "one", MAX_WORD_LENGTH);
98
98
 
99
- ExpectedSolution[index].count = 4;
100
- strncpy(ExpectedSolution[index++].text, "fish", MAX_WORD_LENGTH);
99
+ expected_solution[index].count = 4;
100
+ strncpy(expected_solution[index++].text, "fish", MAX_WORD_LENGTH);
101
101
 
102
- ExpectedSolution[index].count = 1;
103
- strncpy(ExpectedSolution[index++].text, "two", MAX_WORD_LENGTH);
102
+ expected_solution[index].count = 1;
103
+ strncpy(expected_solution[index++].text, "two", MAX_WORD_LENGTH);
104
104
 
105
- ExpectedSolution[index].count = 1;
106
- strncpy(ExpectedSolution[index++].text, "red", MAX_WORD_LENGTH);
105
+ expected_solution[index].count = 1;
106
+ strncpy(expected_solution[index++].text, "red", MAX_WORD_LENGTH);
107
107
 
108
- ExpectedSolution[index].count = 1;
109
- strncpy(ExpectedSolution[index++].text, "blue", MAX_WORD_LENGTH);
108
+ expected_solution[index].count = 1;
109
+ strncpy(expected_solution[index++].text, "blue", MAX_WORD_LENGTH);
110
110
 
111
111
  reset_actual_solution();
112
- actual_word_count = word_count(input_text, ActualSolution);
112
+ actual_word_count = word_count(input_text, actual_solution);
113
113
 
114
- test_solution(ExpectedSolution,
115
- expected_word_count, ActualSolution, actual_word_count);
114
+ test_solution(expected_solution,
115
+ expected_word_count, actual_solution, actual_word_count);
116
116
  }
117
117
 
118
118
  void test_word_count_handles_cramped_lists(void)
@@ -122,25 +122,25 @@ void test_word_count_handles_cramped_lists(void)
122
122
  int actual_word_count;
123
123
  char *input_text = "one,two,three";
124
124
  const int expected_word_count = 3;
125
- WordCount_Word_t ExpectedSolution[expected_word_count];
125
+ word_count_word_t expected_solution[expected_word_count];
126
126
 
127
127
  // build the expected solution
128
- memset(ExpectedSolution, 0, sizeof(ExpectedSolution)); // clear to start with a known value
128
+ memset(expected_solution, 0, sizeof(expected_solution)); // clear to start with a known value
129
129
 
130
- ExpectedSolution[index].count = 1;
131
- strncpy(ExpectedSolution[index++].text, "one", MAX_WORD_LENGTH);
130
+ expected_solution[index].count = 1;
131
+ strncpy(expected_solution[index++].text, "one", MAX_WORD_LENGTH);
132
132
 
133
- ExpectedSolution[index].count = 1;
134
- strncpy(ExpectedSolution[index++].text, "two", MAX_WORD_LENGTH);
133
+ expected_solution[index].count = 1;
134
+ strncpy(expected_solution[index++].text, "two", MAX_WORD_LENGTH);
135
135
 
136
- ExpectedSolution[index].count = 1;
137
- strncpy(ExpectedSolution[index++].text, "three", MAX_WORD_LENGTH);
136
+ expected_solution[index].count = 1;
137
+ strncpy(expected_solution[index++].text, "three", MAX_WORD_LENGTH);
138
138
 
139
139
  reset_actual_solution();
140
- actual_word_count = word_count(input_text, ActualSolution);
140
+ actual_word_count = word_count(input_text, actual_solution);
141
141
 
142
- test_solution(ExpectedSolution,
143
- expected_word_count, ActualSolution, actual_word_count);
142
+ test_solution(expected_solution,
143
+ expected_word_count, actual_solution, actual_word_count);
144
144
  }
145
145
 
146
146
  void test_word_count_handles_expanded_lists(void)
@@ -150,25 +150,25 @@ void test_word_count_handles_expanded_lists(void)
150
150
  int actual_word_count;
151
151
  char *input_text = "one,\ntwo,\nthree";
152
152
  const int expected_word_count = 3;
153
- WordCount_Word_t ExpectedSolution[expected_word_count];
153
+ word_count_word_t expected_solution[expected_word_count];
154
154
 
155
155
  // build the expected solution
156
- memset(ExpectedSolution, 0, sizeof(ExpectedSolution)); // clear to start with a known value
156
+ memset(expected_solution, 0, sizeof(expected_solution)); // clear to start with a known value
157
157
 
158
- ExpectedSolution[index].count = 1;
159
- strncpy(ExpectedSolution[index++].text, "one", MAX_WORD_LENGTH);
158
+ expected_solution[index].count = 1;
159
+ strncpy(expected_solution[index++].text, "one", MAX_WORD_LENGTH);
160
160
 
161
- ExpectedSolution[index].count = 1;
162
- strncpy(ExpectedSolution[index++].text, "two", MAX_WORD_LENGTH);
161
+ expected_solution[index].count = 1;
162
+ strncpy(expected_solution[index++].text, "two", MAX_WORD_LENGTH);
163
163
 
164
- ExpectedSolution[index].count = 1;
165
- strncpy(ExpectedSolution[index++].text, "three", MAX_WORD_LENGTH);
164
+ expected_solution[index].count = 1;
165
+ strncpy(expected_solution[index++].text, "three", MAX_WORD_LENGTH);
166
166
 
167
167
  reset_actual_solution();
168
- actual_word_count = word_count(input_text, ActualSolution);
168
+ actual_word_count = word_count(input_text, actual_solution);
169
169
 
170
- test_solution(ExpectedSolution,
171
- expected_word_count, ActualSolution, actual_word_count);
170
+ test_solution(expected_solution,
171
+ expected_word_count, actual_solution, actual_word_count);
172
172
  }
173
173
 
174
174
  void test_word_count_ignore_punctuation(void)
@@ -178,31 +178,31 @@ void test_word_count_ignore_punctuation(void)
178
178
  int actual_word_count;
179
179
  char *input_text = "car: carpet as java: javascript!!&@$%^&";
180
180
  const int expected_word_count = 5;
181
- WordCount_Word_t ExpectedSolution[expected_word_count];
181
+ word_count_word_t expected_solution[expected_word_count];
182
182
 
183
183
  // build the expected solution
184
- memset(ExpectedSolution, 0, sizeof(ExpectedSolution)); // clear to start with a known value
184
+ memset(expected_solution, 0, sizeof(expected_solution)); // clear to start with a known value
185
185
 
186
- ExpectedSolution[index].count = 1;
187
- strncpy(ExpectedSolution[index++].text, "car", MAX_WORD_LENGTH);
186
+ expected_solution[index].count = 1;
187
+ strncpy(expected_solution[index++].text, "car", MAX_WORD_LENGTH);
188
188
 
189
- ExpectedSolution[index].count = 1;
190
- strncpy(ExpectedSolution[index++].text, "carpet", MAX_WORD_LENGTH);
189
+ expected_solution[index].count = 1;
190
+ strncpy(expected_solution[index++].text, "carpet", MAX_WORD_LENGTH);
191
191
 
192
- ExpectedSolution[index].count = 1;
193
- strncpy(ExpectedSolution[index++].text, "as", MAX_WORD_LENGTH);
192
+ expected_solution[index].count = 1;
193
+ strncpy(expected_solution[index++].text, "as", MAX_WORD_LENGTH);
194
194
 
195
- ExpectedSolution[index].count = 1;
196
- strncpy(ExpectedSolution[index++].text, "java", MAX_WORD_LENGTH);
195
+ expected_solution[index].count = 1;
196
+ strncpy(expected_solution[index++].text, "java", MAX_WORD_LENGTH);
197
197
 
198
- ExpectedSolution[index].count = 1;
199
- strncpy(ExpectedSolution[index++].text, "javascript", MAX_WORD_LENGTH);
198
+ expected_solution[index].count = 1;
199
+ strncpy(expected_solution[index++].text, "javascript", MAX_WORD_LENGTH);
200
200
 
201
201
  reset_actual_solution();
202
- actual_word_count = word_count(input_text, ActualSolution);
202
+ actual_word_count = word_count(input_text, actual_solution);
203
203
 
204
- test_solution(ExpectedSolution,
205
- expected_word_count, ActualSolution, actual_word_count);
204
+ test_solution(expected_solution,
205
+ expected_word_count, actual_solution, actual_word_count);
206
206
  }
207
207
 
208
208
  void test_word_count_include_numbers(void)
@@ -212,25 +212,25 @@ void test_word_count_include_numbers(void)
212
212
  int actual_word_count;
213
213
  char *input_text = "testing, 1, 2 testing";
214
214
  const int expected_word_count = 3;
215
- WordCount_Word_t ExpectedSolution[expected_word_count];
215
+ word_count_word_t expected_solution[expected_word_count];
216
216
 
217
217
  // build the expected solution
218
- memset(ExpectedSolution, 0, sizeof(ExpectedSolution)); // clear to start with a known value
218
+ memset(expected_solution, 0, sizeof(expected_solution)); // clear to start with a known value
219
219
 
220
- ExpectedSolution[index].count = 2;
221
- strncpy(ExpectedSolution[index++].text, "testing", MAX_WORD_LENGTH);
220
+ expected_solution[index].count = 2;
221
+ strncpy(expected_solution[index++].text, "testing", MAX_WORD_LENGTH);
222
222
 
223
- ExpectedSolution[index].count = 1;
224
- strncpy(ExpectedSolution[index++].text, "1", MAX_WORD_LENGTH);
223
+ expected_solution[index].count = 1;
224
+ strncpy(expected_solution[index++].text, "1", MAX_WORD_LENGTH);
225
225
 
226
- ExpectedSolution[index].count = 1;
227
- strncpy(ExpectedSolution[index++].text, "2", MAX_WORD_LENGTH);
226
+ expected_solution[index].count = 1;
227
+ strncpy(expected_solution[index++].text, "2", MAX_WORD_LENGTH);
228
228
 
229
229
  reset_actual_solution();
230
- actual_word_count = word_count(input_text, ActualSolution);
230
+ actual_word_count = word_count(input_text, actual_solution);
231
231
 
232
- test_solution(ExpectedSolution,
233
- expected_word_count, ActualSolution, actual_word_count);
232
+ test_solution(expected_solution,
233
+ expected_word_count, actual_solution, actual_word_count);
234
234
  }
235
235
 
236
236
  void test_word_count_normalize_case(void)
@@ -240,22 +240,22 @@ void test_word_count_normalize_case(void)
240
240
  int actual_word_count;
241
241
  char *input_text = "go Go GO Stop stop";
242
242
  const int expected_word_count = 2;
243
- WordCount_Word_t ExpectedSolution[expected_word_count];
243
+ word_count_word_t expected_solution[expected_word_count];
244
244
 
245
245
  // build the expected solution
246
- memset(ExpectedSolution, 0, sizeof(ExpectedSolution)); // clear to start with a known value
246
+ memset(expected_solution, 0, sizeof(expected_solution)); // clear to start with a known value
247
247
 
248
- ExpectedSolution[index].count = 3;
249
- strncpy(ExpectedSolution[index++].text, "go", MAX_WORD_LENGTH);
248
+ expected_solution[index].count = 3;
249
+ strncpy(expected_solution[index++].text, "go", MAX_WORD_LENGTH);
250
250
 
251
- ExpectedSolution[index].count = 2;
252
- strncpy(ExpectedSolution[index++].text, "stop", MAX_WORD_LENGTH);
251
+ expected_solution[index].count = 2;
252
+ strncpy(expected_solution[index++].text, "stop", MAX_WORD_LENGTH);
253
253
 
254
254
  reset_actual_solution();
255
- actual_word_count = word_count(input_text, ActualSolution);
255
+ actual_word_count = word_count(input_text, actual_solution);
256
256
 
257
- test_solution(ExpectedSolution,
258
- expected_word_count, ActualSolution, actual_word_count);
257
+ test_solution(expected_solution,
258
+ expected_word_count, actual_solution, actual_word_count);
259
259
  }
260
260
 
261
261
  void test_word_count_with_apostrophes(void)
@@ -265,31 +265,31 @@ void test_word_count_with_apostrophes(void)
265
265
  int actual_word_count;
266
266
  char *input_text = "First: don't laugh. Then: don't cry.";
267
267
  const int expected_word_count = 5;
268
- WordCount_Word_t ExpectedSolution[expected_word_count];
268
+ word_count_word_t expected_solution[expected_word_count];
269
269
 
270
270
  // build the expected solution
271
- memset(ExpectedSolution, 0, sizeof(ExpectedSolution)); // clear to start with a known value
271
+ memset(expected_solution, 0, sizeof(expected_solution)); // clear to start with a known value
272
272
 
273
- ExpectedSolution[index].count = 1;
274
- strncpy(ExpectedSolution[index++].text, "first", MAX_WORD_LENGTH);
273
+ expected_solution[index].count = 1;
274
+ strncpy(expected_solution[index++].text, "first", MAX_WORD_LENGTH);
275
275
 
276
- ExpectedSolution[index].count = 2;
277
- strncpy(ExpectedSolution[index++].text, "don't", MAX_WORD_LENGTH);
276
+ expected_solution[index].count = 2;
277
+ strncpy(expected_solution[index++].text, "don't", MAX_WORD_LENGTH);
278
278
 
279
- ExpectedSolution[index].count = 1;
280
- strncpy(ExpectedSolution[index++].text, "laugh", MAX_WORD_LENGTH);
279
+ expected_solution[index].count = 1;
280
+ strncpy(expected_solution[index++].text, "laugh", MAX_WORD_LENGTH);
281
281
 
282
- ExpectedSolution[index].count = 1;
283
- strncpy(ExpectedSolution[index++].text, "then", MAX_WORD_LENGTH);
282
+ expected_solution[index].count = 1;
283
+ strncpy(expected_solution[index++].text, "then", MAX_WORD_LENGTH);
284
284
 
285
- ExpectedSolution[index].count = 1;
286
- strncpy(ExpectedSolution[index++].text, "cry", MAX_WORD_LENGTH);
285
+ expected_solution[index].count = 1;
286
+ strncpy(expected_solution[index++].text, "cry", MAX_WORD_LENGTH);
287
287
 
288
288
  reset_actual_solution();
289
- actual_word_count = word_count(input_text, ActualSolution);
289
+ actual_word_count = word_count(input_text, actual_solution);
290
290
 
291
- test_solution(ExpectedSolution,
292
- expected_word_count, ActualSolution, actual_word_count);
291
+ test_solution(expected_solution,
292
+ expected_word_count, actual_solution, actual_word_count);
293
293
  }
294
294
 
295
295
  void test_word_count_with_quotation(void)
@@ -299,34 +299,34 @@ void test_word_count_with_quotation(void)
299
299
  int actual_word_count;
300
300
  char *input_text = "Joe can't tell between 'large' and large.";
301
301
  const int expected_word_count = 6;
302
- WordCount_Word_t ExpectedSolution[expected_word_count];
302
+ word_count_word_t expected_solution[expected_word_count];
303
303
 
304
304
  // build the expected solution
305
- memset(ExpectedSolution, 0, sizeof(ExpectedSolution)); // clear to start with a known value
305
+ memset(expected_solution, 0, sizeof(expected_solution)); // clear to start with a known value
306
306
 
307
- ExpectedSolution[index].count = 1;
308
- strncpy(ExpectedSolution[index++].text, "joe", MAX_WORD_LENGTH);
307
+ expected_solution[index].count = 1;
308
+ strncpy(expected_solution[index++].text, "joe", MAX_WORD_LENGTH);
309
309
 
310
- ExpectedSolution[index].count = 1;
311
- strncpy(ExpectedSolution[index++].text, "can't", MAX_WORD_LENGTH);
310
+ expected_solution[index].count = 1;
311
+ strncpy(expected_solution[index++].text, "can't", MAX_WORD_LENGTH);
312
312
 
313
- ExpectedSolution[index].count = 1;
314
- strncpy(ExpectedSolution[index++].text, "tell", MAX_WORD_LENGTH);
313
+ expected_solution[index].count = 1;
314
+ strncpy(expected_solution[index++].text, "tell", MAX_WORD_LENGTH);
315
315
 
316
- ExpectedSolution[index].count = 1;
317
- strncpy(ExpectedSolution[index++].text, "between", MAX_WORD_LENGTH);
316
+ expected_solution[index].count = 1;
317
+ strncpy(expected_solution[index++].text, "between", MAX_WORD_LENGTH);
318
318
 
319
- ExpectedSolution[index].count = 2;
320
- strncpy(ExpectedSolution[index++].text, "large", MAX_WORD_LENGTH);
319
+ expected_solution[index].count = 2;
320
+ strncpy(expected_solution[index++].text, "large", MAX_WORD_LENGTH);
321
321
 
322
- ExpectedSolution[index].count = 1;
323
- strncpy(ExpectedSolution[index++].text, "and", MAX_WORD_LENGTH);
322
+ expected_solution[index].count = 1;
323
+ strncpy(expected_solution[index++].text, "and", MAX_WORD_LENGTH);
324
324
 
325
325
  reset_actual_solution();
326
- actual_word_count = word_count(input_text, ActualSolution);
326
+ actual_word_count = word_count(input_text, actual_solution);
327
327
 
328
- test_solution(ExpectedSolution,
329
- expected_word_count, ActualSolution, actual_word_count);
328
+ test_solution(expected_solution,
329
+ expected_word_count, actual_solution, actual_word_count);
330
330
  }
331
331
 
332
332
  void test_word_count_from_example(void)
@@ -336,28 +336,28 @@ void test_word_count_from_example(void)
336
336
  int actual_word_count;
337
337
  char *input_text = "olly olly in come free";
338
338
  const int expected_word_count = 4;
339
- WordCount_Word_t ExpectedSolution[expected_word_count];
339
+ word_count_word_t expected_solution[expected_word_count];
340
340
 
341
341
  // build the expected solution
342
- memset(ExpectedSolution, 0, sizeof(ExpectedSolution)); // clear to start with a known value
342
+ memset(expected_solution, 0, sizeof(expected_solution)); // clear to start with a known value
343
343
 
344
- ExpectedSolution[index].count = 2;
345
- strncpy(ExpectedSolution[index++].text, "olly", MAX_WORD_LENGTH);
344
+ expected_solution[index].count = 2;
345
+ strncpy(expected_solution[index++].text, "olly", MAX_WORD_LENGTH);
346
346
 
347
- ExpectedSolution[index].count = 1;
348
- strncpy(ExpectedSolution[index++].text, "in", MAX_WORD_LENGTH);
347
+ expected_solution[index].count = 1;
348
+ strncpy(expected_solution[index++].text, "in", MAX_WORD_LENGTH);
349
349
 
350
- ExpectedSolution[index].count = 1;
351
- strncpy(ExpectedSolution[index++].text, "come", MAX_WORD_LENGTH);
350
+ expected_solution[index].count = 1;
351
+ strncpy(expected_solution[index++].text, "come", MAX_WORD_LENGTH);
352
352
 
353
- ExpectedSolution[index].count = 1;
354
- strncpy(ExpectedSolution[index++].text, "free", MAX_WORD_LENGTH);
353
+ expected_solution[index].count = 1;
354
+ strncpy(expected_solution[index++].text, "free", MAX_WORD_LENGTH);
355
355
 
356
356
  reset_actual_solution();
357
- actual_word_count = word_count(input_text, ActualSolution);
357
+ actual_word_count = word_count(input_text, actual_solution);
358
358
 
359
- test_solution(ExpectedSolution,
360
- expected_word_count, ActualSolution, actual_word_count);
359
+ test_solution(expected_solution,
360
+ expected_word_count, actual_solution, actual_word_count);
361
361
  }
362
362
 
363
363
  int main(void)