codebreaker_kirill 0.2.3 → 0.2.6

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: 1a7648030d99a0690736c0e8e3867ee5be050430404adb3623e7fb698481d064
4
- data.tar.gz: a3c3124aa61d1925ff1eb8804e56dfbc57e8df7eeab1d48d17bb142f14be1608
3
+ metadata.gz: 1e659a5ef3db41447187b05251fe6e27cf0116ac9f5507d8f1d7239b78402587
4
+ data.tar.gz: fe6f025a8ee47e1101e75fdb0d133df40dc97ca7b09abd9647490f0e0ab32a22
5
5
  SHA512:
6
- metadata.gz: 609aafeca71b39e52c3a9c2a18e6fdb397d70ff70cdb2a7f82e3fcf24252a2a69b3a6fffaa3f9fab2861bcac8602c81a7cc4d06c3b0edfae5ff619cb29143227
7
- data.tar.gz: 1f61d1bcac305ca6e3811ab8af01835d93feb255b31f2fe7fb0c40ffa0d077e065c9413bd81476ad7a387130e30eae238141736068a1ca68ba192caad7cd0b0a
6
+ metadata.gz: 6946a53d70b0d0dbca2cbbebc0ef2dd7f7c35652d267703a5fe101601aab13814f9f2111344a77cb119f016d9bcef1d32f2586b921b125d8bc2721c83e66167d
7
+ data.tar.gz: 21e2c49da1e73a3a13973c310f590a0db529de54628ffdec018c1d5009fc01943a57588de86d780a087649fadd2643383e95cb7bbfc2afdd9af7b350c4e79947
data/.rubocop.yml CHANGED
@@ -1,13 +1,8 @@
1
1
  AllCops:
2
2
  TargetRubyVersion: 2.6
3
3
 
4
- Style/StringLiterals:
5
- Enabled: true
6
- EnforcedStyle: double_quotes
7
-
8
- Style/StringLiteralsInInterpolation:
9
- Enabled: true
10
- EnforcedStyle: double_quotes
4
+ Style/Documentation:
5
+ Enabled: false
11
6
 
12
7
  Layout/LineLength:
13
8
  Max: 120
data/Gemfile CHANGED
@@ -1,10 +1,10 @@
1
1
  # frozen_string_literal: true
2
2
 
3
- source "https://rubygems.org"
3
+ source 'https://rubygems.org'
4
4
 
5
5
  # Specify your gem's dependencies in codebreaker_kirill.gemspec
6
6
  gemspec
7
7
 
8
- gem "rspec"
8
+ gem 'rspec'
9
9
 
10
- gem "rubocop", "~> 1.21"
10
+ gem 'rubocop', '~> 1.21'
data/Rakefile CHANGED
@@ -1,7 +1,7 @@
1
1
  # frozen_string_literal: true
2
2
 
3
- require "bundler/gem_tasks"
4
- require "rubocop/rake_task"
3
+ require 'bundler/gem_tasks'
4
+ require 'rubocop/rake_task'
5
5
 
6
6
  RuboCop::RakeTask.new
7
7
 
@@ -1,4 +1,4 @@
1
1
  # frozen_string_literal: true
2
2
 
3
- require_relative "game"
4
- require_relative "user"
3
+ require_relative 'game'
4
+ require_relative 'user'
@@ -1,7 +1,7 @@
1
1
  # frozen_string_literal: true
2
2
 
3
- require_relative "guess_handler"
4
- require_relative "user"
3
+ require_relative 'guess_handler'
4
+ require_relative 'user'
5
5
 
6
6
  class Game
7
7
  include GuessHandler
@@ -10,19 +10,17 @@ class Game
10
10
 
11
11
  def initialize(user, difficulty)
12
12
  @secret_code = (1..4).to_a.map { |_num| rand(1..6) }
13
- @hint_array = @secret_code.map(&:clone)
14
- @attempts = difficulty[:attempts]
15
- @hints = {
16
- hints_available: difficulty[:hints],
17
- hints_used: 0
18
- }
13
+ @hint_counter = 0
14
+ @attempts = { available: difficulty[:attempts], used: 0 }
15
+ @hints = { available: difficulty[:hints], used: 0 }
19
16
  @name = user.name
20
17
  end
21
18
 
22
19
  def give_a_hint
23
- return @hints[:hints_available].zero ? 0 : @hint_array[0]
24
- @hint_array.shift
25
- @hints[:hints_available] -= 1
26
- @hints[:hints_used]
20
+ return 0 if @hints[:available].zero?
21
+
22
+ @hints[:available] -= 1
23
+ @hints[:used] += 1
24
+ @secret_code[@hints[:used]]
27
25
  end
28
26
  end
@@ -1,20 +1,24 @@
1
1
  # frozen_string_literal: true
2
2
 
3
3
  module GuessHandler
4
- def respond_to_guess(user, input, code)
4
+ def respond_to_guess(game, input, code)
5
5
  result = []
6
- numbers = input.split("").map(&:to_i)
6
+ numbers = input.split('').map(&:to_i)
7
+ return 'win' if numbers == code
7
8
 
8
- return "win" if numbers == code
9
+ game.assess_guess(numbers, code, result)
10
+ game.attempts[:available] -= 1
11
+ game.attempts[:used] += 1
12
+ game.attempts[:available].zero ? 'loss' : result
13
+ end
9
14
 
15
+ def assess_guess(numbers, code, result)
10
16
  numbers.each_with_index do |element, index|
11
17
  if element == code[index]
12
- result << "+"
18
+ result << '+'
13
19
  elsif code.include?(element)
14
- result << "-"
20
+ result << '-'
15
21
  end
16
22
  end
17
-
18
- user.attempts.zero ? "loss" : result
19
23
  end
20
24
  end
@@ -2,6 +2,7 @@
2
2
 
3
3
  class User
4
4
  attr_reader :name
5
+
5
6
  def initialize(name)
6
7
  @name = name
7
8
  end
@@ -1,7 +1,7 @@
1
1
  # frozen_string_literal: true
2
2
 
3
- require_relative "game"
3
+ require_relative 'game'
4
4
 
5
5
  module CodebreakerKirill
6
- VERSION = "0.2.3"
6
+ VERSION = '0.2.6'
7
7
  end
@@ -1,8 +1,8 @@
1
1
  # frozen_string_literal: true
2
2
 
3
- require_relative "codebreaker_kirill/version"
4
- require_relative "codebreaker_kirill/game"
5
- require_relative "codebreaker_kirill/user"
3
+ require_relative 'codebreaker_kirill/version'
4
+ require_relative 'codebreaker_kirill/game'
5
+ require_relative 'codebreaker_kirill/user'
6
6
 
7
7
  module CodebreakerKirill
8
8
  class Error < StandardError; end
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: codebreaker_kirill
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.2.3
4
+ version: 0.2.6
5
5
  platform: ruby
6
6
  authors:
7
7
  - Kirill Dudchenko