Skip to content

Commit

Permalink
Rework system locale
Browse files Browse the repository at this point in the history
  • Loading branch information
codefiles committed Aug 14, 2022
1 parent f20f057 commit 6088114
Show file tree
Hide file tree
Showing 2 changed files with 60 additions and 33 deletions.
76 changes: 55 additions & 21 deletions archinstall/lib/installer.py
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,7 @@
from .disk import get_partitions_in_use, Partition
from .general import SysCommand, generate_password
from .hardware import has_uefi, is_vm, cpu_vendor
from .locale_helpers import verify_keyboard_layout, verify_x11_keyboard_layout
from .locale_helpers import list_locales, verify_keyboard_layout, verify_x11_keyboard_layout
from .disk.helpers import findmnt
from .mirrors import use_mirrors
from .plugins import plugins
Expand Down Expand Up @@ -440,33 +440,67 @@ def set_hostname(self, hostname: str, *args :str, **kwargs :str) -> None:
fh.write(hostname + '\n')

def set_locale(self, locale :str, *args :str, **kwargs :str) -> bool:
space_count = locale.count(' ')
if space_count == 1:
locale_name = locale.split()[0]
elif space_count == 0:
locale_name = locale
locale = ''
for locale_entry in list_locales():
if locale_name == locale_entry.split()[0]:
locale = locale_entry

if not locale:
return False

if not len(locale):
return True
with open(f'{self.target}/etc/locale.gen', 'r') as fp:
contents = fp.readlines()

uncommented = False
for line in contents:
if locale == line.replace('#', '').strip() and line[0] != '#':
uncommented = True

if not uncommented:
count = 0
found = False
for count, line in enumerate(contents):
uncommentted_line = line.replace('#', '')
if locale == uncommentted_line.rstrip():
contents[count] = uncommentted_line
found = True
break
if found:
with open(f'{self.target}/etc/locale.gen', 'w') as fp:
fp.writelines(contents)

if not SysCommand(f'/usr/bin/arch-chroot {self.target} locale-gen').exit_code == 0:
return False

modifier = ''
if '.' in locale_name:
locale_abv, locale_encoding = locale_name.split('.', 1)
locale_encoding = locale_encoding.replace('-','').lower()
locale_name = f'{locale_abv}.{locale_encoding}'

# This is a temporary patch to fix #1200
if '.' in locale:
locale, potential_encoding = locale.split('.', 1)
installed_locales = []
for line in SysCommand(f'/usr/bin/arch-chroot {self.target} locale -a'):
installed_locales.append(line.decode('UTF-8').strip())

# Override encoding if encoding is set to the default parameter
# and the "found" encoding differs.
if encoding == 'UTF-8' and encoding != potential_encoding:
encoding = potential_encoding
if locale_name in installed_locales:
regex = re.compile(r'LANG=(.+)')

# Make sure we extract the modifier, that way we can put it in if needed.
if '@' in locale:
locale, modifier = locale.split('@', 1)
modifier = f"@{modifier}"
# - End patch
if pathlib.Path(f"{self.target}/etc/cryptsetup-keys.d").exists():
with open(f'{self.target}/etc/locale.conf', 'r') as fp:
for line in fp:
found = regex.search(line)

with open(f'{self.target}/etc/locale.gen', 'a') as fh:
fh.write(f'{locale}.{encoding}{modifier} {encoding}\n')
with open(f'{self.target}/etc/locale.conf', 'w') as fh:
fh.write(f'LANG={locale}.{encoding}{modifier}\n')
if found:
sys_locale = found.group(1)
if locale_name == sys_locale:
return True

return True if SysCommand(f'/usr/bin/arch-chroot {self.target} locale-gen').exit_code == 0 else False
with open(f'{self.target}/etc/locale.conf', 'w') as fp:
fp.write(f'LANG={locale_name}\n')

def set_timezone(self, zone :str, *args :str, **kwargs :str) -> bool:
if not zone:
Expand Down
17 changes: 5 additions & 12 deletions archinstall/lib/locale_helpers.py
Original file line number Diff line number Diff line change
Expand Up @@ -14,18 +14,11 @@ def list_keyboard_languages() -> Iterator[str]:
def list_locales() -> List[str]:
with open('/etc/locale.gen', 'r') as fp:
locales = []
# before the list of locales begins there's an empty line with a '#' in front
# so we'll collect the localels from bottom up and halt when we're donw
entries = fp.readlines()
entries.reverse()

for entry in entries:
text = entry.replace('#', '').strip()
if text == '':
break
locales.append(text)

locales.reverse()
for line in fp:
text = line.replace('#', '')
if text[0].isspace():
continue
locales.append(text.strip())
return locales

def get_locale_mode_text(mode):
Expand Down

0 comments on commit 6088114

Please sign in to comment.