commit | f2691ed3dd68cd1c8239fb3b378bbf4037fc94d7 | [log] [tgz] |
---|---|---|
author | dan sinclair <dj2@everburning.com> | Wed Nov 21 18:24:07 2018 -0500 |
committer | GitHub <noreply@github.com> | Wed Nov 21 18:24:07 2018 -0500 |
tree | 8b206077927734af91035a8f938886ab6e33568e | |
parent | 966f714f69becddc3612912ec9b375ed3aaa8e17 [diff] |
Match RelWithDebInfo for MSVC builds (#85) Update build scripts to set the correct flags for the RelWithDebInfo build.
Amber is a multi-API shader test framework.
Amber lets you capture and communicate shader bugs with the fluidity and ease of a scripting flow:
Amber is influenced by Talvos and VkRunner. The VkScript syntax matches the format used by VkRunner.
This is not an officially supported Google product.
git clone git@github.com:google/amber cd amber ./tools/git-sync-deps mkdir -p out/Debug cd out/Debug cmake -GNinja ../.. ninja
There are a number of build bots to verify Amber continues to compile and run on the various targets. Due to bot limitations, the integration tests are not being run on the bots, just the unit tests.
Amber is designed to run against different graphics APIs. Amber will build if no graphics API is found, but will only allow verifying the syntax of the amber script files.
Currently the Vulkan and Dawn graphics APIs are supported.
A Vulkan implementation is found by CMake in the following priority order:
First: If an enclosing CMake project includes the Vulkan-Headers CMake project, then headers will be picked up from there.
In this case the CMake variable Vulkan_LIBRARIES
can name the Vulkan library, or a default of vulkan
will be used.
Second: If you have CMake 3.7 or later, then the Vulkan implementation will be found from a Vulkan SDK as published by LunarG.
Environment variables:
VULKAN_SDK
should point to the platform-specific SDK directory that contains the include
and lib
directories. Example: VULKAN_SDK=$HOME/vulkan-macos-1.1.85.0/macOS
VK_ICD_FILENAMES
should point to the ICD JSON file. Example: VK_ICD_FILENAMES=$VULKAN_SDK/etc/vulkan/icd/MoltenVK_icd.json
We assume you have built Dawn from source, and have access to both the source and build trees. To build a Dawn backend for Amber, set the following CMake variables when configuring Amber:
Dawn_INCLUDE_DIR
: The directory containing dawn/dawn_export.h
(in the source tree).Dawn_GEN_INCLUDE_DIR
: The directory containing generated header dawn/dawncpp.h
(in the build output tree).Dawn_LIBRARY_DIR
: The directory containing the dawn_native
library (in the build output tree).The build will generate an out/Debug/amber
executable which can be used to run amber scripts. The script can be used as out/Debug/amber <path to amber file>
. Where, currently, the amber file is in the VkScript format.
Please see the CONTRIBUTING and CODE_OF_CONDUCT files on how to contribute to Amber.