This repository has been archived on 2024-12-19. You can view files and clone it, but cannot push or open issues or pull requests.
PyBitmessage-2024-12-19/src/paths.py

138 lines
4.4 KiB
Python
Raw Normal View History

2019-09-20 13:19:04 +02:00
"""
2019-10-22 16:23:38 +02:00
Path related functions
2019-09-20 13:19:04 +02:00
"""
# pylint: disable=import-error
2019-09-27 16:09:29 +02:00
import logging
import os
import re
2019-09-27 16:09:29 +02:00
import sys
from datetime import datetime
2019-09-27 16:09:29 +02:00
from shutil import move
from kivy.utils import platform
2019-09-27 16:09:29 +02:00
logger = logging.getLogger('default')
# When using py2exe or py2app, the variable frozen is added to the sys
# namespace. This can be used to setup a different code path for
# binary distributions vs source distributions.
2019-09-20 13:19:04 +02:00
frozen = getattr(sys, 'frozen', None)
def lookupExeFolder():
2019-09-27 16:09:29 +02:00
"""Returns executable folder path"""
if frozen:
2019-09-27 16:09:29 +02:00
exeFolder = (
# targetdir/Bitmessage.app/Contents/MacOS/Bitmessage
2019-09-27 16:09:29 +02:00
os.path.dirname(sys.executable).split(os.path.sep)[0] + os.path.sep
if frozen == "macosx_app" else
os.path.dirname(sys.executable) + os.path.sep)
elif __file__:
2019-09-27 16:09:29 +02:00
exeFolder = os.path.dirname(__file__) + os.path.sep
else:
exeFolder = ''
return exeFolder
def lookupAppdataFolder():
2019-09-27 16:09:29 +02:00
"""Returns path of the folder where application data is stored"""
APPNAME = "PyBitmessage"
2019-09-27 16:09:29 +02:00
dataFolder = os.environ.get('BITMESSAGE_HOME')
if dataFolder:
if dataFolder[-1] not in (os.path.sep, os.path.altsep):
dataFolder += os.path.sep
elif sys.platform == 'darwin':
2019-09-27 16:09:29 +02:00
try:
dataFolder = os.path.join(
os.environ['HOME'],
'Library/Application Support/', APPNAME
2019-10-22 16:23:38 +02:00
) + '/'
2019-09-27 16:09:29 +02:00
except KeyError:
sys.exit(
2019-09-20 13:19:04 +02:00
'Could not find home folder, please report this message'
' and your OS X version to the BitMessage Github.')
elif platform == 'android':
2019-10-11 12:34:30 +02:00
dataFolder = os.path.join(os.environ['ANDROID_PRIVATE'] + '/', APPNAME) + '/'
elif 'win32' in sys.platform or 'win64' in sys.platform:
2019-09-27 16:09:29 +02:00
dataFolder = os.path.join(
os.environ['APPDATA'].decode(
sys.getfilesystemencoding(), 'ignore'), APPNAME
) + os.path.sep
else:
try:
2019-09-27 16:09:29 +02:00
dataFolder = os.path.join(os.environ['XDG_CONFIG_HOME'], APPNAME)
except KeyError:
2019-09-27 16:09:29 +02:00
dataFolder = os.path.join(os.environ['HOME'], '.config', APPNAME)
2019-09-27 16:09:29 +02:00
# Migrate existing data to the proper location
# if this is an existing install
try:
2019-09-27 16:09:29 +02:00
move(os.path.join(os.environ['HOME'], '.%s' % APPNAME), dataFolder)
logger.info('Moving data folder to %s', dataFolder)
except IOError:
# Old directory may not exist.
pass
2019-09-27 16:09:29 +02:00
dataFolder = dataFolder + os.path.sep
return dataFolder
2019-09-20 13:19:04 +02:00
def codePath():
2019-09-27 16:09:29 +02:00
"""Returns path to the program sources"""
2019-10-11 13:11:48 +02:00
# pylint: disable=protected-access
2019-09-27 16:09:29 +02:00
if not frozen:
return os.path.dirname(__file__)
return (
os.environ.get('RESOURCEPATH')
2019-10-22 16:23:38 +02:00
# pylint: disable=protected-access
2019-09-27 16:09:29 +02:00
if frozen == "macosx_app" else sys._MEIPASS)
2019-09-20 13:19:04 +02:00
def tail(f, lines=20):
2019-09-27 16:09:29 +02:00
"""Returns last lines in the f file object"""
total_lines_wanted = lines
BLOCK_SIZE = 1024
f.seek(0, 2)
block_end_byte = f.tell()
lines_to_go = total_lines_wanted
block_number = -1
2019-09-20 13:19:04 +02:00
blocks = []
# blocks of size BLOCK_SIZE, in reverse order starting
# from the end of the file
while lines_to_go > 0 and block_end_byte > 0:
2019-09-20 13:19:04 +02:00
if block_end_byte - BLOCK_SIZE > 0:
# read the last block we haven't yet read
2019-09-20 13:19:04 +02:00
f.seek(block_number * BLOCK_SIZE, 2)
blocks.append(f.read(BLOCK_SIZE))
else:
# file too small, start from begining
f.seek(0, 0)
# only read what was not read
blocks.append(f.read(block_end_byte))
lines_found = blocks[-1].count('\n')
lines_to_go -= lines_found
block_end_byte -= BLOCK_SIZE
block_number -= 1
all_read_text = ''.join(reversed(blocks))
return '\n'.join(all_read_text.splitlines()[-total_lines_wanted:])
def lastCommit():
2019-09-27 16:09:29 +02:00
"""
Returns last commit information as dict with 'commit' and 'time' keys
"""
githeadfile = os.path.join(codePath(), '..', '.git', 'logs', 'HEAD')
result = {}
2019-09-27 16:09:29 +02:00
if os.path.isfile(githeadfile):
try:
with open(githeadfile, 'rt') as githead:
line = tail(githead, 1)
result['commit'] = line.split()[1]
result['time'] = datetime.fromtimestamp(
float(re.search(r'>\s*(.*?)\s', line).group(1))
)
except (IOError, AttributeError, TypeError):
pass
2019-10-11 13:11:48 +02:00
return result