-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathinstall.py
executable file
·96 lines (81 loc) · 2.89 KB
/
install.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
#!/usr/bin/python3
#
# "Install" all the dotfiles, by making loading the install.conf file in each
# folder and by creating simbolic link at the destination path, targetting the
# source file in the repo
#
import logging
import os
import re
import shutil
import subprocess
def update_git_submodule():
for opt in ("init", "sync", "update"):
stdout = subprocess.check_output(["git", "submodule", opt])
if stdout:
print(stdout.decode())
def clean_conf_line(line):
"""
Clean install.conf entries
:param line: line to clean
:returns (src, dest): src is the source file path to target, dest is the
new symlink path
:rtype: tuple
"""
map_path = line.strip().split(":")
# Remove space or '' or "" around the path
for i, item in enumerate(map_path):
map_path[i] = re.sub(r"(^\s*[\"'])|([\"']\s*$)", "", item)
return map_path
def move_existing_dest(dest):
"""
If file already exists, move it as dest.old
"""
logging.debug("File already exists, renaming as .old")
dest_old = dest + ".old"
if os.path.isdir(dest_old) and not os.path.islink(dest_old):
shutil.rmtree(dest_old)
elif os.path.islink(dest_old):
os.remove(dest_old)
shutil.move(dest, dest + ".old")
def create_symlink(path):
install_conf_path = os.path.join(path, "install.conf")
if not os.path.isfile(install_conf_path):
logging.debug("No install.conf for %s", path)
return
with open(install_conf_path, "r") as install_conf:
read_data = install_conf.readlines()
for line in read_data:
src, dest = clean_conf_line(line)
src_path = os.path.abspath(os.path.join(path, src))
logging.debug("src: %s", src_path)
logging.debug("dest: %s", dest)
dest = os.path.expanduser(os.path.expandvars(dest))
if os.path.abspath(dest) == src_path:
continue
if os.path.lexists(dest):
move_existing_dest(dest)
if not os.path.isdir(os.path.dirname(dest)):
os.makedirs(os.path.dirname(dest))
os.symlink(src_path, dest)
# launch post_install.sh if any
post_install = os.path.join(path, "post_install.sh")
if os.path.exists(post_install):
stdout = subprocess.check_output(["bash", post_install])
if stdout:
print(stdout)
# Enable the debug mode
# logging.basicConfig(level=logging.DEBUG)
os.chdir(os.path.dirname(os.path.realpath(__file__)))
update_git_submodule()
dirs = [child for child in os.listdir() if os.path.isdir(child)]
excluded_dirs = (".git",)
for path in dirs:
try:
if path in excluded_dirs:
logging.debug("%s is in excluded_dirs. Ignoring it...", path)
continue
create_symlink(path)
except Exception as e:
logging.error("Error during the dotfiles copy in the directory: %s", path)
logging.exception(e)