2013-03-17 09:32:29 +08:00
|
|
|
#!/usr/bin/env python
|
|
|
|
|
2013-04-11 04:02:28 +08:00
|
|
|
# pylint: disable=W0201
|
|
|
|
# Attribute defined outside __init__: custom commands require breaking this
|
|
|
|
|
2013-04-18 03:14:52 +08:00
|
|
|
import datetime
|
2013-03-17 09:32:29 +08:00
|
|
|
import glob
|
2013-04-04 07:07:42 +08:00
|
|
|
import fnmatch
|
2013-03-17 09:32:29 +08:00
|
|
|
import os
|
2013-03-18 06:18:22 +08:00
|
|
|
import sys
|
|
|
|
import unittest
|
2013-03-17 09:32:29 +08:00
|
|
|
|
|
|
|
from distutils.core import Command, setup
|
2013-04-11 05:25:39 +08:00
|
|
|
from distutils.command.install import install
|
2013-03-17 09:32:29 +08:00
|
|
|
from distutils.command.install_egg_info import install_egg_info
|
2013-04-11 05:25:39 +08:00
|
|
|
from distutils.sysconfig import get_config_var
|
|
|
|
sysprefix = get_config_var("prefix")
|
2013-03-17 09:32:29 +08:00
|
|
|
|
|
|
|
from DistUtilsExtra.auto import sdist_auto
|
|
|
|
from DistUtilsExtra.command.build_i18n import build_i18n
|
|
|
|
from DistUtilsExtra.command.build_extra import build_extra
|
|
|
|
from DistUtilsExtra.command.build_icons import build_icons
|
|
|
|
|
|
|
|
from virtcli import cliconfig
|
|
|
|
|
|
|
|
|
2013-04-04 07:07:42 +08:00
|
|
|
def _generate_potfiles_in():
|
|
|
|
def find(dirname, ext):
|
|
|
|
ret = []
|
2013-04-12 20:26:21 +08:00
|
|
|
for root, ignore, filenames in os.walk(dirname):
|
2013-04-04 07:07:42 +08:00
|
|
|
for filename in fnmatch.filter(filenames, ext):
|
|
|
|
ret.append(os.path.join(root, filename))
|
|
|
|
ret.sort(key=lambda s: s.lower())
|
|
|
|
return ret
|
|
|
|
|
|
|
|
scripts = ["virt-manager", "virt-manager-tui", "virt-install",
|
|
|
|
"virt-clone", "virt-image", "virt-convert"]
|
|
|
|
|
|
|
|
potfiles = "\n".join(scripts) + "\n\n"
|
|
|
|
potfiles += "\n".join(find("virtManager", "*.py")) + "\n\n"
|
|
|
|
potfiles += "\n".join(find("virtManagerTui", "*.py")) + "\n\n"
|
|
|
|
potfiles += "\n".join(find("virtcli", "*.py")) + "\n\n"
|
|
|
|
potfiles += "\n".join(find("virtconv", "*.py")) + "\n\n"
|
|
|
|
potfiles += "\n".join(find("virtinst", "*.py")) + "\n\n"
|
|
|
|
|
|
|
|
potfiles += "\n".join(["[type: gettext/glade]" + f for
|
|
|
|
f in find("ui", "*.ui")])
|
|
|
|
|
|
|
|
return potfiles
|
|
|
|
|
|
|
|
|
2013-03-17 09:32:29 +08:00
|
|
|
class my_build_i18n(build_i18n):
|
|
|
|
"""
|
|
|
|
Add our desktop files to the list, saves us having to track setup.cfg
|
|
|
|
"""
|
|
|
|
def finalize_options(self):
|
|
|
|
build_i18n.finalize_options(self)
|
|
|
|
|
|
|
|
self.desktop_files = ('[("share/applications",' +
|
|
|
|
' ("data/virt-manager.desktop.in", ))]')
|
|
|
|
|
2013-04-04 07:07:42 +08:00
|
|
|
def run(self):
|
|
|
|
potfiles = _generate_potfiles_in()
|
|
|
|
potpath = "po/POTFILES.in"
|
|
|
|
|
|
|
|
try:
|
|
|
|
print "Writing %s" % potpath
|
|
|
|
file(potpath, "w").write(potfiles)
|
|
|
|
build_i18n.run(self)
|
|
|
|
finally:
|
|
|
|
print "Removing %s" % potpath
|
|
|
|
os.unlink(potpath)
|
|
|
|
|
2013-03-17 09:32:29 +08:00
|
|
|
|
|
|
|
class my_build(build_extra):
|
|
|
|
"""
|
|
|
|
Create simple shell wrappers for /usr/bin/ tools to point to /usr/share
|
|
|
|
Compile .pod file
|
|
|
|
"""
|
|
|
|
|
2013-03-18 07:32:19 +08:00
|
|
|
def _make_bin_wrappers(self):
|
|
|
|
cmds = ["virt-manager", "virt-install", "virt-clone",
|
|
|
|
"virt-image", "virt-convert"]
|
2013-03-17 09:32:29 +08:00
|
|
|
if cliconfig.with_tui:
|
|
|
|
cmds += ["virt-manager-tui"]
|
|
|
|
|
2013-03-18 07:32:19 +08:00
|
|
|
if not os.path.exists("build"):
|
|
|
|
os.mkdir("build")
|
|
|
|
|
2013-03-17 09:32:29 +08:00
|
|
|
for app in cmds:
|
2013-04-11 05:34:52 +08:00
|
|
|
sharepath = os.path.join(cliconfig.install_asset_dir, app)
|
2013-03-17 09:32:29 +08:00
|
|
|
|
|
|
|
wrapper = "#!/bin/sh\n\n"
|
2013-03-18 07:32:19 +08:00
|
|
|
wrapper += "exec \"%s\" \"$@\"" % (sharepath)
|
|
|
|
|
|
|
|
newpath = os.path.abspath(os.path.join("build", app))
|
|
|
|
print "Generating %s" % newpath
|
|
|
|
file(newpath, "w").write(wrapper)
|
|
|
|
|
|
|
|
|
|
|
|
def _make_man_pages(self):
|
|
|
|
for path in glob.glob("man/*.pod"):
|
|
|
|
base = os.path.basename(path)
|
|
|
|
|
|
|
|
mantype = "1"
|
|
|
|
newbase = base
|
|
|
|
if base == "virt-image-xml.pod":
|
|
|
|
mantype = "5"
|
|
|
|
newbase = "virt-image.pod"
|
|
|
|
|
|
|
|
newpath = os.path.join(os.path.dirname(path),
|
|
|
|
os.path.splitext(newbase)[0] + "." + mantype)
|
|
|
|
|
|
|
|
print "Generating %s" % newpath
|
|
|
|
ret = os.system('pod2man --release="" '
|
|
|
|
'--center "Virtual Machine Manager" '
|
|
|
|
'< %s > %s' % (path, newpath))
|
|
|
|
if ret != 0:
|
|
|
|
raise RuntimeError("Generating '%s' failed." % newpath)
|
|
|
|
|
|
|
|
if os.system("grep -IRq 'Hey!' man/") == 0:
|
|
|
|
raise RuntimeError("man pages have errors in them! "
|
|
|
|
"(grep for 'Hey!')")
|
|
|
|
|
|
|
|
|
|
|
|
def run(self):
|
|
|
|
self._make_bin_wrappers()
|
|
|
|
self._make_man_pages()
|
2013-03-17 09:32:29 +08:00
|
|
|
|
|
|
|
build_extra.run(self)
|
|
|
|
|
|
|
|
|
|
|
|
class my_build_icons(build_icons):
|
|
|
|
"""
|
|
|
|
Fix up build_icon output to put or private icons in share/virt-manager
|
|
|
|
"""
|
|
|
|
|
|
|
|
def run(self):
|
|
|
|
data_files = self.distribution.data_files
|
|
|
|
|
|
|
|
for size in glob.glob(os.path.join(self.icon_dir, "*")):
|
|
|
|
for category in glob.glob(os.path.join(size, "*")):
|
|
|
|
icons = []
|
2013-04-14 02:34:52 +08:00
|
|
|
for icon in glob.glob(os.path.join(category, "*")):
|
2013-03-17 09:32:29 +08:00
|
|
|
if not os.path.islink(icon):
|
|
|
|
icons.append(icon)
|
|
|
|
if not icons:
|
|
|
|
continue
|
|
|
|
|
|
|
|
category = os.path.basename(category)
|
|
|
|
dest = ("share/icons/hicolor/%s/%s" %
|
|
|
|
(os.path.basename(size), category))
|
|
|
|
if category != "apps":
|
|
|
|
dest = dest.replace("share/", "share/virt-manager/")
|
|
|
|
|
|
|
|
data_files.append((dest, icons))
|
|
|
|
|
|
|
|
|
|
|
|
class my_egg_info(install_egg_info):
|
|
|
|
"""
|
|
|
|
Disable egg_info installation, seems pointless for a non-library
|
|
|
|
"""
|
|
|
|
def run(self):
|
|
|
|
pass
|
|
|
|
|
|
|
|
|
2013-04-11 05:25:39 +08:00
|
|
|
class my_install(install):
|
|
|
|
"""
|
|
|
|
Error if we weren't 'configure'd with the correct install prefix
|
|
|
|
"""
|
|
|
|
def finalize_options(self):
|
|
|
|
if self.prefix is None:
|
|
|
|
if cliconfig.prefix != sysprefix:
|
|
|
|
print "Using prefix from 'configure': %s" % cliconfig.prefix
|
|
|
|
self.prefix = cliconfig.prefix
|
|
|
|
elif self.prefix != cliconfig.prefix:
|
|
|
|
print ("Install prefix=%s doesn't match configure prefix=%s\n"
|
|
|
|
"Pass matching --prefix to 'setup.py configure'" %
|
|
|
|
(self.prefix, cliconfig.prefix))
|
|
|
|
sys.exit(1)
|
|
|
|
|
|
|
|
install.finalize_options(self)
|
|
|
|
|
2013-04-17 08:44:16 +08:00
|
|
|
|
|
|
|
class my_sdist(sdist_auto):
|
2013-04-18 03:14:52 +08:00
|
|
|
user_options = sdist_auto.user_options + [
|
2013-04-17 08:44:16 +08:00
|
|
|
("snapshot", "s", "add snapshot id to version")]
|
|
|
|
|
2013-04-17 20:25:07 +08:00
|
|
|
description = "Update virt-manager.spec; build sdist-tarball."
|
|
|
|
|
2013-04-17 08:44:16 +08:00
|
|
|
def initialize_options(self):
|
|
|
|
self.snapshot = None
|
2013-04-18 03:14:52 +08:00
|
|
|
sdist_auto.initialize_options(self)
|
2013-04-17 08:44:16 +08:00
|
|
|
|
|
|
|
def finalize_options(self):
|
|
|
|
if self.snapshot is not None:
|
|
|
|
self.snapshot = 1
|
|
|
|
cliconfig.__snapshot__ = 1
|
2013-04-18 03:14:52 +08:00
|
|
|
sdist_auto.finalize_options(self)
|
2013-04-17 08:44:16 +08:00
|
|
|
|
2013-04-17 20:25:07 +08:00
|
|
|
def run(self):
|
2013-04-18 03:14:52 +08:00
|
|
|
# Note: cliconfig.__snapshot__ by default is 0, it can be set to 1 by
|
|
|
|
# either sdist or rpm and then the snapshot suffix is appended.
|
2013-04-17 20:25:07 +08:00
|
|
|
ver = cliconfig.__version__
|
2013-04-17 08:44:16 +08:00
|
|
|
if cliconfig.__snapshot__ == 1:
|
2013-04-18 03:14:52 +08:00
|
|
|
ver = ver + '.' + datetime.date.today().isoformat().replace('-', '')
|
2013-04-17 08:44:16 +08:00
|
|
|
cliconfig.__version__ = ver
|
2013-04-18 03:14:52 +08:00
|
|
|
|
2013-04-17 08:44:16 +08:00
|
|
|
setattr(self.distribution.metadata, 'version', ver)
|
2013-04-17 20:25:07 +08:00
|
|
|
f1 = open('virt-manager.spec.in', 'r')
|
|
|
|
f2 = open('virt-manager.spec', 'w')
|
|
|
|
for line in f1:
|
|
|
|
f2.write(line.replace('@VERSION@', ver))
|
|
|
|
f1.close()
|
|
|
|
f2.close()
|
2013-04-18 03:14:52 +08:00
|
|
|
|
2013-04-17 08:44:16 +08:00
|
|
|
sdist_auto.run(self)
|
2013-04-17 20:25:07 +08:00
|
|
|
|
2013-04-11 05:25:39 +08:00
|
|
|
|
2013-03-17 09:32:29 +08:00
|
|
|
###################
|
|
|
|
# Custom commands #
|
|
|
|
###################
|
|
|
|
|
|
|
|
class my_rpm(Command):
|
2013-04-18 03:14:52 +08:00
|
|
|
user_options = [("snapshot", "s", "add snapshot id to version")]
|
2013-04-17 08:44:16 +08:00
|
|
|
|
|
|
|
description = "Build src and noarch rpms."
|
2013-03-17 09:32:29 +08:00
|
|
|
|
|
|
|
def initialize_options(self):
|
2013-04-17 08:44:16 +08:00
|
|
|
self.snapshot = None
|
2013-04-11 05:25:39 +08:00
|
|
|
|
2013-03-17 09:32:29 +08:00
|
|
|
def finalize_options(self):
|
2013-04-17 08:44:16 +08:00
|
|
|
if self.snapshot is not None:
|
|
|
|
self.snapshot = 1
|
|
|
|
cliconfig.__snapshot__ = 1
|
2013-03-17 09:32:29 +08:00
|
|
|
|
|
|
|
def run(self):
|
|
|
|
"""
|
|
|
|
Run sdist, then 'rpmbuild' the tar.gz
|
|
|
|
"""
|
|
|
|
self.run_command('sdist')
|
2013-04-17 08:44:16 +08:00
|
|
|
os.system('rpmbuild -ta --clean dist/virt-manager-%s.tar.gz' %
|
2013-03-17 09:32:29 +08:00
|
|
|
cliconfig.__version__)
|
|
|
|
|
|
|
|
|
|
|
|
class configure(Command):
|
|
|
|
user_options = [
|
2013-04-17 08:44:15 +08:00
|
|
|
("pkgversion=", None, "user specified version-id"),
|
2013-04-11 05:25:39 +08:00
|
|
|
("prefix=", None, "installation prefix"),
|
2013-03-17 09:32:29 +08:00
|
|
|
("without-tui", None, "don't install virt-manager-tui"),
|
|
|
|
("qemu-user=", None,
|
|
|
|
"user libvirt uses to launch qemu processes (default=root)"),
|
|
|
|
("libvirt-package-names=", None,
|
|
|
|
"list of libvirt distro packages virt-manager will check for on "
|
|
|
|
"first run. comma separated string (default=none)"),
|
|
|
|
("kvm-package-names=", None,
|
|
|
|
"recommended kvm packages virt-manager will check for on first run "
|
|
|
|
"(default=none)"),
|
|
|
|
("askpass-package-names=", None,
|
|
|
|
"name of your distro's askpass package(s) (default=none)"),
|
|
|
|
("hide-unsupported-rhel-options", None,
|
|
|
|
"Hide config bits that are not supported on RHEL (default=no)"),
|
|
|
|
("preferred-distros=", None,
|
|
|
|
"Distros to list first in the New VM wizard (default=none)"),
|
|
|
|
("default-graphics=", None,
|
|
|
|
"Default graphics type (spice or vnc) (default=vnc)"),
|
|
|
|
|
|
|
|
]
|
|
|
|
description = "Configure the build, similar to ./configure"
|
|
|
|
|
|
|
|
def finalize_options(self):
|
|
|
|
pass
|
|
|
|
|
|
|
|
def initialize_options(self):
|
|
|
|
self.without_tui = 0
|
|
|
|
self.qemu_user = "root"
|
|
|
|
self.libvirt_package_names = ""
|
|
|
|
self.kvm_package_names = ""
|
|
|
|
self.askpass_package_names = ""
|
|
|
|
self.hide_unsupported_rhel_options = 0
|
|
|
|
self.preferred_distros = ""
|
|
|
|
self.default_graphics = "vnc"
|
2013-04-11 05:25:39 +08:00
|
|
|
self.prefix = sysprefix
|
2013-04-17 08:44:15 +08:00
|
|
|
self.pkgversion = ""
|
2013-03-17 09:32:29 +08:00
|
|
|
|
|
|
|
|
|
|
|
def run(self):
|
|
|
|
template = ""
|
|
|
|
template += "[config]\n"
|
2013-04-11 05:25:39 +08:00
|
|
|
template += "prefix = %s\n" % self.prefix
|
2013-04-17 08:44:15 +08:00
|
|
|
template += "pkgversion = %s\n" % self.pkgversion
|
2013-03-17 09:32:29 +08:00
|
|
|
template += "with_tui = %s\n" % int(not self.without_tui)
|
|
|
|
template += "default_qemu_user = %s\n" % self.qemu_user
|
|
|
|
template += "libvirt_packages = %s\n" % self.libvirt_package_names
|
|
|
|
template += "hv_packages = %s\n" % self.kvm_package_names
|
|
|
|
template += "askpass_packages = %s\n" % self.askpass_package_names
|
|
|
|
template += "preferred_distros = %s\n" % self.preferred_distros
|
|
|
|
template += ("hide_unsupported_rhel_options = %s\n" %
|
|
|
|
self.hide_unsupported_rhel_options)
|
|
|
|
template += "default_graphics = %s\n" % self.default_graphics
|
|
|
|
|
|
|
|
file(cliconfig.cfgpath, "w").write(template)
|
|
|
|
print "Generated %s" % cliconfig.cfgpath
|
|
|
|
|
|
|
|
|
|
|
|
tui_files = [
|
2013-03-18 07:32:19 +08:00
|
|
|
("share/virt-manager/", ["virt-manager-tui"]),
|
2013-03-17 09:32:29 +08:00
|
|
|
|
|
|
|
("share/virt-manager/virtManagerTui",
|
|
|
|
glob.glob("virtManagerTui/*.py")),
|
|
|
|
]
|
|
|
|
if not cliconfig.with_tui:
|
|
|
|
tui_files = []
|
|
|
|
|
|
|
|
|
2013-03-18 06:18:22 +08:00
|
|
|
class TestBaseCommand(Command):
|
|
|
|
user_options = [('debug', 'd', 'Show debug output')]
|
|
|
|
boolean_options = ['debug']
|
|
|
|
|
|
|
|
def initialize_options(self):
|
|
|
|
self.debug = 0
|
|
|
|
self._testfiles = []
|
|
|
|
self._dir = os.getcwd()
|
|
|
|
|
|
|
|
def finalize_options(self):
|
|
|
|
if self.debug and "DEBUG_TESTS" not in os.environ:
|
|
|
|
os.environ["DEBUG_TESTS"] = "1"
|
|
|
|
|
|
|
|
def run(self):
|
|
|
|
try:
|
|
|
|
# Use system 'coverage' if available
|
|
|
|
import coverage
|
|
|
|
use_coverage = True
|
|
|
|
except:
|
|
|
|
use_coverage = False
|
|
|
|
|
|
|
|
tests = unittest.TestLoader().loadTestsFromNames(self._testfiles)
|
|
|
|
t = unittest.TextTestRunner(verbosity=1)
|
|
|
|
|
|
|
|
if use_coverage:
|
|
|
|
coverage.erase()
|
|
|
|
coverage.start()
|
|
|
|
|
|
|
|
if hasattr(unittest, "installHandler"):
|
|
|
|
try:
|
|
|
|
unittest.installHandler()
|
|
|
|
except:
|
|
|
|
print "installHandler hack failed"
|
|
|
|
|
|
|
|
try:
|
|
|
|
result = t.run(tests)
|
|
|
|
except KeyboardInterrupt:
|
|
|
|
sys.exit(1)
|
|
|
|
|
|
|
|
if use_coverage:
|
|
|
|
coverage.stop()
|
|
|
|
|
|
|
|
sys.exit(int(bool(len(result.failures) > 0 or
|
|
|
|
len(result.errors) > 0)))
|
|
|
|
|
|
|
|
|
|
|
|
class TestCommand(TestBaseCommand):
|
|
|
|
description = "Runs a quick unit test suite"
|
|
|
|
user_options = TestBaseCommand.user_options + \
|
|
|
|
[("testfile=", None, "Specific test file to run (e.g "
|
|
|
|
"validation, storage, ...)"),
|
|
|
|
("skipcli", None, "Skip CLI tests")]
|
|
|
|
|
|
|
|
def initialize_options(self):
|
|
|
|
TestBaseCommand.initialize_options(self)
|
|
|
|
self.testfile = None
|
|
|
|
self.skipcli = None
|
|
|
|
|
|
|
|
def finalize_options(self):
|
|
|
|
TestBaseCommand.finalize_options(self)
|
|
|
|
|
|
|
|
def run(self):
|
|
|
|
'''
|
|
|
|
Finds all the tests modules in tests/, and runs them.
|
|
|
|
'''
|
|
|
|
testfiles = []
|
|
|
|
for t in glob.glob(os.path.join(self._dir, 'tests', '*.py')):
|
|
|
|
if (t.endswith("__init__.py") or
|
|
|
|
t.endswith("urltest.py")):
|
|
|
|
continue
|
|
|
|
|
|
|
|
base = os.path.basename(t)
|
|
|
|
if self.testfile:
|
|
|
|
check = os.path.basename(self.testfile)
|
|
|
|
if base != check and base != (check + ".py"):
|
|
|
|
continue
|
|
|
|
if self.skipcli and base.count("clitest"):
|
|
|
|
continue
|
|
|
|
|
|
|
|
testfiles.append('.'.join(['tests', os.path.splitext(base)[0]]))
|
|
|
|
|
|
|
|
if not testfiles:
|
|
|
|
raise RuntimeError("--testfile didn't catch anything")
|
|
|
|
|
|
|
|
self._testfiles = testfiles
|
|
|
|
TestBaseCommand.run(self)
|
|
|
|
|
|
|
|
|
|
|
|
class TestURLFetch(TestBaseCommand):
|
|
|
|
description = "Test fetching kernels and isos from various distro trees"
|
|
|
|
|
|
|
|
user_options = TestBaseCommand.user_options + \
|
|
|
|
[("match=", None, "Regular expression of dist names to "
|
|
|
|
"match [default: '.*']"),
|
|
|
|
("path=", None, "Paths to local iso or directory or check"
|
|
|
|
" for installable distro. Comma separated")]
|
|
|
|
|
|
|
|
def initialize_options(self):
|
|
|
|
TestBaseCommand.initialize_options(self)
|
|
|
|
self.match = None
|
|
|
|
self.path = ""
|
|
|
|
|
|
|
|
def finalize_options(self):
|
|
|
|
TestBaseCommand.finalize_options(self)
|
|
|
|
if self.match is None:
|
|
|
|
self.match = ".*"
|
|
|
|
|
|
|
|
origpath = str(self.path)
|
|
|
|
if not origpath:
|
|
|
|
self.path = []
|
|
|
|
else:
|
|
|
|
self.path = origpath.split(",")
|
|
|
|
|
|
|
|
def run(self):
|
|
|
|
import tests
|
|
|
|
self._testfiles = ["tests.urltest"]
|
|
|
|
tests.urltest.MATCH_FILTER = self.match
|
|
|
|
if self.path:
|
|
|
|
for p in self.path:
|
|
|
|
tests.urltest.LOCAL_MEDIA.append(p)
|
|
|
|
TestBaseCommand.run(self)
|
|
|
|
|
|
|
|
|
2013-04-11 04:02:28 +08:00
|
|
|
class CheckPylint(Command):
|
|
|
|
user_options = []
|
|
|
|
description = "Check code using pylint and pep8"
|
|
|
|
|
|
|
|
def initialize_options(self):
|
|
|
|
pass
|
|
|
|
def finalize_options(self):
|
|
|
|
pass
|
|
|
|
|
|
|
|
def run(self):
|
|
|
|
files = ["setup.py", "virt-install", "virt-clone", "virt-image",
|
|
|
|
"virt-convert", "virt-manager", "virt-manager-tui",
|
|
|
|
"virtcli", "virtinst", "virtconv", "virtManager",
|
|
|
|
"virtManagerTui", "tests"]
|
|
|
|
|
|
|
|
output_format = sys.stdout.isatty() and "colorized" or "text"
|
|
|
|
|
|
|
|
cmd = "pylint "
|
|
|
|
cmd += "--output-format=%s " % output_format
|
|
|
|
cmd += " ".join(files)
|
2013-04-14 02:01:20 +08:00
|
|
|
os.system(cmd + " --rcfile tests/pylint.cfg")
|
2013-04-11 04:02:28 +08:00
|
|
|
|
2013-04-14 02:34:52 +08:00
|
|
|
print "running pep8"
|
|
|
|
cmd = "pep8 "
|
|
|
|
cmd += " ".join(files)
|
|
|
|
os.system(cmd + " --config tests/pep8.cfg")
|
|
|
|
|
2013-04-11 04:02:28 +08:00
|
|
|
|
2013-03-17 09:32:29 +08:00
|
|
|
setup(
|
2013-04-14 02:34:52 +08:00
|
|
|
name="virt-manager",
|
|
|
|
version=cliconfig.__version__,
|
|
|
|
author="Cole Robinson",
|
|
|
|
author_email="virt-tools-list@redhat.com",
|
|
|
|
url="http://virt-manager.org",
|
|
|
|
license="GPLv2+",
|
2013-03-17 09:32:29 +08:00
|
|
|
|
2013-03-18 07:32:19 +08:00
|
|
|
# These wrappers are generated in our custom build command
|
2013-04-14 02:34:52 +08:00
|
|
|
scripts=([
|
2013-03-18 07:32:19 +08:00
|
|
|
"build/virt-manager",
|
|
|
|
"build/virt-clone",
|
|
|
|
"build/virt-install",
|
|
|
|
"build/virt-image",
|
|
|
|
"build/virt-convert"] +
|
|
|
|
(cliconfig.with_tui and ["build/virt-manager-tui"] or [])),
|
2013-03-17 09:32:29 +08:00
|
|
|
|
2013-04-14 02:34:52 +08:00
|
|
|
data_files=[
|
2013-03-18 07:32:19 +08:00
|
|
|
("share/virt-manager/", [
|
|
|
|
"virt-manager",
|
|
|
|
"virt-install",
|
|
|
|
"virt-clone",
|
|
|
|
"virt-image",
|
|
|
|
"virt-convert",
|
|
|
|
]),
|
2013-04-18 05:39:25 +08:00
|
|
|
("share/glib-2.0/schemas",
|
|
|
|
["data/org.virt-manager.virt-manager.gschema.xml"]),
|
2013-03-17 09:32:29 +08:00
|
|
|
("share/virt-manager/ui", glob.glob("ui/*.ui")),
|
|
|
|
|
2013-03-18 07:32:19 +08:00
|
|
|
("share/man/man1", [
|
|
|
|
"man/virt-manager.1",
|
|
|
|
"man/virt-install.1",
|
|
|
|
"man/virt-clone.1",
|
|
|
|
"man/virt-image.1",
|
|
|
|
"man/virt-convert.1"
|
|
|
|
]),
|
|
|
|
("share/man/man5", ["man/virt-image.5"]),
|
2013-03-17 09:32:29 +08:00
|
|
|
|
|
|
|
("share/virt-manager/virtManager", glob.glob("virtManager/*.py")),
|
2013-03-18 07:32:19 +08:00
|
|
|
|
2013-04-11 05:13:02 +08:00
|
|
|
("share/virt-manager/virtcli",
|
2013-04-15 00:51:22 +08:00
|
|
|
glob.glob("virtcli/*.py") + glob.glob("virtcli/cli.cfg")),
|
2013-03-18 07:32:19 +08:00
|
|
|
("share/virt-manager/virtinst", glob.glob("virtinst/*.py")),
|
|
|
|
("share/virt-manager/virtconv", glob.glob("virtconv/*.py")),
|
|
|
|
("share/virt-manager/virtconv/parsers",
|
|
|
|
glob.glob("virtconv/parsers/*.py")),
|
2013-03-17 09:32:29 +08:00
|
|
|
] + tui_files,
|
|
|
|
|
2013-04-14 02:34:52 +08:00
|
|
|
cmdclass={
|
2013-03-17 09:32:29 +08:00
|
|
|
'build': my_build,
|
|
|
|
'build_i18n': my_build_i18n,
|
|
|
|
'build_icons': my_build_icons,
|
2013-04-11 05:25:39 +08:00
|
|
|
|
2013-04-17 20:25:07 +08:00
|
|
|
'sdist': my_sdist,
|
2013-04-11 05:25:39 +08:00
|
|
|
'install': my_install,
|
2013-03-17 09:32:29 +08:00
|
|
|
'install_egg_info': my_egg_info,
|
|
|
|
|
|
|
|
'configure': configure,
|
|
|
|
|
2013-04-11 04:02:28 +08:00
|
|
|
'pylint': CheckPylint,
|
2013-03-17 09:32:29 +08:00
|
|
|
'rpm': my_rpm,
|
2013-03-18 06:18:22 +08:00
|
|
|
'test': TestCommand,
|
|
|
|
'test_urls' : TestURLFetch,
|
2013-03-17 09:32:29 +08:00
|
|
|
}
|
|
|
|
)
|