[PATCH] D136092: [CMake] Add Python script to generate version script symbol exports

Andrew Ng via Phabricator via llvm-commits llvm-commits at lists.llvm.org
Tue Oct 18 04:27:31 PDT 2022


andrewng updated this revision to Diff 468479.
andrewng added a comment.

Update for review comments.


CHANGES SINCE LAST ACTION
  https://reviews.llvm.org/D136092/new/

https://reviews.llvm.org/D136092

Files:
  llvm/cmake/modules/AddLLVM.cmake
  llvm/utils/add_llvm_symbol_exports.py


Index: llvm/utils/add_llvm_symbol_exports.py
===================================================================
--- /dev/null
+++ llvm/utils/add_llvm_symbol_exports.py
@@ -0,0 +1,26 @@
+#!/usr/bin/env python3
+#===----------------------------------------------------------------------===##
+#
+# Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
+# See https://llvm.org/LICENSE.txt for license information.
+# SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
+#
+#===----------------------------------------------------------------------===##
+
+import os
+import sys
+
+if (len(sys.argv) != 4):
+    print('usage: ' + sys.argv[0] + ' <LLVM major version> <input> <output>')
+    sys.exit(1)
+
+with open(sys.argv[3], 'w') as out_fd:
+    out_fd.write('LLVM_' + sys.argv[1] + ' {\n')
+    if os.stat(sys.argv[2]).st_size > 0:
+        out_fd.write('  global:\n')
+        with open(sys.argv[2], 'r') as in_fd:
+            for e in in_fd.readlines():
+                out_fd.write('    ' + e.rstrip() + ';\n')
+    out_fd.write('  local: *;\n};\n')
+
+sys.exit(0)
Index: llvm/cmake/modules/AddLLVM.cmake
===================================================================
--- llvm/cmake/modules/AddLLVM.cmake
+++ llvm/cmake/modules/AddLLVM.cmake
@@ -103,11 +103,7 @@
     # FIXME: Don't write the "local:" line on OpenBSD.
     # in the export file, also add a linker script to version LLVM symbols (form: LLVM_N.M)
     add_custom_command(OUTPUT ${native_export_file}
-      COMMAND echo "LLVM_${LLVM_VERSION_MAJOR} {" > ${native_export_file}
-      COMMAND grep -q "[[:alnum:]]" ${export_file} && echo "  global:" >> ${native_export_file} || :
-      COMMAND sed -e "s/$/;/" -e "s/^/    /" < ${export_file} >> ${native_export_file}
-      COMMAND echo "  local: *;" >> ${native_export_file}
-      COMMAND echo "};" >> ${native_export_file}
+      COMMAND "${Python3_EXECUTABLE}" ${LLVM_MAIN_SRC_DIR}/utils/add_llvm_symbol_exports.py ${LLVM_VERSION_MAJOR} ${export_file} ${native_export_file}
       DEPENDS ${export_file}
       VERBATIM
       COMMENT "Creating export file for ${target_name}")


-------------- next part --------------
A non-text attachment was scrubbed...
Name: D136092.468479.patch
Type: text/x-patch
Size: 2135 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20221018/d4f9c0ef/attachment.bin>


More information about the llvm-commits mailing list