ardupilot/Tools/autotest/pysim/fdpexpect.py

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

84 lines
2.5 KiB
Python
Raw Permalink Normal View History

2011-12-22 21:20:58 -04:00
"""This is like pexpect, but will work on any file descriptor that you pass it.
2016-05-12 14:15:46 -03:00
So you are responsible for opening and close the file descriptor.
2011-12-22 21:20:58 -04:00
$Id: fdpexpect.py 505 2007-12-26 21:33:50Z noah $
"""
2016-11-08 07:06:05 -04:00
from __future__ import print_function
2011-12-22 21:20:58 -04:00
import os
from pexpect import ExceptionPexpect, spawn
2011-12-22 21:20:58 -04:00
__all__ = ['fdspawn']
class fdspawn(spawn):
2011-12-22 21:20:58 -04:00
"""This is like pexpect.spawn but allows you to supply your own open file
descriptor. For example, you could use it to read through a file looking
for patterns, or to control a modem or serial device. """
def __init__(self, fd, args=[], timeout=30, maxread=2000, searchwindowsize=None, logfile=None):
2011-12-22 21:20:58 -04:00
"""This takes a file descriptor (an int) or an object that support the
fileno() method (returning an int). All Python file-like objects
support fileno(). """
# TODO: Add better handling of trying to use fdspawn in place of spawn
# TODO: (overload to allow fdspawn to also handle commands as spawn does.
2011-12-22 21:20:58 -04:00
if not isinstance(fd, int) and hasattr(fd, 'fileno'):
2011-12-22 21:20:58 -04:00
fd = fd.fileno()
if not isinstance(fd, int):
raise ExceptionPexpect(
"The fd argument is not an int. If this is a command string then maybe you want to use pexpect.spawn.")
2011-12-22 21:20:58 -04:00
try: # make sure fd is a valid file descriptor
2011-12-22 21:20:58 -04:00
os.fstat(fd)
except OSError:
raise ExceptionPexpect("The fd argument is not a valid file descriptor.")
2011-12-22 21:20:58 -04:00
self.args = None
self.command = None
spawn.__init__(self, None, args, timeout, maxread, searchwindowsize, logfile)
self.child_fd = fd
self.own_fd = False
self.closed = False
self.name = '<file descriptor %d>' % fd
def __del__(self):
2011-12-22 21:20:58 -04:00
return
def close(self):
2011-12-22 21:20:58 -04:00
if self.child_fd == -1:
return
if self.own_fd:
self.close(self)
2011-12-22 21:20:58 -04:00
else:
self.flush()
os.close(self.child_fd)
self.child_fd = -1
self.closed = True
def isalive(self):
2011-12-22 21:20:58 -04:00
"""This checks if the file descriptor is still valid. If os.fstat()
does not raise an exception then we assume it is alive. """
if self.child_fd == -1:
return False
try:
os.fstat(self.child_fd)
return True
except:
return False
def terminate(self, force=False):
2011-12-22 21:20:58 -04:00
raise ExceptionPexpect('This method is not valid for file descriptors.')
2011-12-22 21:20:58 -04:00
def kill(self, sig):
2011-12-22 21:20:58 -04:00
return