mirror of
				https://gitlab.gnome.org/GNOME/glib.git
				synced 2025-10-31 08:22:16 +01:00 
			
		
		
		
	This should have been dropped in commit
38faeca62e but somehow that didn’t happen
and somehow it wasn’t caught by the CI until afterwards.
Fixes: https://gitlab.gnome.org/GNOME/glib/-/jobs/4049254
Signed-off-by: Philip Withnall <pwithnall@gnome.org>
		
	
		
			
				
	
	
		
			196 lines
		
	
	
		
			4.8 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			196 lines
		
	
	
		
			4.8 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| # -*- Mode: Python -*-
 | |
| 
 | |
| # GDBus - GLib D-Bus Library
 | |
| #
 | |
| # Copyright (C) 2008-2011 Red Hat, Inc.
 | |
| #
 | |
| # SPDX-License-Identifier: LGPL-2.1-or-later
 | |
| #
 | |
| # This library is free software; you can redistribute it and/or
 | |
| # modify it under the terms of the GNU Lesser General Public
 | |
| # License as published by the Free Software Foundation; either
 | |
| # version 2.1 of the License, or (at your option) any later version.
 | |
| #
 | |
| # This library is distributed in the hope that it will be useful,
 | |
| # but WITHOUT ANY WARRANTY; without even the implied warranty of
 | |
| # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 | |
| # Lesser General Public License for more details.
 | |
| #
 | |
| # You should have received a copy of the GNU Lesser General
 | |
| # Public License along with this library; if not, see <http://www.gnu.org/licenses/>.
 | |
| #
 | |
| # Author: David Zeuthen <davidz@redhat.com>
 | |
| 
 | |
| import os
 | |
| import sys
 | |
| import re
 | |
| 
 | |
| 
 | |
| # pylint: disable=too-few-public-methods
 | |
| class Color:
 | |
|     """ANSI Terminal colors"""
 | |
| 
 | |
|     GREEN = "\033[1;32m"
 | |
|     BLUE = "\033[1;34m"
 | |
|     YELLOW = "\033[1;33m"
 | |
|     RED = "\033[1;31m"
 | |
|     END = "\033[0m"
 | |
| 
 | |
| 
 | |
| def print_color(msg, color=Color.END, prefix="MESSAGE"):
 | |
|     """Print a string with a color prefix"""
 | |
|     if os.isatty(sys.stderr.fileno()):
 | |
|         real_prefix = "{start}{prefix}{end}".format(
 | |
|             start=color, prefix=prefix, end=Color.END
 | |
|         )
 | |
|     else:
 | |
|         real_prefix = prefix
 | |
|     sys.stderr.write("{prefix}: {msg}\n".format(prefix=real_prefix, msg=msg))
 | |
| 
 | |
| 
 | |
| def print_error(msg):
 | |
|     """Print an error, and terminate"""
 | |
|     print_color(msg, color=Color.RED, prefix="ERROR")
 | |
|     sys.exit(1)
 | |
| 
 | |
| 
 | |
| def print_warning(msg, fatal=False):
 | |
|     """Print a warning, and optionally terminate"""
 | |
|     if fatal:
 | |
|         color = Color.RED
 | |
|         prefix = "ERROR"
 | |
|     else:
 | |
|         color = Color.YELLOW
 | |
|         prefix = "WARNING"
 | |
|     print_color(msg, color, prefix)
 | |
|     if fatal:
 | |
|         sys.exit(1)
 | |
| 
 | |
| 
 | |
| def print_info(msg):
 | |
|     """Print a message"""
 | |
|     print_color(msg, color=Color.GREEN, prefix="INFO")
 | |
| 
 | |
| 
 | |
| def strip_dots(s):
 | |
|     ret = ""
 | |
|     force_upper = False
 | |
|     for c in s:
 | |
|         if c == ".":
 | |
|             force_upper = True
 | |
|         else:
 | |
|             if force_upper:
 | |
|                 ret += c.upper()
 | |
|                 force_upper = False
 | |
|             else:
 | |
|                 ret += c
 | |
|     return ret
 | |
| 
 | |
| 
 | |
| def dots_to_hyphens(s):
 | |
|     return s.replace(".", "-")
 | |
| 
 | |
| 
 | |
| def camel_case_to_uscore(s):
 | |
|     ret = ""
 | |
|     insert_uscore = False
 | |
|     prev_was_lower = False
 | |
|     initial = True
 | |
|     for c in s:
 | |
|         # Keep initial underscores in camel case
 | |
|         if initial and c == "_":
 | |
|             ret += "_"
 | |
|             continue
 | |
|         initial = False
 | |
| 
 | |
|         if c.isupper():
 | |
|             if prev_was_lower:
 | |
|                 insert_uscore = True
 | |
|             prev_was_lower = False
 | |
|         else:
 | |
|             prev_was_lower = True
 | |
|         if insert_uscore:
 | |
|             ret += "_"
 | |
|         ret += c.lower()
 | |
|         insert_uscore = False
 | |
|     return ret
 | |
| 
 | |
| 
 | |
| def uscore_to_camel_case(s):
 | |
|     return "".join([s[0].upper() + s[1:].lower() if s else "_" for s in s.split("_")])
 | |
| 
 | |
| 
 | |
| def is_ugly_case(s):
 | |
|     if s and s.find("_") > 0:
 | |
|         return True
 | |
|     return False
 | |
| 
 | |
| 
 | |
| def lookup_annotation(annotations, key):
 | |
|     if annotations:
 | |
|         for a in annotations:
 | |
|             if a.key == key:
 | |
|                 return a.value
 | |
|     return None
 | |
| 
 | |
| 
 | |
| def lookup_docs(annotations):
 | |
|     s = lookup_annotation(annotations, "org.gtk.GDBus.DocString")
 | |
|     if s is None:
 | |
|         return ""
 | |
|     else:
 | |
|         return s
 | |
| 
 | |
| 
 | |
| def lookup_since(annotations):
 | |
|     s = lookup_annotation(annotations, "org.gtk.GDBus.Since")
 | |
|     if s is None:
 | |
|         return ""
 | |
|     else:
 | |
|         return s
 | |
| 
 | |
| 
 | |
| def lookup_brief_docs(annotations):
 | |
|     s = lookup_annotation(annotations, "org.gtk.GDBus.DocString.Short")
 | |
|     if s is None:
 | |
|         return ""
 | |
|     else:
 | |
|         return s
 | |
| 
 | |
| 
 | |
| def version_cmp_key(key):
 | |
|     # If the 'since' version is 'UNRELEASED', compare higher than anything else
 | |
|     # If it is empty put a 0 in its place as this will
 | |
|     # allow _parse_version() to work and will always compare lower.
 | |
|     if key[0] == "UNRELEASED":
 | |
|         v = "9999"
 | |
|     elif key[0]:
 | |
|         v = str(key[0])
 | |
|     else:
 | |
|         v = "0"
 | |
|     return (_parse_version(v), key[1])
 | |
| 
 | |
| 
 | |
| def _parse_version(version):
 | |
|     """
 | |
|     Parse a version string into a list of integers and strings.
 | |
| 
 | |
|     This function takes a version string and breaks it down into its component parts.
 | |
|     It separates numeric and non-numeric segments, converting numeric segments to integers.
 | |
| 
 | |
|     Args:
 | |
|         version (str): The version string to parse.
 | |
| 
 | |
|     Returns:
 | |
|         list: A list where each element is either an integer (for numeric parts)
 | |
|               or a string (for non-numeric parts).
 | |
| 
 | |
|     Example:
 | |
|         >>> parseversion("1.2.3a")
 | |
|         [1, 2, 3, 'a']
 | |
|         >>> parseversion("2.0.0-rc1")
 | |
|         [2, 0, 0, 'rc1']
 | |
|     """
 | |
|     blocks = re.findall(r"(\d+|\w+)", version)
 | |
|     return [int(b) if b.isdigit() else b for b in blocks]
 |