Send patches - preferably formatted by git format-patch - to patches at archlinux32 dot org.
summaryrefslogtreecommitdiff
path: root/profiles/bspwm.py
diff options
context:
space:
mode:
authorj-james <35242550+j-james@users.noreply.github.com>2022-04-03 03:58:48 -0700
committerGitHub <noreply@github.com>2022-04-03 12:58:48 +0200
commit656047163ada076640220afd443f28ca64e0a218 (patch)
tree979a90e48c50ca4492ba621f5feca005b464f9fc /profiles/bspwm.py
parent28c63b2354724601b0c88e5cc60473f801968d4d (diff)
Rebase bspwm profile on master (#604)
Diffstat (limited to 'profiles/bspwm.py')
-rw-r--r--profiles/bspwm.py43
1 files changed, 43 insertions, 0 deletions
diff --git a/profiles/bspwm.py b/profiles/bspwm.py
new file mode 100644
index 00000000..0fb67ad6
--- /dev/null
+++ b/profiles/bspwm.py
@@ -0,0 +1,43 @@
+# A desktop environment using the bspwm window manager.
+
+import archinstall
+
+is_top_level_profile = False
+
+__packages__ = [
+ 'bspwm',
+ 'sxhkd',
+ 'dmenu',
+ 'xdo',
+ 'rxvt-unicode',
+ 'lightdm',
+ 'lightdm-gtk-greeter',
+]
+
+def _prep_function(*args, **kwargs):
+ """
+ Magic function called by the importing installer
+ before continuing any further. It also avoids executing any
+ other code in this stage. So it's a safe way to ask the user
+ for more input before any other installer steps start.
+ """
+
+ # bspwm requires a functioning Xorg installation.
+ profile = archinstall.Profile(None, 'xorg')
+ with profile.load_instructions(namespace='xorg.py') as imported:
+ if hasattr(imported, '_prep_function'):
+ return imported._prep_function()
+ else:
+ print('Deprecated (??): xorg profile has no _prep_function() anymore')
+
+
+# Ensures that this code only gets executed if executed
+# through importlib.util.spec_from_file_location("bspwm", "/somewhere/bspwm.py")
+# or through conventional import bspwm
+if __name__ == 'bspwm':
+ # Install dependency profiles
+ archinstall.storage['installation_session'].install_profile('xorg')
+ # Install bspwm packages
+ archinstall.storage['installation_session'].add_additional_packages(__packages__)
+ # Set up LightDM for login
+ archinstall.storage['installation_session'].enable_service('lightdm')