|
@ -108,28 +108,23 @@ def user_dir(): |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def format_satoshis(x, is_diff=False, num_zeros = 0, decimal_point = 8, whitespaces=False): |
|
|
def format_satoshis(x, is_diff=False, num_zeros = 0, decimal_point = 8, whitespaces=False): |
|
|
from decimal import Decimal |
|
|
from locale import localeconv |
|
|
if x is None: |
|
|
if is_diff: |
|
|
return 'unknown' |
|
|
fmt = "{:+n}" |
|
|
s = Decimal(x) |
|
|
else: |
|
|
sign, digits, exp = s.as_tuple() |
|
|
fmt = "{:n}" |
|
|
digits = map(str, digits) |
|
|
scale_factor = pow (10, decimal_point) |
|
|
while len(digits) < decimal_point + 1: |
|
|
integer_part = fmt.format(int(x / float(scale_factor))) |
|
|
digits.insert(0,'0') |
|
|
dp = localeconv()['decimal_point'] |
|
|
digits.insert(-decimal_point,'.') |
|
|
fract_part = ("{:0" + str(decimal_point) + "}").format(abs(x) % scale_factor) |
|
|
s = ''.join(digits).rstrip('0') |
|
|
fract_part = fract_part.rstrip('0') |
|
|
if sign: |
|
|
if len(fract_part) < num_zeros: |
|
|
s = '-' + s |
|
|
fract_part += "0" * (num_zeros - len(fract_part)) |
|
|
elif is_diff: |
|
|
result = integer_part + dp + fract_part |
|
|
s = "+" + s |
|
|
|
|
|
|
|
|
|
|
|
p = s.find('.') |
|
|
|
|
|
s += "0"*( 1 + num_zeros - ( len(s) - p )) |
|
|
|
|
|
if whitespaces: |
|
|
if whitespaces: |
|
|
s += " "*( 1 + decimal_point - ( len(s) - p )) |
|
|
result += " " * (decimal_point - len(fract_part)) |
|
|
s = " "*( 13 - decimal_point - ( p )) + s |
|
|
result = " " * (17 - len(result)) + result |
|
|
return s |
|
|
return result |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def format_time(timestamp): |
|
|
def format_time(timestamp): |
|
|
import datetime |
|
|
import datetime |
|
|