codebreaker_marian 0.2.4 → 0.2.9

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 1f92281dc09601f55b249c61a7b58813d76e6653a3e96ffc386cc1ebbc4da673
4
- data.tar.gz: c2a46e70ee048d444865d30b4be1fd647e13339ab0d29c5505b97f1243199528
3
+ metadata.gz: 24f6f4f6899ba30ab201959eb8016061f9b4fec60422dcf44b503dd75da506b4
4
+ data.tar.gz: 7225e5af0a6431864b1b7b6336d845ed1f70ecd0fe6fa3c1384cf505693028b9
5
5
  SHA512:
6
- metadata.gz: 88f961c9361d2881892c38041b24d3e11465cbd2b6bca92da879d20d5007a58a978b7fb59738c266871c3255c533bf6959b24849f894a39c5ab1a07011ea0650
7
- data.tar.gz: 07bceb9d7bb90bbd66b265616be8f642c3ee6e370ecfa8028fff4c5663b89031ecc05a14749503d69d6ef49e4ebb74ff6189e3ac6239387654bf994940b3921b
6
+ metadata.gz: e621e292579024fec28db4f0a668f63ac7a3d178b74777124f19872309f2d5b2a6c601b7229daf1135527170ef72a5cf524c01895e6733ce392ffbc720a0f889
7
+ data.tar.gz: 41c910e902e1b4c5203d895360576c922a521e9fbdd3cb9a0a8d57575b2a35d275a08e1c016efd472a8837bb97a527d131796f98ef6c202f23de6e3c8a68aaf0
@@ -1,7 +1,7 @@
1
1
  PATH
2
2
  remote: .
3
3
  specs:
4
- codebreaker_marian (0.2.4)
4
+ codebreaker_marian (0.2.9)
5
5
 
6
6
  GEM
7
7
  remote: https://rubygems.org/
@@ -5,13 +5,14 @@ module Codebreaker
5
5
  class Processor
6
6
  MATCHED_DIGIT_CHAR = '+'
7
7
  UNMATCHED_DIGIT_CHAR = '-'
8
+ WRONG_DIGIT_CHAR = ''
8
9
 
9
10
  attr_reader :guess, :code, :result
10
11
 
11
12
  def secret_code_proc(code, guess)
12
13
  @code = code.split('')
13
14
  @guess = guess.split('')
14
- handle_matched_digits.join + handle_matched_digits_with_wrong_position.join
15
+ handle_matched_digits.join + handle_matched_digits_with_wrong_position.join + handle_wrong_digits.join
15
16
  end
16
17
 
17
18
  private
@@ -33,6 +34,14 @@ module Codebreaker
33
34
  UNMATCHED_DIGIT_CHAR
34
35
  end
35
36
  end
37
+
38
+ def handle_wrong_digits
39
+ guess.compact.map do |number|
40
+ next unless @code.include?(number)
41
+
42
+ WRONG_DIGIT_CHAR
43
+ end
44
+ end
36
45
  end
37
46
  end
38
47
  end
@@ -5,7 +5,7 @@ module Codebreaker
5
5
  class Statistics
6
6
  def stats(list)
7
7
  difficulties = list.group_by { |score| score[:difficulty] }
8
- %i[hell medium easy].reduce([]) do |sorted_difficulties, difficulty_name|
8
+ Game::DIFFICULTIES.keys.reverse.reduce([]) do |sorted_difficulties, difficulty_name|
9
9
  if difficulties[difficulty_name]
10
10
  sorted_difficulties + stats_sort(difficulties[difficulty_name])
11
11
  else
@@ -17,7 +17,7 @@ module Codebreaker
17
17
  private
18
18
 
19
19
  def stats_sort(scores)
20
- scores.sort_by! { |score| [score[:attempts_used], score[:hints_used]] }.reverse
20
+ scores.sort_by! { |score| [score[:attempts_used], score[:hints_used]] }
21
21
  end
22
22
  end
23
23
  end
@@ -2,14 +2,12 @@
2
2
 
3
3
  module Codebreaker
4
4
  module Validator
5
- DataValidError = Class.new(StandardError)
6
-
7
5
  def check_type(data, check_type)
8
- raise DataValidError, 'unexpected_type' unless data.instance_of? check_type
6
+ raise TypeError, 'unexpected_type' unless data.instance_of? check_type
9
7
  end
10
8
 
11
9
  def check_length(data, check)
12
- raise DataValidError, 'unexpected_length' unless (check[:min]..check[:max]).cover? data.length
10
+ raise ArgumentError, 'unexpected_length' unless (check[:min]..check[:max]).cover? data.length
13
11
  end
14
12
  end
15
13
  end
@@ -1,5 +1,5 @@
1
1
  # frozen_string_literal: true
2
2
 
3
3
  module Codebreaker
4
- VERSION = '0.2.4'
4
+ VERSION = '0.2.9'
5
5
  end
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: codebreaker_marian
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.2.4
4
+ version: 0.2.9
5
5
  platform: ruby
6
6
  authors:
7
7
  - Marian Rebeha