From b2324b671538b0f4cfe26ba1444ba16d2a97d208 Mon Sep 17 00:00:00 2001 From: Micah Lee Date: Tue, 27 May 2014 19:42:47 -0400 Subject: [PATCH] making onionshare-gui fit the new directory structure, and stop using subprocess --- onionshare-gui.py => bin/onionshare-gui | 32 ++++--------------------- setup.py | 2 +- 2 files changed, 5 insertions(+), 29 deletions(-) rename onionshare-gui.py => bin/onionshare-gui (67%) diff --git a/onionshare-gui.py b/bin/onionshare-gui similarity index 67% rename from onionshare-gui.py rename to bin/onionshare-gui index ac3d1d50..fa61d154 100755 --- a/onionshare-gui.py +++ b/bin/onionshare-gui @@ -1,7 +1,8 @@ #!/usr/bin/env python import Tkinter as tk, tkFont, tkFileDialog -import sys, os, subprocess, time +import sys, os, time +import onionshare from Queue import Queue, Empty from threading import Thread @@ -23,15 +24,8 @@ class OnionShareGUI(object): self.basename = os.path.basename(self.filename) self.root.title('OnionShare - {0}'.format(self.basename)) - # launch onionshare - # trying to do this https://stackoverflow.com/questions/375427/non-blocking-read-on-a-subprocess-pipe-in-python - self.onionshare_bin = os.path.dirname(__file__)+'/onionshare.py' - ON_POSIX = 'posix' in sys.builtin_module_names - self.p = subprocess.Popen([self.onionshare_bin, self.filename], stdout=subprocess.PIPE, bufsize=1) - self.q = Queue() - self.t = Thread(target=self.enqueue_output, args=(self.p.stdout, self.q)) - self.t.daemon = True - self.t.start() + # todo: start onionshare here, and display web server logs in update() method + # this might be helpful: https://stackoverflow.com/questions/375427/non-blocking-read-on-a-subprocess-pipe-in-python # update regularly self.update() @@ -63,24 +57,6 @@ class OnionShareGUI(object): self.quit_button.grid(padx=self.pad, pady=self.pad) def update(self): - """try: - line = self.q.get_nowait() - except Empty: - pass - else: - print line""" - - # wait until the URL gets outputed - """self.url = None - while not self.url: - line = self.p.stdout.readline() - print line - if line[:7] == 'http://': - self.url = line - self.url_text.insert(tk.INSERT, self.url) - self.logs_text.insert(tk.INSERT, line)""" - - self.root.after(500, self.update) def enqueue_output(self, out, queue): diff --git a/setup.py b/setup.py index 3a8d4ded..b0f8225b 100644 --- a/setup.py +++ b/setup.py @@ -28,5 +28,5 @@ setup( license="GPL v3", keywords='onion, share, onionshare, tor, anonymous, web server', packages=['onionshare'], - scripts=['bin/onionshare'] + scripts=['bin/onionshare', 'bin/onionshare-gui'] )