summaryrefslogtreecommitdiff
path: root/var/spack
diff options
context:
space:
mode:
authorThomas Dickerson <elfprince13@gmail.com>2021-11-23 19:45:18 -0500
committerGitHub <noreply@github.com>2021-11-23 16:45:18 -0800
commitc263b64d2ecad12227bb120661ed62298c4b16e1 (patch)
treef8e757976a9c8687542fbe2ac3a9a2c34c2fad37 /var/spack
parentdfc95cdf1c07ad7cde2becc14db5692cd8d7f0dc (diff)
downloadspack-c263b64d2ecad12227bb120661ed62298c4b16e1.tar.gz
spack-c263b64d2ecad12227bb120661ed62298c4b16e1.tar.bz2
spack-c263b64d2ecad12227bb120661ed62298c4b16e1.tar.xz
spack-c263b64d2ecad12227bb120661ed62298c4b16e1.zip
Racket package: disable parallel build; add variants (#27506)
- Prevent `-j` flags to `make`, which has been known to cause problems with Racket builds. - Add variants for various common build flags, including support for both versions of the Racket VM environment. In addition: - Prefer the minimal release to improve install times. Bells and whistles carry their own runtime dependencies and should be installed via `raco`. An enterprising user may even create a `RacoPackage` class to make spack aware of `raco` installed packages. - Match the official version numbering scheme.
Diffstat (limited to 'var/spack')
-rw-r--r--var/spack/repos/builtin/packages/racket/package.py45
1 files changed, 37 insertions, 8 deletions
diff --git a/var/spack/repos/builtin/packages/racket/package.py b/var/spack/repos/builtin/packages/racket/package.py
index 1ae642a588..0b5e9d9a5f 100644
--- a/var/spack/repos/builtin/packages/racket/package.py
+++ b/var/spack/repos/builtin/packages/racket/package.py
@@ -11,28 +11,57 @@ class Racket(Package):
homepage = "https://www.racket-lang.org"
- maintainers = ['arjunguha']
+ maintainers = ['arjunguha', 'elfprince13']
- version('8.3.0', 'c4af1a10b957e5fa0daac2b5ad785cda79805f76d11482f550626fa68f07b949')
+ version('8.3', '3b963cd29ae119e1acc2c6dc4781bd9f25027979589caaae3fdfc021aac2324b')
depends_on('libffi', type=('build', 'link', 'run'))
depends_on('patchutils')
+ depends_on('libtool', type=('build'))
phases = ['configure', 'build', 'install']
def url_for_version(self, version):
- url = "http://mirror.racket-lang.org/installers/{0}/racket-src.tgz"
- return url.format(version.up_to(2))
+ return "https://mirror.racket-lang.org/installers/{0}/racket-minimal-{0}-src-builtpkgs.tgz".format(version)
+
+ variant('cs', default=True, description='Build Racket CS (new ChezScheme VM)')
+ variant('bc', default=False, description='Build Racket BC (old MZScheme VM)')
+ variant('shared', default=True, description="Enable shared")
+ variant('jit', default=True, description="Just-in-Time Compilation")
+
+ parallel = False
+ extendable = True
+
+ def toggle(self, spec, variant):
+ toggle_text = ("enable" if spec.variants[variant].value else "disable")
+ return "--{0}-{1}".format(toggle_text, variant)
def configure(self, spec, prefix):
with working_dir('src'):
- configure = Executable('./configure')
- configure("--prefix", prefix)
+ configure = Executable("./configure")
+ configure_args = [self.toggle(spec, 'cs'),
+ self.toggle(spec, 'bc'),
+ self.toggle(spec, 'jit')]
+ toggle_shared = self.toggle(spec, 'shared')
+ if sys.platform == 'darwin':
+ configure_args += ["--enable-macprefix"]
+ if "+xonx" in spec:
+ configure_args += ["--enable-xonx", toggle_shared]
+ else:
+ configure_args += [toggle_shared]
+ configure_args += ["--prefix={0}".format(prefix)]
+ configure(*configure_args)
def build(self, spec, prefix):
with working_dir('src'):
- make()
+ if spec.variants["bc"].value:
+ make("bc")
+ if spec.variants["cs"].value:
+ make("cs")
def install(self, spec, prefix):
with working_dir('src'):
- make('install')
+ if spec.variants["bc"].value:
+ make('install-bc')
+ if spec.variants["cs"].value:
+ make('install-cs')