2019-07-15 21:14:27 +02:00
|
|
|
"""Functions that help us work with files and folders.
|
|
|
|
"""
|
2019-09-10 14:14:25 +02:00
|
|
|
import logging
|
2019-07-15 21:14:27 +02:00
|
|
|
import os
|
|
|
|
|
2019-09-10 14:14:25 +02:00
|
|
|
from qmk.errors import NoSuchKeyboardError
|
|
|
|
|
2020-01-07 21:54:21 +01:00
|
|
|
|
2019-07-15 21:14:27 +02:00
|
|
|
def keymap(keyboard):
|
|
|
|
"""Locate the correct directory for storing a keymap.
|
|
|
|
|
|
|
|
Args:
|
|
|
|
keyboard
|
|
|
|
The name of the keyboard. Example: clueboard/66/rev3
|
|
|
|
"""
|
|
|
|
for directory in ['.', '..', '../..', '../../..', '../../../..', '../../../../..']:
|
|
|
|
basepath = os.path.normpath(os.path.join('keyboards', keyboard, directory, 'keymaps'))
|
|
|
|
|
|
|
|
if os.path.exists(basepath):
|
|
|
|
return basepath
|
|
|
|
|
|
|
|
logging.error('Could not find keymaps directory!')
|
|
|
|
raise NoSuchKeyboardError('Could not find keymaps directory for: %s' % keyboard)
|
|
|
|
|
|
|
|
|
|
|
|
def normpath(path):
|
|
|
|
"""Returns the fully resolved absolute path to a file.
|
|
|
|
|
|
|
|
This function will return the absolute path to a file as seen from the
|
|
|
|
directory the script was called from.
|
|
|
|
"""
|
|
|
|
if path and path[0] == '/':
|
|
|
|
return os.path.normpath(path)
|
|
|
|
|
|
|
|
return os.path.normpath(os.path.join(os.environ['ORIG_CWD'], path))
|
2019-10-13 19:07:22 +02:00
|
|
|
|
2020-01-07 21:54:21 +01:00
|
|
|
|
2019-10-24 20:33:58 +02:00
|
|
|
def file_lines(filename):
|
|
|
|
""" Return a files content, line by line
|
2019-10-13 19:07:22 +02:00
|
|
|
|
2019-10-24 20:33:58 +02:00
|
|
|
Args:
|
|
|
|
filename: path to the file
|
2019-10-13 19:07:22 +02:00
|
|
|
|
2019-10-24 20:33:58 +02:00
|
|
|
Returns:
|
|
|
|
an list, in which each item is a line of the file
|
2019-10-13 19:07:22 +02:00
|
|
|
"""
|
2019-10-24 20:33:58 +02:00
|
|
|
with open(filename, "r") as fd:
|
|
|
|
return fd.readlines()
|