forked from iqm-finland/KQCircuits
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathsetup_within_klayout.py
107 lines (89 loc) · 4.79 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
# This code is part of KQCircuits
# Copyright (C) 2021 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
from sys import platform
from setup_helper import setup_symlinks, klayout_configdir
def get_klayout_packages_path(path_start):
# KLayout python folder name changes when its python version is updated, try to make sure we find it
python_versions = [(major, minor) for major in [3, 4] for minor in range(30)]
for major, minor in python_versions:
path_start_2 = os.path.join(path_start, f"{major}.{minor}") if platform == "darwin" else path_start
packages_path = os.path.join(path_start_2, "lib", f"python{major}.{minor}", "site-packages")
if os.path.exists(packages_path):
break
return packages_path
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")
parser.add_argument(
"--force-package-reinstall", action="store_true", help="force reinstalling packages that KQCircuits depends on"
)
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/drc", "drc/kqcircuits"),
)
setup_symlinks(kqc_root_path, configdir, link_map, unlink=args.unlink)
if not args.unlink:
print("Installing required packages")
target_dir = "the system Python environment"
if os.name == "nt": # Windows
target_dir = get_klayout_packages_path(os.path.join(os.getenv("APPDATA"), "KLayout"))
pip_args = f'requirements_within_klayout_windows.txt --target="{target_dir}"'
elif os.name == "posix":
pip_args = "requirements_within_klayout_unix.txt" # Linux
if platform == "darwin": # macOS
td = get_klayout_packages_path(
"/Applications/klayout.app/Contents/Frameworks/Python.framework/Versions"
)
if not os.path.exists(td):
# Homebrew installs under /Applications/KLayout/klayout.app
td = get_klayout_packages_path(
"/Applications/KLayout/klayout.app/Contents/Frameworks/Python.framework/Versions"
)
# KLayout may use either its own site-packages or the system site-packages, depending on the build
if os.path.exists(td):
target_dir = td
pip_args += f' --target="{target_dir}"'
else:
raise SystemError("Unsupported operating system.")
if args.force_package_reinstall:
pip_args += " --upgrade"
print(f'Required packages will be installed in "{target_dir}".')
os.system(f"pip install -r {pip_args}")
print("Finished setting up KQC.")
else:
print("KQC unlinked from the Klayout installation")