Skip to content

Commit

Permalink
build: converted Utils class in module
Browse files Browse the repository at this point in the history
  • Loading branch information
Rocco Emanuele Bonanno committed Apr 22, 2024
1 parent ead6fc7 commit c34889e
Show file tree
Hide file tree
Showing 6 changed files with 133 additions and 129 deletions.
2 changes: 1 addition & 1 deletion lib/itax_code/encoder.rb
Original file line number Diff line number Diff line change
Expand Up @@ -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 = ItaxCode::Utils)
@utils = utils

@surname = data[:surname]
Expand Down
2 changes: 1 addition & 1 deletion lib/itax_code/omocode.rb
Original file line number Diff line number Diff line change
Expand Up @@ -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 = ItaxCode::Utils)
@tax_code = tax_code
@utils = utils
end
Expand Down
2 changes: 1 addition & 1 deletion lib/itax_code/parser.rb
Original file line number Diff line number Diff line change
Expand Up @@ -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 = ItaxCode::Utils)
@tax_code = tax_code&.upcase
@utils = utils

Expand Down
244 changes: 124 additions & 120 deletions lib/itax_code/utils.rb
Original file line number Diff line number Diff line change
Expand Up @@ -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
module Utils
class << self
def blank?(obj)
obj.respond_to?(:empty?) ? !!obj.empty? : !obj
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 present?(obj)
!blank?(obj)
end

def months
%w[A B C D E H L M P R S T]
end
def slugged(string)
transliterated = transliterate(string.downcase.strip)
transliterated.gsub(/[^\w-]+/, "-").gsub(/-{2,}/, "-").gsub(/^-+|-+$/, "")
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 transliterate(string)
return string if string.ascii_only?

def vowels
%w[a e i o u]
end
transliterator = Transliterator.new
transliterator.transliterate(string.unicode_normalize(:nfc))
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 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 cin_remainders
("A".."Z").to_a
end
def omocodia_digits
omocodia.keys.join
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 omocodia_letters
omocodia.values.join
end

def omocodia_digits
omocodia.keys.join
end
def omocodia_indexes
[6, 7, 9, 10, 12, 13, 14].reverse
end

def omocodia_letters
omocodia.values.join
end
def omocodia_indexes_combos
(1..omocodia_indexes.size).flat_map do |index|
omocodia_indexes.combination(index).to_a
end
end

def omocodia_indexes
[6, 7, 9, 10, 12, 13, 14].reverse
end
def omocodia_encode(val)
val.tr omocodia_digits, omocodia_letters
end

def omocodia_indexes_combos
(1..omocodia_indexes.size).flat_map do |index|
omocodia_indexes.combination(index).to_a
def omocodia_decode(val)
val.tr omocodia_letters, omocodia_digits
end
end

def omocodia_encode(val)
val.tr omocodia_digits, omocodia_letters
end
def extract_consonants(str)
str.select { |c| consonants.include? c }.join
end

def omocodia_decode(val)
val.tr omocodia_letters, omocodia_digits
end
def extract_vowels(str)
str.select { |c| vowels.include? c }.join
end

def extract_consonants(str)
str.select { |c| consonants.include? c }.join
end
def encode_cin(code)
cin_tot = 0

def extract_vowels(str)
str.select { |c| vowels.include? c }.join
end
code[0..14].each_char.with_index do |char, i|
cin_tot += cin[char][((i + 1) % 2).to_i]
end

def encode_cin(code)
cin_tot = 0
cin_remainders[cin_tot % 26]
end

code[0..14].each_char.with_index do |char, i|
cin_tot += cin[char][((i + 1) % 2).to_i]
def cities
CSV.foreach("#{__dir__}/data/cities.csv", headers: true)
end

cin_remainders[cin_tot % 26]
end
def countries
CSV.foreach("#{__dir__}/data/countries.csv", headers: true)
end

def cities
CSV.foreach("#{__dir__}/data/cities.csv", headers: true)
end
def months
%w[A B C D E H L M P R S T]
end

def countries
CSV.foreach("#{__dir__}/data/countries.csv", headers: true)
private

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
2 changes: 1 addition & 1 deletion lib/itax_code/version.rb
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
# frozen_string_literal: true

module ItaxCode
VERSION = "2.0.3"
VERSION = "2.1.0"
end
10 changes: 5 additions & 5 deletions test/itax_code/utils_test.rb
Original file line number Diff line number Diff line change
Expand Up @@ -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
Expand All @@ -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

Expand Down

0 comments on commit c34889e

Please sign in to comment.