2016-05-25 18:37:40 +03:00
|
|
|
# Low level unix utility functions
|
|
|
|
#
|
|
|
|
# Copyright (C) 2016 Kevin O'Connor <kevin@koconnor.net>
|
|
|
|
#
|
|
|
|
# This file may be distributed under the terms of the GNU GPLv3 license.
|
2016-12-24 18:07:02 +03:00
|
|
|
import os, pty, fcntl, termios, signal, logging, subprocess, traceback, shlex
|
2016-05-25 18:37:40 +03:00
|
|
|
|
|
|
|
# Return the SIGINT interrupt handler back to the OS default
|
|
|
|
def fix_sigint():
|
|
|
|
signal.signal(signal.SIGINT, signal.SIG_DFL)
|
|
|
|
fix_sigint()
|
|
|
|
|
|
|
|
# Set a file-descriptor as non-blocking
|
|
|
|
def set_nonblock(fd):
|
|
|
|
fcntl.fcntl(fd, fcntl.F_SETFL
|
|
|
|
, fcntl.fcntl(fd, fcntl.F_GETFL) | os.O_NONBLOCK)
|
|
|
|
|
2016-12-10 03:04:30 +03:00
|
|
|
# Clear HUPCL flag
|
|
|
|
def clear_hupcl(fd):
|
|
|
|
attrs = termios.tcgetattr(fd)
|
|
|
|
attrs[2] = attrs[2] & ~termios.HUPCL
|
|
|
|
termios.tcsetattr(fd, termios.TCSADRAIN, attrs)
|
|
|
|
|
2016-05-25 18:37:40 +03:00
|
|
|
# Support for creating a pseudo-tty for emulating a serial port
|
|
|
|
def create_pty(ptyname):
|
|
|
|
mfd, sfd = pty.openpty()
|
|
|
|
try:
|
|
|
|
os.unlink(ptyname)
|
|
|
|
except os.error:
|
|
|
|
pass
|
|
|
|
os.symlink(os.ttyname(sfd), ptyname)
|
|
|
|
fcntl.fcntl(mfd, fcntl.F_SETFL
|
|
|
|
, fcntl.fcntl(mfd, fcntl.F_GETFL) | os.O_NONBLOCK)
|
|
|
|
old = termios.tcgetattr(mfd)
|
|
|
|
old[3] = old[3] & ~termios.ECHO
|
|
|
|
termios.tcsetattr(mfd, termios.TCSADRAIN, old)
|
|
|
|
return mfd
|
2016-12-24 18:07:02 +03:00
|
|
|
|
2016-12-29 05:45:29 +03:00
|
|
|
def get_git_version():
|
2016-12-24 18:07:02 +03:00
|
|
|
# Obtain version info from "git" program
|
|
|
|
if not os.path.exists('.git'):
|
|
|
|
logging.debug("No '.git' file/directory found")
|
2016-12-29 05:45:29 +03:00
|
|
|
return "?"
|
2016-12-24 18:07:02 +03:00
|
|
|
prog = "git describe --tags --long --dirty"
|
|
|
|
try:
|
|
|
|
process = subprocess.Popen(shlex.split(prog), stdout=subprocess.PIPE)
|
|
|
|
output = process.communicate()[0]
|
|
|
|
retcode = process.poll()
|
|
|
|
except OSError:
|
|
|
|
logging.debug("Exception on run: %s" % (traceback.format_exc(),))
|
2016-12-29 05:45:29 +03:00
|
|
|
return "?"
|
|
|
|
return output.strip()
|