171 Commits

Author SHA1 Message Date
Callum Andrew
0457e35d0d sxmo_hook_apps.sh: add qalc (cli calculator)
Signed-off-by: Anjandev Momi <anjan@momi.ca>
2024-12-09 17:52:22 -08:00
Callum Andrew
2ae4cee5e2 sxmo_hook_apps.sh: remove duplicate entries
Signed-off-by: Anjandev Momi <anjan@momi.ca>
2024-12-08 23:55:44 -08:00
Maarten van Gompel
b44795554f sxmo_migrate.sh: fixed fallback color diff
It worked with GNU sed but not with busybox sed.
This current version works with both.

Signed-off-by: Maarten van Gompel <proycon@anaproy.nl>
2024-12-03 11:40:43 +01:00
hazardchem
65815b84de sxmo_hook_contextmenu.sh: added links options.
Signed-off-by: hazardchem <hazardchem@disroot.org>
Signed-off-by: Maarten van Gompel <proycon@anaproy.nl>
2024-12-01 14:04:09 +01:00
hazardchem
4c25adcf5f sxmo_hook_apps.sh: Added clipmenu and megapixels to menu.
Signed-off-by: hazardchem <hazardchem@disroot.org>
Signed-off-by: Maarten van Gompel <proycon@anaproy.nl>
2024-12-01 13:53:30 +01:00
hazardchem
9dfac57e70 sxmo_hook_apps.sh: Reordered apps to alphabetical order.
Signed-off-by: hazardchem <hazardchem@disroot.org>
Signed-off-by: Maarten van Gompel <proycon@anaproy.nl>
2024-12-01 13:52:35 +01:00
Callum Andrew
7f036513c5 sxmo_hook_apps.sh: add lpa gtk (esim manager)
also move mepo to the right location

Signed-off-by: Anjandev Momi <anjan@momi.ca>
2024-12-01 01:26:48 -08:00
hazardchem
92a8034653 sxmo_hook_contextmenu.sh: Added All Chats option to iamb.
Signed-off-by: hazardchem <hazardchem@disroot.org>
Signed-off-by: Anjandev Momi <anjan@momi.ca>
2024-12-01 01:24:49 -08:00
Callum Andrew
7b4136253a sxmo_hook_apps.sh: add simple scan
also change seahorse icon to key

Signed-off-by: Maarten van Gompel <proycon@anaproy.nl>
2024-11-30 14:23:34 +01:00
hazardchem
9ccb327d69 sxmo_hook_contextmenu.sh: added enter url to list for netsurf.
Signed-off-by: hazardchem <hazardchem@disroot.org>
Signed-off-by: Maarten van Gompel <proycon@anaproy.nl>
2024-11-30 14:19:34 +01:00
hazardchem
dfd5d67f45 sxmo_hook_inputhandler.sh: added options for links/netsurf.
Actions are similar so it warranted adding to one patch.

Signed-off-by: hazardchem <hazardchem@disroot.org>
Signed-off-by: Maarten van Gompel <proycon@anaproy.nl>
2024-11-30 14:17:08 +01:00
hazardchem
36d0d4d03f Add in touchscreen id into OnePlus 6 profile
This is needed by dwm as screen rotation and screenoff states don't work correctly.

Signed-off-by: hazardchem <hazardchem@disroot.org>
Signed-off-by: Maarten van Gompel <proycon@anaproy.nl>
2024-11-30 14:09:24 +01:00
Maarten van Gompel
fd44d2693d sxmo_hook_lockstatusbar.sh: added exec 2024-11-26 15:14:07 +01:00
Maarten van Gompel
6bb78da702 Disable most of input handler when a locker is running
A problem was introduced in 4562daea67
because it kind-of bypasses the state mechanism. Whenever a locker was
running the state would remain `unlock` and therefore the inputhandler
would be fully enabled and menus could still be opened with gestured
(although they wouldn't show because of the locker).

This patch solves that, it's not an ideal implementation but is
a bit of a minimal temporary patch until we revise/simplify the
entire state locking mechanism.

It also moves the burden of removing icons for peanutbutter to
sxmo_hook_statusbar instead of sxmo_hook_lockstatusbar

Signed-off-by: Willow Barraco <contact@willowbarraco.fr>
2024-11-26 15:06:09 +01:00
Maarten van Gompel
84b61f4a72 Support LEDs on devices like Oneplus 6
This wasn't working out-of-the-box yet. A udev rule is needed.

This re-adds LED permissions as suggested in https://lists.sr.ht/~mil/sxmo-devel/patches/44149
and reverts a small part of 7a77851c9a .

Co-authored-by: Zach Decook <zachdecook@librem.one>

Ref: https://codeberg.org/magdesign/sxmop6/src/branch/main/rules/99-custom-led-permissions.rules
Ref: https://wiki.postmarketos.org/wiki/LEDs#Changing_permissions_in_sysfs
Signed-off-by: Willow Barraco <contact@willowbarraco.fr>
2024-11-26 15:06:09 +01:00
magdesign
d334511370 hide duplicated wifi SSIDs and show the security
If you select to connect to a wifi without security, it will not ask you
for a password anymore.

Ref: https://todo.sr.ht/~mil/sxmo-tickets/603
Co-authored-by: Maarten van Gompel <proycon@anaproy.nl>
Signed-off-by: Willow Barraco <contact@willowbarraco.fr>
2024-11-26 15:06:09 +01:00
Maarten van Gompel
0446e654cd documentation: improved services description
Signed-off-by: Willow Barraco <contact@willowbarraco.fr>
2024-11-26 15:06:09 +01:00
Peter John Hartman
11a82dfa28 Do nothing when dismissing notif
If a user swipes up, they will dismiss the notification without doing
its action, but if they touch the notification they will execute its
action.

This is useful when you get a lot of popups or if you (like me) have
your popup notifications decay only after a very very very long time.

I also thing the default delay for notifications should be extremely
long (24hrs), so you can easily see what sms messages you received.

NB: I have not tested on dwm (may need to add an on-touch option there
too).

NB2: I also think that this might all go into a hook instead so we can
let the user control what to do with popups?

Signed-off-by: Maarten van Gompel <proycon@anaproy.nl>
2024-11-26 14:13:08 +01:00
Maarten van Gompel
3bc52ff642 sxmo_migrate: added a colordiff alternative and allow for different diff order
This implements:
* use of delta instead of colordiff or diff, if installed
* a colordiff fallback if none is installed
* support for different diff order by setting SXMO_MIGRATE_ORDER to
  "user:system", also included a runtime switch
* an extra explanation to interpret the diff correctly

Signed-off-by: Willow Barraco <contact@willowbarraco.fr>
2024-11-26 13:54:21 +01:00
Willow Barraco
a95376738f Back out "sxmo_wm: use lswt to find active window"
This backs out commit 2f800272a0.
2024-11-26 09:33:41 +01:00
Maarten van Gompel
f6377a2cbc added configuration file for hut-cli
makes using hut easier, example:

* hut lists patchset list
* hut ticket list
2024-11-25 22:02:13 +01:00
Maarten van Gompel
a15d514aa3 fixup: tthree-letter icon name 2024-11-25 21:02:37 +01:00
Callum Andrew
664b8b3649 Use neovim logo in app menu
Signed-off-by: Maarten van Gompel <proycon@anaproy.nl>
2024-11-25 21:01:24 +01:00
Maarten van Gompel
899dad32db Moved "All Apps" entry to main menu
For consistency between wofi and other menus, and for easier access

Signed-off-by: Maarten van Gompel <proycon@anaproy.nl>
2024-11-25 19:40:40 +01:00
hazardchem
a73741f643 sxmo_tabbed.sh: Added urxvt launcher
Signed-off-by: hazardchem <hazardchem@disroot.org>
Signed-off-by: Maarten van Gompel <proycon@anaproy.nl>
2024-11-25 19:28:38 +01:00
Maarten van Gompel
793b0c6173 docs: removed part on device-specific hooks (we no longer use them)
Signed-off-by: Maarten van Gompel <proycon@anaproy.nl>
2024-11-25 19:23:23 +01:00
Maarten van Gompel
f8067a1d89 documentation: minor link update 2024-11-25 13:43:19 +01:00
Callum Andrew
eb31dc88ce sxmo_hook_apps.sh: add nautilus and papers (document reader)
also move pavucontrol to the right location

Signed-off-by: Maarten van Gompel <proycon@anaproy.nl>
2024-11-20 11:42:23 +01:00
Maarten van Gompel
f2de84c2a6 making all device profile executable 2024-11-20 11:40:31 +01:00
Callum Andrew
6314236a72 Add deviceprofile for Google Pixel 3a XL (google-bonito)
Signed-off-by: Maarten van Gompel <proycon@anaproy.nl>
2024-11-20 11:39:36 +01:00
Callum Andrew
171cfbdf67 Add Metronome app
Signed-off-by: Maarten van Gompel <proycon@anaproy.nl>
2024-11-17 12:47:05 +01:00
Maarten van Gompel
91c3d645b2 sxmo_hook_apps.sh: added newsraft (RSS reader)
Signed-off-by: Aren Moynihan <aren@peacevolution.org>
2024-11-15 14:31:53 -05:00
Maarten van Gompel
ffce273794 docs: minor clarification 2024-11-15 12:01:26 +01:00
shivers
f1dbcb0b4e sxmo_hook_tailtextlog: Fix DATESEDCMD to be non-greedy
Signed-off-by: Maarten van Gompel <proycon@anaproy.nl>
2024-11-11 16:17:25 +01:00
Maarten van Gompel
94e0122a11 minor language fix in variable/file name 2024-11-08 14:18:27 +01:00
Maarten van Gompel
521d9a6e54 documentation: SXMO_NOTCH 2024-11-08 11:22:55 +01:00
Maarten van Gompel
2e01439104 documentation: significant overhaul (man pages)
This is a significant overhaul of the Sxmo documentation. I'm building
upon the work Peter (wart) started, to provide proper man pages for Sxmo.
I think man pages fit our philosophy well, and ensure that all
essential documentation is always available offline on-device.

The user can simply do `man sxmo` and get the full manual (which was
called our 'user guide' in the old setup). I favour keeping this man
page as the sole source and automatically derive things for the
sxmo-docs repo (which is rather convoluted with multiple branches now).
Storing the documentation right-alongside sxmo-utils has the big
advantage of it describing (ideally) the exact version it is stored
alongside with. Submitted patches can do both implementation and
documentation in one go.

Things in this patch:

* Sections that were missing were added
* Some new man pages dedicated to specific scripts were added  (*.1.scd)
* Rewrote various parts to make the language better/clearer.
* Reordered things.
* Information that was out-of-date or incomplete has been updated (to
  the best of my knowledge)
* Applied a consistent style.
* Added HTML conversions in the Makefile (via groff and some hacky
  post-processing to insert decent hyperlinks, 'man' is a bit ancient)
* Added a 'Help' item in the main menu which opens the Sxmo man page in a terminal
* Updated the description of some hooks

This is not necessarily done yet (is documentation ever?), but it
provides a solid foundation I think. Some sections may need some further
work and everything should at least be checked thoroughly by others for
accuracy.
2024-11-08 11:22:55 +01:00
Maarten van Gompel
d7a77bb1c0 fixup: comment 2024-11-07 23:13:06 +01:00
Maarten van Gompel
2db900ce51 sxmo_hook_lockstatusbar: remove notch placeholder in peanutbutter 2024-11-07 22:57:10 +01:00
Maarten van Gompel
c4f2fb9df5 sxmo_networks: fixed typo in function name 2024-11-07 22:03:21 +01:00
Maarten van Gompel
867fe86ca4 sxmo_hook_statusbar: simple suboptimal notch implementation
* set SXMO_NOTCH to a string to use for the notch (length determines width), do not use spaces/tabs
* optionally set SXMO_NOTCH_PRIO to a placement value (trial and error)

Signed-off-by: Maarten van Gompel <proycon@anaproy.nl>
2024-11-07 21:38:36 +01:00
Kaan Çırağ
7d658baa6d Add device profile for Alcatel Idol 3 (alcatel-idol3)
Signed-off-by: Maarten van Gompel <proycon@anaproy.nl>
2024-11-05 10:29:01 +01:00
Aren Moynihan
843517fb6a Makefile: remove unused references to sxmo sepermissions
The setpermissions daemon was removed, so this is dead code now.
Remove it.

Signed-off-by: Maarten van Gompel <proycon@anaproy.nl>
2024-11-04 22:33:41 +01:00
Aren Moynihan
2f800272a0 sxmo_wm: use lswt to find active window
Using lswt allows us to use the context menu on any wayland compositor
that supports the wlr-foreign-toplevel-management protocol.

Signed-off-by: Aren Moynihan <aren@peacevolution.org>
Signed-off-by: Maarten van Gompel <proycon@anaproy.nl>
2024-11-02 20:36:34 +01:00
Maarten van Gompel
4bcbf0503d add polkit rule for iio-sensor-proxy sensor claim
Signed-off-by: Aren Moynihan <aren@peacevolution.org>
2024-11-02 10:29:11 -04:00
Maarten van Gompel
921fa1e24c Prevent HexagonRPCD from freezing device after wake
This solves the following issue on a Google Pixel 3a:
* https://gitlab.postmarketos.org/postmarketOS/pmaports/-/issues/3052
* https://gitlab.postmarketos.org/postmarketOS/pmaports/-/merge_requests/5400

Since we don't use elogind for suspend, we have to handle this logic
ourselves.

Though I'm not fond of device-specific code in our main scripts, the
generic solution wasn't really recommended.

Signed-off-by: Aren Moynihan <aren@peacevolution.org>
2024-11-02 09:18:09 -04:00
Maarten van Gompel
4562daea67 launch screen lock if installed
This will launch peanutbutter (if it is installed) when the screen turns
off. It also omits the locked/screen-on stage then because it has less
added value and is in the way.

I'd recommend having users explicitly install peanutbutter themselves
(and read the manual) rather than have it pulled in automatically, as
users need to know the default unlock code or they get locked out of
there session. But this way no hooks need to be adapted if it's
installed, and it will out-of-the-box show the status icons on the
lockscreen.

Signed-off-by: Aren Moynihan <aren@peacevolution.org>
2024-11-02 09:14:21 -04:00
Willow Barraco
be4a4366ff Fix sxmo_brun.sh with recent changes
NOw that we need SXMO_MENU, we had the same fallback when it is left
unset than in sxmo_dmenu.sh

We also fix the typo on bmenu.
2024-10-30 21:23:53 +01:00
Willow Barraco
f3ae894e7f Remove unalias wofi 2024-10-30 21:10:55 +01:00
Maarten van Gompel
81d8457b93 fixup: replaced gdbus call with dbus-send for consistency
Co-authored-by: Sicelo A. Mhlongo <absicsz@gmail.com>
2024-10-25 22:06:28 +02:00
Sicelo A. Mhlongo
6534048c03 autorotate: switch to iio-sensor-proxy
iio-sensor-proxy abstracts iio (and sensors exposed in other kernel
subsystems). it can simplify the autorotate script, removing the need for
variables such as ROTATION_GRAVITY.

it also makes it possible to use the same code to support 'non-standard'
accelerometers, such as those on SDM845 devices.

prerequisites:
    - `iio-sensor-proxy must` be installed and be running on the system (it
        provides `monitor-sensor`)
    - a PolicyKit rule to permit the regular user to claim sensors must be
        installed in `/etc/polkit-1/rules.d/01-sensor-claim.rules`, containing
        the following:

        ```
        polkit.addRule(function(action, subject) {
            if (action.id == "net.hadess.SensorProxy.claim-sensor" &&
                subject.isInGroup("plugdev")) {
                    return polkit.Result.YES;
                }
        });
        ```

Signed-off-by: Maarten van Gompel <proycon@anaproy.nl>
2024-10-25 20:23:58 +02:00
Roberto Castagnola
ae8c63508a Add hook for blocking numbers
Signed-off-by: Roberto Castagnola <roberto.castagnola@gmail.com>
Signed-off-by: Maarten van Gompel <proycon@anaproy.nl>
2024-10-25 18:49:37 +02:00
osms
ff4b10aa72 Basic configuration for Asus grouper
Signed-off-by: Maarten van Gompel <proycon@anaproy.nl>
2024-10-25 18:05:26 +02:00
Maarten van Gompel
4d7037d7bf fixup: indentation 2024-10-25 17:46:05 +02:00
hazardchem
0b77df6b6e statusbar: remove redundant symbols when modem has failed or unknown
This modifies the statusbar hook so that if there is a modem state that doesn't
match failed or unknown then show used techs and signal.

Currently if there isn't a sim in the modem there will be $icon_modem_failed, $icon_modem_notech, and $icon_modem_signal_0.

After this all that shows is $icon_modem_failed.

Signed-off-by: hazardchem <hazardchem@disroot.org>
Signed-off-by: Maarten van Gompel <proycon@anaproy.nl>
2024-10-25 17:36:47 +02:00
Elie Le Vaillant
160d25659a configversion: support xml files
This is needed for fontconfig.conf.

Signed-off-by: Maarten van Gompel <proycon@anaproy.nl>
2024-10-22 10:19:48 +02:00
Maarten van Gompel
516c6d25db Added deviceprofile for Google Pixel 3a (google-sargo)
Co-authored-by: fdelamotte
2024-10-18 22:37:24 +02:00
Willow Barraco
ea8a95b58c menu: compute the default SXMO_MENU when unsetted
With the recent wofi patch, we now require for the env variable to be
present (or sxmo_dmenu.sh will fails to actually start something).

With this change, we fallback to the old choice, depending on the WM.
2024-10-15 14:33:11 +02:00
Maarten van Gompel
ab56046aee Added support for wofi as a dmenu/bemenu alternative
I refactored some code to make exchanging menus a little bit easier
and I added wofi as new menu option.

The menu to use can be configured via the new environment variable
SXMO_MENU. Its value may be bemenu, dmenu, or wofi, *NOT* any arbitrary
binary. This variable will be automatically populated if not set, based on if
you're on wayland or Xorg.

setup_config_version.sh was extended to allow a configversion in CSS
comments (needed for wofi). I designed a theme that mimicks the default
style we have for bemenu/dmenu, with slightly more spacing perhaps.

Wofi can scan *.desktop files (drun mode), so I added an "All Apps" option that
makes use of that. Some further work is still required there however
to get wofi to properly launch terminal apps from there.

Wofi also has some issues positioning in landscape mode after the screen
was rotated, so my solution there is a bit hacky. May be an upstream
issue.

Signed-off-by: Willow Barraco <contact@willowbarraco.fr>
2024-10-15 13:21:28 +02:00
Willow Barraco
56f1fe1cdb proximitylock: do not restore initial state if the user changed it in between
To do this, we add store, restore, and flushstored to sxmo_state.sh.

store output an id that the caller have to give back to restore. This way,
multiple caller can store, and only the first one that restore actually
does so. This ensure some consistency to the end state workflow.

Any user click in between automatically flushstored, so that the end of
proximitylock will not restore to initial state.
2024-09-18 11:23:37 +02:00
Willow Barraco
4cda522a09 modem: do not vibrate after muted calls 2024-09-18 11:17:18 +02:00
Willow Barraco
d60c7ca2eb Fix indentation 2024-09-12 17:07:17 +02:00
Willow Barraco
75ed8bc5d3 Fix stretched wallpaper
The argument was quoted, so ignored by swaybg.
2024-09-12 17:03:55 +02:00
Willow Barraco
c9fe95684c fix unreliable sxmo_proximitylock.sh
Most of the time, this feature just does not works on my phone. No event
are triggered. So let's got back to the good old manual probing.
2024-09-12 08:32:55 +02:00
Willow Barraco
73b374f677 sxmo_notification*.sh: Rework and cleanup
This is a complete rewrite, and group every scripts in a single
sxmo_notifs.sh one.

Also: Replace the watch file feature with a more generic notification group
one.

This feature make the user to miss notifications if the conversation file is
already open. It also cause problems when used with Syncthing, as this cause
notifications to be dropped when it synchronise files. It is also pointless
now that opening a notification to an opened conversation just focus the
corresponding terminal.

I think that dropping this feature completly is okay, make things simple,
and simplify the code

But in the same time:

Opening a notification should close all other ones for the same
conversations. So to cover this case, we add an optional group when
creating notifications. Discarding a notification now close all related
ones from the same group.
2024-09-12 08:31:46 +02:00
Willow Barraco
e8baf38440 Bring back SXMO_BG_IMG support 2024-08-25 13:59:13 +02:00
Willow Barraco
3de2fced00 Deduplicate wallpaper services and drop SXMO_BG_IMG 2024-08-25 13:57:10 +02:00
Willow Barraco
9f7c9da445 Keep the bg when reloading config
To achieve this, and more, we move the swaybg command to a monitored
service.
2024-08-25 13:57:08 +02:00
hazardchem
54ebae73d3 app: tabbed
Added tabbed to sxmo_hook_apps.sh by calling sxmo_tabbed.sh

sxmo_tabbed.sh:

This program provides a list of programs with their embedded call and
will start a tabbed session with that program inside, or nothing starts
a tabbed session with nothing inside.

Signed-off-by: hazardchem <hazardchem@disroot.org>
Signed-off-by: Aren Moynihan <aren@peacevolution.org>
2024-08-24 11:13:47 -04:00
hazardchem
f869295c1a sxmo_wm.sh: fix fringe cases in focused program
Found that the mpv pseudo-gui listed its WM_CLASS as `WM_CLASS(STRING) = "gl", "mpv"`

xorgfocusedwindow was only looking at the first field for the app: rename so it
was always set to gl. This patch changes the field to the second.

Testing on my machine hasn't found any issues as everything was detected
correctly on a few different windows.

Signed-off-by: hazardchem <hazardchem@disroot.org>
Signed-off-by: Aren Moynihan <aren@peacevolution.org>
2024-08-21 15:10:33 -04:00
Willow Barraco
23617f1dad sxmo_audio.sh: add a busy mode
This mode disable ring and vibration from calls and messages. It is also
possible to enable this mode for a period of time.

Signed-off-by: Willow Barraco <contact@willowbarraco.fr>
Signed-off-by: Aren Moynihan <aren@peacevolution.org>
2024-08-21 15:05:31 -04:00
Willow Barraco
f446630465 sxmo_hook_sms.sh: use a return fast form
Signed-off-by: Willow Barraco <contact@willowbarraco.fr>
Signed-off-by: Aren Moynihan <aren@peacevolution.org>
2024-08-21 15:05:31 -04:00
hazardchem
20a89df023 contextmenu.sh: fixed issue with tabbed menu sending Ctrl + `
Signed-off-by: hazardchem <hazardchem@disroot.org>
Signed-off-by: Aren Moynihan <aren@peacevolution.org>
2024-08-21 14:56:40 -04:00
Willow Barraco
72c78db377 sms: fix newline EOL while sending messages
Some text editors, as kakoune, automatically add an ending newline while
saving buffers to files. This is because the convention on UNIX systems,
is that files ends with newline.

While sending sms using a file as resource, modem manager keep this. I
already discussed this with the maintainer:

https://gitlab.freedesktop.org/mobile-broadband/ModemManager/-/issues/830

So we basically have to do this ourselves.

The problems appeared when we switched to this new argument
--messaging-create-sms-with-text. It fixes our quoting issues, but it
introduce this problem, when the editor does the right thing.

To solve this, we create a temporary file, without this ending newline.
The finish script trap will clean in afterward.

Signed-off-by: Willow Barraco <contact@willowbarraco.fr>
Signed-off-by: Aren Moynihan <aren@peacevolution.org>
2024-08-21 14:12:46 -04:00
Maarten van Gompel
64b4c63a1b sxmo_hook_apps.sh: added flare (signal client)
Note: If you have no Android/iOS instance to link to as primary device, you
can run signal-cli (either on the same device as flare or on any
other), that also allows you to register a number.

Signed-off-by: Aren Moynihan <aren@peacevolution.org>
2024-08-21 14:12:46 -04:00
Aren Moynihan
07e306e939 builds: add missing linux-headers to env
The build was failing with this error:

programs/sxmo_vibrate.c:16:10: fatal error: linux/input.h: No such file or directory
   16 | #include <linux/input.h>

Signed-off-by: Aren Moynihan <aren@peacevolution.org>
2024-08-21 14:12:46 -04:00
Aren Moynihan
c54ccb1485 spec: sxmo_status_led: fix shellchick directive
Signed-off-by: Aren Moynihan <aren@peacevolution.org>
2024-08-21 12:10:53 -04:00
Aren Moynihan
47b80502d9 Makefile: cleanup handling of c compiler arguments
The c compiler seems to be rather picky about the order arguments are
defined in, I was having trouble building sxmo_status_led in some
conditions because -lm was in the wrong spot.

This is the order that these are supplied in the built-in rules
documentation of the gnu make manual.

While here, make cflags include any cflags passed by environment
variable, such as from a package build script.

Signed-off-by: Willow Barraco <contact@willowbarraco.fr>
2024-08-19 08:33:18 +02:00
Aren Moynihan
86dbca1502 autodetect SXMO_DISABLE_LEDS
The new sxmo_status_led program can tell us if it finds a suitable led
on the system. We can use this to set the SXMO_DISABLE_LEDS env
variable.

Signed-off-by: Willow Barraco <contact@willowbarraco.fr>
2024-08-18 15:40:31 +02:00
Aren Moynihan
ec78d3b95b add program to manage status leds
This also support for multicolor leds which wasn't supported by
brightnessctl. And it provides a significant performance improvement.

The sxmo_led.sh script takes quite a bit of cpu power to run, which
isn't great because it runs about every 2 seconds when the system is
idle. This rewrites most of it in c which should solve help speed it up.

Before the led blink process would consume somewhere around 20% cpu
usage (0.7 seconds / 3 seconds total for a blink). After this patch it
should come down closer 10% cpu usage. This is significantly better, but
still not very good. I think most of the remaining time is being spent
in sxmo_wakelock.sh, reimplementing that and/or finding a way to not
need it will probably be necessary to get this to execute in a
reasonable amount of time.

Before:

$ sudo perf stat -r 8 ./scripts/core/sxmo_led.sh blink red blue
 Performance counter stats for './scripts/core/sxmo_led.sh blink red blue' (8 runs):

     796.76 msec task-clock       #    0.715 CPUs utilized   ( +-  1.64% )
        316      context-switches #  396.604 /sec            ( +-  3.77% )
         35      cpu-migrations   #   43.928 /sec            ( +-  7.87% )
     12,505      page-faults      #   15.695 K/sec           ( +-  0.04% )
883,688,799      cycles           #    1.109 GHz             ( +-  2.16% )
310,020,051      instructions     #    0.35  insn per cycle  ( +-  0.09% )
 33,193,824      branches         #   41.661 M/sec           ( +-  0.09% )
  5,169,519      branch-misses    #   15.57% of all branches ( +-  0.19% )

     1.1151 +- 0.0274 seconds time elapsed  ( +-  2.46% )

$ hyperfine 'sxmo_led.sh blink red blue'
Benchmark 1: sxmo_led.sh blink red blue
  Time (mean ± σ):      1.059 s ±  0.042 s    [User: 0.284 s, System: 0.458 s]
  Range (min … max):    1.013 s …  1.163 s    10 runs

After:

$ sudo perf stat -r 8 sxmo_led.sh blink red blue
Performance counter stats for 'sxmo_led.sh blink red blue' (8 runs):

     347.50 msec task-clock       #    0.337 CPUs utilized   ( +-  2.25% )
        176      context-switches #  506.474 /sec            ( +-  8.81% )
         13      cpu-migrations   #   37.410 /sec            ( +- 19.22% )
      3,243      page-faults      #    9.332 K/sec           ( +-  0.05% )
383,056,720      cycles           #    1.102 GHz             ( +-  2.84% )
143,365,214      instructions     #    0.37  insn per cycle  ( +-  0.14% )
 15,816,749      branches         #   45.516 M/sec           ( +-  0.15% )
  2,520,323      branch-misses    #   15.93% of all branches ( +-  0.46% )

     1.0326 +- 0.0359 seconds time elapsed  ( +-  3.48% )

$ hyperfine 'sxmo_led.sh blink red blue'
Benchmark 1: sxmo_led.sh blink red blue
  Time (mean ± σ):      1.006 s ±  0.027 s    [User: 0.128 s, System: 0.186 s]
  Range (min … max):    0.963 s …  1.051 s    10 runs

Signed-off-by: Willow Barraco <contact@willowbarraco.fr>
2024-08-18 15:40:28 +02:00
Eloi Torrents
c5f4abff77 Add Eye of Gnome to apps
Signed-off-by: Anjandev Momi <anjan@momi.ca>
2024-07-20 22:00:27 -07:00
Raymond Hackley
ba45b2abf3 configs/default_hooks: drop symbolic links to three_button_touchscreen
configs/default_hooks/three_button_touchscreen has been dropped in
b09469d965.
Drop broken symbolic links to it.

Signed-off-by: Raymond Hackley <raymondhackley@protonmail.com>
Signed-off-by: Maarten van Gompel <proycon@anaproy.nl>
2024-07-20 22:41:50 +02:00
hazardchem
c25eacff14 sxmo_hook_contextmenu.sh: tabbed: add menu options
Signed-off-by: hazardchem <hazardchem@disroot.org>
2024-07-10 11:34:49 -04:00
hazardchem
37b7e4ec18 sxmo_hook_contextmenu.sh: mupdf: add menu options
Signed-off-by: hazardchem <hazardchem@disroot.org>
2024-07-10 11:34:49 -04:00
hazardchem
6c6b4aa6ff sxmo_hook_contextmenu.sh: badwolf: fix spacing on reset zoom
Signed-off-by: hazardchem <hazardchem@disroot.org>
2024-07-10 11:34:48 -04:00
hazardchem
96fd0e0088 sxmo_hook_contextmenu.sh: iamb: Add close view/quit menu entry
Signed-off-by: hazardchem <hazardchem@disroot.org>
2024-07-10 11:34:48 -04:00
hazardchem
d1867650fa sxmo_hook_apps.sh: Added new entries for various programs.
Instead of individual patches for each program, this patch includes
my local additions to the hook.

Signed-off-by: hazardchem <hazardchem@disroot.org>
2024-07-10 11:27:05 -04:00
Aljoscha Hartmann
3f41756429 Add Index, Kcalc and Itinerary to the app menu 2024-07-10 11:06:57 -04:00
Sicelo A. Mhlongo
c714514d3a sway: drop nomod mode
91d4319df5 ("sway: add config for Nokia N900") added a new sway mode
to cater for the limitations imposed by the Nokia N900's physical
keyboard. At least one user reported a conflict with their keybinds.
Drop the mode and its binding from the global configuration. It can be
moved to a device-specific configuration, and be stored under
/etc/sway/config.d/* per sway's default/global include directive

Fixes: 91d4319df5 ("sway: add config for Nokia N900")
Fixes: https://lists.sr.ht/~mil/sxmo-devel/patches/53195

Signed-off-by: Sicelo A. Mhlongo <absicsz@gmail.com>
2024-07-10 10:57:43 -04:00
Willow Barraco
585560f018 call: delete call if failed to initiate it 2024-06-17 10:48:25 +02:00
Willow Barraco
6db78c4862 hook_call_audio: drop back and forth hack on mic and speaker
Signed-off-by: Willow Barraco <contact@willowbarraco.fr>
Signed-off-by: Anjandev Momi <anjan@momi.ca>
2024-06-16 21:04:28 -07:00
Sicelo A. Mhlongo
fa2446c568 omap3-n900: provide touchscreen id
Define TOUCHSCREEN_ID so the touchscreen can be reliably disabled when device
is in locked state. When undefined, in some cases it does not get disabled,
causing wakeups.

Signed-off-by: Sicelo A. Mhlongo <absicsz@gmail.com>
Signed-off-by: Anjandev Momi <anjan@momi.ca>
2024-06-16 20:59:28 -07:00
Sicelo A. Mhlongo
a5f81b93aa omap-n900: restore the use of virtual keyboard
While the N900 has a hardware keyboard, it only has a few keys. A virtual keyboard is still very useful to have. Some symbols, especially emoji, cannot be typed easily from hardware keyboard. Hence, restore access to the virtual keyboard using the VolDown key.

Signed-off-by: Sicelo A. Mhlongo <absicsz@gmail.com>
Signed-off-by: Willow Barraco <contact@willowbarraco.fr>
2024-06-11 07:55:21 +02:00
Sicelo A. Mhlongo
27da98032f omap3-n900: set number of lines in dmenu
default dmenu lines are too long for N900's tiny screen. reduce to fit

Signed-off-by: Sicelo A. Mhlongo <absicsz@gmail.com>
Signed-off-by: Anjandev Momi <anjan@momi.ca>
2024-06-09 01:22:42 -07:00
Anjandev Momi
10b4e26d41 n900: disable keyboard 2024-06-09 01:02:40 -07:00
Sicelo A. Mhlongo
fb4928b5a4 rename SXMO_NO_KEYBOARD to make purpose clear
Commit 4913fac4ee ("Cleanup virtual keyboard management") introduced
SXMO_NO_KEYBOARD environment variable to disable virtual keyboard. Rename so
this purpose is clear/obvious from the name.

Drop the variable on Nokia N900, since virtual keyboard is still useful on it,
e.g. for emoji.

Signed-off-by: Sicelo A. Mhlongo <absicsz@gmail.com>
Signed-off-by: Anjandev Momi <anjan@momi.ca>
2024-06-09 00:59:30 -07:00
Willow Barraco
706d1f5fd9 sxmo_version: add msising last line return 2024-06-06 16:16:09 +02:00
Maarten van Gompel
7841952fb1 sxmo_playerctl.sh: return should be exit
In scoprion2185's log I saw:

/usr/bin/sxmo_playerctl.sh: line 31: return: can only `return' from a function or sourced script

As far as I checked, sxmo_playerctl is indeed called normally rather
than sourced so it should be exit instead of return, this patch fixes
that.

Signed-off-by: Willow Barraco <contact@willowbarraco.fr>
2024-06-05 08:14:23 +02:00
Maarten van Gompel
3e03d299ac fixup: syntax 2024-06-04 19:07:53 +02:00
Maarten van Gompel
ee3256b9f6 sxmo_hook_apps.sh: fixed alacritty entry 2024-06-04 19:06:28 +02:00
Willow Barraco
66d866cea2 version: also take un-annotated tags 2024-06-04 15:48:18 +02:00
Aren Moynihan
6d4b5aa4a4 use git attributes to set version in makefile
This adds configuration so that when "git archive" is run, it will
inject the current version into the makefile. This makes it so that we
don't have to do this manually, and packagers don't need to either.

Signed-off-by: Willow Barraco <contact@willowbarraco.fr>
2024-06-04 15:37:13 +02:00
Maarten van Gompel
b6b70ed1f9 sxmo_screenshot: workaround for slurp issues
We've already had a number of patches attempting to resolve this issue,
and an upstream PR to slurp pending for quite a while. I think we need a
solution in the meantime that would work even on the broken version of
slurp (in case distros are behind once a fix is released).

This version also copes with the fat-trembling-finger problem and will
simply take a screenshot of the whole screen if the selection is too
tiny to be reasonable (which may be an issue even in the fixed slurp).

Ref: https://lists.sr.ht/~mil/sxmo-devel/patches/49367
Ref: https://lists.sr.ht/~mil/sxmo-devel/patches/49719
Ref: https://lists.sr.ht/~mil/sxmo-devel/patches/44258
Ref: https://github.com/emersion/slurp/issues/140
Ref: https://github.com/emersion/slurp/pull/141
--
Changes in v2:
- select only one output (adapted from magdesign's patch earlier)
- better error feedback

Signed-off-by: Willow Barraco <contact@willowbarraco.fr>
2024-06-04 15:02:53 +02:00
Willow Barraco
0a1379923f rework how we store VERSION
This drop the hardcoded VERSION, because it is so easy to forget while
releasing. This also fetch better edge tags.

Signed-off-by: Willow Barraco <contact@willowbarraco.fr>
Signed-off-by: Maarten van Gompel <proycon@anaproy.nl>
2024-06-04 12:22:39 +02:00
Maarten van Gompel
e10825ba1a bumped version for next release (we forgot for 1.16) 2024-06-03 21:07:07 +02:00
Willow Barraco
11a16defa5 fix indentation 2024-06-03 08:25:42 +02:00
Willow Barraco
0c1c9ff907 sxmo_rtcwake.sh: refactorise to use sxmo_wakelock.sh run 2024-06-03 00:21:40 +02:00
Willow Barraco
da93740f95 sxmo_rtcwake.sh: make this script actually killeable 2024-06-03 00:01:17 +02:00
Willow Barraco
c68d16d7b6 sxmo_rtcwake.sh: bring back wakelock management
A long time may have passed since sxmo_autosuspend.sh added
sxmo_waiting_cronjob. It means we probably still need to lock before unlocking
here.
2024-06-03 00:01:16 +02:00
Willow Barraco
9c70125f63 sxmo_rtcwake.sh: remove waiting_cronjob lock
This lock may has been set by sxmo_suspend.sh.
2024-06-02 23:30:59 +02:00
Willow Barraco
73390af620 block_suspend: fix eternel loop when mpc is not installed
The logic here has been reverted. We have to exit 1 if it isn't
installed.
2024-06-01 07:47:46 +02:00
Willow Barraco
00c9758a1c wakelock.sh: remove tee error when using "lock infinite"
The code refactorisation feels a bit confusing. But looking at how this
method is implemented, this seems the easiest way.
2024-05-31 18:56:39 +02:00
Willow Barraco
8a92ffde85 sxmo_hook_block_suspend: block if mpc is updating db 2024-05-31 18:54:12 +02:00
Willow Barraco
95bd84db66 sxmo_wakelock.sh: add a run mode to lock and unlock afterward a command
This also remove the automatic lock from the sxmo_rtcwake.sh script. The
user now have to use this cron line to do the same thing:

* * * * * sxmo_rtcwake.sh sxmo_wakelock.sh run sleep 10

This separate both behaviors, and allow more combinations.
2024-05-31 18:51:01 +02:00
Willow Barraco
eaa52601de sxmo_run_periodically.sh: let user choose the clockid
This relies on the previous patchset that implement sxmo_sleep. It
become possible for the user to write a simple daemon that trigger
a command periodically, and waking up the device.
2024-05-31 18:51:01 +02:00
Willow Barraco
fb70b4f8d5 sxmo_run_periodically.sh: rework argument parsing 2024-05-31 18:51:01 +02:00
Willow Barraco
582c9b1b7b sxmo_timer.sh: finish as soon as it get killed
Without this, the script will wait the full second before handling the
kill signal.
2024-05-31 18:46:28 +02:00
Willow Barraco
636053e4f1 sxmo_timer.sh: stop at precise second
-ge means that we wait one additional second. Sleep 5s should actually
wait 5s, no more.
2024-05-31 18:46:27 +02:00
Willow Barraco
13e7a3bc69 sxmo_timer.sh: allow suspension while running
To do this, we implement a new sxmo_sleep program that is a sleep
but that can wake the device from suspension when the timer expires.

Also, stopwatch can perfectly survive a suspension. So we don't have to
wakelock on this.
2024-05-31 18:46:27 +02:00
Willow Barraco
ce59e6b014 bluetoothtoogle: behave correctly when partially blocked
If the devices are partially blocked, the config menu should display a
ton icon, and toggeling should block all remainings.
2024-05-09 18:03:28 +02:00
Willow Barraco
e3554ce5f7 contextmenu: let access to bluetooth menu when at least one device is unblocked
This is necessary if you have multiple devices, and one is blocked while
the other is useable.

This still not behave correctly when there is no bluetooth device at
all.
2024-05-09 18:03:28 +02:00
Willow Barraco
0b58e5e1f2 Inverse periodic blinking condition to blink when suspension is enabled
The behavior introduced with the following commit was wrong. The
condition have to be reversed.

bccc1ab8 hook_screenoff: blink purple only when suspend is enabled
2024-05-09 18:03:17 +02:00
Maarten van Gompel
5fd6528f1e config menu: added log launcher
Opens the Sxmo log and follows new entries as they come in.

Signed-off-by: Willow Barraco <contact@willowbarraco.fr>
2024-05-06 09:38:53 +02:00
Maarten van Gompel
d102a4c5ae deviceprofile: Set default scale for Poco F1 to 3
Tested-by: rd440
Signed-off-by: Willow Barraco <contact@willowbarraco.fr>
2024-05-06 09:38:52 +02:00
Willow Barraco
92b83c6753 sxmo_init.sh: use mkrundir if available
mkrundir is a simple program by whynothugo that simply create the
rundir.

This patch is enough for Sxmo to use /run/user-$uid as XDG_RUNTIME_DIR. Even if
this is still less common that /run/user/$uid, it still is preferable, and more
compatible than our /dev/shm/user/$uid (ex: flatpak refuse to bind mount /dev/
paths).
2024-05-06 09:38:52 +02:00
Aren Moynihan
f09ab84092 contextmenu: detect terminal apps with case statement
This has the potential to cause odd breakages because it doesn't require
full word matches anymore. This can be mitigated by using *" word "*
instead of *"word"*, which I have done where I expect it to be a
problem.

Not needing to fork a bunch of printf / grep processes is a significant
performance improvement. I think this is well worth the risk of breaking
things.

Before:

$ hyperfine --warmup 4 -N sxmo_hook_contextmenu.sh
Benchmark 1: sxmo_hook_contextmenu.sh
  Time (mean ± σ):     421.0 ms ±   4.2 ms    [User: 282.9 ms, System: 233.7 ms]
  Range (min … max):   414.5 ms … 426.2 ms    10 runs

After:

$ hyperfine --warmup 4 -N sxmo_hook_contextmenu.sh
Benchmark 1: sxmo_hook_contextmenu.sh
  Time (mean ± σ):     151.3 ms ±   2.4 ms    [User: 118.8 ms, System: 105.1 ms]
  Range (min … max):   146.7 ms … 154.8 ms    19 runs

These tests were run on a PinePhone with a foot window focused using
bash as the shell.

Signed-off-by: Willow Barraco <contact@willowbarraco.fr>
2024-05-06 09:27:56 +02:00
Aren Moynihan
533e91e68d sxmo_wm: use a single jq call to get focused window
Simplifying this logic should help with performance, this is always
called by sxmo_hook_contextmenu.sh, so it should help make the menus a
little more responsive.

Before:
$ hyperfine --warmup 2 'sxmo_wm.sh focusedwindow'
Benchmark 1: sxmo_wm.sh focusedwindow
  Time (mean ± σ):      78.8 ms ±   1.2 ms    [User: 41.8 ms, System: 40.2 ms]
  Range (min … max):    77.1 ms …  81.5 ms    30 runs

After:
$ hyperfine --warmup 2 'sxmo_wm.sh focusedwindow'
Benchmark 1: ./sxmo_wm.sh focusedwindow
  Time (mean ± σ):      43.4 ms ±   2.0 ms    [User: 27.8 ms, System: 22.1 ms]
  Range (min … max):    41.4 ms …  53.0 ms    48 runs

Signed-off-by: Maarten van Gompel <proycon@anaproy.nl>
2024-05-03 11:53:38 +02:00
Maarten van Gompel
4301899980 fixup: indentation fixes 2024-05-03 11:36:38 +02:00
magdesign
be5dfcde36 add gsm disable/enable toggle
Signed-off-by: Maarten van Gompel <proycon@anaproy.nl>
2024-05-03 11:34:00 +02:00
Aren Moynihan
85b6207521 conky: use builtin time function
This is significantly faster than spawning a shell just to print the
current time.

Signed-off-by: Maarten van Gompel <proycon@anaproy.nl>
2024-05-01 23:09:35 +02:00
hazardchem
711ecff7c7 Acme: add controls and selection options
As acme is a mouse heavy program it needs input from middle and right clicks.
As such this requires xdotool to simulate mouse button clicks.

To make it work I have bound volume up to right click and volume down to middle
click.

There is also options in context menu as backup if the device doesn't have volume
controls.

If the mouse 2 and 3 aren't clear they require you to reselect the spot in less
than 2 seconds for the mouse click to occur at that location.

Signed-off-by: hazardchem <hazardchem@disroot.org>
Signed-off-by: Aren Moynihan <aren@peacevolution.org>
2024-04-28 20:34:29 -04:00
hazardchem
86686a1b29 sxmo_hook_*.sh: add iamb
This patch adds iamb to: sxmo_hook_apps.sh sxmo_hook_contextmenu.sh.

Iamb is a terminal matrix client with vim style keybindings.

Signed-off-by: hazardchem <hazardchem@disroot.org>
Signed-off-by: Aren Moynihan <aren@peacevolution.org>
2024-04-27 22:16:45 -04:00
hazardchem
d5dbfc6586 profile: set st -e to st
st -e has been causing issues when run by sxmo_terminal.sh

Removing from profile will make the default not cause issues if people decide
to uncomment it

Signed-off-by: hazardchem <hazardchem@disroot.org>
Signed-off-by: Aren Moynihan <aren@peacevolution.org>
2024-04-27 16:45:39 -04:00
hazardchem
4b44d664c4 fix xob changes to work on both dwm and sway
This patch fixes modifications in fd27059b95

Signed-off-by: hazardchem <hazardchem@disroot.org>
Signed-off-by: Willow Barraco <contact@willowbarraco.fr>
2024-04-26 14:28:32 +02:00
Willow Barraco
9787be1395 Handle low battery cases 2024-04-26 14:19:20 +02:00
Sicelo A. Mhlongo
91d4319df5 sway: add config for Nokia N900
The Nokia N900's keyboard has very few keys, and RightAlt is already
in use. Provide an alternative binding mode that suits this constraint
while remaining as close as possible to the existing sxmo keybindings

Signed-off-by: Willow Barraco <contact@willowbarraco.fr>
2024-04-26 14:17:50 +02:00
Aren Moynihan
8c0c0e4311 check if flash led exists instead of using SXMO_DISABLE_LEDS
Also use brightnessctl directly, the flash toggle logic doesn't use any
of the features provided on top of it by sxmo_led.sh. This simplifies
the cases that sxmo_led.sh needs to support.

Signed-off-by: Willow Barraco <contact@willowbarraco.fr>
2024-04-26 14:14:04 +02:00
Sicelo A. Mhlongo
1826eaca5b sxmo_led: initial support for lp5xx leds
These leds, found in the Nokia N900, use 'non-standard' naming. Add initial
support for them

Signed-off-by: Willow Barraco <contact@willowbarraco.fr>
2024-04-26 14:14:04 +02:00
Sicelo A. Mhlongo
bccc1ab88d hook_screenoff: blink purple only when suspend is enabled
When autosuspend is disabled, the purple LED blinks indefinitely, since
screenoff is the lowest idle state possible in that case. The purple LED
notification is meant to notify the user that that system is in screenoff, and
will likely suspend soon, thus for users who disable autosuspend, the blink
loses meaning. Disable it for this case.

Signed-off-by: Willow Barraco <contact@willowbarraco.fr>
2024-04-26 14:03:09 +02:00
hazardchem
1172819f59 conky: reduce poll interval
Been noted that with update_interval set to 5 that conky consumes 10% cpu

Setting to 15 reduces it to less than 1%

Signed-off-by: hazardchem <hazardchem@disroot.org>
Signed-off-by: Willow Barraco <contact@willowbarraco.fr>
2024-04-26 14:03:08 +02:00
Sicelo A. Mhlongo
b8d4fa93aa deviceprofile: nokia-n900: disable modem
The Nokia N900's modem is not supported by ofono. Until either sxmo supports
ofono or the modem is made to work with modemmanager, disable it to save a few
cpu cycles

Signed-off-by: Willow Barraco <contact@willowbarraco.fr>
2024-04-26 14:03:08 +02:00
magdesign
967ab3c8ad removed the disable_led since flashlight/torch works nicely
Signed-off-by: Willow Barraco <contact@willowbarraco.fr>
2024-04-26 14:03:08 +02:00
Real Root
ed69f8ae23 add tilix and moment to sxmo_hook_apps.sh
Signed-off-by: Maarten van Gompel <proycon@anaproy.nl>
2024-04-15 19:42:34 +02:00
hazardchem
bcdacb3a18 sxmo_xinit.sh: Fix SXMO_TERMINAL decleration
Currently st -e for SXMO_TERMINAL causes st to exit with error 1

Removing the -e switch makes it so that st behaves correctly.

Signed-off-by: hazardchem <hazardchem@disroot.org>
Signed-off-by: Willow Barraco <contact@willowbarraco.fr>
2024-04-15 08:30:11 +02:00
Real Root
2da465e533 add tilix in sxmo_terminal.sh
Signed-off-by: Maarten van Gompel <proycon@anaproy.nl>
2024-04-13 22:25:43 +02:00
Willow Barraco
dc7b9dd7fe Remove gojq proxy
Recent jq version seems fast enough. We drop this proxy, and use jq
directly

Signed-off-by: Willow Barraco <contact@willowbarraco.fr>
Signed-off-by: Maarten van Gompel <proycon@anaproy.nl>
2024-04-12 22:16:21 +02:00
Willow Barraco
4913fac4ee Cleanup virtual keyboard management
Some devices doesn't need a virtual keyboard, aka Nokia N900, aka
Pinephone with keyboard. This give a way to disable this feature
completely.

Also, we remove the sxmo_dmenu_with_kb.sh script, cause it is poorly
used, and give inconsistent behavior between menus. The user can already open
the keyboard very easily.

For this same reason, we remove some random "sxmo_keyboards.sh open". If
this isn't necessary cause of a specific usage (aka dtmf special
layout.

I also dropped some code in sxmo_dmenu.sh that adapt the available size
depending on if the keyboard is open or not. The keyboard can be open
later, so this is dumb to rely on this, and we should alway be able to
open/close it, and to read all lines.

I adapted the inputhandler a bit when keyboard is disabled. If you guys
think about better usage of freed handler, I'm open!
2024-03-25 17:32:26 +01:00
Willow Barraco
abb50343c1 sxmo_wm.sh: fix execwait 2024-03-25 17:32:26 +01:00
Willow Barraco
fbfde5a886 Standardise notify-send 2024-03-25 17:31:56 +01:00
Willow Barraco
36a67632ad Hide keyboard message while editing messages
When openning the conversation loop, it happens very frequently
that I see some stdouts breaking my kakoune EDITOR when I switch the
keyboard layout.

To solve this, we detach the keyboard stdout from the caller process.
2024-03-25 17:30:45 +01:00
Willow Barraco
f05c300616 sxmo_brightness.sh: fix min brightness handling
Atm if you use SXMO_MIN_BRIGHTNESS=1, you blank the screen when you use
sxmo_brightness.sh.

Re-implement the minimum value handling to solve this.
2024-03-25 17:27:08 +01:00
Willow Barraco
368bc48dc2 sxmo_bluetoothmenu.sh: fix clean re-connection
Do not try to pair before connection. Let's stay consistent with how we
connect to new devices from the main loop. Also, do not trust by
default. The user have to do this themselves manually if they want to.

Add a --timeout to the scan, so that it stay scanning, even if not
in interactive mode.

Sleep 1 so that we don't spam too much the daemon.
2024-03-25 17:23:19 +01:00
Willow Barraco
dca4dffc57 sxmo_bluetoothmenu.sh faster commands
Use timeout instead of --timeout 7 to return faster.
2024-03-25 17:23:19 +01:00
Willow Barraco
d617d31aca sxmo_bluetoothmenu.sh: do not display "(null)" when device list is empty 2024-03-25 17:23:18 +01:00
Willow Barraco
562fa6129a sxmo_state.sh: prevent race condition while checking current state
Add a "get" command to abstract state checks, from inside of the
sxmo_state.sh script. This use the shared flock on this case.

This have to adapt the flocks management, so that the hooks can access
the "get" without staying idle, waiting for themselves to release the
exclusive flock.
2024-03-25 17:12:25 +01:00
Willow Barraco
ac767b8eb0 sxmo_state.sh: fix "screen-off" toogles from menus
To solve this, we have to allow transitions to the same state.
Which is needed when toggeling automatic screen-off from the config
sub-menu.
2024-03-25 17:12:25 +01:00
hazardchem
369557daf2 alacritty: set behaviour to match other terminals
This patch fixes issues with using alacritty as your terminal emulator in sxmo.

Alacritty needs to know if you are trying to exrcute a specific program or $SHELL
as setting the title even with dynamic titles set in config will make the title
permanent

That affects calling sxmo_terminal.sh with power button as the title will stay
as the path to your shell.

To test for this made a check to see if the case is calling $* as shell path or
program

Also added to sxmo_hook_apps.sh

Signed-off-by: hazardchem <hazardchem@disroot.org>
Signed-off-by: Maarten van Gompel <proycon@anaproy.nl>
2024-03-24 22:44:08 +01:00
hazardchem
b5be78d521 badwolf: add entry to context menu
Signed-off-by: hazardchem <hazardchem@disroot.org>
Signed-off-by: Maarten van Gompel <proycon@anaproy.nl>
2024-03-18 17:52:46 +01:00
Joshua Murphy
db537e789a Keep SXMO_OS env for sxmo_bluetoothtoggle.sh
Currently, SXMO_OS is not kept when running sxmo_bluetoothtoggle.sh
using doas. The case statement is therefore skipped entirely. This
patch preserves that var and allows SXMO_OS to be correctly checked.

Signed-off-by: Willow Barraco <contact@willowbarraco.fr>
2024-03-06 17:45:23 +01:00
hazardchem
fd27059b95 Using xob for audio and brightness notifications in dwm
This patch replaces dunst with xob for audio and brightness levels.

Currently xob is only in alpine edge so this will be useful once it moves to
stable.

Xob behaves exactly the same as wob this the file for xob are just renamed from
wob. Alternative proposal is place a if statement in sxmo_wob.sh to start wob
or xob and then remove the $SXMO_WM check.

Signed-off-by: hazardchem <hazardchem@disroot.org>
Signed-off-by: Willow Barraco <contact@willowbarraco.fr>
2024-03-06 17:40:13 +01:00
magdesign
d295949758 krita to app hook
Signed-off-by: Maarten van Gompel <proycon@anaproy.nl>
2024-02-23 20:22:55 +01:00
magdesign
1a348237cd added contextmenu for Krita
Signed-off-by: Maarten van Gompel <proycon@anaproy.nl>
2024-02-23 20:22:52 +01:00
Timotej Lazar
ce699dc01a Add SXMO_VIBRATE_DEV to longcheer deviceprofile
Signed-off-by: Anjandev Momi <anjan@momi.ca>
2024-02-20 17:32:19 -08:00
Maarten van Gompel
69fcc55e5d apps: added fractal (matrix client)
Signed-off-by: Anjandev Momi <anjan@momi.ca>
2024-02-20 17:31:51 -08:00
Caio Barros
fb153ce987 Initial setup of a device profile for Pine Tab 2
Copied from the Pine Phone Pro profile, but (1) removed the modem, (2)
removed wayland scaling and (3) changed the power key to 0:0:rk805_pwrkey

Signed-off-by: Anjandev Momi <anjan@momi.ca>
2024-02-20 17:30:19 -08:00
Patriot-06
6fb3fe6f98 Initial configuration and deviceprofile for Redmi Note 4
Signed-off-by: Patriot-06 <mbmc172@gmail.com>
Signed-off-by: Anjandev Momi <anjan@momi.ca>
2024-02-20 17:28:10 -08:00
Willow Barraco
c6efaf8a94 Support system wallpapers
This add a simple hook "wallpaper" that by default grab the system
wallpaper (ex: provided by postmarketos-artwork-wallpapers). If there is
none, it fallback to the sxmo one.

Of course, the hook is customizable by the user if needed.

Ref: https://gitlab.com/postmarketOS/pmaports/-/issues/2499
Signed-off-by: Willow Barraco <contact@willowbarraco.fr>
Signed-off-by: Anjandev Momi <anjan@momi.ca>
2024-02-20 16:15:38 -08:00
Willow Barraco
6ed845fd03 sxmo_common.sh: xdg_data_path handle escaped separators (\n, \0)
Signed-off-by: Willow Barraco <contact@willowbarraco.fr>
Signed-off-by: Anjandev Momi <anjan@momi.ca>
2024-02-20 16:15:35 -08:00
Willow Barraco
df6b3d3d0d sway_template: bump manual locker shortcut 2024-02-05 16:18:53 +01:00
Willow Barraco
1642daaf49 sway_template: remove transparency on inactive workspace 2024-02-05 16:18:53 +01:00
Sicelo A. Mhlongo
9b6aa786a0 places_for_gps.tsv: use correct name for Swaziland
The name Swaziland was replaced in April 2018. Use correct name for the
country, namely Eswatini

Reference: http://www.times.co.sz/news/118373-kingdom-of-eswatini-change-now-official.html
Signed-off-by: Maarten van Gompel <proycon@anaproy.nl>
2024-01-01 20:11:45 +01:00
136 changed files with 3553 additions and 1152 deletions

View File

@@ -3,9 +3,9 @@ packages:
- shellcheck
- editorconfig-checker
- shellspec
- gojq
- jq
- icu-dev
- linux-headers
sources:
- https://git.sr.ht/~mil/sxmo-utils
tasks:

1
.gitattributes vendored Normal file
View File

@@ -0,0 +1 @@
Makefile export-subst

3
.hut.scfg Normal file
View File

@@ -0,0 +1,3 @@
tracker https://todo.sr.ht/~mil/sxmo-tickets
development-mailing-list ~mil/sxmo-devel@lists.sr.ht
patch-prefix true

View File

@@ -4,6 +4,8 @@ SYSCONFDIR:=/etc
SHAREDIR=$(PREFIX)/share
MANDIR=$(SHAREDIR)/man
CFLAGS := -Wall -std=c99 -D_POSIX_C_SOURCE=200809L $(CFLAGS)
# use $(PREFIX)/lib/systemd/user for systemd integration
SERVICEDIR:=$(PREFIX)/share/superd/services
@@ -11,52 +13,98 @@ SERVICEDIR:=$(PREFIX)/share/superd/services
EXTERNAL_SERVICES:=1
SCDOC=scdoc
SCD2HTML=scd2html
SCD2HTMLFLAGS =
.PHONY: install test shellcheck shellspec test_legacy_nerdfont
.PHONY: install test shellcheck shellspec test_legacy_nerdfont docs html-docs \
install-docs install-html-docs install-sway install-dwm install-scripts
VERSION:=1.15.2
VERSION ?= unknown
GITVERSION:=$(shell git describe --tags)
# git archive will expand $Format:true$ to just true, so we can use it to check
# if we should use the version from the tarball, or to generate it now.
ifeq "$Format:true$" "true"
VERSION := $Format:%(describe:tags)$
else
VERSION := $(shell git -c safe.directory="*" describe --tags)
endif
OPENRC:=1
CC ?= $(CROSS_COMPILE)gcc
PROGRAMS = \
programs/sxmo_aligned_sleep \
programs/sxmo_vibrate
programs/sxmo_sleep \
programs/sxmo_vibrate \
programs/sxmo_status_led
DOCS = \
docs/sxmo.7
docs/sxmo.7 \
docs/sxmo_wakelock.sh.1 \
docs/sxmo_migrate.sh.1 \
docs/sxmo_files.sh.1 \
docs/sxmo_contacts.sh.1 \
HTMLDOCS := $(DOCS:%=%.html)
all: $(PROGRAMS) $(DOCS)
# We convert from SCDOC to HTML , the HTML conversion
# we apply some postprocessing for better internal hyperlinks and styling.
docs/%.html: docs/%.scd
$(SCD2HTML) $(SCD2HTMLFLAGS) < "$<" | \
sed -E -e 's/Georgia/Sans/g' \
-e 's/Menlo/FiraMono Nerd Font, Sxmo, Menlo/g' \
-e 's/See ([A-Z ]+)\./See <a href="#\1">\1<\/a>./g' \
-e 's/\(see ([A-Z ]+)\)/(see <a href="#\1">\1<\/a>)/g' \
-e 's/<u>sxmo_([a-z_\.]+)<\/u>\(([1-9])\)/<a href="sxmo_\1.\2.html"><u>sxmo_\1<\/u><\/a>(\2)/g' | \
sed -e ':loop' \
-e 's/\(href="[^" ]*\) \([^"]*"\)/\1_\2/' \
-e 't loop' > "$@" #this last sed statement replace spaces in href attributes with underscores
docs/%: docs/%.scd
$(SCDOC) <$< >$@
all: $(PROGRAMS) $(DOCS)
docs: $(DOCS)
test: shellcheck shellspec test_legacy_nerdfont
html-docs: $(HTMLDOCS)
test: shellcheck shellspec test_legacy_nerdfont test_status_led
shellcheck:
find . -type f -name '*.sh' -print0 | xargs -0 shellcheck -x --shell=sh
shellspec:
shellspec: ${PROGRAMS}
shellspec
test_status_led: programs/sxmo_status_led.test
./programs/sxmo_status_led.test
test_legacy_nerdfont: programs/test_legacy_nerdfont
programs/test_legacy_nerdfont < configs/default_hooks/sxmo_hook_icons.sh
programs/test_legacy_nerdfont: programs/test_legacy_nerdfont.c
$(CC) $(CFLAGS) $(CPPFLAGS) $(LDFLAGS) -o $@ $< $(shell pkg-config --cflags --libs icu-io)
programs/sxmo_status_led: LDLIBS := -lm
programs/sxmo_status_led.test: LDLIBS := -lm
programs/test_legacy_nerdfont: LDLIBS := $(shell pkg-config --cflags --libs icu-io)
programs/%: programs/%.c
$(CC) $(CFLAGS) $(CPPFLAGS) $(LDFLAGS) -o $@ $<
$(CC) $(CPPFLAGS) $(CFLAGS) $(LDFLAGS) $< $(LOADLIBES) $(LDLIBS) -o $@
# only used for sxmo_status_led
programs/%.test: programs/%.c
$(CC) $(CPPFLAGS) $(CFLAGS) -DTEST $(LDFLAGS) $< $(LOADLIBES) $(LDLIBS) -o $@
clean:
rm -f programs/sxmo_aligned_sleep programs/sxmo_vibrate
rm -f ${PROGRAMS} ${DOCS} ${HTMLDOCS} programs/test_legacy_nerdfont programs/sxmo_status_led.test
install: install-sway install-dwm install-scripts install-docs
install-docs: $(DOCS)
cd docs && find . -type f -name '*.7' -exec install -D -m 0644 "{}" "$(DESTDIR)$(MANDIR)/man7/{}" \; && cd ..
cd docs && find . -type f -name '*.7' -exec install -D -m 0644 "{}" "$(DESTDIR)$(MANDIR)/man7/{}" \; && find . -type f -name '*.1' -exec install -D -m 0644 "{}" "$(DESTDIR)$(MANDIR)/man1/{}" \; && cd ..
install-html-docs: $(HTMLDOCS)
cd docs && find . -type f -name '*.html' -exec install -D -m 0644 "{}" "$(DESTDIR)$(PREFIX)/share/doc/sxmo/html/{}" \; && cd ..
install-sway:
install -D -m 0644 -t $(DESTDIR)$(PREFIX)/share/wayland-sessions/ configs/applications/swmo.desktop
@@ -65,13 +113,13 @@ install-dwm:
install -D -m 0644 -t $(DESTDIR)$(PREFIX)/share/xsessions/ configs/applications/sxmo.desktop
install-scripts: $(PROGRAMS)
cd configs && find . -type f -not -name sxmo-setpermissions -exec install -D -m 0644 "{}" "$(DESTDIR)$(PREFIX)/share/sxmo/{}" \; && cd ..
cd configs && find . -type f -not -exec install -D -m 0644 "{}" "$(DESTDIR)$(PREFIX)/share/sxmo/{}" \; && cd ..
rm -rf "$(DESTDIR)$(PREFIX)/share/sxmo/default_hooks/"
cd configs && find default_hooks -type f -exec install -D -m 0755 "{}" "$(DESTDIR)$(PREFIX)/share/sxmo/{}" \; && cd ..
cd configs && find default_hooks -type l -exec cp -R "{}" "$(DESTDIR)$(PREFIX)/share/sxmo/{}" \; && cd ..
[ -n "$(GITVERSION)" ] && echo "$(GITVERSION)" > "$(DESTDIR)$(PREFIX)/share/sxmo/version" || echo "$(VERSION)" > "$(DESTDIR)$(PREFIX)/share/sxmo/version"
echo "$(VERSION)" > "$(DESTDIR)$(PREFIX)/share/sxmo/version"
cd resources && find . -type f -exec install -D -m 0644 "{}" "$(DESTDIR)$(PREFIX)/share/sxmo/{}" \; && cd ..
@@ -79,6 +127,8 @@ install-scripts: $(PROGRAMS)
install -D -m 0644 -t $(DESTDIR)$(PREFIX)/share/applications/ configs/xdg/mimeapps.list
install -D -m 0644 -t $(DESTDIR)$(SYSCONFDIR)/polkit-1/rules.d/ configs/polkit/01-sensor-claim.rules
install -D -m 0640 -t $(DESTDIR)$(SYSCONFDIR)/doas.d/ configs/doas/sxmo.conf
install -D -m 0644 -T configs/xorg/monitor.conf $(DESTDIR)$(PREFIX)/share/X11/xorg.conf.d/90-monitor.conf
@@ -95,8 +145,8 @@ install-scripts: $(PROGRAMS)
# Bin
install -D -t $(DESTDIR)$(PREFIX)/bin scripts/*/*.sh
install -D programs/sxmo_aligned_sleep $(DESTDIR)$(PREFIX)/bin/
install -D programs/sxmo_vibrate $(DESTDIR)$(PREFIX)/bin/
install -t $(DESTDIR)$(PREFIX)/bin/ ${PROGRAMS}
setcap 'cap_wake_alarm=ep' $(DESTDIR)$(PREFIX)/bin/sxmo_sleep
find $(DESTDIR)$(PREFIX)/share/sxmo/default_hooks/ -type f -exec ./setup_config_version.sh "{}" \;
find $(DESTDIR)$(PREFIX)/share/sxmo/appcfg/ -type f -exec ./setup_config_version.sh "{}" \;
@@ -112,7 +162,5 @@ install-scripts: $(PROGRAMS)
fi
@echo "-------------------------------------------------------------------">&2
@echo "NOTICE 1: Do not forget to add sxmo-setpermissions to your init system, e.g. for openrc: rc-update add sxmo-setpermissions default && rc-service sxmo-setpermissions start" >&2
@echo "-------------------------------------------------------------------">&2
@echo "NOTICE 2: After an upgrade, it is recommended you reboot and when prompted run sxmo_migrate.sh to check and upgrade your configuration files and custom hooks against the defaults (it will not make any changes unless explicitly told to)" >&2
@echo "NOTICE: After an upgrade, it is recommended you reboot and when prompted run sxmo_migrate.sh to check and upgrade your configuration files and custom hooks against the defaults (it will not make any changes unless explicitly told to)" >&2
@echo "-------------------------------------------------------------------">&2

View File

@@ -8,11 +8,11 @@ conky.config = {
draw_shades = true,
font = 'Sxmo:size=13',
use_xft = true,
update_interval = 5,
update_interval = 15,
}
conky.text = [[
${alignc}${font Sxmo:size=50:style=Bold}${exec date +"%H"}${font Sxmo:size=50}:${exec date +"%M"}${font}
${alignc}${font Sxmo:size=50:style=Bold}${time %H}${font Sxmo:size=50}:${time %M}${font}
${font Sxmo:size=20}${exec date +"%a %d %b %Y"}${font}
${font Sxmo:size=20}${time %a %d %b %Y}${font}
]]

View File

@@ -5,6 +5,7 @@ text-color=#000000
border-color=#000000
layer=overlay
group-by=app-name
on-touch=invoke-default-action
[urgency=low]
default-timeout=10000

View File

@@ -3474,6 +3474,26 @@ Palivere, Estonia 58.9702778 23.9033337
Aravete, Estonia 59.1416667 25.7613888
Kiili, Estonia 59.3069444 24.8377781
Lagedi, Estonia 59.4055556 24.9422226
Manzini, Eswatini -26.4833333 31.3666668
Mbabane, Eswatini -26.3166667 31.1333332
Big Bend, Eswatini -26.8166667 31.9333324
Malkerns, Eswatini -26.5666667 31.1833324
Mhlume, Eswatini -26.0333333 31.8500004
Hluti, Eswatini -27.2166667 31.6166668
Siteki, Eswatini -26.4500000 31.9500008
Piggs Peak, Eswatini -25.9666667 31.2500000
Lobamba, Eswatini -26.4666667 31.2000008
Kwaluseni, Eswatini -26.4833333 31.3333340
Bhunya, Eswatini -26.5500000 31.0166664
Mhlambanyatsi, Eswatini -26.4500000 31.0166664
Hlatikulu, Eswatini -26.9666667 31.3166676
Bulembu, Eswatini -25.9666667 31.1333332
Kubuta, Eswatini -26.8833333 31.4833336
Tshaneni, Eswatini -25.9833333 31.7166672
Sidvokodvo, Eswatini -26.6166667 31.4500008
Lavumisa, Eswatini -27.3166667 31.8999996
Darkton, Eswatini -26.2333333 31.0333328
Nsoko, Eswatini -27.0333333 31.9500008
Addis Ababa, Ethiopia 9.0333333 38.7000008
Dire Dawa, Ethiopia 9.5930556 41.8661118
Nazret, Ethiopia 8.5500000 39.2666664
@@ -9240,26 +9260,6 @@ Onverwacht, Suriname 5.5833333 -55.1833344
Totness, Suriname 5.8833333 -56.3166656
Benzdorp (Monte Hermon), Suriname 3.6720670 -54.1035461
Kabana-vo, Suriname 3.6741067 -54.0848846
Manzini, Swaziland -26.4833333 31.3666668
Mbabane, Swaziland -26.3166667 31.1333332
Big Bend, Swaziland -26.8166667 31.9333324
Malkerns, Swaziland -26.5666667 31.1833324
Mhlume, Swaziland -26.0333333 31.8500004
Hluti, Swaziland -27.2166667 31.6166668
Siteki, Swaziland -26.4500000 31.9500008
Piggs Peak, Swaziland -25.9666667 31.2500000
Lobamba, Swaziland -26.4666667 31.2000008
Kwaluseni, Swaziland -26.4833333 31.3333340
Bhunya, Swaziland -26.5500000 31.0166664
Mhlambanyatsi, Swaziland -26.4500000 31.0166664
Hlatikulu, Swaziland -26.9666667 31.3166676
Bulembu, Swaziland -25.9666667 31.1333332
Kubuta, Swaziland -26.8833333 31.4833336
Tshaneni, Swaziland -25.9833333 31.7166672
Sidvokodvo, Swaziland -26.6166667 31.4500008
Lavumisa, Swaziland -27.3166667 31.8999996
Darkton, Swaziland -26.2333333 31.0333328
Nsoko, Swaziland -27.0333333 31.9500008
Stockholm, Sweden 59.3325765 18.0649033
Goteborg, Sweden 57.7071623 11.9667931
Malmoe, Sweden 55.6058691 13.0007315
Can't render this file because it has a wrong number of fields in line 2.

View File

@@ -31,7 +31,7 @@ command -v firefox >/dev/null && export BROWSER=firefox
export TERMCMD="sxmo_terminal.sh"
# Change the used terminal command
# export SXMO_TERMINAL="st -e"
# export SXMO_TERMINAL="st"
# When scrolling past the beginning or end of a menu, wrap it around:
#export DMENU_WRAP_AROUND=1
@@ -68,6 +68,3 @@ export SXMO_RINGNUMBER=10
#Set to the default text for a new text message.
export SXMO_DEFAULT_DRAFT="Enter new message here."
#Set background image
export SXMO_BG_IMG="$(xdg_data_path sxmo/background.jpg)"

View File

@@ -31,7 +31,7 @@ mode "menu" {
# to know the device names, so use it as a fallback so this functionality
# keeps working if a deviceprofile doesn't exist.
# TODO: the correct way to do this is to implement custom keybindings in
# bemenu
# bemenu & wofi
bindsym XF86PowerOff exec wtype -k Return
bindsym XF86AudioRaiseVolume exec wtype -k Up
bindsym XF86AudioLowerVolume exec wtype -k Down
@@ -43,6 +43,15 @@ mode "menu" {
#
input * xkb_options compose:ralt
# Nokia N900 hardware keyboard
input "1:1:TWL4030_Keypad" {
xkb_model "nokiarx51"
xkb_layout "us"
# ralt has special meaning on N900 keyboard so do not use as
# compose key
xkb_options compose:rwin
}
# Start a terminal
bindsym $mod+Return exec $term
@@ -155,7 +164,7 @@ mode "menu" {
bindsym $mod+a focus parent
# Manual locker
bindsym $mod+g exec sxmo_hook_locker.sh
bindsym $mod+g exec sxmo_state.sh set locker
# Shutdown
bindsym $mod+t exec sxmo_appmenu.sh power
@@ -213,7 +222,7 @@ bar {
colors {
statusline #ffffff
background #323232
inactive_workspace #32323200 #32323200 #5c5c5c
inactive_workspace #323232 #323232 #ffffff
font "Sxmo 11"
}
}

View File

@@ -0,0 +1,10 @@
# Space to setup configversion
single_click=true
dynamic_lines=true
line_wrap=word
width=80%
height=60%
allow_images=true
allow_markup=true
show=dmenu
no_actions=true

46
configs/appcfg/wofi.css Normal file
View File

@@ -0,0 +1,46 @@
/* Space to setup configversion */
window {
margin: 5px;
border: 3px solid #005577;
background-color: #222222;
font-family: Sxmo;
font-size: 14pt;
}
#input {
margin: 5px;
border: 2px solid #005577;
background-color: #444444;
color: white;
}
#inner-box {
margin: 5px;
}
#outer-box {
margin: 5px;
}
#scroll {
color: yellow;
}
#text {
margin: 5px;
color: white;
}
#img {
padding-right: 25px;
}
#entry {
padding-top: 8px;
}
#entry:selected {
background-color: #005577;
}
#entry #entry {
background-color: #444444;
}

3
configs/appcfg/xob_styles.cfg Normal file → Executable file
View File

@@ -1,7 +1,8 @@
# Space to setup configversion
default = {
x = {relative = 0.5; offset = 0;};
y = {relative = 0.15; offset = 0;};
y = {relative = 0.05; offset = 0;};
length = {relative = 0.75; offset = 0;};
thickness = 50;
outline = 3;

View File

@@ -20,13 +20,16 @@ write_line_app() {
fi
}
write_line_app gnome-2048 "$icon_gam 2048" "gnome-2048"
write_line_app jami-qt "$icon_msg Jami" "jami-qt"
[ -n "$PLAN9" ] && write_line_app acme "$icon_edt Acme" "acme -c 1 -f $PLAN9/font/pelm/ascii.16.font"
write_line_app adventure "$icon_trm Adventure" "sxmo_terminal.sh adventure"
write_line_app aerc "$icon_eml Aerc" "sxmo_terminal.sh aerc"
write_line_app alacritty "$icon_trm Alacritty" "alacritty"
write_line_app amberol "$icon_mus Amberol" "amberol $XDG_MUSIC_DIR"
write_line_app amfora "$icon_glb Amfora" "sxmo_terminal.sh amfora"
write_line_app animatch "$icon_gam Animatch" "animatch"
write_line_app harbour-amazfish-ui "$icon_wat Amazfish" "harbour-amazfish-ui"
write_line_app amfora "$icon_glb Amfora" "sxmo_terminal.sh amfora"
write_line_app angelfish "$icon_glb Angelfish" "angelfish"
write_line_app animatch "$icon_gam Animatch" "animatch"
write_line_app alpine "$icon_eml Alpine" "sxmo_terminal.sh alpine"
write_line_app anbox-launch "$icon_and Anbox" "anbox"
write_line_app anki "$icon_str Anki" "anki"
@@ -35,12 +38,18 @@ write_line_app badwolf "$icon_glb Badwolf" "badwolf"
write_line_app gnome-calculator "$icon_clc Calculator" "gnome-calculator"
write_line_app calcurse "$icon_clk Calcurse" "sxmo_terminal.sh calcurse"
write_line_app chatty "$icon_msg Chatty" "chatty"
([ "$SXMO_WM" = dwm ] && command -v clipmenu >/dev/null) && \
write_line_app clipmenu "$icon_bok Clipmenu" "clipmenu"
write_line_app cmus "$icon_mus Cmus" "sxmo_terminal.sh cmus"
write_line_app com.github.geigi.cozy "$icon_mus Cozy" "com.github.geigi.cozy"
write_line_app cpupower-gui "$icon_cfg Cpupower-gui" "cpupower-gui"
write_line_app dino "$icon_msg Dino" "GDK_SCALE=1 dino"
write_line_app dolphin "$icon_dir Dolphin" "dolphin"
write_line_app eartag "$icon_mus Eartag" "eartag"
write_line_app elinks "$icon_glb ELinks" "sxmo_terminal.sh elinks"
write_line_app emacs "$icon_edt Emacs (Terminal)" "sxmo_terminal.sh emacs -nw"
write_line_app emacs "$icon_edt Emacs (X)" "emacs"
write_line_app eog "$icon_img Eye of Gnome" "eog"
write_line_app epiphany "$icon_glb Epiphany" "epiphany"
write_line_app epy "$icon_bok Epy" "sxmo_terminal.sh epy"
write_line_app epr "$icon_bok Epr" "sxmo_terminal.sh epr"
@@ -48,10 +57,12 @@ write_line_app evince "$icon_bok Evince" "evince"
write_line_app falkon "$icon_flk Falkon" "falkon"
write_line_app firefox "$icon_ffx Firefox" "firefox"
write_line_app firefox-esr "$icon_ffx Firefox ESR" "firefox-esr"
write_line_app flare "$icon_msg Flare" "flare"
write_line_app foliate "$icon_bok Foliate" "foliate"
( [ "$SXMO_WM" = sway ] && command -v foot >/dev/null) && \
write_line "$icon_trm Foot" "foot $SHELL"
write_line_app foxtrotgps "$icon_gps Foxtrotgps" "foxtrotgps"
write_line_app fractal "$icon_msg Fractal" "fractal"
write_line_app g4music "$icon_mus G4Music" "g4music"
write_line_app geany "$icon_eml Geany" "geany"
write_line_app geary "$icon_eml Geary" "geary"
@@ -60,68 +71,100 @@ write_line_app geeqie "$icon_img Geeqie" "geeqie"
write_line_app geopard "$icon_glb Geopard" "geopard"
write_line_app gerbil "$icon_glb Gerbil" "gerbil"
write_line_app giara "$icon_red Giara" "giara"
write_line_app gnome-2048 "$icon_mvi Gnome-2048" "gnome-2048"
write_line_app gnome-chess "$icon_chs Gnome Chess" "gnome-chess"
write_line_app gnome-firmware "$icon_cfg Gnome Firmware" "gnome-firmware"
write_line_app gnome-weather "$icon_wtr Gnome Weather" "gnome-weather"
write_line_app gnome-disks "$icon_cfg Gnome Disks" "gnome-disks"
write_line_app gomuks "$icon_msg Gomuks" "sxmo_terminal.sh gomuks"
write_line_app gpodder "$icon_rss gPodder" "gpodder"
write_line_app gucharmap "$icon_inf Gucharmap" "gucharmap"
write_line_app hexchat "$icon_msg Hexchat" "hexchat"
write_line_app htop "$icon_cfg Htop" "sxmo_terminal.sh htop"
write_line_app iamb "$icon_msg Iamb" "sxmo_terminal.sh iamb"
write_line_app irssi "$icon_msg Irssi" "sxmo_terminal.sh irssi"
write_line_app ii "$icon_msg Ii" "sxmo_terminal.sh ii"
write_line_app ipython "$icon_trm IPython" "sxmo_terminal.sh ipython"
write_line_app index "$icon_dir Index" "index"
write_line_app itinerary "$icon_map Itinerary" "itinerary"
write_line_app kasts "$icon_rss Kasts" "kasts"
write_line_app kcalc "$icon_clc KCalc" "kcalc"
write_line_app kmail "$icon_eml KMail" "kmail"
write_line_app komikku "$icon_bok Komikku" "komikku"
write_line_app kontact "$icon_msg Kontact" "kontact"
write_line_app konversation "$icon_msg Konversation" "konversation"
write_line_app koreader "$icon_bok KOReader" "koreader"
write_line_app krita "$icon_img Krita" "krita --nosplash"
write_line_app kwrite "$icon_edt Kwrite" "kwrite"
write_line_app lagrange "$icon_glb Lagrange" "lagrange"
write_line_app lf "$icon_dir Lf" "sxmo_terminal.sh lf"
write_line_app librewolf "$icon_glb Librewolf" "librewolf"
write_line_app links "$icon_glb Links" "sxmo_terminal.sh links"
write_line_app links "$icon_glb Links (GUI)" "links -g"
write_line_app lollypop "$icon_mus Lollypop" "lollypop"
write_line_app lpa-gtk "$icon_sim Lpa Gtk" "lpa-gtk"
write_line_app luakit "$icon_glb Luakit" "luakit"
write_line_app marble "$icon_map Marble" "marble"
write_line_app gnome-maps "$icon_map Maps" "gnome-maps"
write_line_app megapixels "$icon_cam Megapixels" "megapixels"
write_line_app mepo "$icon_map Mepo" "mepo"
write_line_app metronome "$icon_mtr Metronome" "metronome"
write_line_app micro "$icon_edt Micro" "sxmo_terminal.sh micro"
write_line_app midori "$icon_glb Midori" "midori"
write_line_app moment "$icon_msg Moment" "moment"
write_line_app mupdf "$icon_bok Mupdf" "mupdf"
write_line_app mupdf-gl "$icon_bok Mupdf-gl" "mupdf-gl"
write_line_app mutt "$icon_eml Mutt" "sxmo_terminal.sh mutt"
write_line_app mumble "$icon_grp Mumble" mumble
write_line_app nano "$icon_edt Nano" "sxmo_terminal.sh nano"
write_line_app nautilus "$icon_dir Nautilus" "nautilus"
write_line_app navit "$icon_gps Navit" "navit"
write_line_app ncmpcpp "$icon_mus Ncmpcpp" "sxmo_terminal.sh ncmpcpp"
write_line_app neomutt "$icon_eml Neomutt" "sxmo_terminal.sh neomutt"
write_line_app nethack "$icon_trm Nethack" "sxmo_terminal.sh nethack"
write_line_app nheko "$icon_msg Nheko" "nheko"
write_line_app nvim "$icon_vim Neovim" "sxmo_terminal.sh nvim"
write_line_app nvim "$icon_nvi Neovim" "sxmo_terminal.sh nvim"
write_line_app netsurf "$icon_glb Netsurf" "netsurf"
write_line_app newsboat "$icon_rss Newsboat" "sxmo_terminal.sh newsboat"
write_line_app com.gitlab.newsflash "$icon_rss Newsflash" com.gitlab.newsflash
write_line_app newsraft "$icon_rss Newsraft" "sxmo_terminal.sh newsraft"
write_line_app nnn "$icon_dir Nnn" "sxmo_terminal.sh nnn"
write_line_app numberstation "$icon_clc Numberstation" "numberstation"
write_line_app nyxt "$icon_glb Nyxt" "nyxt"
write_line_app offpunk "$icon_glb Offpunk" "sxmo_terminal.sh offpunk"
write_line_app osmin "$icon_map Osmin" "osmin"
write_line_app papers "$icon_bok Papers" "papers"
write_line_app pavucontrol "$icon_mus Pavucontrol" "pavucontrol"
write_line_app pidgin "$icon_msg Pidgin" "pidgin"
write_line_app pulsemixer "$icon_mus Pulsemixer" "sxmo_terminal.sh pulsemixer"
write_line_app pure-maps "$icon_map Pure-Maps" "pure-maps"
write_line_app mepo "$icon_map mepo" "mepo"
write_line_app podboat "$icon_rss Podboat" "sxmo_terminal.sh podboat"
write_line_app dev.tchx84.Portfolio "$icon_dir Portfolio" "dev.tchx84.Portfolio"
write_line_app profanity "$icon_msg Profanity" "sxmo_terminal.sh profanity"
write_line_app pulsemixer "$icon_mus Pulsemixer" "sxmo_terminal.sh pulsemixer"
write_line_app pure-maps "$icon_map Pure Maps" "pure-maps"
write_line_app qalc "$icon_clc Qalc" "sxmo_terminal.sh qalc"
write_line_app qutebrowser "$icon_glb Qutebrowser" "qutebrowser"
write_line_app ranger "$icon_dir Ranger" "sxmo_terminal.sh ranger"
write_line_app sacc "$icon_glb Sacc" "sxmo_terminal.sh sacc i-logout.cz/1/bongusta"
write_line_app secrets "$icon_lck Secrets" "secrets"
write_line_app screen "$icon_msg Screen" "sxmo_terminal.sh screen"
write_line_app seahorse "$icon_key Seahorse" "seahorse"
write_line_app senpai "$icon_msg Senpai" "sxmo_terminal.sh senpai"
write_line_app sic "$icon_msg Sic" "sxmo_terminal.sh sic"
write_line_app siglo "$icon_clk Siglo" "siglo"
write_line_app simple-scan "$icon_scn Simple Scan" "simple-scan"
write_line_app snapshot "$icon_cam Snapshot" "snapshot"
([ "$SXMO_WM" = dwm ] && command -v st >/dev/null) && \
write_line "$icon_trm St" "st -e $SHELL"
write_line_app surf "$icon_glb Surf" "surf"
write_line_app syncthing "$icon_rld Syncthing" "syncthing"
write_line_app syncthing-gtk "$icon_rld Syncthing GTK" "syncthing-gtk"
([ "$SXMO_WM" = dwm ] && command -v tabbed >/dev/null) && \
write_line_app tabbed "$icon_grd Tabbed" "sxmo_tabbed.sh"
write_line_app telegram-desktop "$icon_tgm Telegram" "telegram-desktop"
write_line_app termite "$icon_trm Termite" "termite -e $SHELL"
write_line_app thunar "$icon_dir Thunar" "sxmo_terminal.sh thunar"
write_line_app thunderbird "$icon_eml Thunderbird" "thunderbird"
write_line_app tilix "$icon_trm Tilix" "tilix"
write_line_app com.github.bleakgrey.tootle "$icon_msg Tootle" "com.github.bleakgrey.tootle"
write_line_app re.sonny.Tangram "$icon_glb Tangram" "re.sonny.Tangram"
write_line_app totem "$icon_mvi Totem" "totem"
@@ -131,7 +174,6 @@ write_line_app tut "$icon_msg Tut" "sxmo_terminal.sh tut"
write_line_app waydroid "$icon_and Waydroid" "waydroid show-full-ui"
write_line_app weechat "$icon_msg Weechat" "sxmo_terminal.sh weechat"
write_line_app wike "$icon_bok Wike" "wike"
write_line_app pavucontrol "$icon_mus Pavucontrol" "pavucontrol"
write_line_app w3m "$icon_glb W3m" "sxmo_terminal.sh w3m duck.com"
write_line_app vim "$icon_vim Vim" "sxmo_terminal.sh vim"
write_line_app vimb "$icon_glb Vimb" "vimb"
@@ -141,7 +183,7 @@ write_line_app vte-2.91 "$icon_trm VTE 3" "vte-2.91"
write_line_app vte-2.91-gtk4 "$icon_trm VTE 3 (GTK-4)" "vte-2.91-gtk4"
([ "$SXMO_WM" = dwm ] && command -v xcalc >/dev/null) && \
write_line "$icon_clc Xcalc" "xcalc"
write_line_app xfce4-terminal "$icon_trm XFCE4 Terminal" "xfce4-terminal"
write_line_app xournal "$icon_bok Xournal" "xournal"
write_line_app xournalpp "$icon_bok Xournalpp" "xournalpp"
write_line_app zathura "$icon_bok Zathura" "zathura"
write_line_app j4-dmenu-desktop "$icon_grd All apps" "j4-dmenu-desktop --dmenu=sxmo_dmenu.sh --term=sxmo_terminal.sh"

View File

@@ -9,6 +9,8 @@ data_get() {
printf "%b" "$data" | grep "^$1:" | cut -d: -f2
}
SET_LED_PATH="$XDG_RUNTIME_DIR/sxmo_hook_battery_set_led"
device_changed() {
name="$(data_get "native-path")"
state="$(data_get "state")"
@@ -22,6 +24,14 @@ device_changed() {
return
fi
if [ "$percentage" -lt 25 ] && [ ! -f "$SET_LED_PATH" ]; then
touch "$SET_LED_PATH"
sxmo_led.sh set red 100
elif [ -f "$SET_LED_PATH" ]; then
rm "$SET_LED_PATH"
sxmo_led.sh set red 0
fi
sxmo_hook_statusbar.sh battery "$name" "$state" "$percentage"
}

View File

@@ -0,0 +1,8 @@
#!/bin/sh
# This hook is executed to check if a call should be blocked
# If the hook return 0 the call will be blocked
INCOMINGNUMBER="$1"
cut -f1 "$SXMO_BLOCKFILE" 2>/dev/null | grep -q "^$INCOMINGNUMBER$"

View File

@@ -68,8 +68,12 @@ active_mosh() {
command -v mosh-server && pgrep -f mosh-server
}
playing_mpc() {
command -v mpc && mpc status | grep -q '\[playing\]'
active_mpc() {
if ! command -v mpc; then
return 1
fi
mpc status | grep -q '\[playing\]\|Updating'
}
playing_mpris() {
@@ -91,7 +95,7 @@ while [ "$waited" != "0" ]; do
wait_item hotspot_active
wait_item ssh_connected
wait_item active_mosh
wait_item playing_mpc
wait_item active_mpc
wait_item playing_mpris
wait_item photos_processing
done

View File

@@ -9,27 +9,3 @@
# shellcheck source=scripts/core/sxmo_common.sh
. sxmo_common.sh
# Phonecall started
if [ "$1" = "enable" ]; then
sxmo_log "Attempting hack to get things just right."
# fixes bug where sometimes we start with speaker on and mic off
sxmo_modemaudio.sh enable_speaker
sxmo_modemaudio.sh disable_speaker
sxmo_modemaudio.sh mute_mic
sxmo_modemaudio.sh unmute_mic
# Add other things here, e.g., volume boosters
sxmo_modemaudio.sh is_disabled_speaker && sxmo_modemaudio.sh is_unmuted_mic
# Phonecall ended
elif [ "$1" = "disable" ]; then
sxmo_log "Attempting hack to get things just right."
# fixes bug where sometimes we leave call with speaker off
sxmo_modemaudio.sh disable_speaker
sxmo_modemaudio.sh enable_speaker
# Add other things here, e.g., volume boosters
sxmo_modemaudio.sh is_enabled_speaker
fi

View File

@@ -77,8 +77,8 @@ case "$WMCLASS" in
) ^ 1 ^ supertoggle_daemon 'sxmo_hook_lisgd' && (rm $XDG_CACHE_HOME/sxmo/sxmo.nogesture 2>/dev/null || touch $XDG_CACHE_HOME/sxmo/sxmo.nogesture)
$icon_cfg Toggle Bar ^ 0 ^ sxmo_wm.sh togglebar
$icon_bth Bluetooth $(
rfkill list bluetooth | grep -q "yes" &&
printf %b "$icon_tof" || printf %b "$icon_ton";
rfkill list bluetooth -no ID,SOFT,HARD | grep -vq " blocked" &&
printf %b "$icon_ton" || printf %b "$icon_tof";
printf %b "^ 1 ^ doas sxmo_bluetoothtoggle.sh && sxmo_hook_statusbar.sh bluetooth"
)
$(test "$SXMO_WM" = dwm && printf %b "$icon_cfg Invert Colors ^ 1 ^ xcalib -a -invert")
@@ -104,6 +104,7 @@ case "$WMCLASS" in
$icon_cfg Edit configuration ^ 0 ^ sxmo_terminal.sh $EDITOR $XDG_CONFIG_HOME/sxmo/$(test "$SXMO_WM" = sway && printf sway || printf xinit)
$(command -v pmos-tweaks >/dev/null && echo "$icon_cfg PostmarketOS Tweaks ^ 0 ^ GDK_SCALE=1 pmos-tweaks")
$icon_cfg Suspend Blockers ^ 0 ^ sxmo_terminal.sh sxmo_debug_suspend.sh
$icon_inf Log ^ 0 ^ sxmo_terminal.sh tail -n 100 -f ${XDG_STATE_HOME:-$HOME}/sxmo.log
$icon_inf Version ^ 0 ^ sxmo_terminal.sh sxmo_version.sh --block
"
WINNAME=Config
@@ -216,9 +217,18 @@ case "$WMCLASS" in
WINNAME=St
;;
*foot*|*st*|*terminal*|org.gnome.vte.application|*alacritty*)
# First we try to handle the app running inside the terminal:
WMNAME="${1:-$(printf %s "$XPROPOUT" | grep title: | cut -d" " -f2- | tr '[:upper:]' '[:lower:]')}"
if printf %s "$WMNAME" | grep -qi -E -w "(vi|vim|vis|nvim|neovim|kakoune)"; then
# These git commands only launch the editor.
case "$WMNAME" in
*"git add"*|*"git bugreport"*|*"git commit"*|*"git merge"*|*"git notes"*|*"git rebase"*|*"git replace"*|*"git send-email"*|*"git svn"*)
WMNAME="$WMCLASS $EDITOR"
;;
esac
# First we try to handle the app running inside the terminal:
case " $WMNAME " in
*" vi "*|*" vim "*|*" vis "*|*" nvim "*|*neovim*|*kakoune*)
#Vim in foot
CHOICES="
$icon_cls Save and Quit ^ 0 ^ sxmo_type -k Escape -s 300 ':wq' -k Return
@@ -237,7 +247,8 @@ case "$WMCLASS" in
$icon_mnu Terminal menu ^ 0 ^ sxmo_appmenu.sh $WMCLASS
"
WINNAME=Vim
elif printf %s "$WMNAME" | grep -qi -w "nano"; then
;;
*nano*)
#Nano in foot
CHOICES="
$icon_aru Scroll up ^ 1 ^ sxmo_type -k Prior
@@ -252,7 +263,8 @@ case "$WMCLASS" in
$icon_mnu Terminal menu ^ 0 ^ sxmo_appmenu.sh $WMCLASS
"
WINNAME=Nano
elif printf %s "$WMNAME" | grep -qi -w "micro"; then
;;
*micro*)
#Micro
CHOICES="
$icon_aru Scroll up ^ 1 ^ sxmo_type -k Prior
@@ -270,7 +282,8 @@ case "$WMCLASS" in
$icon_mnu Terminal menu ^ 0 ^ sxmo_appmenu.sh $WMCLASS
"
WINNAME=Micro
elif printf %s "$WMNAME" | grep -qi -w "tuir"; then
;;
*tuir*)
#tuir (reddit client) in foot
CHOICES="
$icon_aru Previous ^ 1 ^ sxmo_type k
@@ -288,7 +301,8 @@ case "$WMCLASS" in
$icon_mnu Terminal menu ^ 0 ^ sxmo_appmenu.sh $WMCLASS
"
WINNAME=tuir
elif printf %s "$WMNAME" | grep -qi -w "w3m"; then
;;
*w3m*)
#w3m
CHOICES="
$icon_arl Back ^ 1 ^ sxmo_type b
@@ -304,7 +318,8 @@ case "$WMCLASS" in
$icon_mnu Terminal menu ^ 0 ^ sxmo_appmenu.sh $WMCLASS
"
WINNAME=w3m
elif printf %s "$WMNAME" | grep -qi -w "ncmpcpp"; then
;;
*ncmpcpp*)
#ncmpcpp
CHOICES="
$icon_lst Playlist ^ 0 ^ sxmo_type 1
@@ -320,7 +335,8 @@ case "$WMCLASS" in
$icon_mnu Terminal menu ^ 0 ^ sxmo_appmenu.sh $WMCLASS
"
WINNAME=ncmpcpp
elif printf %s "$WMNAME" | grep -qi -w "aerc"; then
;;
*aerc*)
#aerc
CHOICES="
$icon_pau Archive ^ 1 ^ sxmo_type ':archive flat' -k Return
@@ -331,7 +347,8 @@ case "$WMCLASS" in
$icon_trm xdg-open Part ^ 0 ^ sxmo_type ':open' -k Return
"
WINNAME=aerc
elif printf %s "$WMNAME" | grep -qi -E -w "(less|mless)"; then
;;
*less*|*"git blame"*|*"git diff"*|*"git grep"*|*"git help"*|*"git log"*|*"git stash"*|*"git tag"*|*"git var"*)
#less
CHOICES="
$icon_arr Page next ^ 1 ^ sxmo_type ':n' -k Return
@@ -344,13 +361,8 @@ case "$WMCLASS" in
$icon_mnu Terminal menu ^ 0 ^ sxmo_appmenu.sh $WMCLASS
"
WINNAME=less
elif printf %s "$WMNAME" | grep -qi -w "git \(blame\|diff\|grep\|help\|log\|stash\|tag\|var\)"; then
# These git commands only launch the pager.
exec "$0" "$WMCLASS ${PAGER:-less}"
elif printf %s "$WMNAME" | grep -qi -w "git \(add\|bugreport\|commit\|merge\|notes\|rebase\|replace\|send-email\|svn\)"; then
# These git commands only launch the editor.
exec "$0" "$WMCLASS $EDITOR"
elif printf %s "$WMNAME" | grep -qi -w "git"; then
;;
*git*)
# git am, branch, config, tag (and other commands which launch both).
CHOICES="
$icon_fil ${PAGER:-less} menu ^ 0 ^ sxmo_appmenu.sh '$WMCLASS ${PAGER:-less}'
@@ -358,7 +370,8 @@ case "$WMCLASS" in
$icon_mnu Terminal menu ^ 0 ^ sxmo_appmenu.sh $WMCLASS
"
WINNAME=git
elif printf %s "$WMNAME" | grep -qi -w "senpai"; then
;;
*senpai*)
CHOICES="
$icon_aru Scroll up ^ 1 ^ sxmo_type -k Prior
$icon_ard Scroll down ^ 1 ^ sxmo_type -k Next
@@ -368,7 +381,8 @@ case "$WMCLASS" in
$icon_usr Toggle Members ^ 0 ^ sxmo_type -k F8
"
WINNAME=senpai
elif printf %s "$WMNAME" | grep -qi -w "weechat"; then
;;
*weechat*)
#weechat
CHOICES="
$icon_msg Hotlist Next ^ 1 ^ sxmo_type -M Alt a
@@ -380,7 +394,8 @@ case "$WMCLASS" in
$icon_mnu Terminal menu ^ 0 ^ sxmo_appmenu.sh $WMCLASS
"
WINNAME=weechat
elif printf %s "$WMNAME" | grep -qi -w "sms\|missed call"; then
;;
*" sms "*|*"missed call"*)
number="$(printf "%s\n" "$WMNAME" | xargs -0 pnc find | tr -d '\n')"
#sms
CHOICES="
@@ -405,7 +420,8 @@ case "$WMCLASS" in
$icon_mnu Terminal menu ^ 0 ^ sxmo_appmenu.sh $WMCLASS
"
WINNAME=phone
elif printf %s "$WMNAME" | grep -qi -w "cmus"; then
;;
*cmus*)
# cmus
# requires `:set set_term_title=false` in cmus to match the application
CHOICES="
@@ -419,7 +435,29 @@ case "$WMCLASS" in
$icon_mnu Terminal menu ^ 0 ^ sxmo_appmenu.sh $WMCLASS
"
WINNAME=cmus
else
;;
*iamb*)
CHOICES="
$icon_aru Page Up ^ 1 ^ sxmo_type.sh -k Escape -M Ctrl -k b
$icon_tab Toggle Selection ^ 0 ^ sxmo_type.sh -k Escape -M Ctrl -k W m
$icon_ard Page Down ^ 1 ^ sxmo_type.sh -k Escape -M Ctrl -k f
$icon_ret Reply To Message ^ 0 ^ sxmo_type.sh -k Escape :reply -k Return
$icon_tab New Tab ^ 0 ^ sxmo_type.sh -k Escape :tab rooms -k Return
$icon_arl Previous Tab ^ 0 ^ sxmo_type.sh -k Escape :tabp -k Return
$icon_arr Next Tab ^ 0 ^ sxmo_type.sh -k Escape :tabn -k Return
$icon_cls Close Tab ^ 0 ^ sxmo_type.sh -k Escape :tabclose -k Return
$icon_win Split View ^ 0 ^ sxmo_type.sh -k Escape :split -k Return
$icon_win Split View Vertical ^ 0 ^ sxmo_type.sh -k Escape :vsplit -k Return
$icon_msg All Chats ^ 0 ^ sxmo_type.sh -k Escape :chats -k Return
$icon_msg Direct Messages ^ 0 ^ sxmo_type.sh -k Escape :dms -k Return
$icon_grp Rooms ^ 0 ^ sxmo_type.sh -k Escape :rooms -k Return
$icon_glb Spaces ^ 0 ^ sxmo_type.sh -k Escape :spaces -k Return
$icon_sav Download ^ 0 ^ sxmo_type.sh -k Escape :download -k Return
$icon_cls Close View/Quit ^ 0 ^ sxmo_type.sh -k Escape :quit -k Return
"
WINNAME=iamb
;;
*)
# Now we fallback to the default terminal menu
case "$WMCLASS" in
*st*)
@@ -481,8 +519,8 @@ case "$WMCLASS" in
WINNAME=Alacritty
;;
esac
fi
;;
esac
;;
*okular*)
# Okular
CHOICES="
@@ -536,6 +574,7 @@ case "$WMCLASS" in
# Netsurf
CHOICES="
$icon_flt Pipe URL ^ 0 ^ sxmo_urlhandler.sh
$icon_lnk Enter URL ^ 0 ^ sxmo_type.sh -M Ctrl -k l
$icon_zmi Zoom ^ 1 ^ sxmo_type -M Ctrl -k plus
$icon_zmo Zoom ^ 1 ^ sxmo_type -M Ctrl -k minus
$icon_arl History ^ 1 ^ sxmo_type -M Alt -k Left
@@ -596,9 +635,26 @@ case "$WMCLASS" in
"
WINNAME=Firefox
;;
*krita*)
# Krita
CHOICES="
$icon_fnd Open ^ 0 ^ sxmo_type -M Ctrl o
$icon_sav Save ^ 0 ^ sxmo_type -M Ctrl s
$icon_pst Paste ^ 0 ^ sxmo_type -M Ctrl v
$icon_del Delete ^ 0 ^ sxmo_type -k Delete
$icon_win Select ^ 0 ^ sxmo_type -M Ctrl r
$icon_modem_disabled Deselect ^ 0 ^ sxmo_type -M Ctrl -M Shift a
$icon_wn2 Crop ^ 0 ^ sxmo_type c
$icon_flt Fill ^ 0 ^ sxmo_type f
$icon_modem_connected Gradient ^ 0 ^ sxmo_type g
$icon_dof HSV Adjust ^ 0 ^ sxmo_type -M Ctrl u
$icon_cls Close Image ^ 0 ^ sxmo_type -M Ctrl w
"
WINNAME=Krita
;;
*vimb*)
CHOICES="
$icon_glb Navigate ^ 0 ^ sxmo_type -k Escape o && sxmo_keyboard.sh open
$icon_glb Navigate ^ 0 ^ sxmo_type -k Escape o
$icon_zmi Zoom ^ 1 ^ sxmo_type -k Escape zi
$icon_zmo Zoom ^ 1 ^ sxmo_type -k Escape zo
$icon_arl History ^ 1 ^ sxmo_type -M Ctrl o
@@ -615,12 +671,12 @@ case "$WMCLASS" in
$icon_cls Close Tab ^ 0 ^ sxmo_type -M Ctrl w
$icon_bok Open Bookmarks ^ 0 ^ sxmo_type -M Ctrl b
$icon_pls Add Bookmark ^ 0 ^ sxmo_type -M Ctrl d
$icon_edt Edit Bookmarks ^ 0 ^ sxmo_keyboard.sh open && sxmo_terminal.sh $EDITOR ~/.local/share/geopard/bookmarks.gemini
$icon_edt Edit Bookmarks ^ 0 ^ sxmo_terminal.sh $EDITOR ~/.local/share/geopard/bookmarks.gemini
$icon_zmi Increase Font Size ^ 1 ^ sxmo_type -M Ctrl -k plus
$icon_zmo Decrease Font Size ^ 1 ^ sxmo_type -M Ctrl -k minus
$icon_arl History Back ^ 1 ^ sxmo_type -M Alt -k Left
$icon_arr History Forward ^ 1 ^ sxmo_type -M Alt -k Right
$icon_fnd URL Bar ^ 0 ^ sxmo_keyboard.sh open && sxmo_type -k F6
$icon_fnd URL Bar ^ 0 ^ sxmo_type -k F6
$icon_rld Refresh ^ 0 ^ sxmo_type -k F6 -k Return
"
WINNAME=Geopard
@@ -646,7 +702,7 @@ case "$WMCLASS" in
$icon_zmi Zoom in ^ 1 ^ sxmo_type -M ctrl =
$icon_zmo Zoom out ^ 1 ^ sxmo_type -M ctrl -k minus
$icon_fnd Explore POI ^ 0 ^ sxmo_type -M ctrl -M Shift F
$icon_fnd Search ^ 0 ^ sxmo_type -M ctrl f && sxmo_keyboard.sh open
$icon_fnd Search ^ 0 ^ sxmo_type -M ctrl f
$icon_lst Show last results ^ 0 ^ sxmo_type -M ctrl r
$icon_map Toggle route planner ^ 0 ^ sxmo_type -M ctrl d
$icon_gps Show current location ^ 0 ^ sxmo_type -M ctrl l
@@ -671,26 +727,110 @@ case "$WMCLASS" in
"
WINNAME=Maps
;;
*badwolf*)
# Badwolf Browser
CHOICES="
$icon_tab New Tab ^ 0 ^ sxmo_type -M Ctrl -k t
$icon_cls Close Tab ^ 0 ^ sxmo_type -M Alt -k d
$icon_fnd Reset Zoom ^ 0 ^ sxmo_type -M Ctrl -k 0
$icon_arr History ^ 1 ^ sxmo_type -M Ctrl ]
$icon_arl History ^ 1 ^ sxmo_type -M Ctrl [
$icon_arr Next Tab ^ 1 ^ sxmo_type -M Alt -k Right
$icon_arl Previous Tab ^ 1 ^ sxmo_type -M Alt -k Left
$icon_rld Refresh ^ 0 ^ sxmo_type -M Shift -M Ctrl -k r
$icon_fnd Search ^ 0 ^ sxmo_type -M Shift -M Ctrl -k f
$icon_arr Next (Search) ^ 0 ^ sxmo_type -M Shift -M Ctrl -k g
$icon_arl Previous (Search) ^ 0 ^ sxmo_type -M Shift -M Ctrl -M Shift -k g
$icon_flt URL Bar ^ 0 ^ sxmo_type -M Shift -M Ctrl l
$icon_fnd Open Web Inspector ^ 0 ^ sxmo_type -k F12
"
WINNAME=Badwolf
;;
*acme*)
# Acme
CHOICES="
$icon_mse 2 (Right) [2s delay] ^ 0 ^ sleep 2 && xdotool click 3
$icon_mse 3 (Middle) [2s delay] ^ 0 ^ sleep 2 && xdotool click 2
$icon_itm Autocomplete ^ 0 ^ sxmo_type.sh -M Ctrl -k f
$icon_exp Select Last Typed Text ^ 0 ^ sxmo_type.sh -M Escape
$icon_del Delete To Start Of Line ^ 0 ^ sxmo_type.sh -M Ctrl -k U
$icon_arl Move To Start Of Line ^ 0 ^ sxmo_type.sh -M Ctrl -k A
$icon_arr Move To End Of Line ^ 0 ^ sxmo_type.sh -M Ctrl -k E
"
WINNAME=Acme
;;
*mupdf*)
# Mupdf
CHOICES="
$icon_nxt Next Page ^ 0 ^ sxmo_type -k Space
$icon_prv Previous Page ^ 0 ^ sxmo_type -k b
$icon_chk Mark Page ^ 0 ^ sxmo_type -k m
$icon_ret Pop To Last Mark ^ 0 ^ sxmo_type -k t
$icon_zmi Zoom In ^ 1 ^ sxmo_type -k +
$icon_zmo Zoom Out ^ 1 ^ sxmo_type -k -
$icon_fnd Fit Width ^ 0 ^ sxmo_type -k W
$icon_fnd Fit Height ^ 0 ^ sxmo_type -k H
$icon_fnd Zoom To Fit ^ 0 ^ sxmo_type -k Z
$icon_fnd Reset Zoom ^ 0 ^ sxmo_type -k z
$icon_rol Rotate Counterclockwise ^ 0 ^ sxmo_type -k [
$icon_ror Rotate Clockwise ^ 0 ^ sxmo_type -k ]
$icon_fnd Search ^ 0 ^ sxmo_type -k /
"
WINNAME=Mupdf
;;
*tabbed*)
# Tabbed
CHOICES="
$icon_tab New Tab ^ 0 ^ sxmo_type.sh -M Ctrl -M Shift -M Enter
$icon_arl Previous Tab ^ 1 ^ sxmo_type.sh -M Ctrl -M Shift -k h
$icon_arr Next Tab ^ 1 ^ sxmo_type.sh -M Ctrl -M Shift -k l
$icon_arl Move Tab Left ^ 1 ^ sxmo_type.sh -M Ctrl -M Shift -k j
$icon_arr Move Tab Right ^ 1 ^ sxmo_type.sh -M Ctrl -M Shift -k k
$icon_mnu Menu Prompt ^ 0 ^ sxmo_type.sh -M Ctrl -k U0060
$icon_cls Close Tab ^ 0 ^ sxmo_type.sh -M Ctrl -k q
"
WINNAME=Tabbed
;;
*links*)
# Links Browser
CHOICES="
$icon_mnu Menu ^ 0 ^ sxmo_type.sh -k Escape
$icon_ret Follow Link ^ 0 ^ sxmo_type.sh -k Enter
$icon_arl History ^ 1 ^ sxmo_type.sh -k z
$icon_arr History ^ 1 ^ sxmo_type.sh -k x
$icon_glb Enter URL ^ 0 ^ sxmo_type.sh -k g
$icon_glb Edit Current URL ^ 0 ^ sxmo_type.sh -k G
$icon_glb View Highlighted URL ^ 0 ^ sxmo_type.sh -M Ctrl -k g
$icon_cam Toggle Images ^ 0 ^ sxmo_type.sh -k U002A
$icon_aru Scroll Up ^ 1 ^ sxmo_type.sh -k p
$icon_ard Scroll Down ^ 1 ^ sxmo_type.sh -k l
$icon_arl Scroll Left ^ 1 ^ sxmo_type.sh -k U005B
$icon_arr Scroll Right ^ 1 ^ sxmo_type.sh -k U005D
"
WINNAME=Links
;;
*)
# Default system menu (no matches)
CHOICES="
$icon_grd Scripts ^ 0 ^ sxmo_appmenu.sh scripts
$icon_grd Apps ^ 0 ^ sxmo_appmenu.sh applications
$([ "$SXMO_MENU" = "wofi" ] && echo "$icon_grd All Apps ^ 0 ^ wofi -O alphabetical -i --show drun")
$([ "$SXMO_MENU" != "wofi" ] && command -v j4-dmenu-desktop > /dev/null && echo "$icon_grd All Apps ^ 0 ^ j4-dmenu-desktop --dmenu=sxmo_dmenu.sh --term=sxmo_terminal.sh")
$icon_grd Binaries ^ 0 ^ sxmo_brun.sh
$icon_dir Files ^ 0 ^ sxmo_files.sh
$icon_phn Dialer ^ 0 ^ sxmo_modemdial.sh
$icon_msg Texts ^ 0 ^ sxmo_modemtext.sh
$icon_usr Contacts ^ 0 ^ sxmo_contactmenu.sh
$(
rfkill list bluetooth | grep -q "yes" ||
rfkill list bluetooth -no ID,SOFT,HARD | grep -vq " blocked" &&
printf %b "$icon_bth Bluetooth ^ 1 ^ sxmo_bluetoothmenu.sh"
)
$(command -v megapixels >/dev/null && echo "$icon_cam Camera ^ 0 ^ GDK_SCALE=2 megapixels")
$(
if [ -z "$SXMO_DISABLE_LEDS" ]; then
if brightness="$(brightnessctl -d "white:flash" get)"; then
printf "%s Flashlight " "$icon_fll"
sxmo_led.sh get white | grep -vq ^100$ &&
printf %b "$icon_tof" || printf %b "$icon_ton";
[ "$brightness" -gt 0 ] &&
printf %b "$icon_ton" || printf %b "$icon_tof";
printf %b "^ 1 ^ sxmo_flashtoggle.sh"
fi
)
@@ -699,6 +839,7 @@ case "$WMCLASS" in
$icon_phn Modem ^ 0 ^ sxmo_appmenu.sh modem
$icon_win Windows ^ 0 ^ sxmo_wmmenu.sh
$icon_cfg Config ^ 0 ^ sxmo_appmenu.sh config
$icon_inf Help ^ 0 ^ sxmo_terminal.sh man sxmo
$icon_pwr Power ^ 0 ^ sxmo_appmenu.sh power
"
WINNAME=Sys

View File

@@ -83,11 +83,13 @@ icon_mod="" # modem
icon_mov="󰁁"
icon_mse="󰍽" # computer mouse (🖱️)
icon_msg="󰍦" #text
icon_mtr="󰟚" # metronome
icon_mus="󰎈"
icon_mut="" #mute
icon_mvi="󰎁" #movie
icon_net="󰀂"
icon_nto="" #no touch
icon_nvi="" # neovim
icon_nxt="" #next
icon_out="󰍃" #logout
icon_pau=""
@@ -107,8 +109,10 @@ icon_rol="" #rotate left
icon_ror="" #rotate right
icon_rss=""
icon_sav="󰆓" #save
icon_scn="󰚫" #scanner
icon_sfl="" #shuffle, random
icon_shr="󰁄" #shrink
icon_sim="󰒧" # sim card
icon_snd="" #send
icon_spk="" #speaker
icon_spl=""

View File

@@ -3,7 +3,8 @@
# Copyright 2022 Sxmo Contributors
# This script handles input actions, it is called by lisgd for gestures
# and by dwm for button presses
# and by dwm for button presses. Gestures are tied to actions in
# sxmo_hook_lisgdstart.sh .
ACTION="$1"
@@ -19,9 +20,9 @@ XPROPOUT="$(sxmo_wm.sh focusedwindow)"
WMCLASS="$(printf %s "$XPROPOUT" | grep app: | cut -d" " -f2- | tr '[:upper:]' '[:lower:]')"
WMNAME="$(printf %s "$XPROPOUT" | grep title: | cut -d" " -f2- | tr '[:upper:]' '[:lower:]')"
sxmo_debug "STATE: $(cat "$SXMO_STATE") ACTION: $ACTION WMCLASS: $WMCLASS WMNAME: $WMNAME"
sxmo_debug "STATE: $(sxmo_state.sh get) ACTION: $ACTION WMCLASS: $WMCLASS WMNAME: $WMNAME"
if ! grep -q unlock "$SXMO_STATE"; then
if sxmo_state.sh is_locked; then
case "$WMNAME" in # Handle programs
*"epy"*|*"epr"*)
case "$ACTION" in
@@ -97,6 +98,48 @@ case "$WMCLASS" in
;;
esac
;;
*"acme"*)
case "$ACTION" in
"volup_one")
xdotool click 3
exit 0
;;
"voldown_one")
xdotool click 2
exit 0
;;
esac
;;
*"links"*)
case "$ACTION" in
# you're probably dragging the scrollbar
*"uprightedge") exit 0 ;;
*"downrightedge") exit 0 ;;
*"onedown")
sxmo_type.sh -M Ctrl -M Shift -k b
exit 0
;;
*"oneup")
sxmo_type.sh -M Ctrl -M Shift -k f
exit 0
;;
esac
;;
*"netsurf"*)
case "$ACTION" in
# you're probably dragging the scrollbar
*"uprightedge") exit 0 ;;
*"downrightedge") exit 0 ;;
*"onedown")
sxmo_type.sh -k Page_Up
exit 0
;;
*"oneup")
sxmo_type.sh -k Page_Down
exit 0
;;
esac
;;
*"foot"*|*"st"*|*"vte"*|"terminal") # Terminals
case "$WMCLASS" in # Handle programs without touch support
*"st"*)
@@ -318,7 +361,11 @@ case "$ACTION" in
exit 0
;;
"voldown_one")
sxmo_keyboard.sh toggle
if [ -n "$SXMO_NO_VIRTUAL_KEYBOARD" ]; then
sxmo_killwindow.sh
else
sxmo_keyboard.sh toggle
fi
exit
;;
"voldown_two")
@@ -374,11 +421,19 @@ case "$ACTION" in
exit 0
;;
"upbottomedge")
sxmo_keyboard.sh open
if [ -n "$SXMO_NO_VIRTUAL_KEYBOARD" ]; then
sxmo_terminal.sh
else
sxmo_keyboard.sh open
fi
exit 0
;;
"downbottomedge")
sxmo_keyboard.sh close
if [ -n "$SXMO_NO_VIRTUAL_KEYBOARD" ]; then
sxmo_killwindow.sh
else
sxmo_keyboard.sh close
fi
exit 0
;;
"downtopedge")

View File

@@ -0,0 +1,12 @@
#!/bin/sh
# SPDX-License-Identifier: AGPL-3.0-only
# Copyright 2022 Sxmo Contributors
# For use with peanutbutter (peanutbutter --font Sxmo --statuscommand sxmo_hook_lockstatusbar.sh)
# This filters out the last component (which is usually the time and is already displayed more prominently
# make sure status bar icons are suited for peanutbutter
sxmo_hook_statusbar.sh state_change
# obtain status output to pass to peanutbutter (this keeps running and updating to stdout)
exec sxmo_status_watch.sh -o pango

View File

@@ -2,6 +2,10 @@
# SPDX-License-Identifier: AGPL-3.0-only
# Copyright 2022 Sxmo Contributors
# Runs when a notification arrives,
# Arguments:
# $1 - The notification file which contains the notification text.
# shellcheck source=scripts/core/sxmo_common.sh
. sxmo_common.sh

View File

@@ -47,6 +47,14 @@ vibrate() {
done &
}
# SILENT MODE
if [ -f "$XDG_CONFIG_HOME"/sxmo/.busy ]; then
end="$(cat "$XDG_CONFIG_HOME"/sxmo/.busy)"
if [ -z "$end" ] || [ "$(date +%s)" -lt "$end" ]; then
exit
fi
fi
# RING & VIBRATE MODE (DEFAULT)
if [ ! -f "$XDG_CONFIG_HOME"/sxmo/.noring ] && [ ! -f "$XDG_CONFIG_HOME"/sxmo/.novibrate ]; then
sxmo_log "RING AND VIBRATE"

View File

@@ -22,7 +22,10 @@ sxmo_led.sh blink red blue &
sxmo_wm.sh dpms on
sxmo_wm.sh inputevent touchscreen off
sxmo_jobs.sh start periodic_blink sxmo_run_periodically.sh - 2 sxmo_led.sh blink red blue
if [ ! -e "$XDG_CACHE_HOME"/sxmo/sxmo.nosuspend ]; then
sxmo_jobs.sh start periodic_blink \
sxmo_run_periodically.sh -w 2 -- sxmo_led.sh blink red blue
fi
case "$SXMO_WM" in
dwm)
@@ -37,3 +40,11 @@ esac
sxmo_jobs.sh stop idle_locker
wait
case "$SXMO_WM" in
sway)
if command -v peanutbutter > /dev/null; then
peanutbutter --font Sxmo --statuscommand sxmo_hook_lockstatusbar.sh && sxmo_hook_statusbar.sh state_change &
fi
;;
esac

View File

@@ -17,16 +17,24 @@
. sxmo_common.sh
# do nothing if active call
if ! sxmo_modemcall.sh list_active_calls | grep -q active; then
if [ ! -f "$XDG_CONFIG_HOME"/sxmo/.noring ]; then
mpv --no-resume-playback --quiet --no-video "$SXMO_TEXTSOUND" >> /dev/null 2>&1 &
fi
if [ ! -f "$XDG_CONFIG_HOME"/sxmo/.novibrate ]; then
sxmo_vibrate 500 "${SXMO_VIBRATE_STRENGTH:-1}" &
fi
wait
if sxmo_modemcall.sh list_active_calls | grep -q active; then
exit
fi
# do nothing if silent mode
if [ -f "$XDG_CONFIG_HOME"/sxmo/.busy ]; then
end="$(cat "$XDG_CONFIG_HOME"/sxmo/.busy)"
if [ -z "$end" ] || [ "$(date +%s)" -lt "$end" ]; then
exit
fi
fi
if [ ! -f "$XDG_CONFIG_HOME"/sxmo/.noring ]; then
mpv --no-resume-playback --quiet --no-video "$SXMO_TEXTSOUND" >> /dev/null 2>&1 &
fi
if [ ! -f "$XDG_CONFIG_HOME"/sxmo/.novibrate ]; then
sxmo_vibrate 500 "${SXMO_VIBRATE_STRENGTH:-1}" &
fi
wait

View File

@@ -2,6 +2,8 @@
# SPDX-License-Identifier: AGPL-3.0-only
# Copyright 2022 Sxmo Contributors
# Runs upon system start and starts various background services
# include common definitions
# shellcheck source=scripts/core/sxmo_common.sh
. sxmo_common.sh
@@ -51,10 +53,10 @@ case "$SXMO_WM" in
superctl start sxmo_wob
superctl start sxmo_menumode_toggler
superctl start bonsaid
swaymsg output '*' bg "$SXMO_BG_IMG" fill
;;
dwm)
superctl start dunst
superctl start sxmo_xob
# Auto hide cursor with touchscreen, Show it with a mouse
if command -v "unclutter-xfixes" > /dev/null; then
@@ -69,7 +71,6 @@ case "$SXMO_WM" in
superctl start sxmo-x11-status
superctl start bonsaid
[ -n "$SXMO_MONITOR" ] && xrandr --output "$SXMO_MONITOR" --primary
feh --bg-fill "$SXMO_BG_IMG"
;;
esac
@@ -96,6 +97,9 @@ if [ -z "$SXMO_NO_MODEM" ] && command -v ModemManager > /dev/null; then
sxmo_wakelock.sh lock sxmo_modem_warming_up 120s
fi
# Start the desktop wallpaper
superctl start sxmo_bg
# Start the desktop widget (e.g. clock)
superctl start sxmo_conky

View File

@@ -17,9 +17,14 @@
# right and "variable" icons (that come and go) on the left.
set_time() {
date "+${SXMO_STATUS_DATE_FORMAT:-%H:%M}" | while read -r date; do
sxmobar -a time 99 "$date"
done
if pidof peanutbutter > /dev/null; then
#peanutbutter already features a clock, no need for one in the icon bar
sxmobar -d time
else
date "+${SXMO_STATUS_DATE_FORMAT:-%H:%M}" | while read -r date; do
sxmobar -a time 99 "$date"
done
fi
}
set_state() {
@@ -32,8 +37,13 @@ set_state() {
return
fi
STATE_LABEL="$(cat "$SXMO_STATE")"
case "$STATE_LABEL" in
if command -v peanutbutter > /dev/null; then
# no need for a state icon in this (default) scenario, the state will be obvious, either peanutbutter is on or it isn't
sxmobar -d state
return
fi
case "$(sxmo_state.sh get)" in
screenoff)
sxmobar -a -e bold -f red state 90 "$icon_state_screenoff" # filled circle
;;
@@ -179,8 +189,10 @@ set_modem() {
;;
esac
sxmobar -a -f "$fgcolor" -b "$bgcolor" -t "$style" \
if [ "$MODEMSTATE" != failed ] && [ "$MODEMSTATE" != unknown ]; then
sxmobar -a -f "$fgcolor" -b "$bgcolor" -t "$style" \
modem-tech 11 "$MODEMTECHCMP"
fi
MODEMSIGNALCMP="$icon_modem_signal_0"
bgcolor=default
@@ -200,8 +212,10 @@ set_modem() {
;;
esac
sxmobar -a -f "$fgcolor" -b "$bgcolor" -t "$style" \
if [ "$MODEMSTATE" != failed ] && [ "$MODEMSTATE" != unknown ]; then
sxmobar -a -f "$fgcolor" -b "$bgcolor" -t "$style" \
modem-signal 12 "$MODEMSIGNALCMP"
fi
}
# $1 = type (wifi, tun)
@@ -415,6 +429,14 @@ set_volume() {
fi
}
set_notch() {
if [ -n "$SXMO_NOTCH" ] && ! pidof peanutbutter > /dev/null; then
sxmobar -a notch "${SXMO_NOTCH_PRIO:-29}" "$SXMO_NOTCH"
else
sxmobar -d notch
fi
}
sxmo_debug "$@"
case "$1" in
network)
@@ -425,7 +447,7 @@ case "$1" in
shift
set_battery "$@"
;;
time|modem|volume|state|notifications)
time|modem|volume|state|notifications|notch)
set_"$1"
;;
periodics|state_change) # 55 s loop and screenlock triggers
@@ -433,6 +455,7 @@ case "$1" in
if [ -z "$SXMO_NO_MODEM" ]; then
set_modem
fi
set_notch
set_state
set_network wifi wlan0
;;
@@ -447,6 +470,7 @@ case "$1" in
fi
set_state
set_notifications
set_notch
set_network wifi wlan0
;;
*)

View File

@@ -1,6 +1,6 @@
#!/bin/sh
# Runs after wm has been stopped.
# Runs after wm has been stopped., useful for cleanup
# clean up misc. stale files (if any)
rm -rf "$XDG_RUNTIME_DIR"/sxmo*

View File

@@ -33,7 +33,7 @@ mkcontactssedcmd() {
TODAY="$(date +%F)"
YESTERDAY="$(date -d "- 1 day" +%F)"
TWO_DAYS="$(date -d "- 2 day" +%F)"
DATESEDCMD="s/at.*${TODAY}T/today at /; s/at.*${YESTERDAY}T/yesterday at /; s/at.*${TWO_DAYS}T/two days ago at /; s/[-+][0-9][0-9][0-9][0-9]://; s/\(-[0-9][0-9]\)T\([0-9][0-9]\)/\1 \2/;"
DATESEDCMD="s/ at ${TODAY}T/today at /; s/ at ${YESTERDAY}T/yesterday at /; s/ at ${TWO_DAYS}T/two days ago at /; s/[-+][0-9][0-9][0-9][0-9]://; s/\(-[0-9][0-9]\)T\([0-9][0-9]\)/\1 \2/;"
# TODO
#ALIGNSEDCMD="s/^Sent/<right align>/;s/^Received/<left align>/;"

View File

@@ -0,0 +1,28 @@
#!/bin/sh -e
# SPDX-License-Identifier: AGPL-3.0-only
# Copyright 2022 Sxmo Contributors
# shellcheck source=scripts/core/sxmo_common.sh
. sxmo_common.sh
# This script is executed once, and must output the wallpaper to display
installed_wallpapers() {
xdg_data_path wallpapers 0 "\0" | xargs -r0I{} find "{}" -name "$SXMO_OS.*"
}
sxmo_wallpaper() {
xdg_data_path sxmo/background.jpg
}
all_wallpapers() {
installed_wallpapers
sxmo_wallpaper
}
if [ -n "$SXMO_BG_IMG" ]; then
printf "%s" "$SXMO_BG_IMG"
exit
fi
all_wallpapers | head -n1

View File

@@ -1 +0,0 @@
./three_button_touchscreen

View File

@@ -1 +0,0 @@
./three_button_touchscreen

View File

@@ -1 +0,0 @@
./three_button_touchscreen

View File

@@ -1 +0,0 @@
./three_button_touchscreen

View File

@@ -4,7 +4,7 @@ permit nopass :wheel as root cmd busybox args reboot
permit nopass :wheel as root cmd poweroff
permit nopass :wheel as root cmd reboot
permit nopass :wheel as root cmd sxmo_wifitoggle.sh
permit nopass :wheel as root cmd sxmo_bluetoothtoggle.sh
permit nopass setenv { SXMO_OS } :wheel as root cmd sxmo_bluetoothtoggle.sh
permit nopass :wheel as root cmd rc-service args bluetooth restart
permit nopass :wheel as root cmd systemctl args restart bluetooth
permit nopass :wheel as root cmd tinydm-set-session
@@ -20,3 +20,5 @@ permit nopass :wheel as root cmd rtcwake
permit nopass :wheel as root cmd tee args -a /sys/power/wake_lock
permit nopass :wheel as root cmd tee args -a /sys/power/wake_unlock
permit nopass :wheel as root cmd tee args /sys/power/wakeup_count
permit nopass :wheel as root cmd rc-service args hexagonrpcd-adsp-sensorspd stop
permit nopass :wheel as root cmd systemctl args stop hexagonrpcd-adsp-sensorspd

View File

@@ -0,0 +1,6 @@
polkit.addRule(function(action, subject) {
if (action.id == "net.hadess.SensorProxy.claim-sensor" &&
subject.isInGroup("plugdev")) {
return polkit.Result.YES;
}
});

View File

@@ -48,6 +48,11 @@ _sxmo_find_runtime_dir() {
fi
done
if command -v mkrundir > /dev/null 2>&1; then
mkrundir
return
fi
# Fallback to a shared memory location
printf "/dev/shm/user/%s" "$(id -u)"
}

View File

@@ -0,0 +1,7 @@
[Unit]
Description=The Sxmo wallpaper as a service
[Service]
Type=simple
Restart=always
ExecStart=sxmo_bg.sh fill

View File

@@ -4,4 +4,4 @@ Description=display notifications popup messages
[Service]
Type=simple
Restart=always
ExecStart=/usr/bin/sxmo_notificationmonitor.sh
ExecStart=/usr/bin/sxmo_notifs.sh monitor

View File

@@ -4,4 +4,4 @@ Description=A lightweight overlay volume/backlight/progress/anything bar for Way
[Service]
Type=simple
Restart=always
ExecStart=/usr/bin/sxmo_wob.sh
ExecStart=/usr/bin/sxmo_ob.sh wob

View File

@@ -0,0 +1,7 @@
[Unit]
Description=A lightweight overlay volume/backlight/progress/anything bar for X11
[Service]
Type=simple
Restart=always
ExecStart=/usr/bin/sxmo_ob.sh xob

View File

@@ -8,3 +8,9 @@ ACTION=="add", SUBSYSTEM=="iio", TEST=="in_proximity_raw" RUN+="/bin/chmod g+rw
## Read device to monitor event
ACTION=="add", SUBSYSTEM=="iio", TEST=="in_proximity_raw" RUN+="/bin/chgrp input $devnode"
ACTION=="add", SUBSYSTEM=="iio", TEST=="in_proximity_raw" RUN+="/bin/chmod g+r $devnode"
# LEDs
ACTION=="add", SUBSYSTEM=="leds", RUN+="/bin/chgrp video /sys/class/leds/%k/brightness"
ACTION=="add", SUBSYSTEM=="leds", RUN+="/bin/chmod g+w /sys/class/leds/%k/brightness"
ACTION=="add", SUBSYSTEM=="leds", RUN+="/bin/chgrp video /sys/class/leds/%k/multi_intensity"
ACTION=="add", SUBSYSTEM=="leds", RUN+="/bin/chmod g+w /sys/class/leds/%k/multi_intensity"

File diff suppressed because it is too large Load Diff

View File

@@ -6,18 +6,18 @@ sxmo_contact.sh - a simple contacts manager
# SYNOPSIS
sxmo_contacts.sh allows you to store and lookup contacts in a variety of ways.
*sxmo_contacts.sh* [options]
# DESCRIPTION
TODO
Allows you to store and lookup contacts in a variety of ways.
# OPTIONS
_string_ (default)
If _string_ is given, search the contact book for _string_. The output
will be CONTACTNAME: PHONENUMBER for each hit. Note it uses grep so
multiple hits are possible.
multiple hits Are possible.
If no argument is given, then return *all* contacts from the contact
book and also every number that has ever texted or called you.
The output will be CONTACTNAME: PHONENUMBER (if in the contact book) or
@@ -46,38 +46,29 @@ _string_ (default)
*--me*
Return the phonenumber associated with the *Me* entry in contact book.
*--name-or-nuber* _phonenumber_
*--name-or-number* _phonenumber_
Return the contact name (if present) or _phone number_ (if not).
*--name* _phonenumber_
Return the contact name (if present) or *???* (if not)
# EXIT STATUS
# RETURN VALUE
# ERRORS
# ENVIRONMENT
*SXMO_CONTACTFILE*
a TSV file containing contacts (~/.config/sxmo/contacts.tsv by default)
# FILES
~/.local/share/sxmo/modem/modemlog.tsv - a TSV file containing every phone
number that has ever texted or called you.
~/.config/sxmo/contacts.tsv - a TSV file containing contacts in the format
PHONENUMBER tab CONTACTNAME
# NOTES
# BUGS
# EXAMPLES
# AUTHORS
# REPORTING BUGS
PHONENUMBER tab CONTACTNAME
# COPYRIGHT
GNU Affero General Public License v3
# SEE ALSO
_sxmo_(7), c.f. CONTACTS section

View File

@@ -0,0 +1,17 @@
sxmo_files.sh(1)
# NAME
sxmo_files.sh
# SYNOPSIS
*sxmo_files.sh*
# DESCRIPTION
A menu-based file manager for Sxmo. Invokes _sxmo_open.sh_(1) to open files.
# SEE ALSO
_sxmo_(7)

View File

@@ -1,34 +1,69 @@
*Update migrations*
sxmo_migrate.sh(1)
While developing sxmo, we will regularly update certain configuration
files such as the xinit/sway template, the hooks or whatever. These
files are typically a mixture of changes by us and customizations by
the user. This mixture gives the user maximum flexibility to adapt Sxmo
to their liking. However, when we update such files, the challenge is
to ensure that user modifications can be easily merged back in again.
Moreover, we must ensure the system is never in a broken state because
of outdated configurations and version mismatches.
# NAME
Whenever your configuration files are out-of-date when starting Sxmo,
they will be moved aside (i.e. renamed with *.needs-revision* extension)
and the default configuration will take its place. A red notification
will pop up telling you have configuration files that need to be
migrated. This migration is done by running a script named
_sxmo_migrate_(1). This script can simply be launched from the
configuration menu or via ssh (recommended).
It first shows the differences between your configuration and the new
default, and allows you to edit and apply your configuration accordingly.
_sxmo_migrate_(1) use *$DIFFTOOL* to help you merge your changes. By default
$DIFFTOOL is set to *vimdiff*.
sxmo_migrate.sh - migration tool for sxmo
If you have any pending migrations, always make sure to complete the
migration process before making any new changes to your configuration.
It is also recommended to keep your configuration under version control
(e.g. git).
# SYNOPSIS
*sxmo_migrate.sh* [subcommands...]
*Techical details*:
# SUBCOMMANDS
Sxmo (since 1.8.1) uses explicitly versioned configuration files, meaning
*reset*
Reverts *all* your configuration files and hooks to the default. Be careful with this one.
This is intended as a last resort if you end up with a broken system.
All your configuration files will moved out of the way and
flagged for migration then.
*state*
Reports whether there are any configuration files/hooks pending migration.
*sync*
Triggers a check of the versions of your configuration files and hooks.
It runs automatically when Sxmo starts.
*sync state*
Use this combination after you just finished a migration but didn't restart the
system yet
# DESCRIPTION
While developing sxmo, we will regularly update certain configuration files
such as the xinit/sway template, the hooks or whatever. These files are
typically a mixture of changes by us and customizations by the user. This
mixture gives the user maximum flexibility to adapt Sxmo to their liking.
However, when we update such files, the challenge is to ensure that user
modifications can be easily merged back in again. Moreover, we must ensure the
system is never in a broken state because of outdated configurations and
version mismatches.
Whenever your configuration files are out-of-date when starting Sxmo, they will
be moved aside (i.e. renamed with *.needs-revision* extension) and the default
configuration will take its place. This ensures that the system always remains
functional and no conflicts should arise. A red notification will pop up
telling you have configuration files that need to be migrated.
The migration is done by running a script named _sxmo_migrate_(1). This script
can simply be launched from the configuration menu or via ssh (recommended). It
first shows the differences between your configuration and the new default, and
allows you to edit and apply your configuration accordingly. If you have
_delta_(1) or _colordiff_(1) installed, they will be used to show the diff. In the
edit stage, _sxmo_migrate_(1) uses *$DIFFTOOL* to help you merge your changes.
By default $DIFFTOOL is set to *vimdiff*. If not available, your regular
*$EDITOR* will be used.
If you have any pending migrations, always make sure to complete the migration
process before making any new changes to your configuration. It is also
recommended to keep your configuration under version control (e.g. git).
*Note:* The order of the diff arguments can be changed by setting environment
variable *$SXMO_MIGRATE_ORDER* to "user:system", instead of the default
"system:user". It can also be toggled at runtime.
# TECHNICAL DETAILS
Sxmo uses explicitly versioned configuration files, meaning
that they each carry a simple version hash unique to the file.
This version hash is expressed in a comment in the file itself, such as:
@@ -38,28 +73,29 @@ This version hash is expressed in a comment in the file itself, such as:
You should *only* update this version hash when *sxmo_migrate.sh*
prompts you to do so by showing a diff of a newer configversion hash.
This information is used to determine whether your custom configuration
is up-to-date with the system-supplied defaults.
If you want to see what files are disabled and need migration, run
*sxmo_migrate.sh state*, or run *sxmo_migrate.sh sync state* if
you just performed an upgrade and haven't restarted yet. If you want to
revert *all* your configuration files to the default, then you can
run *sxmo_migrate.sh reset*. This is usually a last resort if you
end up with a broken system and can be considered a kind of factory
reset, all your configuration files will moved out of the way and
flagged for migration then.
## RESOLVING SYSTEM CONFIGURATIONS ON SYSTEM UPGRADE AND MAKE
The process that checks the versions of your configuration files is
*sxmo_migrate.sh sync*, it runs automatically when Sxmo starts.
_apk_(1), on postmarketOS, will install new configs as *.apk-new* on upgrades if you
have modified the original config in */etc*. Moreover, when hacking on Sxmo,
you will often run *make install* and this may _modify_ a config in */etc* from
apk's perspective. You can merge apk's config changes by running *doas
update-conf*. You can also run *apk audit* to list all the files that have
changed from what apk originally installed.
*Resolving system configs on system upgrade and make*
# ENVIRONMENT
Apk will install new configs as
*.apk-new* on upgrades if you have modified the original config in */etc*.
Moreover, when hacking on Sxmo, you will often run `make install`and this may "modify"
a config in /etc from apk's perspective.
You can merge apk's config changes by running `doas update-conf`. You can also run `apk audit`
to list all the files that have changed from what apk originally installed.
_sxmo_migrate_(1) read the following environment variables:
SEE ALSO: _sxmo_migrate_(1)
*DIFFTOOL*
The diff tool to use for *editing* and resolving migrations (not for display).
*SXMO_MIGRATE_ORDER*
Can be set to "user:system" or "system:user" (default). Determines the order
in which arguments are passed to diff and therefore how results are colored.
# SEE ALSO
_sxmo_(7)

View File

@@ -0,0 +1,33 @@
sxmo_wakelock.sh(1)
# NAME
sxmo_wakelock.sh - Sets or remove wakelocks
# SYNOPSIS
*sxmo_wakelock.sh* [subcommand]
# DESCRIPTION
This script sets or removes a wakelock, a wakelock tells the kernel to ensure a device is awake at a particular time.
# SUBCOMMNANDS
*isenabled*
Indicates whether a wake lock funcionality is available. Exit code 0 means it is, non-zero means it is not.
*lock* <lock-name> <DURATION|nanosec|infinite>
Sets a wakelock, *DURATION* is be an integer with suffix ms (milliseconds),
s (seconds) ,h (hours), mn (minutes), or an integer in nanoseconds if no
unit was provided. It may also be the string "infinite".
*unlock* <lock-name>
Removes a wakelock
*run* <command>
Spawn a command and set set a wakelock for its entire duration.
# SEE ALSO
_sxmo_(7)

70
programs/sxmo_sleep.c Normal file
View File

@@ -0,0 +1,70 @@
#include <errno.h> // error handling
#include <stdint.h> // uint64_t type
#include <stdio.h> // dprintf
#include <stdlib.h> // strtol, exit
#include <string.h> // strerror, strcmp
#include <sys/timerfd.h> // timers
#include <unistd.h> // read
static void error(char *message, int err) {
dprintf(2, "%s: %s\n", message, strerror(err));
exit(1);
}
static void usage(char *cmd, char *msg) {
dprintf(2, "Usage: %s [-c <clock-name>] <seconds>\n", cmd);
dprintf(2, "%s\n", msg);
exit(1);
}
int main(int argc, char **argv) {
uint64_t buf;
long duration = -1;
int time_fd;
int clockid = CLOCK_REALTIME;
struct itimerspec time = {
.it_value = { .tv_sec = 0, .tv_nsec = 0 },
.it_interval = { .tv_sec = 0, .tv_nsec = 0 }
};
for (int i = 1; i < argc; i += 1) {
if (0 == strcmp(argv[i], "-c")) {
if (argc <= i + 1) {
usage(argv[0], "You must pass a clock name.");
}
if (0 == strcmp(argv[i+1], "realtime")) {
clockid = CLOCK_REALTIME;
} else if (0 == strcmp(argv[i+1], "monotonic")) {
clockid = CLOCK_MONOTONIC;
} else if (0 == strcmp(argv[i+1], "boottime")) {
clockid = CLOCK_BOOTTIME;
} else if (0 == strcmp(argv[i+1], "realtime_alarm")) {
clockid = CLOCK_REALTIME_ALARM;
} else if (0 == strcmp(argv[i+1], "boottime_alarm")) {
clockid = CLOCK_BOOTTIME_ALARM;
} else {
usage(argv[0], "Unknown clock name.");
}
i += 1;
continue;
}
duration = strtol(argv[i], NULL, 0);;
}
if (duration <= 0) {
usage(argv[0], "You must pass a duration in second.");
}
// Setup timer
if ((time_fd = timerfd_create(clockid, TFD_CLOEXEC)) == -1)
error("Failed to create timerfd", errno);
time.it_value.tv_sec = duration;
if (timerfd_settime(time_fd, 0, &time, NULL) == -1)
error("Failed to set timer",errno);
// Wait for timer
read(time_fd, &buf, sizeof(uint64_t));
}

584
programs/sxmo_status_led.c Normal file
View File

@@ -0,0 +1,584 @@
// SPDX-License-Identifier: AGPL-3.0-only
// Copyright 2024 Aren Moynihan
// Copyright 2024 Sxmo Contributors
#include <ctype.h>
#include <errno.h>
#include <fcntl.h>
#include <math.h>
#include <stdbool.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <time.h>
#include <unistd.h>
// for tests
#include <assert.h>
#define BIT(n) 1<<n
// Logging functions
#define info(...) ({ if (verbose) fprintf(stderr, __VA_ARGS__); })
#define error(format, ...) ({ if (!quiet) fprintf(stderr, format "\n", ## __VA_ARGS__); })
static bool quiet = false;
static bool verbose = false;
static char *led_dir = "/sys/class/leds";
enum color {
COLOR_RED,
COLOR_GREEN,
COLOR_BLUE,
COLOR_MAX,
};
typedef union {
double colors[COLOR_MAX];
struct {
double red;
double green;
double blue;
};
} led_state;
struct led_handle {
int brightness;
int max_brightness;
};
void close_single_led(struct led_handle *led) {
if (led->brightness > 0)
close(led->brightness);
}
struct multicolor_handle {
enum color color_ids[3];
// file descriptors, names match sysfs
FILE *brightness;
FILE *multi_intensity;
int max_brightness;
};
enum led_type {
LED_GROUP,
LED_MULTICOLOR,
};
struct status_handle {
enum led_type type;
union {
struct multicolor_handle multicolor;
struct led_handle group[COLOR_MAX];
};
};
struct timespec delay_length = {
.tv_sec = 0,
// 150ms
.tv_nsec = 150000000,
};
// see include/dt-bindings/leds/common.h in linux kernel source
char *types[] = {
"status",
"indicator",
NULL,
};
int dreadint(int fd, int *value) {
int ret;
char buf[128];
char *end;
*value = 0;
ret = lseek(fd, 0, SEEK_SET);
if (ret == -1) {
perror("dreadint: lseek");
return -1;
}
ret = read(fd, buf, sizeof(buf) - 1);
if (ret == -1) {
perror("dreadint: read");
return -1;
}
buf[ret] = 0;
ret = strtol(buf, &end, 10);
if (end == buf) {
return -1;
}
*value = ret;
return 0;
}
int parse_color_ids(char *input, int length, enum color colors[]) {
int color_index = 0;
int start = 0;
int i = 0;
memset(colors, COLOR_MAX, sizeof(enum color)*3);
while (i < length) {
// skip whitespace
while (i < length && isspace(input[i])) { i++; }
start = i;
// find the end of the word (next whitespace)
while (i < length && !isspace(input[i])) { i++; }
if (i == start) break;
// now start points to the first char in the word and i is the last
if (strncmp(&input[start], "red", i-start) == 0) {
colors[color_index] = COLOR_RED;
} else if (strncmp(&input[start], "green", i-start) == 0) {
colors[color_index] = COLOR_GREEN;
} else if (strncmp(&input[start], "blue", i-start) == 0) {
colors[color_index] = COLOR_BLUE;
} else {
info("Unknown color: \"%.*s\"\n", i-start, &input[start]);
return false;
}
color_index++;
}
// We expect to find a controls for green, red, and blue channels. To
// check this, we convert the colors we found to a bitflag and compare
// them to what we expected to have. The color enum starts at zero and
// increments by 1, so we can bitshift by that number to decide what bit
// to use.
return (BIT(colors[0]) | BIT(colors[1]) | BIT(colors[2]))
== (BIT(COLOR_RED) | BIT(COLOR_BLUE) | BIT(COLOR_GREEN));
}
bool open_multicolor_led(char *type, struct multicolor_handle *dst) {
int ret, fd = 0;
char buf[128];
memset(dst, 0, sizeof(*dst));
snprintf(buf, sizeof(buf), "%s/rgb:%s/multi_index", led_dir, type);
fd = open(buf, O_RDONLY);
if (fd == -1) {
info("failed to open %s\n", buf);
goto error;
}
int size = read(fd, buf, sizeof(buf));
buf[size] = 0;
if (size <= 0) {
perror("while reading multi_index");
exit(1);
}
close(fd);
if (!parse_color_ids(buf, size, dst->color_ids)) {
info("failed to parse multi_index\n");
goto error;
}
snprintf(buf, sizeof(buf), "%s/rgb:%s/max_brightness", led_dir, type);
fd = open(buf, O_RDONLY);
if (fd <= 0)
goto error;
ret = dreadint(fd, &dst->max_brightness);
if (ret == -1) {
info("dreadint: read: %d\n", errno);
goto error;
}
close(fd);
snprintf(buf, sizeof(buf), "%s/rgb:%s/brightness", led_dir, type);
dst->brightness = fopen(buf, "r+");
if (dst->brightness == NULL)
goto error;
snprintf(buf, sizeof(buf), "%s/rgb:%s/multi_intensity", led_dir, type);
dst->multi_intensity = fopen(buf, "r+");
if (dst->multi_intensity == NULL)
goto error;
return true;
error:
if (fd > 0) close(fd);
if (dst->brightness) fclose(dst->brightness);
if (dst->multi_intensity) fclose(dst->multi_intensity);
return false;
}
int open_monocolor_led(char *color, char *type, bool flip, struct led_handle *led) {
char buf[128];
int fd, ret;
if (flip) {
char *tmp = type;
type = color;
color = tmp;
}
snprintf(buf, sizeof(buf), "%s/%s:%s/brightness", led_dir, color, type);
info("attempting to open %s\n", buf);
led->brightness = open(buf, O_RDWR);
if (led->brightness < 0)
return led->brightness;
snprintf(buf, sizeof(buf), "%s/%s:%s/max_brightness", led_dir, color, type);
fd = open(buf, O_RDONLY);
if (fd <= 0)
return fd;
ret = dreadint(fd, &led->max_brightness);
if (ret == -1) {
info("dreadint: read: %d\n", errno);
}
close(fd);
return ret;
}
bool open_led_group(
struct status_handle *led,
char *type, char *red, char *green, char *blue, bool flip
) {
struct led_handle *ret = led->group;
memset(ret, 0, sizeof(struct led_handle) * 3);
if (-1 == open_monocolor_led(red, type, flip, &ret[COLOR_RED]))
goto error;
if (-1 == open_monocolor_led(green, type, flip, &ret[COLOR_GREEN]))
goto error;
if (-1 == open_monocolor_led(blue, type, flip, &ret[COLOR_BLUE]))
goto error;
return true;
error:
close_single_led(&ret[COLOR_RED]);
close_single_led(&ret[COLOR_GREEN]);
close_single_led(&ret[COLOR_BLUE]);
return false;
}
bool open_status_leds(struct status_handle *led) {
// 1) rgb:status
// 2) rgb:indicator
led->type = LED_MULTICOLOR;
for (int i = 0; types[i] != NULL; i++) {
if (open_multicolor_led(types[i], &led->multicolor))
return true;
}
// We check all the multicolor leds, then all the monocolor leds. It's
// relatively safe to assume that monocolor leds with the same type, are
// in fact the same device, but not guaranteed. Also when
// leds-group-multicolor is in use, one device will have both monocolor
// and multicolor files, but the monocolor ones will be read only.
led->type = LED_GROUP;
// NOTE: these might not be a single led, there's a good chance we'll
// guess right, but we prefer multicolor leds because they don't have
// this issue.
// 3) {red,green,blue}:status
// 4) {red,green,blue}:indicator
for (int i = 0; types[i] != NULL; i++) {
if (open_led_group(led, types[i], "red", "green", "blue", false))
return true;
}
// 5) status-led:{red,green,blue} (Motorola Droid 4)
if (open_led_group(led, "status-led", "red", "green", "blue", true))
return true;
// 6) lp5523:{r,g,b} (Nokia N900)
if (open_led_group(led, "lp5523", "r", "g", "b", true))
return true;
return false;
}
int led_max_brightness(struct status_handle *led, enum color led_color) {
if (led->type == LED_MULTICOLOR) {
return led->multicolor.max_brightness;
} else {
return led->group[led_color].max_brightness;
}
}
int led_pct_to_abs(struct status_handle *led, enum color led_color, double brightness_pct) {
return ceil(brightness_pct * (led_max_brightness(led, led_color) / 100.0));
}
double led_abs_to_pct(struct status_handle *led, enum color led_color, int brightness_pct) {
return brightness_pct * (100.0 / led_max_brightness(led, led_color));
}
led_state led_state_read(struct status_handle *led) {
led_state state = {{ 0, 0, 0 }};
if (led->type == LED_MULTICOLOR) {
int colors[3];
rewind(led->multicolor.multi_intensity);
int ret;
ret = fscanf(led->multicolor.multi_intensity, "%d %d %d", &colors[0], &colors[1], &colors[2]);
if (ret != 3) {
error("Failed to parse multi_intensity file");
return state;
}
for (int i = 0; i < 3; i++) {
state.colors[led->multicolor.color_ids[i]] =
led_abs_to_pct(led, led->multicolor.color_ids[i], colors[i]);
}
// This isn't necessary, but it makes the output more consistent
// for integration tests.
rewind(led->multicolor.multi_intensity);
rewind(led->multicolor.brightness);
return state;
} else if (led->type == LED_GROUP) {
for (int color_id = 0; color_id < COLOR_MAX; color_id++) {
int brightness;
dreadint(led->group[color_id].brightness , &brightness);
state.colors[color_id] = led_abs_to_pct(led, color_id, brightness);
}
return state;
} else {
error("unknown led type. This is a bug.");
exit(1);
}
}
void led_state_write(struct status_handle *led, led_state state, int color_mask) {
if (led->type == LED_MULTICOLOR) {
FILE *intensity = led->multicolor.multi_intensity;
enum color *color_ids = led->multicolor.color_ids;
int all_color_mask = (1<<COLOR_MAX) - 1;
if (color_mask != all_color_mask) {
info("state missing colors, reading them\n");
led_state base_state = led_state_read(led);
for (int i = 0; i < COLOR_MAX; i++) {
if ((color_mask & BIT(i)) == 0)
state.colors[i] = base_state.colors[i];
}
}
info("setting colors: red: %.0f%%, green: %.0f%%, blue: %.0f%% (mask: 0x%x)\n",
state.red, state.green, state.blue, color_mask);
fprintf(intensity, "%d %d %d\n",
// The max brightness for all multicolor leds is the
// same, so we can hard code it
led_pct_to_abs(led, COLOR_MAX, state.colors[color_ids[0]]),
led_pct_to_abs(led, COLOR_MAX, state.colors[color_ids[1]]),
led_pct_to_abs(led, COLOR_MAX, state.colors[color_ids[2]])
);
fprintf(led->multicolor.brightness, "%d", led->multicolor.max_brightness);
fflush(intensity);
fflush(led->multicolor.brightness);
} else if (led->type == LED_GROUP) {
info("setting colors: red: %.0f%%, green: %.0f%%, blue: %.0f%% (mask: 0x%x)\n",
state.red, state.green, state.blue, color_mask);
for (int color_id = 0; color_id < COLOR_MAX; color_id++) {
if (BIT(color_id) & color_mask) {
dprintf(
led->group[color_id].brightness, "%d\n",
led_pct_to_abs(led, color_id, state.colors[color_id])
);
}
}
} else {
error("unknown led type. This is a bug.");
exit(1);
}
}
void blink_pattern(char *colors[], int argc, struct status_handle *led) {
led_state new_state = {{ 0, 0, 0 }};
led_state null_state = {{ 0, 0, 0 }};
led_state old_state = led_state_read(led);
int color_mask = BIT(COLOR_RED) | BIT(COLOR_BLUE) | BIT(COLOR_GREEN);
for (int i=0; i<argc; i++) {
if (strcmp("red", colors[i]) == 0) {
new_state.red = 100;
} else if (strcmp("green", colors[i]) == 0) {
new_state.green = 100;
} else if (strcmp("blue", colors[i]) == 0) {
new_state.blue = 100;
} else {
error("expected color to be one of red, green, or blue. Found %s.", colors[i]);
exit(1);
}
}
led_state_write(led, null_state, color_mask);
nanosleep(&delay_length, NULL);
led_state_write(led, new_state, color_mask);
nanosleep(&delay_length, NULL);
led_state_write(led, null_state, color_mask);
nanosleep(&delay_length, NULL);
led_state_write(led, old_state, color_mask);
}
void set_usage(char *name) {
printf("usage: %s: [-q] [-v] set <color> <value> [color value]...\n", name);
}
int set_main(struct status_handle *led, int argi, int argc, char *argv[]) {
int args = argc - (argi);
int color_mask = 0;
led_state state;
if (args % 2 != 0 || args < 2) {
set_usage(argv[0]);
return 1;
}
for (int i = argi; (i + 1) < argc; i += 2) {
char *color_str = argv[i];
char *value_str = argv[i + 1];
char *end = NULL;
enum color color_id;
errno = 0;
long value = strtol(value_str, &end, 10);
if (end == NULL || *end != 0 || errno) {
error("Unable to convert \"%s\" to a number", value_str);
exit(1);
}
if (strcmp(color_str, "red") == 0) {
color_id = COLOR_RED;
} else if (strcmp(color_str, "green") == 0) {
color_id = COLOR_GREEN;
} else if (strcmp(color_str, "blue") == 0) {
color_id = COLOR_BLUE;
} else {
error("Unknown color \"%s\", expected one of \"red\", \"green\", or \"blue\"", color_str);
}
info("setting color %s(%d) to %ld\n", color_str, color_id, value);
state.colors[color_id] = value;
color_mask |= BIT(color_id);
}
led_state_write(led, state, color_mask);
return 0;
}
int cmd_main(int argc, char *argv[]) {
int argi = 1;
while (argi < argc) {
char *arg = argv[argi];
if (strcmp(arg, "-q") == 0) {
quiet = true;
} else if (strcmp(arg, "-v") == 0) {
verbose = true;
info("enabling verbose mode\n");
} else if (strcmp(arg, "--debug-led-dir") == 0) {
argi++;
if (argi >= argc) {
error("--debug-led-dir requires a path paraemter");
exit(1);
}
led_dir = argv[argi];
} else {
break;
}
argi++;
}
struct status_handle led;
if (!open_status_leds(&led)) {
error("Unable to find suitable status led");
exit(1);
}
info("found a suitable status led\n");
for (int i = argi; i < argc; i++) {
if (strcmp("set", argv[i]) == 0) {
return set_main(&led, i + 1, argc, argv);
} else if (strcmp("blink", argv[i]) == 0) {
blink_pattern(&argv[i+1], argc-i-1, &led);
break;
} else if (strcmp("check", argv[i]) == 0) {
// status leds have already been successfully acquired
return 0;
} else {
fprintf(stderr, "Error: expected command to be one of set, or blink. Found %s\n.", argv[i]);
}
}
return 0;
}
bool parse_color_ids_str(char *input, enum color words[]) {
return parse_color_ids(input, strlen(input), words);
}
#define assert_colors(zero, one, two) \
assert(words[0] == zero && words[1] == one && words[2] == two)
int test_main() {
info("starting test suite\n");
enum color words[3];
bool ret;
ret = parse_color_ids_str("red green blue", words);
assert(ret);
assert_colors(COLOR_RED, COLOR_GREEN, COLOR_BLUE);
// it should handle newlines
ret = parse_color_ids_str("blue green red\n", words);
assert(ret);
assert_colors(COLOR_BLUE, COLOR_GREEN, COLOR_RED);
ret = parse_color_ids_str("green blue red", words);
assert(ret);
assert_colors(COLOR_GREEN, COLOR_BLUE, COLOR_RED);
ret = parse_color_ids_str("green blue brown red", words);
assert(!ret);
ret = parse_color_ids_str("blue red brown", words);
assert(!ret);
ret = parse_color_ids_str("blue green", words);
assert(!ret);
return 0;
}
int main(int argc, char *argv[]) {
#ifdef TEST
return test_main();
#else
return cmd_main(argc, argv);
#endif
}

View File

@@ -11,7 +11,7 @@
menu() {
SUBREDDIT="$(
printf %b "Close Menu\n$(echo "$SXMO_SUBREDDITS" | tr " " '\n')" |
sxmo_dmenu_with_kb.sh -p "Subreddit:"
sxmo_dmenu.sh -p "Subreddit:"
)" || exit 0
[ "Close Menu" = "$SUBREDDIT" ] && exit 0

View File

@@ -5,7 +5,6 @@
# scrot refuses to work with double quotes
# shellcheck disable=SC2016
set -e
exit_msg() {
printf "%s\n" "$1" > /dev/stderr
@@ -22,7 +21,18 @@ sway_screenshot() {
check_command slurp || exit_msg "slurp command must be available to make a selection."
area="$(slurp -o)"
grim -g "$area" "$1"
if [ -z "$area" ]; then
area="$(swaymsg -t get_outputs | jq -r '.[] |select (.focused) | .rect | "\(.x),\(.y) \(.width)x\(.height)"')"
fi
wxh=$(echo "$area" | cut -d " " -f 2)
w=$(echo "$wxh" | cut -d "x" -f 1)
h=$(echo "$wxh" | cut -d "x" -f 2)
if [ -n "$wxh" ] && [ "$w" -gt 9 ] && [ "$h" -gt 9 ]; then
#we have a selection (bigger than 9x9)
grim -g "$area" "$1" || exit_msg "Screenshot failed"
else
exit_msg "Invalid screenshot selection (too small)"
fi
}
xorg_screenshot() {
@@ -67,4 +77,4 @@ screenshot "$FILENAME"
yank "$FILENAME"
printf %s "$FILENAME"
notify-send --urgency=low "Screenshot taken"
notify-send --urgency=low "Screenshot taken" "$FILENAME"

View File

@@ -1,5 +0,0 @@
#!/bin/sh
# SPDX-License-Identifier: AGPL-3.0-only
# Copyright 2022 Sxmo Contributors
# title="$icon_cam Screenshot (selection)"
sxmo_screenshot.sh selection

View File

@@ -6,20 +6,44 @@
# shellcheck source=scripts/core/sxmo_common.sh
. sxmo_common.sh
_finish_timerrun() {
_releasealarm
exit
}
_setupalarm() {
sxmo_sleep -c boottime_alarm "$1" &
alarmpid=$!
}
_releasealarm() {
if [ -n "$alarmpid" ]; then
kill "$alarmpid" 2> /dev/null
unset alarmpid
fi
}
timerrun() {
trap '_finish_timerrun' INT TERM EXIT
TIME="$(
echo "$@" |
sed 's/\([^0-9]\)\([0-9]\)/\1+\2/g; s/h/*60m/g; s/m/*60s/g; s/s//g' |
bc
)"
_setupalarm "$TIME"
DATE1="$(($(date +%s) + TIME))";
while [ "$DATE1" -ge "$(date +%s)" ]; do
while [ "$DATE1" -gt "$(date +%s)" ]; do
printf "%s\r" "$(date -u --date @$((DATE1 - $(date +%s))) +%H:%M:%S)";
sxmo_aligned_sleep 1
sxmo_aligned_sleep 1 &
wait $!
done
echo "Done with $*"
_releasealarm
while : ;
do notify-send "Done with $*";
sxmo_vibrate 1000 "${SXMO_VIBRATE_STRENGTH:-1}"
@@ -27,10 +51,6 @@ timerrun() {
done
}
cleanwakelock() {
sxmo_wakelock.sh unlock sxmo_"$(basename "$0")"
}
stopwatchrun() {
start="$(date +%s)"
while : ; do
@@ -41,7 +61,7 @@ stopwatchrun() {
}
menu() {
TIMEINPUT="$(sxmo_dmenu_with_kb.sh -p Timer <<EOF
TIMEINPUT="$(sxmo_dmenu.sh -p Timer <<EOF
Stopwatch
1h
10m
@@ -63,13 +83,9 @@ EOF
exit 0
;;
"Stopwatch")
sxmo_wakelock.sh lock sxmo_"$(basename "$0")" infinite
trap 'cleanwakelock' INT TERM EXIT
sxmo_terminal.sh "$0" stopwatchrun
;;
*)
sxmo_wakelock.sh lock sxmo_"$(basename "$0")" infinite
trap 'cleanwakelock' INT TERM EXIT
sxmo_terminal.sh "$0" timerrun "$TIMEINPUT"
;;
esac

View File

@@ -138,7 +138,7 @@ weathermenu() {
)" |
grep -vE '^#' |
sed "s/\t/: /g" |
sxmo_dmenu_with_kb.sh -i -c -l 10 -p "Locations"
sxmo_dmenu.sh -i -p "Locations"
)" || exit 0
if [ "$CHOICE" = "Close Menu" ]; then
exit 0

View File

@@ -6,7 +6,7 @@
# shellcheck source=scripts/core/sxmo_common.sh
. sxmo_common.sh
SEARCHQUERY="$(echo "Close Menu" | sxmo_dmenu_with_kb.sh -p "Search:")" || exit 0
SEARCHQUERY="$(echo "Close Menu" | sxmo_dmenu.sh -p "Search:")" || exit 0
case "$SEARCHQUERY" in
"Close Menu") exit 0 ;;

View File

@@ -34,7 +34,7 @@ searchmenu() {
xargs -0 echo |
sed '/^[[:space:]]*$/d' |
awk '{$1=$1};1' |
sxmo_dmenu_with_kb.sh -p "Yt Search"
sxmo_dmenu.sh -p "Yt Search"
)" || exit 0
if [ "Close Menu" = "$ENTRY" ]; then

View File

@@ -81,7 +81,7 @@ getprogchoices() {
NNOTIFICATIONS="$(find "$SXMO_NOTIFDIR" -type f | wc -l)"
if [ "$NNOTIFICATIONS" -gt 0 ]; then
CHOICES="
$icon_bel Notifications ($NNOTIFICATIONS) ^ 0 ^ sxmo_notificationsmenu.sh
$icon_bel Notifications ($NNOTIFICATIONS) ^ 0 ^ sxmo_notifs.sh menu
$CHOICES
"
fi

View File

@@ -16,10 +16,10 @@ notifyvol() {
if [ "muted" = "$vol" ]; then
vol=0
fi
if [ "$SXMO_WM" = "sway" ] && [ -z "$SXMO_WOB_DISABLE" ]; then
printf "%s\n" "$vol" > "$XDG_RUNTIME_DIR"/sxmo.wobsock
if [ -z "$SXMO_WOB_DISABLE" ]; then
printf "%s\n" "$vol" > "$XDG_RUNTIME_DIR"/sxmo.obsock
else
dunstify -r 999 "$icon_audio Volume $vol"
notify-send -r 999 "$icon_audio Volume $vol"
fi
}
@@ -195,6 +195,22 @@ _ringmodesubmenu() {
else
printf " %s Vibrate ^ touch \"$XDG_CONFIG_HOME\"/sxmo/.novibrate\n" "$icon_ton"
fi
if [ -f "$XDG_CONFIG_HOME"/sxmo/.busy ]; then
end="$(cat "$XDG_CONFIG_HOME"/sxmo/.busy)"
if [ -n "$end" ] && [ "$(date +%s)" -gt "$end" ]; then
rm "$XDG_CONFIG_HOME"/sxmo/.busy
fi
fi
if [ -f "$XDG_CONFIG_HOME"/sxmo/.busy ]; then
printf " %s Busy ^ rm -f \"$XDG_CONFIG_HOME\"/sxmo/.busy\n" "$icon_ton"
else
printf " %s Busy ^ touch \"$XDG_CONFIG_HOME\"/sxmo/.busy\n" "$icon_tof"
printf " %s Busy for 15 min ^ date '+%%s+15*60' | bc > \"$XDG_CONFIG_HOME\"/sxmo/.busy\n" "$icon_tmr"
printf " %s Busy for 30 min ^ date '+%%s+30*60' | bc > \"$XDG_CONFIG_HOME\"/sxmo/.busy\n" "$icon_tmr"
printf " %s Busy for 1 hour ^ date '+%%s+60*60' | bc > \"$XDG_CONFIG_HOME\"/sxmo/.busy\n" "$icon_tmr"
printf " %s Busy for 2 hour ^ date '+%%s+2*60*60' | bc > \"$XDG_CONFIG_HOME\"/sxmo/.busy\n" "$icon_tmr"
printf " %s Busy for 3 hour ^ date '+%%s+3*60*60' | bc > \"$XDG_CONFIG_HOME\"/sxmo/.busy\n" "$icon_tmr"
fi
}
menuchoices() {

View File

@@ -5,25 +5,40 @@
# shellcheck source=scripts/core/sxmo_common.sh
. sxmo_common.sh
ROTATION_GRAVITY="${SXMO_ROTATION_GRAVITY:-"16374"}"
ROTATION_THRESHOLD="${SXMO_ROTATION_THRESHOLD:-"400"}"
POLL_TIME="${SXMO_ROTATION_POLL_TIME:-1}"
RIGHT_SIDE_UP="$(echo "$ROTATION_GRAVITY - $ROTATION_THRESHOLD" | bc)"
UPSIDE_DOWN="$(echo "-$ROTATION_GRAVITY + $ROTATION_THRESHOLD" | bc)"
FILE_Y="$(find /sys/bus/iio/devices/iio:device*/ -iname in_accel_y_raw)"
FILE_X="$(find /sys/bus/iio/devices/iio:device*/ -iname in_accel_x_raw)"
cleanly_quit() {
kill $BGPROC
}
while true; do
y_raw="$(cat "$FILE_Y")"
x_raw="$(cat "$FILE_X")"
if [ "$x_raw" -ge "$RIGHT_SIDE_UP" ] && sxmo_rotate.sh isrotated ; then
sxmo_rotate.sh rotnormal
elif [ "$x_raw" -le "$UPSIDE_DOWN" ] && [ "$(sxmo_rotate.sh isrotated)" != "invert" ]; then
sxmo_rotate.sh rotinvert
elif [ "$y_raw" -le "$UPSIDE_DOWN" ] && [ "$(sxmo_rotate.sh isrotated)" != "right" ]; then
sxmo_rotate.sh rotright
elif [ "$y_raw" -ge "$RIGHT_SIDE_UP" ] && [ "$(sxmo_rotate.sh isrotated)" != "left" ]; then
sxmo_rotate.sh rotleft
fi
sleep "$POLL_TIME"
done
# check if iio-sensor-proxy found a proximity sensor
dbus-send --system --dest=net.hadess.SensorProxy --print-reply=literal \
/net/hadess/SensorProxy org.freedesktop.DBus.Properties.Get \
string:net.hadess.SensorProxy string:HasAccelerometer | grep -q 'true' || exit
trap 'cleanly_quit' INT TERM EXIT
monitor-sensor --accel | while read -r line; do
# first line checks if iio-sensor-proxy is running
echo "$line" | grep -qi 'waiting' && continue
# second line confirms iio-sensor-proxy is running
echo "$line" | grep -qi 'appeared' && continue
# read orientation
orientation=$(echo "$line" | cut -d ':' -f 2)
case "$orientation" in
# on the very first sensor claim, the orientation might be
# reported as "undefined." assume "normal" in that case
*"undefined"*|*"normal"*)
sxmo_rotate.sh rotnormal
;;
*"bottom-up"*)
sxmo_rotate.sh rotinvert
;;
*"left-up"*)
sxmo_rotate.sh rotleft
;;
*"right-up"*)
sxmo_rotate.sh rotright
;;
esac
done &
BGPROC=$?
wait

12
scripts/core/sxmo_bg.sh Normal file
View File

@@ -0,0 +1,12 @@
#!/bin/sh
bg="$(sxmo_hook_wallpaper.sh)"
case "$SXMO_WM" in
dwm)
exec feh "${1+--bg-$1}" "$bg"
;;
sway)
exec swaybg -i "$bg" ${1+-m "$1"}
;;
esac

View File

@@ -19,7 +19,7 @@ _prompt() {
_device_list() {
bluetoothctl devices | \
cut -d" " -f2 | \
xargs -n1 bluetoothctl info | \
xargs -rn1 bluetoothctl info | \
awk '
function print_cached_device() {
print icon linkedsep paired connected " " name " " mac
@@ -67,25 +67,16 @@ _full_reconnection() {
notify-send 'Make the device discoverable'
bluetoothctl remove '$1'
sxmo_jobs.sh start bluetooth_scan bluetoothctl scan on
sxmo_jobs.sh start bluetooth_scan bluetoothctl --timeout 300 scan on
sleep 5
while : ; do
bluetoothctl --timeout 5 pair '$1'
if bluetoothctl info '$1' | grep -q 'Paired: yes'; then
break
fi
done
sleep 1
bluetoothctl trust '$1'
while : ; do
bluetoothctl --timeout 7 connect '$1'
timeout 7 bluetoothctl connect '$1'
if bluetoothctl info '$1' | grep -q 'Connected: yes'; then
break
fi
sleep 1
done
"
sxmo_jobs.sh stop bluetooth_scan
@@ -112,9 +103,9 @@ toggle_connection() {
MAC="$(printf "%s\n" "$DEVICE" | awk '{print $NF}')"
if printf "%s\n" "$PICK" | grep -q "$icon_a2x"; then
_can_fail sxmo_terminal.sh bluetoothctl --timeout 7 disconnect "$MAC"
_can_fail timeout 7 sxmo_terminal.sh bluetoothctl disconnect "$MAC"
else
_can_fail sxmo_terminal.sh bluetoothctl --timeout 7 connect "$MAC"
_can_fail timeout 7 sxmo_terminal.sh bluetoothctl connect "$MAC"
fi
}
@@ -154,7 +145,7 @@ EOF
;;
"Paired $icon_tof")
INDEX=2
_can_fail sxmo_terminal.sh bluetoothctl --timeout 7 pair "$MAC"
_can_fail timeout 7 sxmo_terminal.sh bluetoothctl "$MAC"
;;
"Trusted $icon_ton")
INDEX=3
@@ -166,11 +157,11 @@ EOF
;;
"Connected $icon_ton")
INDEX=4
_can_fail sxmo_terminal.sh bluetoothctl --timeout 7 disconnect "$MAC"
_can_fail timeout 7 sxmo_terminal.sh bluetoothctl disconnect "$MAC"
;;
"Connected $icon_tof")
INDEX=4
_can_fail sxmo_terminal.sh bluetoothctl --timeout 7 connect "$MAC"
_can_fail timeout 7 sxmo_terminal.sh bluetoothctl "$MAC"
;;
"Blocked $icon_ton")
INDEX=5

View File

@@ -43,9 +43,9 @@ case "$1" in
off
;;
*) #toggle
if rfkill list bluetooth | grep -q "yes"; then
on
else
if rfkill list bluetooth -no ID,SOFT,HARD | grep -vq " blocked"; then
off
else
on
fi
esac

View File

@@ -9,10 +9,10 @@
. sxmo_hook_icons.sh
notify() {
if [ "$SXMO_WM" = "sway" ] && [ -z "$SXMO_WOB_DISABLE" ]; then
getvalue > "$XDG_RUNTIME_DIR"/sxmo.wobsock
if [ -z "$SXMO_WOB_DISABLE" ]; then
getvalue > "$XDG_RUNTIME_DIR"/sxmo.obsock
else
getvalue | xargs dunstify -r 888 "$icon_brightness Brightness"
getvalue | xargs notify-send -r 888 "$icon_brightness Brightness"
fi
}
@@ -28,11 +28,18 @@ down() {
# bugged https://github.com/Hummer12007/brightnessctl/issues/82
# brightnessctl --min-value "${SXMO_MIN_BRIGHTNESS:-5}" set 5%-
if [ "$(getvalue)" -gt "${SXMO_MIN_BRIGHTNESS:-5}" ]; then
brightnessctl -q set 5%-
else
brightnessctl -q set "${SXMO_MIN_BRIGHTNESS:-5}"%
value="$(getvalue)"
if [ "$value" -le "${SXMO_MIN_BRIGHTNESS:-5}" ]; then
return
fi
if [ "$((value-5))" -ge "${SXMO_MIN_BRIGHTNESS:-5}" ]; then
brightnessctl -q set 5%-
return
fi
brightnessctl -q set "${SXMO_MIN_BRIGHTNESS:-5}"%
}
getvalue() {

View File

@@ -6,11 +6,27 @@
# shellcheck source=scripts/core/sxmo_common.sh
. sxmo_common.sh
case "$SXMO_WM" in
dwm)
if [ -z "$SXMO_MENU" ]; then
case "$SXMO_WM" in
sway)
SXMO_MENU=bemenu
;;
dwm)
SXMO_MENU=dmenu
;;
esac
fi
case "$SXMO_MENU" in
dmenu)
exec dmenu_run "$@"
;;
sway)
bemenu)
exec bemenu-run "$@"
;;
wofi)
exec wofi -O alphabetical -i --show run "$@"
;;
esac

View File

@@ -15,7 +15,6 @@ command -v shopt > /dev/null && shopt -s expand_aliases
alias dmenu="sxmo_dmenu.sh"
alias bemenu="sxmo_dmenu.sh"
alias jq="gojq" # better performances
if ! command -v sxmobar > /dev/null; then
sxmobar() {
@@ -65,7 +64,7 @@ xdg_data_path() {
break
fi
if [ $instance -gt 0 ]; then
printf '%s' "${sep}"
printf '%b' "${sep}"
fi
printf '%s' "${dir}/${filepath}"
instance=$((instance+1))

View File

@@ -11,7 +11,7 @@ set -e
# shellcheck disable=SC2120
newcontact() {
name="$(printf "" | sxmo_dmenu_with_kb.sh -p "$icon_usr Name")"
name="$(printf "" | sxmo_dmenu.sh -p "$icon_usr Name")"
number="$1"
if [ -n "$number" ]; then
@@ -19,7 +19,7 @@ newcontact() {
fi
while [ -z "$number" ]; do
number="$(sxmo_contacts.sh --unknown | sxmo_dmenu_with_kb.sh -p "$icon_phl Number")"
number="$(sxmo_contacts.sh --unknown | sxmo_dmenu.sh -p "$icon_phl Number")"
number="$(sxmo_validnumber.sh "$number")" || continue
done
@@ -35,7 +35,7 @@ editcontactname() {
ENTRIES="$(printf %b "Old name: $oldname")"
PICKED="$(
printf %b "$ENTRIES" |
sxmo_dmenu_with_kb.sh -p "$icon_edt Edit Contact"
sxmo_dmenu.sh -p "$icon_edt Edit Contact"
)"
if ! printf %s "$PICKED" | grep -q "^Old name: "; then
@@ -56,7 +56,7 @@ editcontactnumber() {
while [ -z "$PICKED" ]; do
PICKED="$(
printf %b "$ENTRIES" |
sxmo_dmenu_with_kb.sh -p "$icon_edt Edit Contact"
sxmo_dmenu.sh -p "$icon_edt Edit Contact"
)"
if printf %s "$PICKED" | grep -q "(Old number)$"; then
editcontact "$1"
@@ -166,7 +166,7 @@ main() {
PICKED="$(
printf %b "$ENTRIES" |
sxmo_dmenu_with_kb.sh -i -p "$icon_lst Contacts"
sxmo_dmenu.sh -i -p "$icon_lst Contacts"
)"
case "$PICKED" in

View File

@@ -5,6 +5,13 @@
# We still use dmenu in dwm|worgs cause pointer/touch events
# are not implemented yet in the X11 library of bemenu
# Note: Only pass parameters to this script that are unambiguous across all
# supported implementations! (dmenu, wofi, dmenu), which are only:
# -p PROMPT
# -i (case insensitive)
# include common definitions
# shellcheck source=scripts/core/sxmo_common.sh
. sxmo_common.sh
@@ -13,26 +20,46 @@
unalias bemenu
unalias dmenu
if [ -z "$SXMO_MENU" ]; then
case "$SXMO_WM" in
sway)
SXMO_MENU=bemenu
;;
dwm)
SXMO_MENU=dmenu
;;
esac
fi
case "$1" in
isopen)
case "$SXMO_WM" in
sway)
case "$SXMO_MENU" in
bemenu)
exec pgrep bemenu >/dev/null
;;
dwm)
wofi)
exec pgrep wofi >/dev/null
;;
dmenu)
exec pgrep dmenu >/dev/null
;;
esac
;;
close)
case "$SXMO_WM" in
sway)
case "$SXMO_MENU" in
bemenu)
if ! pgrep bemenu >/dev/null; then
exit
fi
exec pkill bemenu >/dev/null
;;
dwm)
wofi)
if ! pgrep wofi >/dev/null; then
exit
fi
exec pkill wofi >/dev/null
;;
dmenu)
if ! pgrep dmenu >/dev/null; then
exit
fi
@@ -43,40 +70,45 @@ case "$1" in
esac
if [ -n "$WAYLAND_DISPLAY" ]; then
if grep -q unlock "$SXMO_STATE"; then
if sxmo_state.sh get | grep -q unlock; then
swaymsg mode menu -q # disable default button inputs
cleanmode() {
swaymsg mode default -q
}
trap 'cleanmode' TERM INT
fi
bemenu -l "$(sxmo_rotate.sh isrotated > /dev/null && \
printf %s "${SXMO_BEMENU_LANDSCAPE_LINES:-8}" || \
printf %s "${SXMO_BEMENU_PORTRAIT_LINES:-16}")" "$@"
returned=$?
cleanmode
exit "$returned"
fi
if [ -n "$DISPLAY" ]; then
if [ -n "$WAYLAND_DISPLAY" ] || [ -n "$DISPLAY" ]; then
case "$SXMO_MENU" in
bemenu)
bemenu -l "$(sxmo_rotate.sh isrotated > /dev/null && \
printf %s "${SXMO_BEMENU_LANDSCAPE_LINES:-8}" || \
printf %s "${SXMO_BEMENU_PORTRAIT_LINES:-16}")" "$@"
returned=$?
# TODO: kill dmenu?
if sxmo_keyboard.sh isopen; then
# shellcheck disable=SC2086
exec dmenu $SXMO_DMENU_OPTS -l "$(sxmo_rotate.sh isrotated > /dev/null && \
printf %s "${SXMO_DMENU_WITH_KB_LANDSCAPE_LINES:-5}" || \
printf %s "${SXMO_DMENU_WITH_KB_PORTRAIT_LINES:-12}")" "$@"
else
# shellcheck disable=SC2086
exec dmenu $SXMO_DMENU_OPTS -l "$(sxmo_rotate.sh isrotated > /dev/null && \
printf %s "${SXMO_DMENU_LANDSCAPE_LINES:-7}" || \
printf %s "${SXMO_DMENU_PORTRAIT_LINES:-15}")" "$@"
fi
exit
[ -n "$WAYLAND_DISPLAY" ] && cleanmode
exit "$returned"
;;
wofi)
#let wofi handle the number of lines dynamically
# (wofi is a bit confused after rotating to horizontal mode though)
# shellcheck disable=SC2046
# (not quoted because we want to split args here)
wofi $(sxmo_rotate.sh isrotated > /dev/null && echo -W "${SXMO_WOFI_LANDSCAPE_WIDTH:-640}" -H "${SXMO_WOFI_LANDSCAPE_HEIGHT:-200}" -l top) "$@"
returned=$?
cleanmode
exit "$returned"
;;
dmenu)
# shellcheck disable=SC2086
exec dmenu $SXMO_DMENU_OPTS -l "$(sxmo_rotate.sh isrotated > /dev/null && \
printf %s "${SXMO_DMENU_LANDSCAPE_LINES:-5}" || \
printf %s "${SXMO_DMENU_PORTRAIT_LINES:-12}")" "$@"
;;
esac
else
#fallback to tty menu (e.g. over ssh)
export BEMENU_BACKEND=curses
exec bemenu -w "$@"
fi
export BEMENU_BACKEND=curses
exec bemenu -w "$@"

View File

@@ -1,21 +0,0 @@
#!/bin/sh
# SPDX-License-Identifier: AGPL-3.0-only
# Copyright 2022 Sxmo Contributors
if [ -n "$WAYLAND_DISPLAY$DISPLAY" ]; then
if sxmo_keyboard.sh isopen; then
wasopen="1"
fi
sxmo_keyboard.sh open
sleep .1 # give keyboard time to open
fi
OUTPUT="$(cat | sxmo_dmenu.sh "$@")"
exitcode=$?
if [ -z "$wasopen" ]; then
sxmo_keyboard.sh close
fi
printf %s "$OUTPUT"
exit $exitcode

View File

@@ -1,9 +1,9 @@
#!/bin/sh
# SPDX-License-Identifier: AGPL-3.0-only
# Copyright 2022 Sxmo Contributors
# Copyright 2024 Sxmo Contributors
if sxmo_led.sh get white | grep -vq ^100$; then
sxmo_led.sh set white 100
if [ "$(brightnessctl -d "white:flash" get)" -gt 0 ]; then
brightnessctl -q -d "white:flash" set "0%"
else
sxmo_led.sh set white 0
brightnessctl -q -d "white:flash" set "100%"
fi

View File

@@ -25,6 +25,12 @@ finish() {
exit
}
shared_envvars() {
if ! sxmo_status_led check; then
export SXMO_DISABLE_LEDS="1"
fi
}
init() {
# shellcheck source=/dev/null
. /etc/profile.d/sxmo_init.sh
@@ -32,6 +38,7 @@ init() {
_sxmo_load_environments
_sxmo_prepare_dirs
envvars
shared_envvars
sxmo_migrate.sh sync
defaults

View File

@@ -14,10 +14,13 @@ isopen() {
}
open() {
if [ -n "$SXMO_NO_VIRTUAL_KEYBOARD" ]; then
return
fi
if [ -n "$KEYBOARD" ]; then
#Note: KEYBOARD_ARGS is not quoted by design as it may includes a pipe and further tools
# shellcheck disable=SC2086
isopen || eval "$KEYBOARD" $KEYBOARD_ARGS &
isopen || eval "$KEYBOARD" $KEYBOARD_ARGS >> "${XDG_STATE_HOME:-$HOME}"/sxmo.log 2>&1 &
fi
}

View File

@@ -5,79 +5,17 @@
# shellcheck source=scripts/core/sxmo_common.sh
. sxmo_common.sh
get_led() {
color="$1"
usage() {
printf "usage: %s get [red|green|blue|white]\n" "$0"
exit 1
}
[ $# -lt 1 ] && usage
# need brightnessctl release after 0.5.1 to have --percentage
value="$(brightnessctl -d "$color:*" get)"
max="$(brightnessctl -d "$color:*" max)"
printf "scale=0; %s / %s * 100\n" "$value" "$max" | bc -l
}
set_led() {
usage (){
printf "usage: %s set [red|green|blue|white] [0-100]\n" "$0"
exit 1
}
[ $# -lt 2 ] && usage
color="$1"
percent="$2"
brightnessctl -q -d "$color:*" set "$percent%"
}
set_leds() {
while [ "$#" -ge 2 ]; do
set_led "$1" "$2" &
shift 2
done
wait
}
set -e
finish_blinking() {
sxmo_wakelock.sh unlock sxmo_playing_with_leds
eval set_leds green '$'old_green blue '$'old_blue red '$'old_red ${white:+white '$'old_white}
exit
trap - INT TERM EXIT
}
blink_leds() {
for color in green blue red white; do
percent="$(get_led "$color")"
eval "old_$color=$percent" # store old value
done
sxmo_wakelock.sh lock sxmo_playing_with_leds 2s
trap 'finish_blinking' TERM INT EXIT
while [ -n "$1" ]; do
case "$1" in
green|blue|red|white)
eval "$1=100"
shift
;;
esac
done
# shellcheck disable=SC2154
set_leds green 0 blue 0 red 0 ${white:+white 0}
sleep 0.1 # Make blink noticable
set_leds green "${green:-0}" blue "${blue:-0}" red "${red:-0}" ${white:+white "${white:-0}"}
sleep 0.1 # Make blink noticable
set_leds green 0 blue 0 red 0 ${white:+white 0}
sleep 0.1 # Make blink noticable
sxmo_status_led blink "$@"
}
[ -z "$SXMO_DISABLE_LEDS" ] || exit 1
@@ -87,12 +25,12 @@ exec 3<> "${XDG_RUNTIME_DIR:-$HOME}/sxmo.led.lock"
cmd="$1"
shift
case "$cmd" in
"set"|blink)
set)
flock -x 3
"$cmd"_leds "$@"
sxmo_status_led set "$@"
;;
get)
flock -s 3
get_led "$@"
blink)
flock -x 3
blink_leds "$@"
;;
esac

View File

@@ -15,10 +15,28 @@ if [ -z "$SXMO_DEVICE_NAME" ]; then
fi
smartdiff() {
if command -v colordiff > /dev/null; then
colordiff "$@"
#argument one is the system default
#argument two is the user version (to be migrated)
if [ "$SXMO_MIGRATE_ORDER" = "user:system" ]; then
printf "Your user file is in \e[31mred (-)\e[0m, the system default in \e[32mgreen (+)\e[0m\n"
else
diff "$@"
printf "The system default is in \e[31mred (-)\e[0m, your user changes in \e[32mgreen (+)\e[0m\n"
#swap arguments
set -- "$2" "$1"
echo "$@"
fi
if command -v delta > /dev/null; then
# shellcheck disable=SC2086
delta "$@"
elif command -v colordiff > /dev/null; then
# shellcheck disable=SC2086
colordiff -ud "$@"
else
# poor man's ad-hoc colordiff
ESC=$(printf "\e")
# shellcheck disable=SC1087
diff -ud "$@" | sed -E -e "s/^-(.*)$/-$ESC[31m\1$ESC[0m/" -e "s/^\+(.*)$/+$ESC[32m\1$ESC[0m/" -e "s/^@@(.*)$/$ESC[34m@@\1$ESC[0m/"
fi
}
@@ -32,7 +50,7 @@ resolvedifference() {
(
printf "\e[31mThe file \e[32m%s\e[31m differs\e[0m\n" "$userfile"
smartdiff -ud "$defaultfile" "$userfile"
smartdiff "$userfile" "$defaultfile"
) | more
printf "\e[31mMigration options for \e[32m%s\e[31m:\e[0m\n" "$userfile"
@@ -41,6 +59,7 @@ resolvedifference() {
printf "2 - Open [e]ditor and merge the changes yourself; take care to set the same configversion.\n"
printf "3 - Use your [u]ser version as-is; you verified it's compatible. (Auto-updates configversion only).\n"
printf "4 - [i]gnore, do not resolve and don't change anything, ask again next time. (default)\n"
printf "5 - Change the diff argument [o]rder and ask again\n"
printf "\e[33mHow do you want to resolve this? Choose one of the options above [1234deui]\e[0m "
@@ -64,9 +83,17 @@ resolvedifference() {
#open editor with both files and the diff
export DIFFTOOL="${DIFFTOOL:-vimdiff}"
if [ -n "$DIFFTOOL" ] && command -v "$DIFFTOOL" >/dev/null; then # ex vimdiff
set -- "$DIFFTOOL" "$defaultfile" "$userfile"
if [ "$SXMO_MIGRATE_ORDER" = "user:system" ]; then
set -- "$DIFFTOOL" "$userfile" "$defaultfile"
else
set -- "$DIFFTOOL" "$defaultfile" "$userfile"
fi
else
diff -u "$defaultfile" "$userfile" > "${XDG_RUNTIME_DIR}/migrate.diff"
if [ "$SXMO_MIGRATE_ORDER" = "user:system" ]; then
diff -u "$userfile" "$defaultfile" > "${XDG_RUNTIME_DIR}/migrate.diff"
else
diff -u "$defaultfile" "$userfile" > "${XDG_RUNTIME_DIR}/migrate.diff"
fi
# shellcheck disable=SC2086
set -- $EDITOR "$userfile" "$defaultfile" "${XDG_RUNTIME_DIR}/migrate.diff"
fi
@@ -92,6 +119,13 @@ resolvedifference() {
sed -i "2i$refline" "$userfile" || abort=1
fi
;;
[5oO]*)
if [ "$SXMO_MIGRATE_ORDER" = "user:system" ]; then
SXMO_MIGRATE_ORDER="system:user"
else
SXMO_MIGRATE_ORDER="user:system"
fi
;;
*)
abort=1
;;
@@ -249,7 +283,7 @@ checkhooks() {
fi
elif [ "$MODE" != "sync" ]; then
(
smartdiff -ud "/dev/null" "$hook"
smartdiff "$hook" "/dev/null"
printf "\e[31mThe hook \e[32m%s\e[31m does not exist (anymore), remove it? [y/N] \e[0m\n" "$hook"
) | more
read -r reply < /dev/tty
@@ -273,6 +307,8 @@ sway() {
defaultconfig "$(xdg_data_path sxmo/appcfg/bonsai_tree.json)" "$XDG_CONFIG_HOME/sxmo/bonsai_tree.json" 644
defaultconfig "$(xdg_data_path sxmo/appcfg/wob.ini)" "$XDG_CONFIG_HOME/wob/wob.ini" 644
defaultconfig "$(xdg_data_path sxmo/appcfg/conky.conf)" "$XDG_CONFIG_HOME/sxmo/conky.conf" 644
defaultconfig "$(xdg_data_path sxmo/appcfg/wofi.config)" "$XDG_CONFIG_HOME/wofi/config" 644
defaultconfig "$(xdg_data_path sxmo/appcfg/wofi.css)" "$XDG_CONFIG_HOME/wofi/style.css" 644
}
xorg() {

View File

@@ -24,7 +24,7 @@ menu() {
dmenu -i "$@"
}
notify_sucess() {
notify_success() {
MSG="$1"
shift
if "$@"; then
@@ -55,7 +55,7 @@ toggleconnection() {
CONNLINE="$1"
if echo "$CONNLINE" | grep -q "^$icon_don "; then
CONNNAME="$(echo "$CONNLINE" | cut -d' ' -f3-)"
notify_sucess "Disabling connection" \
notify_success "Disabling connection" \
nmcli c down "$CONNNAME"
else
CONNNAME="$(echo "$CONNLINE" | cut -d' ' -f3-)"
@@ -64,11 +64,21 @@ toggleconnection() {
sxmo_notify_user.sh "Enabling wifi first."
doas sxmo_wifitoggle.sh
fi
notify_sucess "Enabling connection" \
notify_success "Enabling connection" \
nmcli c up "$CONNNAME"
fi
}
togglegsm() {
if nmcli radio wwan | grep -q "enabled"; then
sxmo_notify_user.sh "Disabling GSM"
nmcli radio wwan off
else
sxmo_notify_user.sh "Enabling GSM"
nmcli radio wwan on
fi
}
deletenetworkmenu() {
CHOICE="$(
printf %b "$icon_cls Close Menu\n$(connections)" |
@@ -77,7 +87,7 @@ deletenetworkmenu() {
[ -z "$CHOICE" ] && return
echo "$CHOICE" | grep -q "Close Menu" && return
CONNNAME="$(echo "$CHOICE" | cut -d' ' -f3-)"
notify_sucess "Deleting connection" \
notify_success "Deleting connection" \
nmcli c delete "$CONNNAME"
}
@@ -94,14 +104,14 @@ getifname() {
addnetworkgsmmenu() {
CONNNAME="$(
echo "$icon_cls Close Menu" |
sxmo_dmenu_with_kb.sh -p "Alias"
sxmo_dmenu.sh -p "Alias"
)"
[ -z "$CONNNAME" ] && return
echo "$CONNNAME" | grep -q "Close Menu" && return
APN="$(
echo "$icon_cls Close Menu" |
sxmo_dmenu_with_kb.sh -p "APN"
sxmo_dmenu.sh -p "APN"
)"
[ -z "$APN" ] && return
echo "$APN" | grep -q "Close Menu" && return
@@ -126,33 +136,39 @@ addnetworkgsmmenu() {
;;
esac
notify_sucess "Adding connection" \
notify_success "Adding connection" \
nmcli c add type gsm ifname "$(getifname gsm)" con-name "$CONNNAME" \
apn "$APN" ${PASSWORD:+gsm.password "$PASSWORD"} \
${USERNAME:+gsm.username "$USERNAME"}
}
addnetworkwpamenu() {
SSID="$(cat <<EOF | sxmo_dmenu_with_kb.sh -p "SSID"
SSID="$(cat <<EOF | sxmo_dmenu.sh -p "SSID"
$icon_cls Close Menu
$(nmcli d wifi list | tail -n +2 | grep -v '^\*' | awk -F' ' '{ print $6 }' | grep -v '\-\-')
$(nmcli -t -f SSID,SECURITY dev wifi | awk '!seen[$0]++' | sed 's/:/ /')
EOF
)"
[ -z "$SSID" ] && return
echo "$SSID" | grep -q "Close Menu" && return
PASSPHRASE="$(cat <<EOF | sxmo_dmenu_with_kb.sh -p "Passphrase"
SECURITY_TYPE="$(echo "$SSID" | cut -d" " -f 2)"
SSID="$(echo "$SSID" | cut -d" " -f 1)"
# If no security type, or it is '--' (not sure if this happens in terse mode), skip passphrase input
if [ -n "$SECURITY_TYPE" ] && [ "$SECURITY_TYPE" != "--" ]; then
PASSPHRASE="$(cat <<EOF | sxmo_dmenu.sh -p "Passphrase"
$icon_cls Close Menu
None
EOF
)"
)"
if [ -z "$PASSPHRASE" ] || [ "None" = "$PASSPHRASE" ]; then
unset PASSPHRASE
if [ -z "$PASSPHRASE" ] || [ "None" = "$PASSPHRASE" ]; then
unset PASSPHRASE
fi
echo "$PASSPHRASE" | grep -q "Close Menu" && return
fi
echo "$PASSPHRASE" | grep -q "Close Menu" && return
notify_sucess "Adding connection" \
notify_success "Adding connection" \
nmcli c add type wifi ifname wlan0 con-name "$SSID" ssid "$SSID" \
${PASSPHRASE:+802-11-wireless-security.key-mgmt wpa-psk 802-11-wireless-security.psk "$PASSPHRASE"}
}
@@ -160,13 +176,13 @@ EOF
addhotspotusbmenu() {
CONNNAME="$(
echo "$icon_cls Close Menu" |
sxmo_dmenu_with_kb.sh -p "Alias"
sxmo_dmenu.sh -p "Alias"
)"
[ -z "$CONNNAME" ] && return
echo "$CONNNAME" | grep -q "Close Menu" && return
# TODO: restart udhcpd after disconnecting on postmarketOS
notify_sucess "Adding hotspot" \
notify_success "Adding hotspot" \
nmcli c add type ethernet ifname usb0 con-name "$CONNNAME" \
ipv4.method shared
}
@@ -174,21 +190,21 @@ addhotspotusbmenu() {
addhotspotwifimenu() {
SSID="$(
echo "$icon_cls Close Menu" |
sxmo_dmenu_with_kb.sh -p "SSID"
sxmo_dmenu.sh -p "SSID"
)"
[ -z "$SSID" ] && return
echo "$SSID" | grep -q "Close Menu" && return
key="$(
echo "$icon_cls Close Menu" |
sxmo_dmenu_with_kb.sh -p "Passphrase"
sxmo_dmenu.sh -p "Passphrase"
)"
[ -z "$key" ] && return
echo "$key" | grep -q "Close Menu" && return
key1="$(
echo "$icon_cls Close Menu" |
sxmo_dmenu_with_kb.sh -p "Confirm"
sxmo_dmenu.sh -p "Confirm"
)"
[ -z "$key1" ] && return
echo "$key1" | grep -q "Close Menu" && return
@@ -210,12 +226,12 @@ addhotspotwifimenu() {
fi
channel="$(
printf "%s Close Menu\n11\n" "$icon_cls" | sxmo_dmenu_with_kb.sh -p "Channel"
printf "%s Close Menu\n11\n" "$icon_cls" | sxmo_dmenu.sh -p "Channel"
)"
[ -z "$channel" ] && return
echo "$channel" | grep -q "Close Menu" && return
notify_sucess "Adding hotspot wifi" \
notify_success "Adding hotspot wifi" \
nmcli device wifi hotspot ifname wlan0 con-name "Hotspot $SSID" \
ssid "$SSID" channel "$channel" band bg password "$key"
}
@@ -247,6 +263,13 @@ $(
fi
)
$icon_cfg Nmtui
$(
if nmcli radio wwan | grep -q "enabled"; then
printf "%s Disable GSM\n" $icon_modem_disabled
else
printf "%s Enable GSM\n" $icon_modem_registered
fi
)
$icon_cfg Ifconfig
$([ -z "$WIFI_ENABLED" ] || printf "%s Scan Wifi Networks\n" "$icon_wif")
EOF
@@ -274,6 +297,9 @@ EOF
*"Nmtui" )
sxmo_terminal.sh nmtui || continue # Killeable
;;
*"Disable GSM"|*"Enable GSM" )
togglegsm
;;
*"Ifconfig" )
sxmo_terminal.sh watch -n 2 ifconfig || continue # Killeable
;;

193
scripts/core/sxmo_notifs.sh Executable file
View File

@@ -0,0 +1,193 @@
#!/bin/sh
# SPDX-License-Identifier: AGPL-3.0-only
# Copyright 2022 Sxmo Contributors
# include common definitions
# shellcheck source=scripts/core/sxmo_common.sh
. sxmo_common.sh
# shellcheck source=configs/default_hooks/sxmo_hook_icons.sh
. sxmo_hook_icons.sh
_clear_notif_group() {
find "$SXMO_NOTIFDIR" -type f | while read -r file; do
if awk NR==1 "$file" | grep -lxq "$1"; then
rm "$file"
fi
done
}
_handle_new_notif_file(){
file="$1"
if [ "$(wc -l "$file" | cut -d' ' -f1)" -lt 3 ]; then
sxmo_log "Invalid notification file $file found, deleting!"
rm -f "$file"
return
fi
sxmo_hook_notification.sh "$file" &
group="$(awk NR==1 "$file")"
action="$(awk NR==2 "$file")"
msg="$(tail -n+3 "$file" | cut -c1-70)"
case "$(dunstify --action="default,Open" "$msg")" in
"2")
#
# _clear_notif_group "$group"
#
;;
"default")
_clear_notif_group "$group"
setsid -f sh -c "$action" > /dev/null 2>&1
;;
esac
}
_notifications_hook() {
sxmo_hook_notifications.sh "$(find "$SXMO_NOTIFDIR"/ -type f | wc -l)"
}
monitor() {
mkdir -p "$SXMO_NOTIFDIR"
find "$SXMO_NOTIFDIR" -type f | while read -r file; do
_handle_new_notif_file "$file"
done
_notifications_hook
fifo="$(mktemp -u)"
mkfifo "$fifo"
inotifywait -mq -e attrib,move,delete "$SXMO_NOTIFDIR" >> "$fifo" &
inotif_pid=$!
finish() {
kill "$inotif_pid"
rm "$fifo"
exit
}
trap 'finish' TERM INT EXIT
while read -r notif_folder notif_type notif_file; do
if echo "$notif_type" | grep -qE "CREATE|MOVED_TO|ATTRIB"; then
_handle_new_notif_file "$notif_folder$notif_file"
fi
_notifications_hook
done < "$fifo"
wait "$inotif_pid"
}
_menu_lines() {
find "$SXMO_NOTIFDIR" -type f | while read -r file; do
msg="$(tail -n+3 "$file" | tr "\n^" " ")"
hrandmin="$(stat --printf %y "$file" | grep -oE '[0-9]{2}:[0-9]{2}')"
cat <<EOF
$hrandmin $msg^$file
EOF
done
}
menu() {
choices="$(cat <<EOF
$icon_cls Close Menu
$icon_del Clear Notifications
$(_menu_lines)
EOF
)"
picked="$(
printf "%b" "$choices" |
cut -d^ -f1 |
sxmo_dmenu.sh -i -p "Notifs"
)"
case "$picked" in
"$icon_cls Close Menu"|"")
exit
;;
"$icon_del Clear Notifications")
rm "$SXMO_NOTIFDIR"/*
# we must update statusbar here because this function depends
# on number of files in $SXMO_NOTIFDIR
sxmo_hook_statusbar.sh notifications
exit
;;
*)
file="$(
printf "%b" "$choices" |
grep -F "$picked" |
cut -d^ -f2
)"
group="$(awk NR==1 "$file")"
action="$(awk NR==2 "$file")"
_clear_notif_group "$group"
setsid -f sh -c "$action" > /dev/null 2>&1
;;
esac
}
new() {
while : ; do
case "$1" in
-i)
id="$2"
shift 2
;;
-g)
group="$2"
shift 2
;;
*)
break
;;
esac
done
if [ "$#" -lt 2 ]; then
usage
exit 1
fi
if [ -z "$id" ]; then
id="$(tr -dc 'a-zA-Z0-9' < /dev/urandom 2>/dev/null | head -c 10)"
fi
if [ -z "$group" ]; then
group="$(tr -dc 'a-zA-Z0-9' < /dev/urandom 2>/dev/null | head -c 10)"
fi
action="$1"
msg="$2"
touch "$SXMO_NOTIFDIR/$id"
printf "%s\n%s\n%b\n" "$group" "$action" "$msg" > "$SXMO_NOTIFDIR/$id"
sxmo_hook_statusbar.sh notifications
}
usage() {
cat <<EOF
$(basename "$0"): manage sxmo notifications
Subcommands:
monitor
Watch for new notification, dispatch libnotify events, handle actions
menu
Open a menu to dismiss notifications
new [-i id] [-g group] <action> <message...>
Register a new notification
EOF
}
cmd="$1"
shift
case "$cmd" in
monitor) monitor "$@";;
menu) menu "$@";;
new) new "$@";;
*)
usage
exit 1
;;
esac

View File

@@ -2,27 +2,27 @@
# SPDX-License-Identifier: AGPL-3.0-only
# Copyright 2022 Sxmo Contributors
# This script is responsible for starting wob, and making sure it exits cleanly
# This script is responsible for starting wob, or xob, and making sure it exits cleanly
# include common definitions
# shellcheck source=scripts/core/sxmo_common.sh
. sxmo_common.sh
wob_sock="$XDG_RUNTIME_DIR"/sxmo.wobsock
rm -f "$wob_sock"
mkfifo "$wob_sock"
ob_sock="$XDG_RUNTIME_DIR"/sxmo.obsock
rm -f "$ob_sock"
mkfifo "$ob_sock"
# By opening the socket as read-write it isn't closed after the first write
# see https://unix.stackexchange.com/questions/392697
wob <> "$wob_sock" &
WOBPID=$!
"${1:-wob}" <> "$ob_sock" &
OBPID=$!
finish() {
# Only finish once
trap - TERM INT EXIT
kill "$WOBPID"
rm -f "$wob_sock"
kill "$OBPID"
rm -f "$ob_sock"
}
trap 'finish' TERM INT EXIT
wait "$WOBPID"
wait "$OBPID"

View File

@@ -9,7 +9,7 @@ menu() {
printf %b "$(
echo "Close Menu";
echo "$INPUT" | grep -Eo '\S+' | tr -d '[:blank:]' | sort | uniq
)" | sxmo_dmenu_with_kb.sh -p "$PROMPT" -i
)" | sxmo_dmenu.sh -p "$PROMPT" -i
)"
}

View File

@@ -24,11 +24,11 @@ resume_all() {
}
if ! command -v playerctl >/dev/null; then
return
exit
fi
if ! playerctl status >/dev/null 2>&1; then
return
exit
fi
case "$1" in

View File

@@ -9,44 +9,22 @@
# This hook enables the proximity lock.
finish() {
kill "$EVENTMONITORPID"
kill "$TAILPID"
rm "$tmp"
# De-activate thresholds
printf 0 > "$prox_path/events/in_proximity_thresh_falling_value"
# The in_proximity_scale affects the maximum threshold value
# (see static const int stk3310_ps_max[4])
printf 6553 > "$prox_path/events/in_proximity_thresh_rising_value"
sxmo_wakelock.sh unlock sxmo_proximity_lock_running
if [ -n "$INITIALSTATE" ]; then
sxmo_state.sh set "$INITIALSTATE"
fi
sxmo_state.sh restore "$storeid"
exit
}
near() {
if [ -z "$INITIALSTATE" ]; then
INITIALSTATE="$(cat "$SXMO_STATE")"
fi
sxmo_debug "near"
sxmo_state.sh set screenoff
}
far() {
if [ -z "$INITIALSTATE" ]; then
INITIALSTATE="$(cat "$SXMO_STATE")"
fi
sxmo_debug "far"
sxmo_state.sh set unlock
}
trap 'finish' TERM INT
trap 'finish' TERM INT EXIT
sxmo_wakelock.sh lock sxmo_proximity_lock_running infinite
@@ -56,35 +34,17 @@ if [ -z "$SXMO_PROX_RAW_BUS" ]; then
else
prox_raw_bus="$SXMO_PROX_RAW_BUS"
fi
prox_path="$(dirname "$prox_raw_bus")"
prox_name="$(cat "$prox_path/name")" # e.g. stk3310
# set some sane defaults
printf "%d" "${SXMO_PROX_FALLING:-50}" > "$prox_path/events/in_proximity_thresh_falling_value"
printf "%d" "${SXMO_PROX_RISING:-100}" > "$prox_path/events/in_proximity_thresh_rising_value"
storeid="$(sxmo_state.sh store)"
tmp="$(mktemp)"
# TODO: stdbuf not needed with linux-tools-iio >=5.17
stdbuf -o L iio_event_monitor "$prox_name" >> "$tmp" &
EVENTMONITORPID=$!
tail -f "$tmp" | while read -r line; do
if echo "$line" | grep -q rising; then
while : ; do
value="$(cat "$prox_raw_bus")"
if [ "$value" -gt 100 ] && [ "$last" != "near" ]; then
near
elif echo "$line" | grep -q falling; then
last=near
elif [ "$value" -lt 100 ] && [ "$last" != "far" ]; then
far
last=far
fi
done &
TAILPID=$!
initial_distance="$(cat "$prox_raw_bus")"
if [ "$initial_distance" -gt "${SXMO_PROX_FALLING:-50}" ]; then
near
elif [ "$initial_distance" -lt "${SXMO_PROX_RISING:-100}" ]; then
far
fi
wait
finish
sleep 0.5
done

View File

@@ -7,16 +7,7 @@
. sxmo_common.sh
# We can have multiple cronjobs at the same time
sxmo_wakelock.sh lock sxmo_executing_cronjob_$$ infinite
sxmo_wakelock.sh unlock sxmo_waiting_cronjob
finish() {
sxmo_wakelock.sh unlock sxmo_executing_cronjob_$$
exit 0
}
trap 'finish' TERM INT EXIT
sxmo_log "Running $*"
"$@"
exec sxmo_wakelock.sh run sh -c '
sxmo_wakelock.sh unlock sxmo_waiting_cronjob
exec "$@"
' "" "$@"

View File

@@ -2,13 +2,40 @@
# SPDX-License-Identifier: AGPL-3.0-only
# Copyright 2022 Sxmo Contributors
if [ "$1" = "-" ]; then
waitfirst=1
shift
fi
usage() {
cat <<-EOF >&2
Usage: $(basename "$0") [-w] [-c <clock-name>] <timeout> [--] <cmd...>
EOF
exit 1
}
timeout="$1"
shift
while [ -n "$*" ]; do
case "$1" in
"--")
shift
break;
;;
"-w")
waitfirst=1
shift
;;
"-c")
clockname="$2"
shift 2
;;
*)
if [ -n "$timeout" ]; then
break;
fi
timeout="$1"
shift
;;
esac
done
if [ -z "$timeout" ] || [ -z "$*" ]; then
usage
fi
finish() {
[ -n "$CMDPID" ] && kill "$CMDPID"
@@ -19,7 +46,7 @@ finish() {
trap 'finish' TERM INT
if [ -n "$waitfirst" ]; then
sleep "$timeout" &
sxmo_sleep ${clockname:+-c $clockname} "$timeout" &
SLEEPPID="$!"
wait "$SLEEPPID"
unset SLEEPPID
@@ -31,7 +58,7 @@ while : ; do
wait "$CMDPID"
unset CMDPID
sleep "$timeout" &
sxmo_sleep ${clockname:+-c $clockname} "$timeout" &
SLEEPPID="$!"
wait "$SLEEPPID"
unset SLEEPPID

View File

@@ -4,7 +4,13 @@
# shellcheck source=scripts/core/sxmo_common.sh
. sxmo_common.sh
SXMO_STATES="${SXMO_STATES:-unlock lock screenoff}"
SXMO_STATE="${SXMO_STATE:-$XDG_RUNTIME_DIR/sxmo.state}"
if command -v peanutbutter > /dev/null; then
#no separate lock stage needed when peanutbutter is used
SXMO_STATES="${SXMO_STATES:-unlock screenoff}"
else
SXMO_STATES="${SXMO_STATES:-unlock lock screenoff}"
fi
SXMO_SUSPENDABLE_STATES="${SXMO_SUSPENDABLE_STATES:-screenoff 3}"
transition_can_suspend() {
@@ -48,15 +54,11 @@ transition_can_suspend() {
transition() {
state="$1"
# We don't transition if we stay with the same state
# shellcheck disable=SC2153
if [ "$state" = "$(cat "$SXMO_STATE")" ]; then
return
fi
sxmo_log "transitioning to stage $state"
printf %s "$state" > "$SXMO_STATE"
lock_shared
(
# We need a subshell so we can close the lock fd, without
# releasing the lock
@@ -95,6 +97,7 @@ click() {
else
transition "$state"
fi
flushstored
}
idle() {
@@ -116,18 +119,75 @@ idle() {
sxmo_log "idle: not transitioning from $state"
}
exec 3<> "$SXMO_STATE.lock"
flock -x 3
store() {
storeid="$(tr -dc 'a-zA-Z0-9' < /dev/urandom 2>/dev/null | head -c 10)"
printf %s "$state" > "$SXMO_STATE.stored.$storeid"
printf %s "$storeid"
}
state="$(cat "$SXMO_STATE")"
flushstored() {
find "$(dirname "$SXMO_STATE")" -name 'sxmo.state.stored.*' -delete
}
restore() {
storeid="$1"
if [ -f "$SXMO_STATE.stored.$storeid" ]; then
state="$(cat "$SXMO_STATE.stored.$storeid")"
transition "$state"
flushstored
fi
}
exec 3<> "$SXMO_STATE.lock"
lock_exclusive() {
flock -x 3
}
lock_shared() {
flock -s 3
}
read_state() {
state="$(cat "$SXMO_STATE")"
}
action="$1"
shift
case "$action" in
click|idle) "$action" "$@" ;;
click|idle)
lock_exclusive
read_state
"$action" "$@" ;;
get)
lock_shared
read_state
printf %s "$state"
;;
is_locked)
pidof peanutbutter swaylock waylock i3lock > /dev/null && exit 0
if sxmo_state.sh get | grep -q unlock; then
exit 1
fi
;;
set)
lock_exclusive
read_state
if printf "%b\n" "$SXMO_STATES" | tr ' ' '\n' | grep -xq "$1"; then
transition "$1"
fi
;;
store)
lock_exclusive
read_state
store
;;
restore)
lock_exclusive
restore "$1"
;;
flushstored)
lock_exclusive
flushstored
;;
esac

View File

@@ -75,7 +75,5 @@ link_select() {
link_normalize "$(xprop -id "$SURF_WINDOW" _SURF_URI | cut -d '"' -f 2)"
}
sxmo_keyboard.sh open
VAL="$(link_select)"
sxmo_keyboard.sh close
echo "$VAL"

View File

@@ -21,6 +21,26 @@ if [ -n "$mnc" ] && [ "$mnc" -gt 0 ] && [ "$mnc" -lt "$YEARS8_TO_SEC" ]; then
fi
fi
if [ "$SXMO_DEVICE_NAME" = "google,b4s4-sdm670" ]; then #(google pixel 3a)
# Quoting Richard Acayan from: https://gitlab.postmarketos.org/postmarketOS/pmaports/-/merge_requests/5400/ :
#
# There is a bug in FastRPC when waking from suspend. Since HexagonRPCD is
# currently only useful for a few moments when the ADSP is requesting the
# sensor registry, it can just be stopped without affecting sensor
# support. Add a pre-suspend hook to stop HexagonRPCD so it doesn't crash
# the ADSP when the device wakes up.
#
case "$SXMO_OS" in
alpine|postmarketos)
doas -n rc-service hexagonrpcd-adsp-sensorspd stop
;;
arch|archarm|nixos|debian)
doas -n systemctl stop hexagonrpcd-adsp-sensorspd
;;
esac
fi
sxmo_log "calling suspend with suspend_time <$suspend_time>"
start="$(date "+%s")"

33
scripts/core/sxmo_tabbed.sh Executable file
View File

@@ -0,0 +1,33 @@
#!/bin/sh
# SPDX-License-Identifier: AGPL-3.0-only
# Copyright 2024 Sxmo Contributors
# Tabbed options for various programs
# include common definitions
# shellcheck source=scripts/core/sxmo_common.sh
. sxmo_common.sh
OPTIONS="
alacritty --embed
st -w
surf -e
urxvt -embed
zathura -e
"
LIST="$(grep . <<-EOF | sxmo_dmenu.sh -p "Tabbed Embed"
$OPTIONS
Nothing
Close
EOF
)"
case "$LIST" in
"Close"|"") exit 0 ;;
"Nothing") tabbed ;;
*)
# shellcheck disable=SC2086
tabbed $LIST
;;
esac

View File

@@ -15,6 +15,9 @@ case "$SXMO_TERMINAL" in
"st"*)
set -- $SXMO_TERMINAL -T "$TERMNAME" -e "$@"
;;
"tilix"*)
set -- $SXMO_TERMINAL -t "$TERMNAME" -e "$@"
;;
"foot"*)
set -- $SXMO_TERMINAL -T "$TERMNAME" "$@"
;;
@@ -22,7 +25,13 @@ case "$SXMO_TERMINAL" in
set -- ${SXMO_TERMINAL% --} --title "$TERMNAME" -- "$@"
;;
"alacritty"*)
set -- $SXMO_TERMINAL -T "$TERMNAME" -e "$@"
# Test if alacritty was called with shell or a program
# Even with dynamic_title = true in config title will be static with -T switch
if [ "$*" = "$SHELL" ]; then
set -- $SXMO_TERMINAL
else
set -- $SXMO_TERMINAL -T "$TERMNAME" -e "$@"
fi
;;
*)
printf "%s: '%s'\n" "Not implemented for SXMO_TERMINAL" "$SXMO_TERMINAL" >&2

View File

@@ -30,7 +30,7 @@ menu() {
find "$zoneinfo_dir" -type f |
sed "s#^${zoneinfo_dir}/##g" |
sort |
sxmo_dmenu_with_kb.sh -p Timezone -i
sxmo_dmenu.sh -p Timezone -i
)" || exit 0
sxmo_terminal.sh "$0" "$T"
}

View File

@@ -38,7 +38,7 @@ pactl info
/usr/bin/mmcli --version | head -n 1
uname -m
. /etc/os-release
printf "%s %s" "$NAME" "$VERSION"
printf "%s %s\n" "$NAME" "$VERSION"
# shellcheck disable=SC2034
if [ "$1" = "--block" ]; then

View File

@@ -11,6 +11,7 @@ Usage: $(basename "$0") ACTION
isenabled
lock <lock-name> <duration|nanosec|infinite>
unlock <lock-name>
run <cmd...>
duration: <value><unit>
value: integer
unit: ms|s|mn|h (milisec, sec, minute, hour)
@@ -38,8 +39,7 @@ lock() {
case "$2" in
infinite)
sxmo_debug "lock $1 infinite"
echo "$1" | doas tee -a /sys/power/wake_lock > /dev/null
exit
set "$1"
;;
*ms)
_validint "${2%ms}"
@@ -59,8 +59,13 @@ lock() {
;;
esac
sxmo_debug "lock $1 $2"
echo "$1 $2" | doas tee -a /sys/power/wake_lock > /dev/null
if [ -n "$2" ]; then
sxmo_debug "lock $1 $2"
echo "$1 $2" | doas tee -a /sys/power/wake_lock > /dev/null
else
sxmo_debug "lock $1 indefinitely"
echo "$1" | doas tee -a /sys/power/wake_lock > /dev/null
fi
}
unlock() {
@@ -88,6 +93,30 @@ case "$cmd" in
isenabled) isenabled "$@";;
lock) lock "$@";;
unlock) unlock "$@";;
run)
finish() {
if [ -n "$cmdpid" ]; then
kill "$cmdpid" 2> /dev/null
fi
unlock "sxmo_wakelock_$$"
exit
}
if isenabled; then
lock "sxmo_wakelock_$$" infinite
trap finish INT TERM EXIT
else
cat <<-EOF >&2
Warning: we can't wakelock, we can't make sure no suspension will occur...
EOF
fi
"$@" &
cmdpid=$!
wait "$cmdpid"
unset cmdpid
;;
*)
sxmo_log "warning: sxmo_wakelock.sh $*"
usage; exit 1;;

View File

@@ -7,6 +7,7 @@ envvars() {
export MOZ_ENABLE_WAYLAND=1
export SDL_VIDEODRIVER=wayland
export XDG_CURRENT_DESKTOP=sway
[ -z "$SXMO_MENU" ] && export SXMO_MENU=bemenu
# shellcheck disable=SC2086
command -v $SXMO_TERMINAL "" >/dev/null || export SXMO_TERMINAL="foot"
command -v "$KEYBOARD" >/dev/null || export KEYBOARD=wvkbd-mobintl
@@ -24,7 +25,17 @@ with_dbus() {
cleanup() {
sxmo_jobs.sh stop all
pkill bemenu
case "$SXMO_MENU" in
bemenu)
pkill bemenu
;;
wofi)
pkill wofi
;;
dmenu)
pkill dmenu
;;
esac
pkill wvkbd
pkill superd
}

View File

@@ -73,7 +73,7 @@ swayinputevent() {
# If we dont have any matching input
if ! swaymsg -t get_inputs \
| gojq -r ".[] | select(.type == \"$TOUCH_POINTER_ID\" )" \
| jq -r ".[] | select(.type == \"$TOUCH_POINTER_ID\" )" \
| grep -q .; then
if [ -z "$2" ]; then
@@ -103,7 +103,7 @@ swayinputevent() {
xorgfocusedwindow() {
activeoutput="$(xprop -id "$(xdotool getactivewindow 2>/dev/null)" 2>/dev/null)"
printf %s "$activeoutput" | \
grep ^WM_CLASS | cut -d" " -f3- | cut -d"," -f1 | \
grep ^WM_CLASS | cut -d" " -f3- | cut -d"," -f2 | \
xargs printf 'app: %s'
printf "\n"
printf %s "$activeoutput" | \
@@ -112,27 +112,20 @@ xorgfocusedwindow() {
}
swayfocusedwindow() {
TREE="$(swaymsg -t get_tree)"
FOCUS="$(
printf %s "$TREE" | jq -r '
recurse(.nodes[]) |
select((.focused == true) and (.app_id != null)) |
{app_id: .app_id, name: .name} |
"app: " + .app_id, "title: " + .name
'
)"
if [ -z "$FOCUS" ]; then
#app_id is null, fall back to detect xwayland app:
FOCUS="$(
printf %s "$TREE" | jq -r '
recurse(.nodes[]) |
select((.focused == true) and (.shell == "xwayland")) |
{app_id: .window_properties.class, name: .window_properties.title} |
"app: " + .app_id, "title: " + .name
'
)"
fi
printf "%s\n" "$FOCUS"
swaymsg -t get_tree | jq -r '
recurse(.nodes[]) |
select(.focused == true) |
{
app_id: (if .app_id != null then
.app_id
else
.window_properties.class
end),
name: .name,
} |
select(.app_id != null and .name != null) |
"app: " + .app_id, "title: " + .name
'
}
swaypaste() {
@@ -151,7 +144,7 @@ swayexec() {
swayexecwait() {
PIDFILE="$(mktemp)"
printf '"%s" & printf %%s "$!" > "%s"' "$*" "$PIDFILE" \
| xargs -I{} swaymsg exec -- sh -c '{}'
| xargs -I{} swaymsg exec -- '{}'
while : ; do
sleep 0.5
kill -0 "$(cat "$PIDFILE")" 2> /dev/null || break

View File

@@ -8,8 +8,9 @@
envvars() {
export SXMO_WM=dwm
export XDG_CURRENT_DESKTOP=dwm
[ -z "$SXMO_MENU" ] && export SXMO_MENU=dmenu
# shellcheck disable=SC2086
command -v $SXMO_TERMINAL "" >/dev/null || export SXMO_TERMINAL="st -e"
command -v $SXMO_TERMINAL "" >/dev/null || export SXMO_TERMINAL="st"
command -v "$KEYBOARD" >/dev/null || defaultkeyboard
[ -z "$MOZ_USE_XINPUT2" ] && export MOZ_USE_XINPUT2=1
}
@@ -47,7 +48,14 @@ with_dbus() {
cleanup() {
sxmo_jobs.sh stop all
pkill svkbd
pkill dmenu
case "$SXMO_MENU" in
dmenu)
pkill dmenu
;;
bemenu)
pkill bemenu
;;
esac
pkill superd
}

View File

@@ -44,16 +44,8 @@ export SXMO_MODEM_GPIO_KEY_RI | If the modem driver handle a gpio, sxmo have to
export SXMO_NO_MODEM | Disable modem related features
### Screen-related
SXMO_ROTATION_POLL_TIME | Polling time for rotate in seconds (decimals allowed e.g. .1) [default: 1]
SXMO_ROTATION_GRAVITY | Override gravity for calculating rotation [default: 500]
SXMO_ROTATION_THRESHOLD | Threshold for detecting rotation [default: 60]
SXMO_MIN_BRIGHTNESS | Minimum brightness level [default: 5]
SXMO_DISABLE_LEDS | Disable leds (1 or 0) [default: 0]
SXMO_SWAY_SCALE | Screen scale for hidpi screens. Can be fractional [SWAY-ONLY].
SXMO_ROTATE_DIRECTION | The direction to rotate when using the gesture [default: right]
@@ -79,6 +71,8 @@ SXMO_DISABLE_KEYBINDS | Disable most custom Sxmo binds on volume keys if set.
SXMO_MONITOR | Display "Output" from `swaymsg -t get_outputs`. Should be the same as the output from the `xrandr` command when running dwm.
SXMO_NO_VIRTUAL_KEYBOARD | Disable all virtual keyboard management, and change some related gesture behavior.
### General / Misc.
SXMO_VIBRATE_DEV | Path to vibration device (see sxmo_vibrate.c and clickclack.c) [default: /dev/input/by-path/platform-vibrator-event]
SXMO_VIBRATE_STRENGTH | Strength parameter to pass to sxmo_vibrate [default: 1]

View File

@@ -0,0 +1,8 @@
#!/bin/sh
# Alcatel OneTouch Idol 3 (5.5) (6045Y)
# SPDX-License-Identifier: AGPL-3.0-only
# Copyright 2024 Sxmo Contributors
export SXMO_VIBRATE_DEV="/dev/input/by-path/platform-200f000.spmi-platform-200f000.spmi:pmic@1:vibrator@c000-event"
export SXMO_MIN_BRIGHTNESS=1 # Still visible
export SXMO_VIBRATE_STRENGTH=256 # Is activated between 256 and 65535, from lowest to highest

View File

@@ -0,0 +1 @@
export SXMO_NO_MODEM=1

2
scripts/deviceprofiles/sxmo_deviceprofile_desktop.sh Normal file → Executable file
View File

@@ -1,6 +1,6 @@
export SXMO_DISABLE_LEDS=1
export SXMO_STATUS_DATE_FORMAT="%Y-%m-%d %H:%M"
export SXMO_DISABLE_KEYBINDS=1
export SXMO_STATES="unlock locker"
export SXMO_UNLOCK_IDLE_TIME=300
export SXMO_NO_MODEM=1
export SXMO_NO_VIRTUAL_KEYBOARD=1

View File

View File

@@ -0,0 +1,9 @@
#!/bin/sh
# SPDX-License-Identifier: AGPL-3.0-only
# Copyright 2024 Sxmo Contributors
export SXMO_VOLUME_BUTTON="1:1:gpio-keys 0:0:pm8941_resin"
export SXMO_POWER_BUTTON="0:0:pm8941_pwrkey"
export SXMO_VIBRATE_DEV="/dev/input/event2"
export SXMO_VIBRATE_STRENGTH="50000"
export SXMO_SWAY_SCALE="3"

Some files were not shown because too many files have changed in this diff Show More