2022-04-13 08:00:18 +00:00
""" This script automates the conversion of font files into a format QMK firmware understands.
"""
from io import BytesIO
from qmk . path import normpath
2024-03-10 00:29:09 +00:00
from qmk . painter_qff import _generate_font_glyphs_list , QFFFont
from qmk . painter import generate_subs , render_header , render_source , valid_formats
2022-04-13 08:00:18 +00:00
from milc import cli
@cli.argument ( ' -f ' , ' --font ' , required = True , help = ' Specify input font file. ' )
@cli.argument ( ' -o ' , ' --output ' , required = True , help = ' Specify output image path. ' )
@cli.argument ( ' -s ' , ' --size ' , default = 12 , help = ' Specify font size. Default 12. ' )
@cli.argument ( ' -n ' , ' --no-ascii ' , arg_only = True , action = ' store_true ' , help = ' Disables output of the full ASCII character set (0x20..0x7E), exporting only the glyphs specified. ' )
@cli.argument ( ' -u ' , ' --unicode-glyphs ' , default = ' ' , help = ' Also generate the specified unicode glyphs. ' )
@cli.argument ( ' -a ' , ' --no-aa ' , arg_only = True , action = ' store_true ' , help = ' Disable anti-aliasing on fonts. ' )
@cli.subcommand ( ' Converts an input font to something QMK understands ' )
def painter_make_font_image ( cli ) :
# Create the font object
font = QFFFont ( cli )
# Read from the input file
cli . args . font = normpath ( cli . args . font )
font . generate_image ( cli . args . font , cli . args . size , include_ascii_glyphs = ( not cli . args . no_ascii ) , unicode_glyphs = cli . args . unicode_glyphs , use_aa = ( False if cli . args . no_aa else True ) )
# Render out the data
font . save_to_image ( normpath ( cli . args . output ) )
@cli.argument ( ' -i ' , ' --input ' , help = ' Specify input graphic file. ' )
@cli.argument ( ' -o ' , ' --output ' , default = ' ' , help = ' Specify output directory. Defaults to same directory as input. ' )
@cli.argument ( ' -n ' , ' --no-ascii ' , arg_only = True , action = ' store_true ' , help = ' Disables output of the full ASCII character set (0x20..0x7E), exporting only the glyphs specified. ' )
@cli.argument ( ' -u ' , ' --unicode-glyphs ' , default = ' ' , help = ' Also generate the specified unicode glyphs. ' )
2024-03-10 00:29:09 +00:00
@cli.argument ( ' -f ' , ' --format ' , required = True , help = f ' Output format, valid types: { " , " . join ( valid_formats . keys ( ) ) } ' )
2022-04-13 08:00:18 +00:00
@cli.argument ( ' -r ' , ' --no-rle ' , arg_only = True , action = ' store_true ' , help = ' Disable the use of RLE to minimise converted image size. ' )
2022-11-08 15:47:07 +00:00
@cli.argument ( ' -w ' , ' --raw ' , arg_only = True , action = ' store_true ' , help = ' Writes out the QFF file as raw data instead of c/h combo. ' )
2022-04-13 08:00:18 +00:00
@cli.subcommand ( ' Converts an input font image to something QMK firmware understands ' )
def painter_convert_font_image ( cli ) :
# Work out the format
format = valid_formats [ cli . args . format ]
# Create the font object
font = QFFFont ( cli . log )
# Read from the input file
cli . args . input = normpath ( cli . args . input )
font . read_from_image ( cli . args . input , include_ascii_glyphs = ( not cli . args . no_ascii ) , unicode_glyphs = cli . args . unicode_glyphs )
# Work out the output directory
if len ( cli . args . output ) == 0 :
cli . args . output = cli . args . input . parent
cli . args . output = normpath ( cli . args . output )
# Render out the data
out_data = BytesIO ( )
2024-03-10 00:29:09 +00:00
font . save_to_qff ( format , not cli . args . no_rle , out_data )
2022-11-08 15:47:07 +00:00
out_bytes = out_data . getvalue ( )
if cli . args . raw :
2024-03-10 00:29:09 +00:00
raw_file = cli . args . output / f " { cli . args . input . stem } .qff "
2022-11-08 15:47:07 +00:00
with open ( raw_file , ' wb ' ) as raw :
raw . write ( out_bytes )
return
2022-04-13 08:00:18 +00:00
# Work out the text substitutions for rendering the output data
2024-03-10 00:29:09 +00:00
args_str = " " . join ( ( f " -- { arg } { getattr ( cli . args , arg . replace ( ' - ' , ' _ ' ) ) } " for arg in [ " input " , " output " , " no-ascii " , " unicode-glyphs " , " format " , " no-rle " ] ) )
command = f " qmk painter-convert-font-image { args_str } "
metadata = { " glyphs " : _generate_font_glyphs_list ( not cli . args . no_ascii , cli . args . unicode_glyphs ) }
subs = generate_subs ( cli , out_bytes , font_metadata = metadata , command = command )
2022-04-13 08:00:18 +00:00
# Render and write the header file
header_text = render_header ( subs )
2024-03-10 00:29:09 +00:00
header_file = cli . args . output / f " { cli . args . input . stem } .qff.h "
2022-04-13 08:00:18 +00:00
with open ( header_file , ' w ' ) as header :
print ( f " Writing { header_file } ... " )
header . write ( header_text )
# Render and write the source file
source_text = render_source ( subs )
2024-03-10 00:29:09 +00:00
source_file = cli . args . output / f " { cli . args . input . stem } .qff.c "
2022-04-13 08:00:18 +00:00
with open ( source_file , ' w ' ) as source :
print ( f " Writing { source_file } ... " )
source . write ( source_text )