2016-02-24 11:33:49 +03:00
|
|
|
import os
|
2016-02-26 17:32:36 +03:00
|
|
|
import time
|
2016-07-07 13:54:02 +03:00
|
|
|
import shutil
|
2016-11-01 00:04:48 +03:00
|
|
|
import sys
|
2017-02-12 23:15:33 +03:00
|
|
|
import re
|
2016-02-20 00:10:24 +03:00
|
|
|
|
2017-06-20 19:58:59 +03:00
|
|
|
|
2017-07-09 17:37:05 +03:00
|
|
|
program_version = '0.3.1'
|
2016-02-21 23:25:37 +03:00
|
|
|
|
|
|
|
|
2017-04-17 22:04:22 +03:00
|
|
|
def cached(func):
|
|
|
|
saved_result = None
|
|
|
|
|
|
|
|
def wrapped_func():
|
|
|
|
nonlocal saved_result
|
|
|
|
if saved_result is None:
|
|
|
|
saved_result = func()
|
|
|
|
|
|
|
|
return saved_result
|
|
|
|
|
|
|
|
return wrapped_func
|
|
|
|
|
|
|
|
|
2016-02-20 00:10:24 +03:00
|
|
|
def log(data):
|
2017-07-03 21:36:11 +03:00
|
|
|
try:
|
|
|
|
with open(curr_directory() + '/logs.log', 'a') as fl:
|
|
|
|
fl.write(str(data) + '\n')
|
|
|
|
except:
|
|
|
|
pass
|
2016-02-20 00:10:24 +03:00
|
|
|
|
2016-02-20 11:06:24 +03:00
|
|
|
|
2017-04-17 22:04:22 +03:00
|
|
|
@cached
|
2016-02-24 11:33:49 +03:00
|
|
|
def curr_directory():
|
|
|
|
return os.path.dirname(os.path.realpath(__file__))
|
2016-02-24 18:32:35 +03:00
|
|
|
|
|
|
|
|
2016-02-26 17:32:36 +03:00
|
|
|
def curr_time():
|
2016-03-13 15:06:06 +03:00
|
|
|
return time.strftime('%H:%M')
|
|
|
|
|
|
|
|
|
2016-07-07 13:54:02 +03:00
|
|
|
def copy(src, dest):
|
|
|
|
if not os.path.exists(dest):
|
|
|
|
os.makedirs(dest)
|
|
|
|
src_files = os.listdir(src)
|
|
|
|
for file_name in src_files:
|
|
|
|
full_file_name = os.path.join(src, file_name)
|
|
|
|
if os.path.isfile(full_file_name):
|
|
|
|
shutil.copy(full_file_name, dest)
|
|
|
|
else:
|
|
|
|
copy(full_file_name, os.path.join(dest, file_name))
|
|
|
|
|
|
|
|
|
2016-10-22 20:31:34 +03:00
|
|
|
def remove(folder):
|
2016-11-05 16:04:17 +03:00
|
|
|
if os.path.isdir(folder):
|
|
|
|
shutil.rmtree(folder)
|
2016-10-22 20:31:34 +03:00
|
|
|
|
|
|
|
|
2016-03-13 15:06:06 +03:00
|
|
|
def convert_time(t):
|
2017-01-22 00:19:56 +03:00
|
|
|
offset = time.timezone + time_offset() * 60
|
2016-08-30 20:23:55 +03:00
|
|
|
sec = int(t) - offset
|
2016-03-13 15:06:06 +03:00
|
|
|
m, s = divmod(sec, 60)
|
|
|
|
h, m = divmod(m, 60)
|
|
|
|
d, h = divmod(h, 24)
|
|
|
|
return '%02d:%02d' % (h, m)
|
2016-02-26 17:32:36 +03:00
|
|
|
|
|
|
|
|
2017-04-17 22:04:22 +03:00
|
|
|
@cached
|
2017-01-13 21:08:54 +03:00
|
|
|
def time_offset():
|
2017-01-22 00:19:56 +03:00
|
|
|
hours = int(time.strftime('%H'))
|
|
|
|
minutes = int(time.strftime('%M'))
|
2017-01-13 21:08:54 +03:00
|
|
|
sec = int(time.time()) - time.timezone
|
|
|
|
m, s = divmod(sec, 60)
|
|
|
|
h, m = divmod(m, 60)
|
|
|
|
d, h = divmod(h, 24)
|
2017-01-22 00:19:56 +03:00
|
|
|
result = hours * 60 + minutes - h * 60 - m
|
|
|
|
return result
|
2017-01-13 21:08:54 +03:00
|
|
|
|
|
|
|
|
2016-11-01 00:04:48 +03:00
|
|
|
def append_slash(s):
|
2016-11-01 00:24:37 +03:00
|
|
|
if len(s) and s[-1] not in ('\\', '/'):
|
2016-11-01 00:04:48 +03:00
|
|
|
s += '/'
|
|
|
|
return s
|
|
|
|
|
|
|
|
|
2017-06-11 22:58:11 +03:00
|
|
|
@cached
|
2016-11-01 00:04:48 +03:00
|
|
|
def is_64_bit():
|
|
|
|
return sys.maxsize > 2 ** 32
|
|
|
|
|
|
|
|
|
2017-02-12 23:15:33 +03:00
|
|
|
def is_re_valid(regex):
|
|
|
|
try:
|
|
|
|
re.compile(regex)
|
|
|
|
except re.error:
|
|
|
|
return False
|
|
|
|
else:
|
|
|
|
return True
|
|
|
|
|
|
|
|
|
2016-06-21 14:58:11 +03:00
|
|
|
class Singleton:
|
|
|
|
_instance = None
|
2016-02-24 18:32:35 +03:00
|
|
|
|
2016-06-22 14:35:22 +03:00
|
|
|
def __init__(self):
|
|
|
|
self.__class__._instance = self
|
2016-03-03 22:19:09 +03:00
|
|
|
|
|
|
|
@classmethod
|
|
|
|
def get_instance(cls):
|
|
|
|
return cls._instance
|