summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAdam J. Stewart <ajstewart426@gmail.com>2016-09-28 13:58:51 -0500
committerTodd Gamblin <tgamblin@llnl.gov>2016-09-28 14:58:51 -0400
commit66c2ac0bc9639888f98cd0bd54688ac721045781 (patch)
treee27a738533b87eb8f32e39059f9c1f1c07cd532d
parent9aa77178f33793103653da1c81a73dd6a9e250be (diff)
downloadspack-66c2ac0bc9639888f98cd0bd54688ac721045781.tar.gz
spack-66c2ac0bc9639888f98cd0bd54688ac721045781.tar.bz2
spack-66c2ac0bc9639888f98cd0bd54688ac721045781.tar.xz
spack-66c2ac0bc9639888f98cd0bd54688ac721045781.zip
Tell Mercurial where to find CA certs (#1873)
-rw-r--r--var/spack/repos/builtin/packages/mercurial/package.py35
1 files changed, 30 insertions, 5 deletions
diff --git a/var/spack/repos/builtin/packages/mercurial/package.py b/var/spack/repos/builtin/packages/mercurial/package.py
index e51069662f..ea77953f15 100644
--- a/var/spack/repos/builtin/packages/mercurial/package.py
+++ b/var/spack/repos/builtin/packages/mercurial/package.py
@@ -22,23 +22,48 @@
# License along with this program; if not, write to the Free Software
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
##############################################################################
-
from spack import *
+import llnl.util.tty as tty
+import os
class Mercurial(Package):
"""Mercurial is a free, distributed source control management tool."""
+
homepage = "https://www.mercurial-scm.org"
url = "https://www.mercurial-scm.org/release/mercurial-3.9.tar.gz"
- version('3.9' , 'e2b355da744e94747daae3a5339d28a0')
+ version('3.9.1', '3759dd10edb8c1a6dfb8ff0ce82658ce')
+ version('3.9', 'e2b355da744e94747daae3a5339d28a0')
version('3.8.4', 'cec2c3db688cb87142809089c6ae13e9')
version('3.8.3', '97aced7018614eeccc9621a3dea35fda')
version('3.8.2', 'c38daa0cbe264fc621dc3bb05933b0b3')
version('3.8.1', '172a8c588adca12308c2aca16608d7f4')
- depends_on("python @2.6:2.7.999")
- depends_on("py-docutils", type="build")
+ extends('python')
+ depends_on('python@2.6:2.8')
+ depends_on('py-docutils', type='build')
def install(self, spec, prefix):
- make('PREFIX=%s' % prefix, 'install')
+ make('install', 'PREFIX={0}'.format(prefix))
+
+ # Configuration of HTTPS certificate authorities
+ # https://www.mercurial-scm.org/wiki/CACertificates
+ hgrc_filename = join_path(prefix.etc, 'mercurial', 'hgrc')
+ mkdirp(os.path.dirname(hgrc_filename))
+
+ with open(hgrc_filename, 'w') as hgrc:
+ if os.path.exists('/etc/ssl/certs/ca-certificates.crt'):
+ # Debian/Ubuntu/Gentoo/Arch Linux
+ hgrc.write('[web]\ncacerts = /etc/ssl/certs/ca-certificates.crt') # noqa
+ elif os.path.exists('/etc/pki/tls/certs/ca-bundle.crt'):
+ # Fedora/RHEL/CentOS
+ hgrc.write('[web]\ncacerts = /etc/pki/tls/certs/ca-bundle.crt')
+ elif os.path.exists('/etc/ssl/ca-bundle.pem'):
+ # openSUSE/SLE
+ hgrc.write('[web]\ncacerts = /etc/ssl/ca-bundle.pem')
+ else:
+ tty.warn('CA certificate not found. You may not be able to '
+ 'connect to an HTTPS server. If your CA certificate '
+ 'is in a non-standard location, you should add it to '
+ '{0}'.format(hgrc_filename))