2021-02-06 15:29:26 -05:00
|
|
|
import pathlib
|
|
|
|
|
|
|
|
here = pathlib.Path(__file__).parent
|
2021-02-19 17:50:57 -05:00
|
|
|
file_readme = here / '../../test.md'
|
2021-02-06 14:48:34 -05:00
|
|
|
with open(file_readme, 'r') as read_readme:
|
2021-02-24 12:19:43 -05:00
|
|
|
content = read_readme.readlines()
|
2021-02-06 14:48:34 -05:00
|
|
|
|
2021-02-11 18:24:13 -05:00
|
|
|
|
2021-02-24 12:19:43 -05:00
|
|
|
class FeaturedPlaylists():
|
2021-02-19 17:50:57 -05:00
|
|
|
"""
|
2021-02-24 12:19:43 -05:00
|
|
|
Contains methods for the detection of various
|
|
|
|
rules asigned to the "Featured playlists:" sections.
|
|
|
|
These methods edit the readme.md file (the awe-
|
|
|
|
some list) in-place if any of the rules isn't
|
|
|
|
met.
|
2021-02-11 18:24:13 -05:00
|
|
|
|
2021-02-24 12:19:43 -05:00
|
|
|
Attributes:
|
|
|
|
checker (str): matches the "Featured playlists:" string.
|
|
|
|
length (int): minimum length of the line to break line.
|
|
|
|
result (str): result of the operation.
|
2021-02-19 17:50:57 -05:00
|
|
|
"""
|
2021-02-06 14:48:34 -05:00
|
|
|
|
2021-02-24 12:19:43 -05:00
|
|
|
checker = "Featured playlists:"
|
2021-02-19 17:50:57 -05:00
|
|
|
length = 124
|
2021-02-11 18:24:13 -05:00
|
|
|
|
2021-02-24 12:19:43 -05:00
|
|
|
def __init__(self):
|
|
|
|
self.result = "🟢 0: perfect."
|
|
|
|
|
|
|
|
def trailing_slash(self):
|
|
|
|
"""
|
|
|
|
Looks for backslash and the end of all the matching
|
|
|
|
lines ("Featured playlists:" lines) and a line
|
|
|
|
break tag "<br>" at the next line.
|
|
|
|
"""
|
|
|
|
|
|
|
|
for line, value in enumerate(content):
|
|
|
|
if self.checker in value:
|
|
|
|
last = value[-2]
|
|
|
|
if len(value) < self.length:
|
|
|
|
if last != "\\" and "<br>" not in content[line+1]:
|
|
|
|
if last == " ":
|
|
|
|
content[line] = f"{value[:-1]}\\\n<br>\n"
|
|
|
|
else:
|
|
|
|
content[line] = f"{value[:-1]} \\\n<br>\n"
|
|
|
|
|
|
|
|
with open(file_readme, 'w') as write_readme:
|
|
|
|
write_readme.writelines(content)
|
|
|
|
|
|
|
|
self.result = "🔴 -1: backslash | line break.\nFixed."
|
|
|
|
elif last != "\\" and "<br>" in content[line+1]:
|
|
|
|
if last == " ":
|
|
|
|
content[line] = f"{value[:-1]}\\\n"
|
|
|
|
else:
|
|
|
|
content[line] = f"{value[:-1]} \\\n"
|
|
|
|
|
|
|
|
with open(file_readme, 'w') as write_readme:
|
|
|
|
write_readme.writelines(content)
|
|
|
|
|
|
|
|
self.result = "🔴 -1: backslash.\nFixed."
|
|
|
|
elif last == "\\" and "<br>" not in content[line+1]:
|
|
|
|
content[line+1] = "<br>\n\n"
|
|
|
|
|
|
|
|
with open(file_readme, 'w') as write_readme:
|
|
|
|
write_readme.writelines(content)
|
|
|
|
|
|
|
|
self.result = "🔴 -1: line break.\nFixed."
|
|
|
|
|
|
|
|
return self.result
|
|
|
|
|
|
|
|
def closed_backsticks(self):
|
|
|
|
"""
|
|
|
|
Looks that all backsticks of every word are co-
|
|
|
|
rrectly opened and subsequent closed.
|
|
|
|
"""
|
|
|
|
|
|
|
|
return self.result
|
|
|
|
|
|
|
|
|
|
|
|
featured_playlists = FeaturedPlaylists()
|
|
|
|
print(featured_playlists.trailing_slash())
|