forked from links-ads/template-python
-
Notifications
You must be signed in to change notification settings - Fork 0
/
init.py
123 lines (98 loc) · 4.4 KB
/
init.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
119
120
121
122
123
import os
import re
from datetime import datetime
DEFAULT_PY_VERSION = ">=3.10"
def query_params(validate: bool = True):
"""
Query the user for the project parameters.
"""
while True:
while not (name := input("What is your name? ")):
print("Please enter your name, or press Ctrl+C to exit.")
while not (email := input("What is your email address? ")):
print("Please enter your email address, or press Ctrl+C to exit.")
while not (project_name := input("What should we call the project? (e.g., scikit-learn) ")):
print("Please enter a project name, or press Ctrl+C to exit.")
while not (package_name := input("What should we call the package? (e.g., sklearn) ")):
print("Please enter a project name, or press Ctrl+C to exit.")
while not (project_description := input("What is your project about? ")):
print("Please enter a project description, or press Ctrl+C to exit.")
py_version = (
input(f"What minimum version of Python do you want to use? (default: {DEFAULT_PY_VERSION}) ")
or DEFAULT_PY_VERSION
)
if validate:
print("So far, we have:")
print(f" - Author: {name} <{email}>")
print(f" - Project name: {project_name}")
print(f" - Package name: {package_name}")
print(f" - Project description: {project_description}")
print(f" - Python version: {py_version}")
if input("Is this correct? (y/n) ").lower() != "y":
print("Alright, let's try again.")
continue
return name, email, project_name, package_name, project_description, py_version
def rename_package(project_name: str, root: str):
"""
Rename the project by recursively replacing the string "project_name" with the project name.
"""
for rel_path in os.listdir(root):
if rel_path in ["__pycache__", ".git"]:
continue
abs_path = os.path.join(root, rel_path)
if os.path.isdir(abs_path):
rename_package(project_name, root=abs_path)
elif os.path.isfile(abs_path):
with open(abs_path) as f:
data = f.read()
with open(abs_path, "w") as f:
f.write(data.replace("project_name", project_name))
def update_license(name: str):
"""
Replace the <year> and <name> placeholders in the LICENSE file with the actual values.
At the moment the license is hardcoded to MIT.
"""
with open("LICENSE") as f:
data = f.read()
data = data.replace("<year>", str(datetime.now().year))
data = data.replace("<name>", name)
with open("LICENSE", "w") as f:
f.write(data)
def update_toml_property(data: str, key: str, value: str):
"""
Update a property in a toml string.
"""
return re.sub(f"{key} = .*", f"{key} = {value}", data)
def main():
try:
with open("pyproject.toml") as f:
data = f.read()
except FileNotFoundError:
print("No pyproject.toml found, exiting.")
exit(1)
try:
print("Hi! Let's get started.")
print("Please answer the following questions to help us get you set up.")
name, email, project_name, package_name, project_description, py_version = query_params()
data = update_toml_property(data, "name", f'"{project_name}"')
data = update_toml_property(data, "description", f'"{project_description}"')
data = update_toml_property(data, "requires-python", f'"{py_version}"')
data = update_toml_property(data, "authors", f'[{{name = "{name}", email = "{email}"}}]')
data = update_toml_property(data, "version", f'{{attr = "{package_name}.__version__"}}')
print("Updating license...")
update_license(name)
# storing the updated pyproject.toml
print("Updating pyproject.toml...")
with open("pyproject.toml", "w") as f:
f.write(data)
# update package name and dynamic versioning
print("Renaming package files and folders...")
rename_package(package_name, root="src")
rename_package(package_name, root="tests")
os.rename("src/project_name", f"src/{package_name}")
print("Your project is ready. Deleting myself from existence, farewell!")
os.remove(__file__)
except KeyboardInterrupt:
print("Exiting.")
if __name__ == "__main__":
main()