ad1e7b5bdb
This mechanism sets up CMake variables that allow a user to select which modules/libraries to create. Dependencies will be tracked down to ensure that all of a module's dependencies are also enabled. The modules are also arranged into groups. Groups allow you to set the enable flag for a group of modules at once. Thus, if you have several modules that are likely to be used together, you can create a group for them. This can be handy in converting user-friendly CMake options (such as `VTKm_ENABLE_RENDERING`) to the modules that enable that by pointing to the appropriate group.
116 lines
3.2 KiB
C++
116 lines
3.2 KiB
C++
//============================================================================
|
|
// Copyright (c) Kitware, Inc.
|
|
// All rights reserved.
|
|
// See LICENSE.txt for details.
|
|
//
|
|
// This software is distributed WITHOUT ANY WARRANTY; without even
|
|
// the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
|
|
// PURPOSE. See the above copyright notice for more information.
|
|
//============================================================================
|
|
|
|
#include <vtkm/cont/arg/TransportTagExecObject.h>
|
|
|
|
#include <vtkm/exec/FunctorBase.h>
|
|
|
|
#include <vtkm/cont/DeviceAdapter.h>
|
|
#include <vtkm/cont/ExecutionObjectBase.h>
|
|
#include <vtkm/cont/TryExecute.h>
|
|
|
|
#include <vtkm/cont/testing/Testing.h>
|
|
|
|
#define EXPECTED_NUMBER 42
|
|
|
|
namespace unittesttransportexecobject
|
|
{
|
|
|
|
struct NotAnExecutionObject
|
|
{
|
|
};
|
|
struct InvalidExecutionObject : vtkm::cont::ExecutionObjectBase
|
|
{
|
|
};
|
|
|
|
template <typename Device>
|
|
struct ExecutionObject
|
|
{
|
|
vtkm::Int32 Number;
|
|
};
|
|
|
|
struct TestExecutionObject : public vtkm::cont::ExecutionObjectBase
|
|
{
|
|
vtkm::Int32 Number;
|
|
|
|
template <typename Device>
|
|
VTKM_CONT ExecutionObject<Device> PrepareForExecution(Device, vtkm::cont::Token&) const
|
|
{
|
|
ExecutionObject<Device> object;
|
|
object.Number = this->Number;
|
|
return object;
|
|
}
|
|
};
|
|
|
|
template <typename Device>
|
|
struct TestKernel : public vtkm::exec::FunctorBase
|
|
{
|
|
ExecutionObject<Device> Object;
|
|
|
|
VTKM_EXEC
|
|
void operator()(vtkm::Id) const
|
|
{
|
|
if (this->Object.Number != EXPECTED_NUMBER)
|
|
{
|
|
this->RaiseError("Got bad execution object.");
|
|
}
|
|
}
|
|
};
|
|
|
|
template <typename Device>
|
|
bool TryExecObjectTransport(Device device)
|
|
{
|
|
std::cout << "Trying ExecObject transport with " << device.GetName() << std::endl;
|
|
|
|
TestExecutionObject contObject;
|
|
contObject.Number = EXPECTED_NUMBER;
|
|
|
|
vtkm::cont::arg::Transport<vtkm::cont::arg::TransportTagExecObject, TestExecutionObject, Device>
|
|
transport;
|
|
|
|
vtkm::cont::Token token;
|
|
|
|
TestKernel<Device> kernel;
|
|
kernel.Object = transport(contObject, nullptr, 1, 1, token);
|
|
|
|
vtkm::cont::DeviceAdapterAlgorithm<Device>::Schedule(kernel, 1);
|
|
|
|
return true;
|
|
}
|
|
|
|
void TestExecObjectTransport()
|
|
{
|
|
std::cout << "Checking ExecObject queries." << std::endl;
|
|
VTKM_TEST_ASSERT(!vtkm::cont::internal::IsExecutionObjectBase<NotAnExecutionObject>::value,
|
|
"Bad query");
|
|
VTKM_TEST_ASSERT(vtkm::cont::internal::IsExecutionObjectBase<InvalidExecutionObject>::value,
|
|
"Bad query");
|
|
VTKM_TEST_ASSERT(vtkm::cont::internal::IsExecutionObjectBase<TestExecutionObject>::value,
|
|
"Bad query");
|
|
|
|
VTKM_TEST_ASSERT(!vtkm::cont::internal::HasPrepareForExecution<NotAnExecutionObject>::value,
|
|
"Bad query");
|
|
VTKM_TEST_ASSERT(!vtkm::cont::internal::HasPrepareForExecution<InvalidExecutionObject>::value,
|
|
"Bad query");
|
|
VTKM_TEST_ASSERT(vtkm::cont::internal::HasPrepareForExecution<TestExecutionObject>::value,
|
|
"Bad query");
|
|
|
|
VTKM_TEST_ASSERT(
|
|
vtkm::cont::TryExecute([](auto device) { return TryExecObjectTransport(device); }));
|
|
}
|
|
|
|
} // namespace unittesttransportexecobject
|
|
|
|
int UnitTestTransportExecObject(int argc, char* argv[])
|
|
{
|
|
return vtkm::cont::testing::Testing::Run(
|
|
unittesttransportexecobject::TestExecObjectTransport, argc, argv);
|
|
}
|