diff --git a/.rubocop.yml b/.rubocop.yml index a6227e1..013d2d4 100644 --- a/.rubocop.yml +++ b/.rubocop.yml @@ -45,6 +45,11 @@ Metrics/MethodLength: Enabled: true CountAsOne: ['array', 'hash'] +Metrics/ModuleLength: + Enabled: true + Exclude: + - 'lib/itax_code/utils.rb' + Style/Documentation: Enabled: false diff --git a/lib/itax_code/encoder.rb b/lib/itax_code/encoder.rb index eaebfc4..18d1031 100644 --- a/lib/itax_code/encoder.rb +++ b/lib/itax_code/encoder.rb @@ -22,7 +22,7 @@ class Encoder # @option data [String] :gender The user gender # @option data [String, Date] :birthdate The user birthdate # @option data [String] :birthplace The user birthplace - def initialize(data = {}, utils = Utils.new) + def initialize(data = {}, utils = Utils) @utils = utils @surname = data[:surname] diff --git a/lib/itax_code/omocode.rb b/lib/itax_code/omocode.rb index a398d01..b6b952f 100644 --- a/lib/itax_code/omocode.rb +++ b/lib/itax_code/omocode.rb @@ -8,7 +8,7 @@ class Omocode # # @param [String] tax_code # @param [Utils] utils - def initialize(tax_code, utils = Utils.new) + def initialize(tax_code, utils = Utils) @tax_code = tax_code @utils = utils end diff --git a/lib/itax_code/parser.rb b/lib/itax_code/parser.rb index cb47759..dbb6796 100644 --- a/lib/itax_code/parser.rb +++ b/lib/itax_code/parser.rb @@ -15,7 +15,7 @@ class Parser # @param [String] tax_code # @param [Utils] utils - def initialize(tax_code, utils = Utils.new) + def initialize(tax_code, utils = Utils) @tax_code = tax_code&.upcase @utils = utils diff --git a/lib/itax_code/utils.rb b/lib/itax_code/utils.rb index 0a0f7ec..def0db1 100644 --- a/lib/itax_code/utils.rb +++ b/lib/itax_code/utils.rb @@ -4,148 +4,152 @@ require "itax_code/transliterator" module ItaxCode - class Utils - def blank?(obj) - obj.respond_to?(:empty?) ? !!obj.empty? : !obj - end - - def present?(obj) - !blank?(obj) - end - - def slugged(string) - transliterated = transliterate(string.downcase.strip) - transliterated.gsub(/[^\w-]+/, "-").gsub(/-{2,}/, "-").gsub(/^-+|-+$/, "") - end - - def transliterate(string) - return string if string.ascii_only? - - transliterator = Transliterator.new - transliterator.transliterate(string.unicode_normalize(:nfc)) - end - - def tax_code_sections_regex - /^([A-Z]{3})([A-Z]{3}) - (([A-Z\d]{2})([ABCDEHLMPRST]{1})([A-Z\d]{2})) - ([A-Z]{1}[A-Z\d]{3}) - ([A-Z]{1})$/x - end - - def months - %w[A B C D E H L M P R S T] - end + module Utils + class << self + def blank?(obj) + obj.respond_to?(:empty?) ? !!obj.empty? : !obj + end - def consonants - %w[b c d f g h j k l m n p q r s t v w x y z] - end + def present?(obj) + !blank?(obj) + end - def vowels - %w[a e i o u] - end + def slugged(string) + transliterated = transliterate(string.downcase.strip) + transliterated.gsub(/[^\w-]+/, "-").gsub(/-{2,}/, "-").gsub(/^-+|-+$/, "") + end - def cin - { - "0" => [0, 1], - "1" => [1, 0], - "2" => [2, 5], - "3" => [3, 7], - "4" => [4, 9], - "5" => [5, 13], - "6" => [6, 15], - "7" => [7, 17], - "8" => [8, 19], - "9" => [9, 21], - "A" => [0, 1], - "B" => [1, 0], - "C" => [2, 5], - "D" => [3, 7], - "E" => [4, 9], - "F" => [5, 13], - "G" => [6, 15], - "H" => [7, 17], - "I" => [8, 19], - "J" => [9, 21], - "K" => [10, 2], - "L" => [11, 4], - "M" => [12, 18], - "N" => [13, 20], - "O" => [14, 11], - "P" => [15, 3], - "Q" => [16, 6], - "R" => [17, 8], - "S" => [18, 12], - "T" => [19, 14], - "U" => [20, 16], - "V" => [21, 10], - "W" => [22, 22], - "X" => [23, 25], - "Y" => [24, 24], - "Z" => [25, 23] - } - end + def transliterate(string) + return string if string.ascii_only? - def cin_remainders - ("A".."Z").to_a - end + transliterator = Transliterator.new + transliterator.transliterate(string.unicode_normalize(:nfc)) + end - def omocodia - { - "0": "L", "1": "M", "2": "N", "3": "P", "4": "Q", - "5": "R", "6": "S", "7": "T", "8": "U", "9": "V" - } - end + def tax_code_sections_regex + /^([A-Z]{3})([A-Z]{3}) + (([A-Z\d]{2})([ABCDEHLMPRST]{1})([A-Z\d]{2})) + ([A-Z]{1}[A-Z\d]{3}) + ([A-Z]{1})$/x + end - def omocodia_digits - omocodia.keys.join - end + def months + %w[A B C D E H L M P R S T] + end - def omocodia_letters - omocodia.values.join - end + def omocodia_indexes + [6, 7, 9, 10, 12, 13, 14].reverse + end - def omocodia_indexes - [6, 7, 9, 10, 12, 13, 14].reverse - end + def omocodia_indexes_combos + (1..omocodia_indexes.size).flat_map do |index| + omocodia_indexes.combination(index).to_a + end + end - def omocodia_indexes_combos - (1..omocodia_indexes.size).flat_map do |index| - omocodia_indexes.combination(index).to_a + def omocodia_encode(val) + val.tr omocodia_digits, omocodia_letters end - end - def omocodia_encode(val) - val.tr omocodia_digits, omocodia_letters - end + def omocodia_decode(val) + val.tr omocodia_letters, omocodia_digits + end - def omocodia_decode(val) - val.tr omocodia_letters, omocodia_digits - end + def extract_consonants(str) + str.select { |c| consonants.include? c }.join + end - def extract_consonants(str) - str.select { |c| consonants.include? c }.join - end + def extract_vowels(str) + str.select { |c| vowels.include? c }.join + end - def extract_vowels(str) - str.select { |c| vowels.include? c }.join - end + def encode_cin(code) + cin_tot = 0 - def encode_cin(code) - cin_tot = 0 + code[0..14].each_char.with_index do |char, i| + cin_tot += cin[char][((i + 1) % 2).to_i] + end - code[0..14].each_char.with_index do |char, i| - cin_tot += cin[char][((i + 1) % 2).to_i] + cin_remainders[cin_tot % 26] end - cin_remainders[cin_tot % 26] - end + def cities + CSV.foreach("#{__dir__}/data/cities.csv", headers: true) + end - def cities - CSV.foreach("#{__dir__}/data/cities.csv", headers: true) - end + def countries + CSV.foreach("#{__dir__}/data/countries.csv", headers: true) + end - def countries - CSV.foreach("#{__dir__}/data/countries.csv", headers: true) + private + + def omocodia_letters + omocodia.values.join + end + + def omocodia_digits + omocodia.keys.join + end + + def consonants + %w[b c d f g h j k l m n p q r s t v w x y z] + end + + def vowels + %w[a e i o u] + end + + def cin + { + "0" => [0, 1], + "1" => [1, 0], + "2" => [2, 5], + "3" => [3, 7], + "4" => [4, 9], + "5" => [5, 13], + "6" => [6, 15], + "7" => [7, 17], + "8" => [8, 19], + "9" => [9, 21], + "A" => [0, 1], + "B" => [1, 0], + "C" => [2, 5], + "D" => [3, 7], + "E" => [4, 9], + "F" => [5, 13], + "G" => [6, 15], + "H" => [7, 17], + "I" => [8, 19], + "J" => [9, 21], + "K" => [10, 2], + "L" => [11, 4], + "M" => [12, 18], + "N" => [13, 20], + "O" => [14, 11], + "P" => [15, 3], + "Q" => [16, 6], + "R" => [17, 8], + "S" => [18, 12], + "T" => [19, 14], + "U" => [20, 16], + "V" => [21, 10], + "W" => [22, 22], + "X" => [23, 25], + "Y" => [24, 24], + "Z" => [25, 23] + } + end + + def cin_remainders + ("A".."Z").to_a + end + + def omocodia + { + "0": "L", "1": "M", "2": "N", "3": "P", "4": "Q", + "5": "R", "6": "S", "7": "T", "8": "U", "9": "V" + } + end end end end diff --git a/test/itax_code/utils_test.rb b/test/itax_code/utils_test.rb index e89fd90..105b918 100644 --- a/test/itax_code/utils_test.rb +++ b/test/itax_code/utils_test.rb @@ -7,25 +7,25 @@ class UtilsTest < Minitest::Test test "#blank?(obj) is truthy when the argument is empty" do empty_object = [] - assert klass.new.blank?(empty_object) + assert klass.blank?(empty_object) end test "#blank?(obj) is falsy when the argument isn't empty" do non_empty_object = [1, 2, 3] - refute klass.new.blank?(non_empty_object) + refute klass.blank?(non_empty_object) end test "#blank?(obj) is truthy when the argument is nil and don't respont to empty?" do nil_object = nil - assert klass.new.blank?(nil_object) + assert klass.blank?(nil_object) end test "#blank?(obj) is falsy when the argument is not nil and don't respont to empty?" do some_object = 1 - refute klass.new.blank?(some_object) + refute klass.blank?(some_object) end test "#slugged(string)" do @@ -36,7 +36,7 @@ class UtilsTest < Minitest::Test } diacritic_names.each do |input, output| - assert_equal output, klass.new.slugged(input) + assert_equal output, klass.slugged(input) end end