# ***** BEGIN GPL LICENSE BLOCK ***** # # This program is free software; you can redistribute it and/or # modify it under the terms of the GNU General Public License # as published by the Free Software Foundation; either version 2 # of the License, or (at your option) any later version. # # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU General Public License for more details. # # You should have received a copy of the GNU General Public License # along with this program; if not, write to the Free Software Foundation, # Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. # # ***** END GPL LICENCE BLOCK ***** # # (c) 2018, Blender Foundation - Sybren A. Stüvel """Common functionality for CLI parsers.""" import typing import pathlib def add_flag(argparser, flag_name: str, **kwargs): """Add a CLI argument for the flag. The flag defaults to False, and when present on the CLI stores True. """ argparser.add_argument('-%s' % flag_name[0], '--%s' % flag_name, default=False, action='store_true', **kwargs) def shorten(cwd: pathlib.Path, somepath: pathlib.Path) -> pathlib.Path: """Return 'somepath' relative to CWD if possible.""" try: return somepath.relative_to(cwd) except ValueError: return somepath def humanize_bytes(size_in_bytes: int, precision: typing.Optional[int]=None): """Return a humanized string representation of a number of bytes. Source: http://code.activestate.com/recipes/577081-humanized-representation-of-a-number-of-bytes :param size_in_bytes: The size to humanize :param precision: How many digits are shown after the comma. When None, it defaults to 1 unless the entire number of bytes is shown, then it will be 0. >>> humanize_bytes(1) '1 B' >>> humanize_bytes(1024) '1.0 kB' >>> humanize_bytes(1024*123, 0) '123 kB' >>> humanize_bytes(1024*123) '123.0 kB' >>> humanize_bytes(1024*12342) '12.1 MB' >>> humanize_bytes(1024*12342,2) '12.05 MB' >>> humanize_bytes(1024*1234,2) '1.21 MB' >>> humanize_bytes(1024*1234*1111,2) '1.31 GB' >>> humanize_bytes(1024*1234*1111,1) '1.3 GB' """ if precision is None: precision = size_in_bytes >= 1024 abbrevs = ( (1 << 50, 'PB'), (1 << 40, 'TB'), (1 << 30, 'GB'), (1 << 20, 'MB'), (1 << 10, 'kB'), (1, 'B') ) for factor, suffix in abbrevs: if size_in_bytes >= factor: break else: factor = 1 suffix = 'B' return '%.*f %s' % (precision, size_in_bytes / factor, suffix) if __name__ == '__main__': import doctest doctest.testmod()