Files
spack/var/spack/repos/spack_repo/builtin/packages/libfive/package.py
Harmen Stoppels 2929ea02a1 Move builders into builtin repo (#50452)
Builders and package classes refer to packages from the builtin package
repo and are often modified together with packages. That means that
these classes should move into `spack_repo.builtin`.

* move `spack.build_systems` -> `spack_repo.builtin.build_systems`

* Remove the following re-exports from the `spack.package` module:
  - `AspellDictPackage`                 - `LuaPackage`
  - `AutotoolsPackage`                  - `MakefilePackage`
  - `BundlePackage`                     - `MavenPackage`
  - `CachedCMakePackage`                - `MesonPackage`
  - `cmake_cache_filepath`              - `MSBuildPackage`
  - `cmake_cache_option`                - `NMakePackage`
  - `cmake_cache_path`                  - `OctavePackage`
  - `cmake_cache_string`                - `PerlPackage`
  - `CargoPackage`                      - `PythonExtension`
  - `CMakePackage`                      - `PythonPackage`
  - `generator`                         - `QMakePackage`
  - `CompilerPackage`                   - `RacketPackage`
  - `CudaPackage`                       - `RPackage`
  - `Package`                           - `ROCmPackage`
  - `GNUMirrorPackage`                  - `RubyPackage`
  - `GoPackage`                         - `SConsPackage`
  - `IntelPackage`                      - `SIPPackage`
  - `IntelOneApiLibraryPackageWithSdk`  - `SourceforgePackage`
  - `IntelOneApiLibraryPackage`         - `SourcewarePackage`
  - `IntelOneApiStaticLibraryList`      - `WafPackage`
  - `IntelOneApiPackage`                - `XorgPackage`
  - `INTEL_MATH_LIBRARIES`

* update mock packages to repo v2.0 and add copies of packages/build
  systems they use from builtin

* add missing imports to build systems in `package.py` from builtin
  and test repos

* update various tests

This PR is breaking because of removal of various names from
 `spack.package`, but breakage should be minimal thanks to #50496, which
 ensures the above names are always imported in repo v1 packages.

Specifically this PR breaks imports like the following in `package.py` files:

```python
from spack.package import Package
```

but if your repo is v1.0 (see `spack repo list`) and has the following
much more common pattern:

```python
from spack.package import *
```

nothing should break.
2025-05-18 20:31:20 -07:00

61 lines
2.2 KiB
Python

# Copyright Spack Project Developers. See COPYRIGHT file for details.
#
# SPDX-License-Identifier: (Apache-2.0 OR MIT)
from spack_repo.builtin.build_systems.cmake import CMakePackage
from spack.package import *
from ..boost.package import Boost
class Libfive(CMakePackage):
"""libfive is a software library and set of tools for solid modeling."""
homepage = "https://libfive.com"
git = "https://github.com/libfive/libfive.git"
license("GPL-2.0")
# https://libfive.com/download/ recommends working from the master branch
# and currently, all tags are from 2017:
version("master", branch="master")
depends_on("cxx", type="build") # generated
depends_on("pkgconfig", type="build")
depends_on("cmake@3.12:", type="build")
depends_on("boost@1.65:")
# TODO: replace this with an explicit list of components of Boost,
# for instance depends_on('boost +filesystem')
# See https://github.com/spack/spack/pull/22303 for reference
depends_on(Boost.with_default_variants)
depends_on("eigen@3.3.0:")
depends_on("libpng")
depends_on("python@3:", when="+python", type=("link", "run"))
depends_on("guile@2.2.1:", when="+guile")
# In case build of future git master fails, check raising the minimum Qt version
depends_on("qt@5.15.2:+opengl", when="+qt")
variant("qt", default=True, description="Enable Studio UI(with Guile or Python)")
variant("guile", default=True, description="Enable Guile support for Studio UI")
variant("python", default=True, description="Enable Python support for Studio UI")
variant(
"packed_opcodes",
default=False,
description="packed opcodes breaks compatibility with saved f-reps!",
)
def cmake_args(self):
if self.spec.satisfies("+qt~guile~python"):
raise InstallError("The Qt-based Studio UI (+qt) needs +guile or +python!")
return [
self.define_from_variant("BUILD_STUDIO_APP", "qt"),
self.define_from_variant("BUILD_GUILE_BINDINGS", "guile"),
self.define_from_variant("BUILD_PYTHON_BINDINGS", "python"),
self.define_from_variant("LIBFIVE_PACKED_OPCODES", "packed_opcodes"),
]