summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rwxr-xr-xsetup.py51
-rwxr-xr-xtools/build-on-freebsd4
2 files changed, 38 insertions, 17 deletions
diff --git a/setup.py b/setup.py
index 7b061824..b09c0456 100755
--- a/setup.py
+++ b/setup.py
@@ -90,6 +90,42 @@ def read_requires():
return str(deps).splitlines()
+# Install everything in the right location and take care of Linux (default) and
+# FreeBSD systems.
+def read_datafiles():
+ sysname = os.uname()[0]
+ if sysname == 'FreeBSD':
+ return [
+ ('/usr/local/etc/cloud', glob('config/*.cfg')),
+ ('/usr/local/etc/cloud/cloud.cfg.d', glob('config/cloud.cfg.d/*')),
+ ('/usr/local/etc/cloud/templates', glob('templates/*')),
+ ('/usr/local/share/cloud-init', []),
+ ('/usr/local/lib/cloud-init',
+ ['tools/uncloud-init', 'tools/write-ssh-key-fingerprints']),
+ ('/usr/local/share/doc/cloud-init',
+ [f for f in glob('doc/*') if is_f(f)]),
+ ('/usr/local/share/doc/cloud-init/examples',
+ [f for f in glob('doc/examples/*') if is_f(f)]),
+ ('/usr/local/share/doc/cloud-init/examples/seed',
+ [f for f in glob('doc/examples/seed/*') if is_f(f)]),
+ ]
+ else:
+ return [
+ ('/etc/cloud', glob('config/*.cfg')),
+ ('/etc/cloud/cloud.cfg.d', glob('config/cloud.cfg.d/*')),
+ ('/etc/cloud/templates', glob('templates/*')),
+ ('/usr/share/cloud-init', []),
+ ('/usr/lib/cloud-init',
+ ['tools/uncloud-init', 'tools/write-ssh-key-fingerprints']),
+ ('/usr/share/doc/cloud-init',
+ [f for f in glob('doc/*') if is_f(f)]),
+ ('/usr/share/doc/cloud-init/examples',
+ [f for f in glob('doc/examples/*') if is_f(f)]),
+ ('/usr/share/doc/cloud-init/examples/seed',
+ [f for f in glob('doc/examples/seed/*') if is_f(f)]),
+ ]
+
+
# TODO: Is there a better way to do this??
class InitsysInstallData(install):
init_system = None
@@ -138,20 +174,7 @@ setuptools.setup(name='cloud-init',
'tools/cloud-init-per',
],
license='GPLv3',
- data_files=[('/etc/cloud', glob('config/*.cfg')),
- ('/etc/cloud/cloud.cfg.d', glob('config/cloud.cfg.d/*')),
- ('/etc/cloud/templates', glob('templates/*')),
- ('/usr/share/cloud-init', []),
- ('/usr/lib/cloud-init',
- ['tools/uncloud-init',
- 'tools/write-ssh-key-fingerprints']),
- ('/usr/share/doc/cloud-init',
- [f for f in glob('doc/*') if is_f(f)]),
- ('/usr/share/doc/cloud-init/examples',
- [f for f in glob('doc/examples/*') if is_f(f)]),
- ('/usr/share/doc/cloud-init/examples/seed',
- [f for f in glob('doc/examples/seed/*') if is_f(f)]),
- ],
+ data_files=read_datafiles(),
install_requires=read_requires(),
cmdclass={
# Use a subclass for install that handles
diff --git a/tools/build-on-freebsd b/tools/build-on-freebsd
index 7d19f44c..6e6ce8b6 100755
--- a/tools/build-on-freebsd
+++ b/tools/build-on-freebsd
@@ -17,9 +17,7 @@ touch /tmp/c-i.dependencieschecked
python setup.py build
python setup.py install -O1 --skip-build --prefix /usr/local/ --init-system sysvinit_freebsd
-# Move the configdir to /usr/local/ and use freebsd.cfg:
-[ -d /usr/local/etc/cloud ] && rm -rf /usr/local/etc/cloud
-mv /etc/cloud /usr/local/etc/
+# Use the correct config file:
mv /usr/local/etc/cloud/cloud.freebsd.cfg /usr/local/etc/cloud/cloud.cfg
# Enable cloud-init in /etc/rc.conf: