mirror of
				https://github.com/Z3Prover/z3
				synced 2025-10-26 17:29:21 +00:00 
			
		
		
		
	try separate x86
Signed-off-by: Nikolaj Bjorner <nbjorner@microsoft.com>
This commit is contained in:
		
							parent
							
								
									6013d5da47
								
							
						
					
					
						commit
						d6ce05009b
					
				
					 1 changed files with 52 additions and 31 deletions
				
			
		|  | @ -21,17 +21,26 @@ def mk_dir(d): | ||||||
|     if not os.path.exists(d): |     if not os.path.exists(d): | ||||||
|         os.makedirs(d) |         os.makedirs(d) | ||||||
| 
 | 
 | ||||||
|  | os64_info = {"z64-ubuntu-14" : ('so', 'linux-x64'), | ||||||
|  |              'ubuntu-18' : ('so', 'linux-x64'), | ||||||
|  |              'ubuntu-20' : ('so', 'linux-x64'), | ||||||
|  |              'glibc-2.31' : ('so', 'linux-x64'), | ||||||
|  |              'x64-win' : ('dll', 'win-x64'), | ||||||
|  |              'osx' : ('dylib', 'osx-x64'), | ||||||
|  |              'debian' : ('so', 'linux-x64') } | ||||||
| 
 | 
 | ||||||
| os_info = {"z64-ubuntu-14" : ('so', 'linux-x64'), | os86_info = { 'x86-win' : ('dll', 'win-x86') } | ||||||
|            'ubuntu-18' : ('so', 'linux-x64'), |  | ||||||
|            'ubuntu-20' : ('so', 'linux-x64'), |  | ||||||
|            'glibc-2.31' : ('so', 'linux-x64'), |  | ||||||
|            'x64-win' : ('dll', 'win-x64'), |  | ||||||
|            'x86-win' : ('dll', 'win-x86'), |  | ||||||
|            'osx' : ('dylib', 'osx-x64'), |  | ||||||
|            'debian' : ('so', 'linux-x64') } |  | ||||||
| 
 | 
 | ||||||
| def classify_package(f): | 
 | ||||||
|  | def os_info(arch): | ||||||
|  |     if arch == "x64": | ||||||
|  |         return os64_info | ||||||
|  |     else: | ||||||
|  |         return os86_info | ||||||
|  |          | ||||||
|  | 
 | ||||||
|  | def classify_package(f, arch): | ||||||
|  |     os_info = os_info(arch) | ||||||
|     for os_name in os_info: |     for os_name in os_info: | ||||||
|         if os_name in f: |         if os_name in f: | ||||||
|             ext, dst = os_info[os_name] |             ext, dst = os_info[os_name] | ||||||
|  | @ -45,7 +54,7 @@ def replace(src, dst): | ||||||
|     except: |     except: | ||||||
|         shutil.move(src, dst) |         shutil.move(src, dst) | ||||||
|      |      | ||||||
| def unpack(packages, symbols): | def unpack(packages, symbols, arch): | ||||||
|     # unzip files in packages |     # unzip files in packages | ||||||
|     # out |     # out | ||||||
|     # +- runtimes |     # +- runtimes | ||||||
|  | @ -57,14 +66,14 @@ def unpack(packages, symbols): | ||||||
|     tmp = "tmp" if not symbols else "tmpsym" |     tmp = "tmp" if not symbols else "tmpsym" | ||||||
|     for f in os.listdir(packages): |     for f in os.listdir(packages): | ||||||
|         print(f) |         print(f) | ||||||
|         if f.endswith(".zip") and classify_package(f): |         if f.endswith(".zip") and classify_package(f, arch): | ||||||
|             os_name, package_dir, ext, dst = classify_package(f) |             os_name, package_dir, ext, dst = classify_package(f) | ||||||
|             path = os.path.abspath(os.path.join(packages, f)) |             path = os.path.abspath(os.path.join(packages, f)) | ||||||
|             zip_ref = zipfile.ZipFile(path, 'r') |             zip_ref = zipfile.ZipFile(path, 'r') | ||||||
|             zip_ref.extract(f"{package_dir}/bin/libz3.{ext}", f"{tmp}") |             zip_ref.extract(f"{package_dir}/bin/libz3.{ext}", f"{tmp}") | ||||||
|             mk_dir(f"out/runtimes/{dst}/native") |             mk_dir(f"out/runtimes/{dst}/native") | ||||||
|             replace(f"{tmp}/{package_dir}/bin/libz3.{ext}", f"out/runtimes/{dst}/native/libz3.{ext}")             |             replace(f"{tmp}/{package_dir}/bin/libz3.{ext}", f"out/runtimes/{dst}/native/libz3.{ext}")             | ||||||
|             if "x64-win" in f: |             if "x64-win" in f or "x86-win" in f: | ||||||
|                 mk_dir("out/lib/netstandard2.0/") |                 mk_dir("out/lib/netstandard2.0/") | ||||||
|                 if symbols: |                 if symbols: | ||||||
|                     zip_ref.extract(f"{package_dir}/bin/libz3.pdb", f"{tmp}") |                     zip_ref.extract(f"{package_dir}/bin/libz3.pdb", f"{tmp}") | ||||||
|  | @ -85,7 +94,7 @@ def mk_icon(source_root): | ||||||
|     shutil.copy(f"{source_root}/resources/icon.jpg", "out/content/icon.jpg") |     shutil.copy(f"{source_root}/resources/icon.jpg", "out/content/icon.jpg") | ||||||
| 
 | 
 | ||||||
|      |      | ||||||
| def create_nuget_spec(version, repo, branch, commit, symbols): | def create_nuget_spec(version, repo, branch, commit, symbols, arch): | ||||||
|     contents = """<?xml version="1.0" encoding="utf-8"?> |     contents = """<?xml version="1.0" encoding="utf-8"?> | ||||||
| <package xmlns="http://schemas.microsoft.com/packaging/2010/07/nuspec.xsd"> | <package xmlns="http://schemas.microsoft.com/packaging/2010/07/nuspec.xsd"> | ||||||
|     <metadata> |     <metadata> | ||||||
|  | @ -113,28 +122,40 @@ Linux Dependencies: | ||||||
| </package>""".format(version, repo, branch, commit) | </package>""".format(version, repo, branch, commit) | ||||||
|     print(contents) |     print(contents) | ||||||
|     sym = "sym." if symbols else "" |     sym = "sym." if symbols else "" | ||||||
|     file = f"out/Microsoft.Z3.{sym}nuspec" |     arch = f"{arch}." if arch == "x86" else "" | ||||||
|  |     file = f"out/Microsoft.Z3.{arch}{sym}nuspec" | ||||||
|     print(file) |     print(file) | ||||||
|     with open(file, 'w') as f: |     with open(file, 'w') as f: | ||||||
|         f.write(contents) |         f.write(contents) | ||||||
|  | 
 | ||||||
|  | class Env: | ||||||
|  |     def __init__(self, argv): | ||||||
|  |         self.packages = argv[1] | ||||||
|  |         self.version = argv[2] | ||||||
|  |         self.repo = argv[3] | ||||||
|  |         self.branch = argv[4] | ||||||
|  |         self.commit = argv[5] | ||||||
|  |         self.source_root = argv[6] | ||||||
|  |         self.symbols = False | ||||||
|  |         if len(argv) > 7 and "symbols" == argv[7]: | ||||||
|  |             self.symbols = True | ||||||
|  | 
 | ||||||
|  |     def create(self, arch): | ||||||
|  |         mk_dir(self.packages) | ||||||
|  |         unpack(self.packages, self.symbols, arch) | ||||||
|  |         mk_targets(self.source_root) | ||||||
|  |         mk_icon(self.source_root) | ||||||
|  |         create_nuget_spec(self.version, self.repo, self.branch, self.commit, self.symbols, arch) | ||||||
|  | 
 | ||||||
|  |     def clear(self): | ||||||
|  |         os.rmtree("out/runtimes") | ||||||
|  |         os.rmtree("out/lib") | ||||||
|          |          | ||||||
| def main(): | def main(): | ||||||
|     packages = sys.argv[1] |     env = Env(sys.argv) | ||||||
|     version = sys.argv[2] |     print(env.packages) | ||||||
|     repo = sys.argv[3] |     self.create("x64") | ||||||
|     branch = sys.argv[4] |     self.clear() | ||||||
|     commit = sys.argv[5] |     self.create("x86") | ||||||
|     source_root = sys.argv[6] |  | ||||||
|     symbols = False |  | ||||||
|     if len(sys.argv) > 7: |  | ||||||
|         print(sys.argv[7]) |  | ||||||
|     if len(sys.argv) > 7 and "symbols" == sys.argv[7]: |  | ||||||
|         symbols = True |  | ||||||
|     print(packages) |  | ||||||
|     mk_dir(packages) |  | ||||||
|     unpack(packages, symbols) |  | ||||||
|     mk_targets(source_root) |  | ||||||
|     mk_icon(source_root) |  | ||||||
|     create_nuget_spec(version, repo, branch, commit, symbols) |  | ||||||
| 
 | 
 | ||||||
| main() | main() | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue