import os
import xml.etree.ElementTree as ET
import re
table_columns = 6
img_domain = "https://edent.github.io/SuperTinyIcons/"
svg_dir = "images/svg/"
ref_dir = "images/reference/"
svg_list = sorted(os.listdir( svg_dir ))
ref_list = sorted(os.listdir( ref_dir ))
svg_data = {}
total_bytes = 0
# Loop through all the SVGs
for svg_file in svg_list:
# Ignore anything which isn't an .svg
if not svg_file.endswith('.svg'):
continue
# Replace Windows line endings (CRLF) with Unix (LF)
with open( svg_dir + svg_file, 'rb' ) as open_file:
content = open_file.read()
content = content.replace( b'\r\n', b'\n')
# Remove trailing newline
content = content.strip()
with open( svg_dir + svg_file, 'wb' ) as open_file:
open_file.write(content)
# Get the filename of the service. E.g. service.svg
svg = svg_file.split('.')[0]
svg_data[svg] = { 'svg_file' : svg_file }
# Get the name of the service from the ARIA label
svg_data[svg]['name'] = ET.parse(f'{svg_dir}{svg_file}').getroot().attrib["aria-label"]
# Get the file size
bytes = os.stat(f'{svg_dir}{svg_file}').st_size
svg_data[svg]['bytes'] = bytes
total_bytes += bytes
# Get all reference images
for ref_file in ref_list:
if ref_file.endswith('.url'):
continue
ref_name = ref_file.split('.')[0]
if ref_name in svg_data:
svg_data[ref_name]['ref_file'] = ref_file
# Get all the reference URls
for ref_url in ref_list:
if ref_url.endswith('.url'):
ref_name = ref_url.split('.')[0]
if ref_name in svg_data:
svg_data[ref_name]['source'] = open(ref_dir + ref_url, "r").readline().rstrip()
# Set up the tables
readme_table = "
\n"
check_table = 'Name | SVG Icon | Circle Icon | Reference | Source |
\n'
reference_table = "-|-|-|-\n"
missing_table = "No Reference Image Found
\n\n"
missing_table += "Name | Icon | Filename\n-|-|-\n"
counter = 0
# Loop through all the SVG data
for svg in svg_data:
svg_file = svg_data[svg]['svg_file']
name = svg_data[svg]['name']
bytes = svg_data[svg]['bytes']
# Add it to the check table
check_table += f'{name} |  |  | '
# If a reference image exists, add it to the reference table and check table
if 'ref_file' in svg_data[svg]:
ref_file = svg_data[svg]['ref_file']
reference_table += f'{name} |
|
| '
check_table += f' | '
if 'source' in svg_data[svg]:
source = svg_data[svg]['source']
reference_table += source
check_table += f'{source} | '
reference_table += '\n'
else:
# No reference image. Add it to the missing table
missing_table += f'{name} |
| {svg}.svg \n'
check_table += '
\n'
if counter == 0 :
readme_table += "\n"
readme_table += f'{name} '
readme_table += f' '
readme_table += f'{bytes} bytes | \n'
counter +=1
if counter == table_columns:
readme_table += "
\n\n"
counter = 0
if counter != 0 :
readme_table += "\n\n"
readme_table += "
"
check_table += "
"
# Calculate the number of icons and average size
readme_summary_text = f"There are currently {len(svg_list)} icons and the average size is _under_ {round(total_bytes / len(svg_list))} bytes!"
# Replace the table in README with the new one
with open('README.md','r+', encoding="utf-8") as f:
file = f.read()
file = re.sub(r"(?s)", readme_table, file)
file = re.sub("There are currently \d* icons and the average size is _under_ \d* bytes\!", readme_summary_text, file)
f.seek(0)
f.write(file)
f.truncate()
print(f"README.md updated with {len(svg_list)} icons.")
# Replace the tables in the REFERENCE document
with open('REFERENCE.md','r+', encoding="utf-8") as f:
file = f.read()
file = re.sub(r"(?s)-\|-\|-.*", reference_table, file)
file += missing_table
f.seek(0)
f.write(file)
f.truncate()
print(f"REFERENCE.md updated.")
# Replace the table in the CHECK document
with open('CHECK.html','r+', encoding="utf-8") as f:
file = f.read()
file = re.sub(r"(?s)", check_table, file)
f.seek(0)
f.write(file)
f.truncate()
print(f"CHECK.html updated.")