codebreaker_kirill 0.2.1 → 0.2.4

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: 6f6dfe081039c6bf692df80673d2894a12cdc2de694a95a1c46b1dc5b71454ce
4
- data.tar.gz: 42ed6faefa107bdc809ce0922b46fb10d95b401049c89b69e4855bc123f1c452
3
+ metadata.gz: 46df65d5d48157981c0c2d654c7acdb25cdeb87ff2eca14fd0f4c8b4342cf258
4
+ data.tar.gz: ebb67a91fbc4d497fcc1d205e0b6b0653addc280368f543428219c9e0ea68890
5
5
  SHA512:
6
- metadata.gz: c406619ffbe000d55d4c7becad2c9903d9cec126e4a88027b12d6b55875a2314bdd56a5ebf15f77f0e582fed6ec80bc4f16f3f5ebcb1a658b5de71e34d33ce18
7
- data.tar.gz: 11acc9e1ef66227741c1bc18b8e39216ce13f0ef9b61f7e9a3e01f5b8acc600a7b8964ad9a1f4a999bf8e9c068b99bb58918a9048a0ac296011a9152e9d3a956
6
+ metadata.gz: 958fef4c1aadeda354a5ff3b0ded9759cbd8260542ea324054409bacaf5e0464566339c9556aa05326c0fbb374561fe472885cf6b2c4fad5482408877fa81287
7
+ data.tar.gz: 5aeeb3eec0a7dc988170aa291c5cf5d9b6c581143a6eaf96a1cb14865462dc1955d2d0418b713074c63cf164249c0612811a4d52d5347b6d8e229f4c97da9340
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,20 +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
- @num_of_hints = 2
15
- @user = user
16
- @difficulty = difficulty
13
+ @hint_counter = 0
14
+ @attempts = { available: difficulty[:attempts], used: 0 }
15
+ @hints = { available: difficulty[:hints], used: 0 }
16
+ @name = user.name
17
17
  end
18
18
 
19
19
  def give_a_hint
20
- if @num_of_hints.zero?
21
- puts "No more hints!"
22
- return
23
- end
20
+ return 0 if @hints[:available].zero?
24
21
 
25
- print @hint_array[0]
26
- @hint_array.shift
27
- @num_of_hints -= 1
22
+ @hints[:available] -= 1
23
+ @hints[:used] += 1
24
+ @secret_code[@hints[:used]]
28
25
  end
29
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)
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)
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
@@ -1,6 +1,8 @@
1
1
  # frozen_string_literal: true
2
2
 
3
3
  class User
4
+ attr_reader :name
5
+
4
6
  def initialize(name)
5
7
  @name = name
6
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.1"
6
+ VERSION = '0.2.4'
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.1
4
+ version: 0.2.4
5
5
  platform: ruby
6
6
  authors:
7
7
  - Kirill Dudchenko