aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorFlorian Weimer <fweimer@redhat.com>2021-03-16 15:56:50 +0100
committerFlorian Weimer <fweimer@redhat.com>2021-03-16 15:57:04 +0100
commitb9e29037120380d1cde7b80b47fe1baee3f77a7a (patch)
treec4d1058ffc30799400284379afa2c71b3dfc5dc4
parent4b7259555c6ded82a2b4b598efa770c2086e203f (diff)
downloadglibc-b9e29037120380d1cde7b80b47fe1baee3f77a7a.tar
glibc-b9e29037120380d1cde7b80b47fe1baee3f77a7a.tar.gz
glibc-b9e29037120380d1cde7b80b47fe1baee3f77a7a.tar.bz2
glibc-b9e29037120380d1cde7b80b47fe1baee3f77a7a.zip
scripts/glibcsymbols.py: Extract from scripts/move-symbol-to-libc.py
Reviewed-by: Adhemerval Zanella <adhemerval.zanella@linaro.org>
-rw-r--r--scripts/glibcsymbols.py80
-rw-r--r--scripts/move-symbol-to-libc.py75
2 files changed, 93 insertions, 62 deletions
diff --git a/scripts/glibcsymbols.py b/scripts/glibcsymbols.py
new file mode 100644
index 0000000000..e329ead7f2
--- /dev/null
+++ b/scripts/glibcsymbols.py
@@ -0,0 +1,80 @@
+#!/usr/bin/python3
+# Processing of symbols and abilist files.
+# Copyright (C) 2020-2021 Free Software Foundation, Inc.
+# This file is part of the GNU C Library.
+#
+# The GNU C 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.
+#
+# The GNU C 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 the GNU C Library; if not, see
+# <https://www.gnu.org/licenses/>.
+
+"""Symbol processing for glibc."""
+
+import os
+
+def replace_file(path, new_contents):
+ """Atomically replace PATH with lines from NEW_CONTENTS.
+
+ NEW_CONTENTS must be a sequence of strings.
+
+ """
+ temppath = path + 'T'
+ with open(temppath, 'w') as out:
+ for line in new_contents:
+ out.write(line)
+ os.rename(temppath, path)
+
+class VersionedSymbol:
+ """A combination of a symbol and its version."""
+
+ def __init__(self, symbol, version):
+ """Construct a new versioned symbol."""
+ assert symbol
+ assert version
+ self.symbol = symbol
+ self.version = version
+
+ def __str__(self):
+ return self.symbol + '@' + self.version
+
+ def __eq__(self, other):
+ return self.symbol == other.symbol and self.version == other.version
+
+ def __hash__(self):
+ return hash(self.symbol) ^ hash(self.version)
+
+def read_abilist(path):
+ """Read the abilist file at PATH.
+
+ Return a dictionary from VersionedSymbols to their flags (as
+ strings).
+
+ """
+ result = {}
+ with open(path) as inp:
+ for line in inp:
+ version, symbol, flags = line.strip().split(' ', 2)
+ result[VersionedSymbol(symbol, version)] = flags
+ return result
+
+def abilist_lines(symbols):
+ """Build the abilist file contents (as a list of lines).
+
+ SYMBOLS is a dictionary from VersionedSymbols to their flags.
+
+ """
+ result = []
+ for versym, flags in symbols.items():
+ result.append('{} {} {}\n'.format(
+ versym.version, versym.symbol, flags))
+ result.sort()
+ return result
diff --git a/scripts/move-symbol-to-libc.py b/scripts/move-symbol-to-libc.py
index f6b55edeb1..41cc357763 100644
--- a/scripts/move-symbol-to-libc.py
+++ b/scripts/move-symbol-to-libc.py
@@ -29,76 +29,25 @@ import argparse
import os.path
import sys
-def replace_file(path, new_contents):
- """Atomically replace PATH with lines from NEW_CONTENTS.
+# Make available glibc Python modules.
+sys.path.append(os.path.dirname(os.path.realpath(__file__)))
- NEW_CONTENTS must be a sequence of strings.
-
- """
- temppath = path + 'T'
- with open(temppath, 'w') as out:
- for line in new_contents:
- out.write(line)
- os.rename(temppath, path)
-
-class VersionedSymbol:
- """A combination of a symbol and its version."""
-
- def __init__(self, symbol, version):
- """Construct a new versioned symbol."""
- assert symbol
- assert version
- self.symbol = symbol
- self.version = version
-
- def __str__(self):
- return self.symbol + '@' + self.version
-
- def __eq__(self, other):
- return self.symbol == other.symbol and self.version == other.version
-
- def __hash__(self):
- return hash(self.symbol) ^ hash(self.version)
-
-def read_abilist(path):
- """Read the abilist file at PATH.
-
- Return a dictionary from VersionedSymbols to their flags (as
- strings).
-
- """
- result = {}
- with open(path) as inp:
- for line in inp:
- version, symbol, flags = line.strip().split(' ', 2)
- result[VersionedSymbol(symbol, version)] = flags
- return result
-
-def abilist_lines(symbols):
- """Build the abilist file contents (as a list of lines).
-
- SYMBOLS is a dictionary from VersionedSymbols to their flags.
-
- """
- result = []
- for versym, flags in symbols.items():
- result.append('{} {} {}\n'.format(
- versym.version, versym.symbol, flags))
- result.sort()
- return result
+import glibcsymbols
def add_to_libc_path(path, new_symbols):
"""Add SYMBOLS to the abilist file PATH.
- NEW_SYMBOLS is a dictionary from VersionedSymbols to their flags.
+ NEW_SYMBOLS is a dictionary from glibcsymbols.VersionedSymbol
+ objects to their flags.
"""
- original_symbols = read_abilist(path)
+ original_symbols = glibcsymbols.read_abilist(path)
updated_symbols = original_symbols.copy()
updated_symbols.update(new_symbols)
if updated_symbols != original_symbols:
sys.stdout.write('updating libc abilist {}\n'.format(path))
- replace_file(path, abilist_lines(updated_symbols))
+ glibcsymbols.replace_file(
+ path, glibcsymbols.abilist_lines(updated_symbols))
# The name of the libc.so abilist file.
libc_abilist = 'libc.abilist'
@@ -156,7 +105,7 @@ def move_symbols_1(path, to_move, moved_symbols):
new_lines = []
changed = False
- old_symbols = read_abilist(path)
+ old_symbols = glibcsymbols.read_abilist(path)
old_versions = set(versym.version for versym in old_symbols.keys())
matching_symbols = dict(e for e in old_symbols.items()
if e[0].symbol in to_move)
@@ -169,9 +118,11 @@ def move_symbols_1(path, to_move, moved_symbols):
# going away completely.
new_versions = set(versym.version for versym in new_symbols.keys())
for missing_version in old_versions - new_versions:
- new_symbols[VersionedSymbol(placeholder, missing_version)] = 'F'
+ new_symbols[glibcsymbols.VersionedSymbol(
+ placeholder, missing_version)] = 'F'
- replace_file(path, abilist_lines(new_symbols))
+ glibcsymbols.replace_file(
+ path, glibcsymbols.abilist_lines(new_symbols))
moved_symbols.update(matching_symbols)