Merge pull request 'make statusbar work with phone' (#3) from statusbar-experimental into master
Reviewed-on: #3
This commit is contained in:
commit
a03d535034
|
@ -1,4 +1,4 @@
|
||||||
termux: termux-pkgs termux-dots utils-sh rebuild-sh st pip-pkgs git-annex.linux sssg
|
termux: termux-pkgs termux-dots utils-sh rebuild-sh st pip-pkgs git-annex.linux sssg statusbar-polyfill
|
||||||
|
|
||||||
list: options # alias
|
list: options # alias
|
||||||
options:
|
options:
|
||||||
|
@ -87,3 +87,6 @@ git-annex.linux:
|
||||||
sssg:
|
sssg:
|
||||||
-cp ~/git/sssg/sssg.sh ~/.local/bin/sssg
|
-cp ~/git/sssg/sssg.sh ~/.local/bin/sssg
|
||||||
-chmod +x ~/.local/bin/sssg
|
-chmod +x ~/.local/bin/sssg
|
||||||
|
|
||||||
|
statusbar-polyfill:
|
||||||
|
cp ~/dot_testing/builds/statusbar/termux-statusbar-polyfill ~/.local/bin
|
||||||
|
|
|
@ -1,8 +1,8 @@
|
||||||
from multiprocessing import Process, Queue
|
from multiprocessing import Process, Queue
|
||||||
from collections import defaultdict
|
from collections import defaultdict
|
||||||
from sys import argv
|
from sys import argv, stdout
|
||||||
from sys import stdout
|
|
||||||
from math import floor
|
from math import floor
|
||||||
|
from socket import gethostname
|
||||||
import datetime
|
import datetime
|
||||||
import signal
|
import signal
|
||||||
import subprocess
|
import subprocess
|
||||||
|
@ -56,7 +56,10 @@ def filemodfactory(filename: str, modname: str):
|
||||||
|
|
||||||
def new_mail(queue, _):
|
def new_mail(queue, _):
|
||||||
while True:
|
while True:
|
||||||
dir_output = os.listdir("/home/usr/Mail/main/INBOX/new")
|
try:
|
||||||
|
dir_output = os.listdir("/home/usr/Mail/main/INBOX/new")
|
||||||
|
except FileNotFoundError: # we're on the phone, no mail here
|
||||||
|
return
|
||||||
dir_output = len(dir_output)
|
dir_output = len(dir_output)
|
||||||
queue.put({
|
queue.put({
|
||||||
"module": "newmail",
|
"module": "newmail",
|
||||||
|
@ -69,7 +72,10 @@ def bspwm(queue, monitor):
|
||||||
socket.AF_UNIX,
|
socket.AF_UNIX,
|
||||||
socket.SOCK_STREAM
|
socket.SOCK_STREAM
|
||||||
)
|
)
|
||||||
client.connect("/tmp/bspwm_1_0-socket")
|
try:
|
||||||
|
client.connect("/tmp/bspwm_1_0-socket")
|
||||||
|
except: # perhaps we're on the phone?
|
||||||
|
client.connect("/data/data/com.termux/files/usr/tmp/bspwm_1_0-socket")
|
||||||
|
|
||||||
message = "subscribe\0".encode()
|
message = "subscribe\0".encode()
|
||||||
client.send(message)
|
client.send(message)
|
||||||
|
@ -143,37 +149,57 @@ def render(modules) -> str:
|
||||||
print(output, end='')
|
print(output, end='')
|
||||||
stdout.flush()
|
stdout.flush()
|
||||||
|
|
||||||
|
def start_statusbars():
|
||||||
|
# is there an actually good xrandr library?
|
||||||
|
xrandr = subprocess.Popen(['xrandr'], stdout=subprocess.PIPE, stderr=subprocess.STDOUT)
|
||||||
|
output = list(xrandr.stdout)
|
||||||
|
output = [i.decode("utf-8") for i in output if " connected" in i.decode("utf-8")]
|
||||||
|
serialized = []
|
||||||
|
for i in output:
|
||||||
|
splitted = i.split(' ')
|
||||||
|
print(splitted)
|
||||||
|
displayname = splitted[0]
|
||||||
|
geometry = splitted[2]
|
||||||
|
if geometry == "primary":
|
||||||
|
geometry = splitted[3]
|
||||||
|
|
||||||
|
try:
|
||||||
|
geometry_splitted = [int(i) for i in geometry.replace('x', '+').split('+')]
|
||||||
|
except ValueError:
|
||||||
|
continue
|
||||||
|
geometry_splitted[1] = 20
|
||||||
|
print(displayname, geometry_splitted)
|
||||||
|
os.system("st -c statusbar -p -g {}x{}+{}+{} -e statusbar {} & disown".format(
|
||||||
|
*map(str, geometry_splitted),
|
||||||
|
displayname
|
||||||
|
))
|
||||||
|
|
||||||
def main():
|
def main():
|
||||||
try:
|
try:
|
||||||
os.mkdir("/home/usr/.cache/statusbar")
|
os.mkdir("/home/usr/.cache/statusbar")
|
||||||
except FileExistsError:
|
except FileExistsError:
|
||||||
pass
|
pass
|
||||||
|
except FileNotFoundError:
|
||||||
|
# we're on the phone
|
||||||
|
try:
|
||||||
|
os.mkdir("/data/data/com.termux/files/home/.cache/statusbar")
|
||||||
|
except FileExistsError:
|
||||||
|
pass
|
||||||
|
|
||||||
if argv[1] == "start_statusbars":
|
if argv[1] == "start_statusbars":
|
||||||
# get the monitors
|
hostname = gethostname()
|
||||||
xrandr = subprocess.Popen(['xrandr'], stdout=subprocess.PIPE, stderr=subprocess.STDOUT)
|
|
||||||
output = list(xrandr.stdout)
|
|
||||||
output = [i.decode("utf-8") for i in output if " connected" in i.decode("utf-8")]
|
|
||||||
serialized = []
|
|
||||||
for i in output:
|
|
||||||
splitted = i.split(' ')
|
|
||||||
print(splitted)
|
|
||||||
displayname = splitted[0]
|
|
||||||
geometry = splitted[2]
|
|
||||||
if geometry == "primary":
|
|
||||||
geometry = splitted[3]
|
|
||||||
|
|
||||||
try:
|
if not hostname == "localhost": # if we're not the phone
|
||||||
geometry_splitted = [int(i) for i in geometry.replace('x', '+').split('+')]
|
start_statusbars()
|
||||||
except ValueError:
|
else:
|
||||||
continue
|
# we are the phone
|
||||||
geometry_splitted[1] = 20
|
os.system("/data/data/com.termux/files/usr/bin/bash -c 'st -c statusbar -p -g {}x{}+{}+{} -e termux-statusbar-polyfill {} & disown'".format(
|
||||||
print(displayname, geometry_splitted)
|
1920, 50, 0, 980,
|
||||||
os.system("st -c statusbar -p -g {}x{}+{}+{} -e statusbar {} & disown".format(
|
"VNC-0"
|
||||||
*map(str, geometry_splitted),
|
|
||||||
displayname
|
|
||||||
))
|
))
|
||||||
|
|
||||||
return
|
return
|
||||||
|
|
||||||
queue = Queue()
|
queue = Queue()
|
||||||
modules = [bspwm, clock, battery, batterystatus, sxhkdmode, new_mail]
|
modules = [bspwm, clock, battery, batterystatus, sxhkdmode, new_mail]
|
||||||
[Process(target=module, args=(queue, argv[1])).start() for module in modules]
|
[Process(target=module, args=(queue, argv[1])).start() for module in modules]
|
||||||
|
|
|
@ -0,0 +1,3 @@
|
||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
python3 ~/dot_testing/builds/statusbar/statusbar/statusbar.py $@
|
|
@ -183,6 +183,7 @@ case "$(hostname)" in
|
||||||
bspc config top_padding 0
|
bspc config top_padding 0
|
||||||
bspc config bottom_padding 100
|
bspc config bottom_padding 100
|
||||||
mkdir -p ~/.cache/statusbar
|
mkdir -p ~/.cache/statusbar
|
||||||
|
termux-statusbar-polyfill start_statusbars
|
||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue