From: Zbigniew Jędrzejewski-Szmek Date: Thu, 20 May 2021 18:00:18 +0000 (+0200) Subject: man: add example os-release mangling in python X-Git-Tag: v249-rc1~173^2~3 X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=3ca606d103cb9c4011cfcb1d377b6749fb73aaec;p=thirdparty%2Fsystemd.git man: add example os-release mangling in python This is also not entirely obvious. I think the code I came up with is pretty elegant ;] The final part of of the code that makes use of the parsed data is kept very similar to the shell code on purpose, even though it could be written a bit more idiomatically. --- diff --git a/man/check-os-release.py b/man/check-os-release.py new file mode 100644 index 00000000000..f6d23c8c463 --- /dev/null +++ b/man/check-os-release.py @@ -0,0 +1,28 @@ +#!/usr/bin/python + +import ast +import re + +def read_os_release(): + try: + f = open('/etc/os-release') + except FileNotFoundError: + f = open('/usr/lib/os-release') + + for line_number, line in enumerate(f): + if m := re.match(r'([A-Z][A-Z_0-9]+)=(.*)', line): + name, val = m.groups() + if val and val[0] in '"\'': + val = ast.literal_eval(val) + yield name, val + else: + print(f'Warning: bad line {line_number}: {line}', file=sys.stderr) + +os_release = dict(read_os_release()) + +pretty_name = os_release.get('PRETTY_NAME', 'Linux') +print(f'Running on {pretty_name}') + +if (os_release.get('ID', 'linux') == 'debian' or + os_release.get('ID_LIKE', None) == 'debian'): + print('Looks like Debian!') diff --git a/man/os-release.xml b/man/os-release.xml index 36e5bed62e3..a00b8a5264a 100644 --- a/man/os-release.xml +++ b/man/os-release.xml @@ -419,6 +419,14 @@ VARIANT_ID=workstation + + + Reading <filename>os-release</filename> in + <citerefentry><refentrytitle>python</refentrytitle><manvolnum>1</manvolnum></citerefentry> + + + +