Send patches - preferably formatted by git format-patch - to patches at archlinux32 dot org.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAnton Hvornum <anton@hvornum.se>2021-05-15 09:47:20 +0000
committerGitHub <noreply@github.com>2021-05-15 09:47:20 +0000
commit46e934380641eaa7f34d6d08445464da788cc253 (patch)
tree815b7a3f760a6048311082306a148d010b5bb09c
parent935cdef63fbefb6125043f9bda254d532a6fc03e (diff)
parent2ebf92e5fa27c9d26b2ed674d9cb86291c45a94a (diff)
Merge pull request #440 from dylanmtaylor/enlightenment
Implement enlightenment desktop environment
-rw-r--r--profiles/desktop.py3
-rw-r--r--profiles/enlightenment.py37
2 files changed, 39 insertions, 1 deletions
diff --git a/profiles/desktop.py b/profiles/desktop.py
index eca8803e..9e1d8b4c 100644
--- a/profiles/desktop.py
+++ b/profiles/desktop.py
@@ -16,7 +16,8 @@ def _prep_function(*args, **kwargs):
for more input before any other installer steps start.
"""
- supported_desktops = ['gnome', 'kde', 'awesome', 'sway', 'cinnamon', 'xfce4', 'lxqt', 'i3', 'budgie', 'mate', 'deepin']
+ supported_desktops = ['gnome', 'kde', 'awesome', 'sway', 'cinnamon', 'xfce4', 'lxqt', 'i3', 'budgie', 'mate', 'deepin', 'enlightenment']
+
desktop = archinstall.generic_select(supported_desktops, 'Select your desired desktop environment: ',
allow_empty_input=False, sort=True)
diff --git a/profiles/enlightenment.py b/profiles/enlightenment.py
new file mode 100644
index 00000000..6ff334de
--- /dev/null
+++ b/profiles/enlightenment.py
@@ -0,0 +1,37 @@
+# A desktop environment using "Enlightenment".
+
+import archinstall, os
+
+is_top_level_profile = False
+
+__packages__ = ["enlightenment", "terminology", "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.
+ """
+
+ # Enlightenment 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("enlightenment", "/somewhere/enlightenment.py")
+# or through conventional import enlightenment
+if __name__ == 'enlightenment':
+ # Install dependency profiles
+ archinstall.storage['installation_session'].install_profile('xorg')
+
+ # Install the enlightenment packages
+ archinstall.storage['installation_session'].add_additional_packages(__packages__)
+
+ # Enable autostart of enlightenment for all users
+ archinstall.storage['installation_session'].enable_service('lightdm')