mirror of
https://git.yoctoproject.org/meta-arm
synced 2026-04-20 11:29:54 +00:00
runfvp: refactor terminal selection
Rewrite the terminal code to have a priority list of terminals when selecting a default, allow the user to pick a default with a configuration file, and add gnome-terminal to the list. Signed-off-by: Ross Burton <ross.burton@arm.com>
This commit is contained in:
@@ -1,6 +1,7 @@
|
|||||||
#! /usr/bin/env python3
|
#! /usr/bin/env python3
|
||||||
|
|
||||||
import asyncio
|
import asyncio
|
||||||
|
import collections
|
||||||
import json
|
import json
|
||||||
import os
|
import os
|
||||||
import re
|
import re
|
||||||
@@ -12,25 +13,59 @@ import pathlib
|
|||||||
import logging
|
import logging
|
||||||
logger = logging.getLogger("RunFVP")
|
logger = logging.getLogger("RunFVP")
|
||||||
|
|
||||||
|
from typing import List, Optional
|
||||||
|
|
||||||
|
def get_config_dir() -> pathlib.Path:
|
||||||
|
value = os.environ.get("XDG_CONFIG_HOME")
|
||||||
|
if value and os.path.isabs(value):
|
||||||
|
return pathlib.Path(value)
|
||||||
|
else:
|
||||||
|
return pathlib.Path.home() / ".config"
|
||||||
|
|
||||||
|
class Terminals:
|
||||||
|
Terminal = collections.namedtuple("Terminal", ["priority", "name", "command"])
|
||||||
|
|
||||||
|
def __init__(self):
|
||||||
|
self.terminals = []
|
||||||
|
|
||||||
|
def add_terminal(self, priority, name, command):
|
||||||
|
self.terminals.append(Terminals.Terminal(priority, name, command))
|
||||||
|
# Keep this list sorted by priority
|
||||||
|
self.terminals.sort(reverse=True, key=lambda t: t.priority)
|
||||||
|
self.name_map = {t.name: t for t in self.terminals}
|
||||||
|
|
||||||
|
def configured_terminal(self) -> Optional[str]:
|
||||||
|
import configparser
|
||||||
|
|
||||||
|
config = configparser.ConfigParser()
|
||||||
|
config.read(get_config_dir() / "runfvp.conf")
|
||||||
|
return config.get("RunFVP", "Terminal", fallback=None)
|
||||||
|
|
||||||
|
def preferred_terminal(self) -> str:
|
||||||
|
import shlex, shutil
|
||||||
|
|
||||||
|
preferred = self.configured_terminal()
|
||||||
|
if preferred:
|
||||||
|
return preferred
|
||||||
|
|
||||||
|
for t in self.terminals:
|
||||||
|
if t.command and shutil.which(shlex.split(t.command)[0]):
|
||||||
|
return t.name
|
||||||
|
return self.terminals[-1].name
|
||||||
|
|
||||||
|
def all_terminals(self) -> List[str]:
|
||||||
|
return self.name_map.keys()
|
||||||
|
|
||||||
|
def __getitem__(self, name: str):
|
||||||
|
return self.name_map[name]
|
||||||
|
|
||||||
|
terminals = Terminals()
|
||||||
# TODO: option to switch between telnet and netcat
|
# TODO: option to switch between telnet and netcat
|
||||||
connect_command = "telnet localhost %port"
|
connect_command = "telnet localhost %port"
|
||||||
|
terminals.add_terminal(2, "tmux", f"tmux new-window -n \"%title\" \"{connect_command}\""),
|
||||||
terminal_map = {
|
terminals.add_terminal(2, "gnome-terminal", f"gnome-terminal --window --title \"%title\" --command \"{connect_command}\""),
|
||||||
"tmux": f"tmux new-window -n \"%title\" \"{connect_command}\"",
|
terminals.add_terminal(1, "xterm", f"xterm -title \"%title\" -e {connect_command}"),
|
||||||
"xterm": f"xterm -title \"%title\" -e {connect_command}",
|
terminals.add_terminal(0, "none", None)
|
||||||
"none": ""
|
|
||||||
# TODO more terminals
|
|
||||||
}
|
|
||||||
|
|
||||||
def get_default_terminal():
|
|
||||||
import shutil
|
|
||||||
import shlex
|
|
||||||
|
|
||||||
for terminal in "xterm",:
|
|
||||||
command = shlex.split(terminal_map[terminal])[0]
|
|
||||||
if shutil.which(command):
|
|
||||||
return terminal
|
|
||||||
return "none"
|
|
||||||
|
|
||||||
def get_image_directory(machine=None):
|
def get_image_directory(machine=None):
|
||||||
"""
|
"""
|
||||||
@@ -59,7 +94,7 @@ def parse_args(arguments):
|
|||||||
parser = argparse.ArgumentParser(description="Run images in a FVP")
|
parser = argparse.ArgumentParser(description="Run images in a FVP")
|
||||||
parser.add_argument("config", nargs="?", help="Machine name or path to .fvpconf file")
|
parser.add_argument("config", nargs="?", help="Machine name or path to .fvpconf file")
|
||||||
group = parser.add_mutually_exclusive_group()
|
group = parser.add_mutually_exclusive_group()
|
||||||
group.add_argument("-t", "--terminals", choices=terminal_map.keys(), default=get_default_terminal(), help="Automatically start terminals (default: %(default)s)")
|
group.add_argument("-t", "--terminals", choices=terminals.all_terminals(), default=terminals.preferred_terminal(), help="Automatically start terminals (default: %(default)s)")
|
||||||
group.add_argument("-c", "--console", action="store_true", help="Attach the first uart to stdin/stdout")
|
group.add_argument("-c", "--console", action="store_true", help="Attach the first uart to stdin/stdout")
|
||||||
parser.add_argument("--verbose", action="store_true", help="Output verbose logging")
|
parser.add_argument("--verbose", action="store_true", help="Output verbose logging")
|
||||||
parser.usage = f"{parser.format_usage().strip()} -- [ arguments passed to FVP ]"
|
parser.usage = f"{parser.format_usage().strip()} -- [ arguments passed to FVP ]"
|
||||||
|
|||||||
Reference in New Issue
Block a user