forked from ambv/.dot_files
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathinstall.py
executable file
·171 lines (138 loc) · 5.74 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
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
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
#!/usr/bin/env python
import sys
import os
import subprocess
import optparse
try:
from hashlib import md5
except ImportError:
import md5
md5 = md5.new
if sys.version_info[:2] < (2, 4):
# subprocess was introduced in Python 2.4
print "Sorry, Python 2.4 required."
sys.exit(1)
user_home_dir = os.path.expanduser("~")
dot_files_dir = os.path.dirname(__file__)
if not dot_files_dir:
dot_files_dir = '.'
parser = optparse.OptionParser()
parser.add_option("-U", "--uninstall",
action="store_true",
dest="uninstall",
default=False,
help="uninstall the distribution from the home directory")
parser.add_option("-v", "--verbose",
action="store_true",
dest="verbose",
default=False,
help="more detailed output")
parser.add_option("-d", "--dir",
dest="dir",
default=user_home_dir,
help="specify a directory to install to/uninstall from",
metavar="DIR")
(options, args) = parser.parse_args()
class Command(object):
warnings = []
verbose = []
class Install(Command):
cmd_message = "Installing dot_files to"
def no_target(self, source, target):
status = subprocess.call("ln -s %s %s" % (os.path.realpath(source), os.path.realpath(target)), shell=True)
if status == 0:
self.verbose.append("linked %s to %s" % (source, target))
else:
self.warnings.append("creating link %s to %s failed with status code %d" % (source, target, status))
def target_link_same(self, source, target, real_source, real_target):
self.verbose.append("link from %s to %s already exists" % (source, target))
def target_link_different(self, source, target, real_source, real_target):
self.warnings.append("link at %s exists but points to %s" % (target, real_target))
def target_different(self, source, target):
self.warnings.append("target %s exists but is not a link" % (target, ))
class Uninstall(Command):
cmd_message = "Uninstalling dot_files from"
def no_target(self, source, target):
self.verbose.append("target %s was missing" % (target,))
def target_link_same(self, source, target, real_source, real_target):
os.unlink(target)
self.verbose.append("link from %s to %s removed" % (source, target))
def target_link_different(self, source, target, real_source, real_target):
self.warnings.append("skipped target at %s: link points to %s" % (target, real_target))
def target_different(self, source, target):
self.warnings.append("skipped target at %s: not a link" % (target, ))
def obtain_machine_type():
"""Checks common locations for files holding the current version of the OS."""
if os.path.exists('/etc/redhat-release'):
f = open('/etc/redhat-release')
os_version = f.read().strip()
os_type = 'redhat'
elif os.path.exists('/etc/debian_version'):
f = open('/etc/debian_version')
os_version = f.read().strip()
os_type = 'debian'
elif os.path.exists('/System/Library/CoreServices/SystemVersion.plist'):
from xml.dom.minidom import parse
f = parse('/System/Library/CoreServices/SystemVersion.plist')
keys = f.getElementsByTagName('dict')[0].getElementsByTagName('key')
prod_name = ""
prod_version = ""
for k in keys:
if k.childNodes[0].data.strip() == u"ProductName":
sibling = k.nextSibling
while sibling.__class__.__name__ != 'Element':
sibling = sibling.nextSibling
if sibling.tagName == u"string":
prod_name = sibling.childNodes[0].data.strip()
if k.childNodes[0].data.strip() == u"ProductVersion":
sibling = k.nextSibling
while sibling.__class__.__name__ != 'Element':
sibling = sibling.nextSibling
if sibling.tagName == u"string":
prod_version = sibling.childNodes[0].data.strip()
os_version = "%s %s" % (prod_name, prod_version)
os_type = 'darwin'
elif os.path.exists('/cygdrive'):
os_version = 'Cygwin'
os_type = 'cygwin'
else:
os_version = 'unknown'
os_type = None
return os_type, os_version
if not options.uninstall:
handler = Install()
else:
handler = Uninstall()
machine_type, machine_version = obtain_machine_type()
if machine_type:
additional_info = "%s with extras for %s" % (options.dir, machine_version)
else:
additional_info = options.dir
print handler.cmd_message, "%s..." % additional_info,
for entry in os.listdir(dot_files_dir):
source = os.path.join(dot_files_dir, entry)
target = os.path.join(options.dir, ".%s" % entry)
if entry.startswith('.') or entry.endswith('~') or \
entry in ('install.py', 'bin', 'README.rst'):
continue
elif entry == 'profile_machine':
if not machine_type:
continue
source = os.path.join(dot_files_dir, entry, machine_type)
if not os.path.exists(target):
handler.no_target(source, target)
elif os.path.islink(target):
real_source = os.path.realpath(source)
real_target = os.path.realpath(target)
if real_source == real_target:
handler.target_link_same(source, target, real_source, real_target)
else:
handler.target_link_different(source, target, real_source, real_target)
else:
handler.target_different(source, target)
print "done."
for w in handler.warnings:
print "Warning:", w
if options.verbose:
for v in handler.verbose:
print v