This repository has been archived on 2025-09-14. You can view files and clone it, but cannot push or open issues or pull requests.
Files
zhuyujia-webhopper/collector/adg-linux/gen/gpu/ipc/common/sync_token.mojom-shared.h
little_stone bd2d50cf35 code update
2022-05-05 20:41:28 +08:00

218 lines
6.5 KiB
C++
Executable File

// Copyright 2016 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef GPU_IPC_COMMON_SYNC_TOKEN_MOJOM_SHARED_H_
#define GPU_IPC_COMMON_SYNC_TOKEN_MOJOM_SHARED_H_
#include <stdint.h>
#include <functional>
#include <ostream>
#include <type_traits>
#include <utility>
#include "base/compiler_specific.h"
#include "base/containers/flat_map.h"
#include "mojo/public/cpp/bindings/array_data_view.h"
#include "mojo/public/cpp/bindings/enum_traits.h"
#include "mojo/public/cpp/bindings/interface_data_view.h"
#include "mojo/public/cpp/bindings/lib/bindings_internal.h"
#include "mojo/public/cpp/bindings/lib/serialization.h"
#include "mojo/public/cpp/bindings/map_data_view.h"
#include "mojo/public/cpp/bindings/string_data_view.h"
#include "gpu/ipc/common/sync_token.mojom-shared-internal.h"
#include "mojo/public/cpp/bindings/lib/interface_serialization.h"
#include "mojo/public/cpp/bindings/native_enum.h"
#include "mojo/public/cpp/bindings/lib/native_struct_serialization.h"
namespace gpu {
namespace mojom {
class SyncTokenDataView;
} // namespace mojom
} // namespace gpu
namespace mojo {
namespace internal {
template <>
struct MojomTypeTraits<::gpu::mojom::SyncTokenDataView> {
using Data = ::gpu::mojom::internal::SyncToken_Data;
using DataAsArrayElement = Pointer<Data>;
static constexpr MojomTypeCategory category = MojomTypeCategory::STRUCT;
};
} // namespace internal
} // namespace mojo
namespace gpu {
namespace mojom {
enum class CommandBufferNamespace : int32_t {
INVALID = -1,
GPU_IO,
IN_PROCESS,
MOJO,
MOJO_LOCAL,
NUM_COMMAND_BUFFER_NAMESPACES,
kMinValue = -1,
kMaxValue = 4,
};
inline std::ostream& operator<<(std::ostream& os, CommandBufferNamespace value) {
switch(value) {
case CommandBufferNamespace::INVALID:
return os << "CommandBufferNamespace::INVALID";
case CommandBufferNamespace::GPU_IO:
return os << "CommandBufferNamespace::GPU_IO";
case CommandBufferNamespace::IN_PROCESS:
return os << "CommandBufferNamespace::IN_PROCESS";
case CommandBufferNamespace::MOJO:
return os << "CommandBufferNamespace::MOJO";
case CommandBufferNamespace::MOJO_LOCAL:
return os << "CommandBufferNamespace::MOJO_LOCAL";
case CommandBufferNamespace::NUM_COMMAND_BUFFER_NAMESPACES:
return os << "CommandBufferNamespace::NUM_COMMAND_BUFFER_NAMESPACES";
default:
return os << "Unknown CommandBufferNamespace value: " << static_cast<int32_t>(value);
}
}
inline bool IsKnownEnumValue(CommandBufferNamespace value) {
return internal::CommandBufferNamespace_Data::IsKnownValue(
static_cast<int32_t>(value));
}
class SyncTokenDataView {
public:
SyncTokenDataView() {}
SyncTokenDataView(
internal::SyncToken_Data* data,
mojo::internal::SerializationContext* context)
: data_(data) {}
bool is_null() const { return !data_; }
bool verified_flush() const {
return data_->verified_flush;
}
template <typename UserType>
WARN_UNUSED_RESULT bool ReadNamespaceId(UserType* output) const {
auto data_value = data_->namespace_id;
return mojo::internal::Deserialize<::gpu::mojom::CommandBufferNamespace>(
data_value, output);
}
CommandBufferNamespace namespace_id() const {
return static_cast<CommandBufferNamespace>(data_->namespace_id);
}
uint64_t command_buffer_id() const {
return data_->command_buffer_id;
}
uint64_t release_count() const {
return data_->release_count;
}
private:
internal::SyncToken_Data* data_ = nullptr;
};
} // namespace mojom
} // namespace gpu
namespace std {
template <>
struct hash<::gpu::mojom::CommandBufferNamespace>
: public mojo::internal::EnumHashImpl<::gpu::mojom::CommandBufferNamespace> {};
} // namespace std
namespace mojo {
template <>
struct EnumTraits<::gpu::mojom::CommandBufferNamespace, ::gpu::mojom::CommandBufferNamespace> {
static ::gpu::mojom::CommandBufferNamespace ToMojom(::gpu::mojom::CommandBufferNamespace input) { return input; }
static bool FromMojom(::gpu::mojom::CommandBufferNamespace input, ::gpu::mojom::CommandBufferNamespace* output) {
*output = input;
return true;
}
};
namespace internal {
template <typename MaybeConstUserType>
struct Serializer<::gpu::mojom::CommandBufferNamespace, MaybeConstUserType> {
using UserType = typename std::remove_const<MaybeConstUserType>::type;
using Traits = EnumTraits<::gpu::mojom::CommandBufferNamespace, UserType>;
static void Serialize(UserType input, int32_t* output) {
*output = static_cast<int32_t>(Traits::ToMojom(input));
}
static bool Deserialize(int32_t input, UserType* output) {
return Traits::FromMojom(static_cast<::gpu::mojom::CommandBufferNamespace>(input), output);
}
};
} // namespace internal
namespace internal {
template <typename MaybeConstUserType>
struct Serializer<::gpu::mojom::SyncTokenDataView, MaybeConstUserType> {
using UserType = typename std::remove_const<MaybeConstUserType>::type;
using Traits = StructTraits<::gpu::mojom::SyncTokenDataView, UserType>;
static void Serialize(MaybeConstUserType& input,
Buffer* buffer,
::gpu::mojom::internal::SyncToken_Data::BufferWriter* output,
SerializationContext* context) {
if (CallIsNullIfExists<Traits>(input))
return;
void* custom_context = CustomContextHelper<Traits>::SetUp(input, context);
(*output).Allocate(buffer);
(*output)->verified_flush = CallWithContext(Traits::verified_flush, input, custom_context);
mojo::internal::Serialize<::gpu::mojom::CommandBufferNamespace>(
CallWithContext(Traits::namespace_id, input, custom_context), &(*output)->namespace_id);
(*output)->command_buffer_id = CallWithContext(Traits::command_buffer_id, input, custom_context);
(*output)->release_count = CallWithContext(Traits::release_count, input, custom_context);
CustomContextHelper<Traits>::TearDown(input, custom_context);
}
static bool Deserialize(::gpu::mojom::internal::SyncToken_Data* input,
UserType* output,
SerializationContext* context) {
if (!input)
return CallSetToNullIfExists<Traits>(output);
::gpu::mojom::SyncTokenDataView data_view(input, context);
return Traits::Read(data_view, output);
}
};
} // namespace internal
} // namespace mojo
namespace gpu {
namespace mojom {
} // namespace mojom
} // namespace gpu
#endif // GPU_IPC_COMMON_SYNC_TOKEN_MOJOM_SHARED_H_