#!/usr/bin/env python3 # -*- coding: utf-8 -*- # Copyright (C) 2018 Andy Stewart # # Author: Andy Stewart # Maintainer: Andy Stewart # # This program is free software: you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by # the Free Software Foundation, either version 3 of the License, or # any later version. # # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU General Public License for more details. # # You should have received a copy of the GNU General Public License # along with this program. If not, see . from PyQt5.QtCore import QUrl from PyQt5.QtGui import QColor from core.browser import BrowserBuffer from core.utils import PostGui, get_free_port import os import subprocess import signal import threading import getpass class AppBuffer(BrowserBuffer): def __init__(self, buffer_id, url, config_dir, arguments, emacs_var_dict, module_path, is_dark_mode): BrowserBuffer.__init__(self, buffer_id, url, config_dir, arguments, emacs_var_dict, module_path, is_dark_mode, False, QColor(255, 255, 255, 255)) # Get free port to render markdown. self.port = get_free_port() self.url = url argument_list = arguments.split("ᛡ") self.command = argument_list[0] self.start_directory = argument_list[1] # Start wetty process. self.background_process = subprocess.Popen( "wetty -p {0} --base / --sshuser {1} --sshauth publickey -c {2}".format( self.port, getpass.getuser(), "'{}'".format(self.command)), stdout=subprocess.PIPE, stderr=subprocess.STDOUT, shell=True) # Add timer make load markdown preview link after grip process start finish. threading.Timer(1, self.load_wetty_server).start() self.reset_default_zoom() @PostGui() def load_wetty_server(self): self.buffer_widget.setUrl(QUrl("http://localhost:{0}".format(self.port))) self.update_title() def update_title(self): self.change_title("{0}-{1}".format( os.path.basename(os.path.normpath(os.path.expanduser(self.start_directory))), self.random_string() )) def before_destroy_buffer(self): os.kill(self.background_process.pid, signal.SIGTERM) def random_string(self): import hashlib import time hash = hashlib.sha1() hash.update(str(time.time()).encode("utf-8")) return hash.hexdigest()[:4]