File: //home/arjun/projects/env/lib64/python3.10/site-packages/fontTools/__pycache__/ttx.cpython-310.pyc
o
we A � @ s d Z ddlmZmZ ddlmZ ddlmZ ddlm Z m
Z
ddlmZ ddl
mZ ddlmZ dd lZdd lZdd lZdd lZdd lZe�d
�Ze�d�ZG dd
� d
e�Zdd� Zeed�dd� �Zeed�dd� �Zdd� Zdd� Z dd� Z!ddd�Z"e#dkr�e�$e"� � d S d S ) aX usage: ttx [options] inputfile1 [... inputfileN]
TTX -- From OpenType To XML And Back
If an input file is a TrueType or OpenType font file, it will be
decompiled to a TTX file (an XML-based text format).
If an input file is a TTX file, it will be compiled to whatever
format the data is in, a TrueType or OpenType/CFF font file.
A special input value of - means read from the standard input.
Output files are created so they are unique: an existing file is
never overwritten.
General options
===============
-h Help print this message.
--version show version and exit.
-d <outputfolder> Specify a directory where the output files are
to be created.
-o <outputfile> Specify a file to write the output to. A special
value of - would use the standard output.
-f Overwrite existing output file(s), ie. don't append
numbers.
-v Verbose: more messages will be written to stdout
about what is being done.
-q Quiet: No messages will be written to stdout about
what is being done.
-a allow virtual glyphs ID's on compile or decompile.
Dump options
============
-l List table info: instead of dumping to a TTX file, list
some minimal info about each table.
-t <table> Specify a table to dump. Multiple -t options
are allowed. When no -t option is specified, all tables
will be dumped.
-x <table> Specify a table to exclude from the dump. Multiple
-x options are allowed. -t and -x are mutually exclusive.
-s Split tables: save the TTX data into separate TTX files per
table and write one small TTX file that contains references
to the individual table dumps. This file can be used as
input to ttx, as long as the table files are in the
same directory.
-g Split glyf table: Save the glyf data into separate TTX files
per glyph and write a small TTX for the glyf table which
contains references to the individual TTGlyph elements.
NOTE: specifying -g implies -s (no need for -s together
with -g)
-i Do NOT disassemble TT instructions: when this option is
given, all TrueType programs (glyph programs, the font
program and the pre-program) will be written to the TTX
file as hex data instead of assembly. This saves some time
and makes the TTX file smaller.
-z <format> Specify a bitmap data export option for EBDT:
{'raw', 'row', 'bitwise', 'extfile'} or for the CBDT:
{'raw', 'extfile'} Each option does one of the following:
-z raw
export the bitmap data as a hex dump
-z row
export each row as hex data
-z bitwise
export each row as binary in an ASCII art style
-z extfile
export the data as external files with XML references
If no export format is specified 'raw' format is used.
-e Don't ignore decompilation errors, but show a full traceback
and abort.
-y <number> Select font number for TrueType Collection (.ttc/.otc),
starting from 0.
--unicodedata <UnicodeData.txt>
Use custom database file to write character names in the
comments of the cmap TTX output.
--newline <value>
Control how line endings are written in the XML file. It
can be 'LF', 'CR', or 'CRLF'. If not specified, the
default platform-specific line endings are used.
Compile options
===============
-m Merge with TrueType-input-file: specify a TrueType or
OpenType font file to be merged with the TTX file. This
option is only valid when at most one TTX file is specified.
-b Don't recalc glyph bounding boxes: use the values in the
TTX file as-is.
--recalc-timestamp
Set font 'modified' timestamp to current time.
By default, the modification time of the TTX file will be
used.
--no-recalc-timestamp
Keep the original font 'modified' timestamp.
--flavor <type>
Specify flavor of output font file. May be 'woff' or 'woff2'.
Note that WOFF2 requires the Brotli Python extension,
available at https://github.com/google/brotli
--with-zopfli
Use Zopfli instead of Zlib to compress WOFF. The Python
extension is available at https://pypi.python.org/pypi/zopfli
� )�TTFont�
TTLibError)�getMacCreatorAndType)�setUnicodeData)�Tag�tostr)�timestampSinceEpoch)�Timer)�makeOutputFileNameNz
fontTools.ttxzsfntVersion=['"]OTTO["']c @ s\ e Zd ZdZdZdZdZdZdZdZ dZ
dZdZdZ
dZdZdZdZdZdZdZdd� ZdS )�OptionsFNT�raw�
c
C s6 g | _ g | _d| _|D �]0\}}|dkrtt� t�d� q|dkr2ddlm} t|� t�d� q|dkrEt j
�|�sAt�
d��|| _q|dkrM|| _q|d krUd
| _q|dkr]d
| _q|dkred
| _q|d
krmd
| _q|dkr}|�d�}| j �|� q|dkr�|�d�}| j�|� q|dkr�d
| _q|dkr�d
| _d
| _q|dkr�d| _q|dkr�d}||vr�t�
d||f ��|| _q|dkr�t|�| _q|dkr�|| _q|dkr�d| _q|dkr�d| _q|dkr�|| _q|dk�rd}|dkr�d | _q|d!k�rd"| _q|d#k�r
d$| _qt�
d%|d&� t!t"|��f ��|d'k�r"d
| _#q|d(k�r+d| _#q|d)k�r4|| _$q|d*k�r<d
| _%q| j�rJ| j�rJt�
d+��| j�rSt&j'| _(n
| j�r\t&j)| _(nt&j*| _(| j�rm| j$�rmt�
d,��| j �rz| j�rzt�
d-��| j�r�|d.k�r�t�
d/��| j$d0k�r�| j%�r�t�
d1��d S d S )2N���z-hr z --version)�versionz-dz1The -d option value must be an existing directoryz-oz-fTz-vz-qz-lz-t� z-xz-sz-gz-iFz-z)r �row�bitwise�extfilez(-z does not allow %s as a format. Use %sz-yz-mz-bz-ez
--unicodedataz --newline)�LF�CR�CRLFr r
r �
r z
z1Invalid choice for --newline: %r (choose from %s)z, z--recalc-timestampz--no-recalc-timestampz--flavorz
--with-zopfliz(-q and -v options are mutually exclusivez.-m and --flavor options are mutually exclusivez(-t and -x options are mutually exclusive� z6Must specify exactly one TTX source file when using -m�woffz---with-zopfli option requires --flavor 'woff')+�
onlyTables�
skipTables�
fontNumber�print�__doc__�sys�exit� fontToolsr �os�path�isdir�getopt�GetoptError� outputDir�
outputFile� overWrite�verbose�quiet�
listTables�ljust�append�splitTables�splitGlyphs�disassembleInstructions�bitmapGlyphDataFormat�int� mergeFile�recalcBBoxes�ignoreDecompileErrors�unicodedata�
newlinestr�join�map�repr�recalcTimestamp�flavor� useZopfli�logging�DEBUG�logLevel�WARNING�INFO)�self�
rawOptions�numFiles�option�valuer �validOptions� rJ �F/home/arjun/projects/env/lib/python3.10/site-packages/fontTools/ttx.py�__init__� s� �
��
��
�
�
�zOptions.__init__)�__name__�
__module__�__qualname__r, r'