forked from smartpm/smart
-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathsmart.py
executable file
·212 lines (195 loc) · 6.35 KB
/
smart.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
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
#!/usr/bin/env python
#
# Copyright (c) 2004 Conectiva, Inc.
#
# Written by Gustavo Niemeyer <[email protected]>
#
# This file is part of Smart Package Manager.
#
# Smart Package Manager 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 2 of the License, or (at
# your option) any later version.
#
# Smart Package Manager 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 Smart Package Manager; if not, write to the Free Software
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
#
# Copyright (C) 2016 FUJITSU LIMITED
#
import sys
if sys.version_info < (2, 3):
sys.exit("error: Python 2.3 or later required")
from smart import init, initDistro, initPlugins, initPycurl, initPsyco
from smart.const import VERSION, DATADIR
from smart.option import OptionParser
from smart import *
import pwd
import os
# Avoid segfault due to strange linkage order. Remove this ASAP.
import pyexpat
USAGE=_("smart command [options] [arguments]")
DESCRIPTION=_("""
Action commands:
update
init
install
reinstall
upgrade
remove
check
fix
download
clean
Query commands:
search
query
newer
info
stats
Setup commands:
config
channel
priority
mirror
flag
Run "smart command --help" for more information.
""")
EXAMPLES = _("""
smart install --help
smart install pkgname
smart --gui
smart --gui install pkgname
smart --shell
""")
def parse_options(argv):
parser = OptionParser(usage=USAGE,
description=DESCRIPTION,
examples=EXAMPLES,
skipunknown=True,
add_help_option=False,
version="smart %s" % VERSION)
parser.add_option("--config-file", metavar=_("FILE"),
help=_("configuration file "
"(default is <data-dir>/config)"))
parser.add_option("--rootfs-dir", metavar=_("DIR"),
help=_("rootfs directory"))
parser.add_option("--data-dir", metavar=_("DIR"),
help=_("data directory (default is %s)") % DATADIR)
parser.add_option("--log-level", metavar=_("LEVEL"),
help=_("set the log level to LEVEL (debug, info, "
"warning, error)"))
parser.add_option("--gui", action="store_true",
help=_("use the default graphic interface"))
parser.add_option("--shell", action="store_true",
help=_("use the default shell interface"))
parser.add_option("--quiet", action="store_true",
help=_("use the quiet interface"))
parser.add_option("--interface", metavar=_("NAME"),
help=_("use the given interface"))
parser.add_option("--ignore-locks", action="store_true",
help=_("don't respect locking"))
parser.add_option("-o", "--option", action="append", default=[],
metavar=_("OPT"),
help=_("set the option given by a name=value pair"))
opts, args = parser.parse_args()
if args:
opts.command = arg = args[0]
opts.argv = args[1:]
if arg and arg[0] == "-":
if arg == "-h" or len(arg) > 2 and "--help".startswith(arg):
parser.print_help()
sys.exit(0)
else:
raise Error, _("no such option: %s") % arg
else:
opts.command = None
opts.argv = []
if not (opts.command or opts.gui or opts.shell or opts.interface):
parser.print_help()
sys.exit(1)
return opts
def set_config_options(options):
import re
globals = {}
globals["__builtins__"] = {}
globals["True"] = True
globals["true"] = True
globals["yes"] = True
globals["False"] = False
globals["false"] = False
globals["no"] = False
SETRE = re.compile(r"^(\S+?)(\+?=)(.*)$")
for opt in options:
m = SETRE.match(opt)
if not m:
raise Error, _("Invalid option: %s") % opt
path, assign, value = m.groups()
try:
value = int(value)
except ValueError:
try:
value = eval(value, globals)
except:
pass
if assign == "+=":
sysconf.add(path, value, soft=True)
else:
sysconf.set(path, value, soft=True)
def main(argv):
# Get the right $HOME, even when using sudo.
if os.getuid() == 0:
os.environ["HOME"] = pwd.getpwuid(0)[5]
opts = None
ctrl = None
exitcode = 1
try:
opts = parse_options(argv)
if opts.rootfs_dir:
datadir = opts.rootfs_dir + DATADIR
else:
datadir = opts.data_dir
ctrl = init(command=opts.command, argv=opts.argv,
datadir=datadir, configfile=opts.config_file,
gui=opts.gui, shell=opts.shell, quiet=opts.quiet,
interface=opts.interface, forcelocks=opts.ignore_locks,
loglevel=opts.log_level)
if opts.option:
set_config_options(opts.option)
initDistro(ctrl)
initPlugins()
initPycurl()
initPsyco()
exitcode = iface.run(opts.command, opts.argv)
if exitcode is None:
exitcode = 0
ctrl.saveSysConf()
ctrl.restoreMediaState()
except Error, e:
if opts and opts.log_level == "debug":
import traceback
traceback.print_exc()
if iface.object:
iface.error(unicode(e))
else:
sys.stderr.write(_("error: %s\n") % e)
if ctrl:
ctrl.saveSysConf()
ctrl.restoreMediaState()
except KeyboardInterrupt:
if opts and opts.log_level == "debug":
import traceback
traceback.print_exc()
sys.exit(1)
sys.stderr.write(_("\nInterrupted\n"))
print
if exitcode != 0:
sys.exit(exitcode)
if __name__ == "__main__":
main(sys.argv[1:])
# vim:ts=4:sw=4:et