forked from iqm-finland/KQCircuits
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathsetup_within_klayout.py
118 lines (102 loc) · 5.17 KB
/
setup_within_klayout.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
# This code is part of KQCircuits
# Copyright (C) 2024 IQM Finland Oy
#
# This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public
# License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later
# version.
#
# This program 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 General Public License for more details.
#
# You should have received a copy of the GNU General Public License along with this program. If not, see
# https://www.gnu.org/licenses/gpl-3.0.html.
#
# The software distribution should follow IQM trademark policy for open-source software
# (meetiqm.com/iqm-open-source-trademark-policy). IQM welcomes contributions to the code.
# Please see our contribution agreements for individuals (meetiqm.com/iqm-individual-contributor-license-agreement)
# and organizations (meetiqm.com/iqm-organization-contributor-license-agreement).
"""
Installs required packages and creates symlinks, so that kqcircuits can be used in KLayout Editor.
It is assumed that KLayout is installed and that pip is available in the shell where you run this.
Usage:
> cd directory_where_this_file_is
> python3 setup_within_klayout.py
(depending on your OS and Python setup, may need to replace "python3" by "py" or "python", but make sure it refers
to Python 3)
To set up a secondary klayout environment just run it from a differently named directory, like
KQcircuits_2. To use this secondary environment with KLayout the KLAYOUT_HOME environment
variable needs to point to it.
"""
import os
import argparse
import site
import sys
from io import IOBase
from sys import executable, platform
from setup_helper import setup_symlinks, klayout_configdir, get_klayout_python_info
if __name__ == "__main__":
# KQCircuits source path
kqc_root_path = os.path.dirname(os.path.abspath(__file__))
parser = argparse.ArgumentParser(description="KQC setup within klayout")
parser.add_argument("--unlink", action="store_true", help="remove links")
args = parser.parse_args()
configdir = klayout_configdir(kqc_root_path)
# create symlink between KLayout python folder and kqcircuits folder
link_map = (
("klayout_package/python/kqcircuits", "python/kqcircuits"),
("klayout_package/python/scripts", "python/kqcircuits_scripts"),
("klayout_package/python/requirements", "python/kqcircuits_requirements"),
("klayout_package/python/drc", "drc/kqcircuits"),
)
setup_symlinks(kqc_root_path, configdir, link_map, unlink=args.unlink)
if not args.unlink:
klayout_py_version, klayout_py_platforms, target_dir = get_klayout_python_info()
print(f"Detected that KLayout was compiled to use python version '{klayout_py_version}'")
test_file = IOBase()
try:
test_file_path = os.path.join(target_dir, ".test.file")
# Following will throw PermissionError if target_dir needs sudo
test_file = open(test_file_path, "x", encoding="utf-8")
test_file.close()
if os.path.exists(test_file_path):
os.remove(test_file_path)
except PermissionError:
target_dir = site.USER_SITE.replace(
f"{sys.version_info[0]}.{sys.version_info[1]}", f"{'.'.join(klayout_py_version.split('.')[:2])}"
)
print("")
print("KLayout's reported site-packages directory is sudo-protected.")
print("This usually means that the KLayout executable is linked to system Python installation.")
print(f"In such cases we simply install dependencies under USER_SITE: {target_dir}")
print(
"If this still causes issues, at your own risk you can run this command "
+ "with sudo to install dependencies into system directory."
)
print("")
finally:
test_file.close()
print("Installing required packages")
detected_os = None
if os.name == "nt": # Windows
detected_os = "win"
elif os.name == "posix":
if platform == "darwin": # macOS
detected_os = "mac"
else:
detected_os = "linux"
else:
raise SystemError("Unsupported operating system.")
print(f'Required packages will be installed in "{target_dir}".')
# The specific pip package may be further pinpointed by specifying --abi and --implementation.
# Specifying those doesn't seem to be needed at the moment.
platform_args = ""
for platform in klayout_py_platforms:
platform_args += f"--platform {platform} "
os.system(
f"{executable} -m pip install -r klayout_package/python/requirements/{detected_os}/gui-requirements.txt "
+ f"--python-version {klayout_py_version} {platform_args} --only-binary=:all: "
+ f"--upgrade --target={target_dir}"
)
print("Finished setting up KQC.")
else:
print("KQC unlinked from the Klayout installation")