mirror of
https://github.com/public-apis/public-apis.git
synced 2025-07-04 10:17:46 +02:00
Add padding check for each line value
This commit is contained in:
parent
e2b71b22c4
commit
fbd07b8f4b
1 changed files with 31 additions and 5 deletions
|
@ -18,35 +18,61 @@ File.foreach(filename).with_index do | line, line_num |
|
||||||
if line.eql? "|---|---|---|---|---|\n"
|
if line.eql? "|---|---|---|---|---|\n"
|
||||||
next
|
next
|
||||||
end
|
end
|
||||||
|
|
||||||
values = line.split("|")
|
values = line.split("|")
|
||||||
|
|
||||||
|
values.each.with_index do |val, val_index|
|
||||||
|
msg = ""
|
||||||
|
case val_index
|
||||||
|
when 1..5
|
||||||
|
if val[0] != " " || val[val.length-1] != " "
|
||||||
|
case val_index
|
||||||
|
when 1
|
||||||
|
msg = "spacing on Title is invalid"
|
||||||
|
when 2
|
||||||
|
msg = "spacing on Description is invalid"
|
||||||
|
when 3
|
||||||
|
msg = "spacing on Auth is invalid"
|
||||||
|
when 4
|
||||||
|
msg = "spacing on HTTPS is invalid"
|
||||||
|
when 5
|
||||||
|
msg = "spacing on Link is invalid"
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
if msg != ""
|
||||||
|
add_error(line_num, "#{msg} (pad before and after string)")
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
################# DESCRIPTION ################
|
################# DESCRIPTION ################
|
||||||
# First character should be capitalized
|
# First character should be capitalized
|
||||||
desc_val = values[2].lstrip.chop
|
desc_val = values[2].lstrip.chop
|
||||||
if !/[[:upper:]]/.match(desc_val[0])
|
if !/[[:upper:]]/.match(desc_val[0])
|
||||||
add_error(line_num, "Invalid Description (first char not uppercase): #{desc_val}")
|
add_error(line_num, "invalid Description (first char not uppercase): #{desc_val}")
|
||||||
end
|
end
|
||||||
# value should not be punctuated
|
# value should not be punctuated
|
||||||
last_char = desc_val[desc_val.length-1]
|
last_char = desc_val[desc_val.length-1]
|
||||||
if punctuation.include?(last_char)
|
if punctuation.include?(last_char)
|
||||||
add_error(line_num, "Invalid Description (description should not end with \"#{last_char}\")")
|
add_error(line_num, "invalid Description (description should not end with \"#{last_char}\")")
|
||||||
end
|
end
|
||||||
#################### AUTH ####################
|
#################### AUTH ####################
|
||||||
# Values should conform to valid options only
|
# Values should conform to valid options only
|
||||||
auth_val = values[3].lstrip.chop.tr('``', '')
|
auth_val = values[3].lstrip.chop.tr('``', '')
|
||||||
if !auth_keys.include?(auth_val)
|
if !auth_keys.include?(auth_val)
|
||||||
add_error(line_num, "Invalid Auth (not a valid option): #{auth_val}")
|
add_error(line_num, "invalid Auth (not a valid option): #{auth_val}")
|
||||||
end
|
end
|
||||||
#################### HTTPS ###################
|
#################### HTTPS ###################
|
||||||
# Values should be either "Yes" or "No"
|
# Values should be either "Yes" or "No"
|
||||||
https_val = values[4].lstrip.chop
|
https_val = values[4].lstrip.chop
|
||||||
if !https_keys.include?(https_val)
|
if !https_keys.include?(https_val)
|
||||||
add_error(line_num, "(#{line_num}) Invalid HTTPS: (must use \"Yes\" or \"No\"): #{https_val}")
|
add_error(line_num, "invalid HTTPS (must use \"Yes\" or \"No\"): #{https_val}")
|
||||||
end
|
end
|
||||||
#################### LINK ####################
|
#################### LINK ####################
|
||||||
# Url should be wrapped in "[Go!]" view
|
# Url should be wrapped in "[Go!]" view
|
||||||
link_val = values[5].lstrip.chop
|
link_val = values[5].lstrip.chop
|
||||||
if !link_val.start_with?("[Go!](") || !link_val.end_with?(')')
|
if !link_val.start_with?("[Go!](") || !link_val.end_with?(')')
|
||||||
add_error(line_num, "(#{line_num}) Invalid Link: (format should be \"[Go!](<LINK>)\"): #{link_val}")
|
add_error(line_num, "invalid Link (format should be \"[Go!](<LINK>)\"): #{link_val}")
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue