2022-06-08 19:03:28 +10:00
<!-- markdownlint - disable - file MD004 -->
<!-- markdownlint - disable - file MD034 -->
2019-06-28 18:52:00 +10:00
# 🌋 ash-molten
2019-06-29 10:02:18 +10:00
2020-10-28 01:00:05 +11:00
[![Embark ](https://img.shields.io/badge/embark-open%20source-blueviolet.svg )](https://embark.dev)
[![Embark ](https://img.shields.io/badge/discord-ark-%237289da.svg?logo=discord )](https://discord.gg/dAuKfZS)
[![Crates.io ](https://img.shields.io/crates/v/ash-molten.svg )](https://crates.io/crates/ash-molten)
2019-06-29 10:02:18 +10:00
[![Docs ](https://docs.rs/ash-molten/badge.svg )](https://docs.rs/ash-molten)
2020-10-28 01:00:05 +11:00
[![dependency status ](https://deps.rs/repo/github/EmbarkStudios/ash-molten/status.svg )](https://deps.rs/repo/github/EmbarkStudios/ash-molten)
[![Build status ](https://github.com/EmbarkStudios/ash-molten/workflows/CI/badge.svg )](https://github.com/EmbarkStudios/ash-molten/actions)
2019-06-29 10:02:18 +10:00
2019-06-09 03:22:06 +10:00
`ash-molten` is built on top of [ash ](https://github.com/MaikKlein/ash ) and exposes a new entry point to statically link with [MoltenVK ](https://github.com/KhronosGroup/MoltenVK ).
2019-06-05 18:22:29 +10:00
2020-11-10 07:34:57 +11:00
Requires Xcode 12 and Mac OS 10.15 (Catalina) to compile.
2019-11-07 08:06:10 +11:00
2019-06-09 03:22:06 +10:00
## Why?
2019-06-05 18:22:29 +10:00
2021-10-14 20:46:24 +11:00
* You want to compile down to a single binary that doesn't need any environment variables to bet set.
2019-06-05 18:22:29 +10:00
2019-06-09 03:22:06 +10:00
* You just want to try out [MoltenVK ](https://github.com/KhronosGroup/MoltenVK ) without needing to setup the SDK.
2019-06-05 18:22:29 +10:00
2019-06-09 03:22:06 +10:00
## Why not?
2021-10-14 20:46:24 +11:00
* [ash ](https://github.com/MaikKlein/ash ) already supports [MoltenVK ](https://github.com/KhronosGroup/MoltenVK ) via runtime linking. Runtime linking is the preferred way of using Vulkan because the loader can be updated at anytime without needing to recompile.
2019-06-09 03:22:06 +10:00
2021-10-14 20:46:24 +11:00
* `ash-molten` doesn't have access to the validation layers and therefore can not output any debug information.
2019-06-09 03:22:06 +10:00
## How?
2019-11-07 08:06:10 +11:00
2019-06-05 18:27:20 +10:00
```Rust
2019-06-05 18:22:29 +10:00
let entry = ash_molten::MoltenEntry::load().expect("Unable to load Molten");
let app_name = CString::new("Hello Static Molten").unwrap();
let appinfo = vk::ApplicationInfo::builder()
.application_name(& app_name)
.application_version(0)
.engine_name(& app_name)
.engine_version(0)
.api_version(vk_make_version!(1, 0, 0));
let create_info = vk::InstanceCreateInfo::builder().application_info(&appinfo);
let instance = entry.create_instance(& create_info, None).expect("Instance");
let devices = instance.enumerate_physical_devices();
println!("{:?}", devices);
```
2022-06-08 19:03:28 +10:00
2019-06-09 03:32:29 +10:00
You can run the example with `cargo run` .
2019-06-07 18:45:55 +10:00
2019-06-09 03:22:06 +10:00
## How does it work?
`ash-molten` links statically with [MoltenVK ](https://github.com/KhronosGroup/MoltenVK ), it then uses `vkGetInstanceProcAddr` to resolve all the function pointers at runtime.
2019-06-18 00:58:04 +10:00
### Features
2020-11-15 10:53:14 +11:00
`cargo build` will clone a specific release of [MoltenVK ](https://github.com/KhronosGroup/MoltenVK ) compile and statically link it with your application.
`cargo build --features pre-built` will download a pre-built version of MoltenVK from a release of ash-molten.
`cargo build --features external` provide own MoltenVK library.
2019-10-29 02:46:57 +11:00
2019-06-18 18:14:19 +10:00
If you want to compile [MoltenVK ](https://github.com/KhronosGroup/MoltenVK ) yourself, you can use the `external` feature. `cargo build --features external` requires `libMoltenVK` to be visible (`LD_LIBRARY_PATH`).
2019-06-18 00:58:04 +10:00
2019-10-29 02:46:57 +11:00
### How to update
To update the version of [MoltenVK ](https://github.com/KhronosGroup/MoltenVK ) uses, change the following:
2020-11-15 10:53:14 +11:00
- In `build.rs` , change `static VERSION = "1.1.0"` to the new [MoltenVK release ](https://github.com/KhronosGroup/MoltenVK/releases ) tag name
2019-10-29 02:46:57 +11:00
- Update the crate version in `Cargo.toml`
- Bump the patch version
2021-10-14 20:46:24 +11:00
- Set the version metadata to the MoltenVK release.
2022-06-08 19:03:28 +10:00
- E.g. `0.2.0+1.1.9` -> `0.2.1+1.1.10` .
- Before you can submit the PR, you must also update the prebuilt version. See the next section.
2019-10-29 02:46:57 +11:00
2020-11-15 10:53:14 +11:00
### Updating pre-built version
2022-06-08 19:03:28 +10:00
To update the prebuilt version of MoltenVK that ash-molten uses, change the following:
2020-11-15 10:53:14 +11:00
- Follow the steps mentioned above.
- Download the MoltenVK XCFramework from, for example, the Vulkan SDK for Mac or build [MoltenVK ](https://github.com/KhronosGroup/MoltenVK/ ) yourself.
- in the case of downloading it from an external source make sure MoltenVK version matches `static VERSION` .
- From the XCFramework folder, from the built version of MoltenVK, zip the folders of platforms that need to be supported individually.
2021-02-24 20:57:56 +11:00
- Create a release with the tag: MoltenVK-{version number}.
2020-11-15 10:53:14 +11:00
- Upload the zip files to the release with the MoltenVK-{version number} tag.
2019-07-10 00:26:37 +10:00
## Contributing
2020-10-28 01:00:05 +11:00
[![Contributor Covenant ](https://img.shields.io/badge/contributor%20covenant-v1.4-ff69b4.svg )](../CODE_OF_CONDUCT.md)
2019-07-10 00:26:37 +10:00
We welcome community contributions to this project.
Please read our [Contributor Guide ](CONTRIBUTING.md ) for more information on how to get started.
2019-06-07 18:45:55 +10:00
## License
Licensed under either of
* Apache License, Version 2.0, ([LICENSE-APACHE](LICENSE-APACHE) or http://www.apache.org/licenses/LICENSE-2.0)
* MIT license ([LICENSE-MIT](LICENSE-MIT) or http://opensource.org/licenses/MIT)
at your option.
### Contribution
Unless you explicitly state otherwise, any contribution intentionally
submitted for inclusion in the work by you, as defined in the Apache-2.0
license, shall be dual licensed as above, without any additional terms or
conditions.