mirror of
https://github.com/encounter/dawn-cmake.git
synced 2025-10-24 10:40:30 +00:00
Change-Id: I77044ee7f0ce1b066dd8c8a1ee1b34e07f5e9766 Reviewed-on: https://dawn-review.googlesource.com/c/dawn/+/128660 Commit-Queue: Loko Kung <lokokung@google.com> Reviewed-by: Austin Eng <enga@chromium.org> Kokoro: Kokoro <noreply+kokoro@google.com>
188 lines
6.5 KiB
C
188 lines
6.5 KiB
C
//* This template itself is part of the Dawn source and follows Dawn's license,
|
|
//* which is Apache 2.0.
|
|
//*
|
|
//* The WebGPU native API is a joint project used by Google, Mozilla, and Apple.
|
|
//* It was agreed to use a BSD 3-Clause license so that it is GPLv2-compatible.
|
|
//*
|
|
//* As a result, the template comments using //* at the top of the file are
|
|
//* removed during generation such that the resulting file starts with the
|
|
//* BSD 3-Clause comment, which is inside BSD_LICENSE as included below.
|
|
//*
|
|
//* Copyright 2020 The Dawn Authors
|
|
//*
|
|
//* Licensed under the Apache License, Version 2.0 (the "License");
|
|
//* you may not use this file except in compliance with the License.
|
|
//* You may obtain a copy of the License at
|
|
//*
|
|
//* http://www.apache.org/licenses/LICENSE-2.0
|
|
//*
|
|
//* Unless required by applicable law or agreed to in writing, software
|
|
//* distributed under the License is distributed on an "AS IS" BASIS,
|
|
//* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
//* See the License for the specific language governing permissions and
|
|
//* limitations under the License.
|
|
//*
|
|
//*
|
|
{% include 'BSD_LICENSE' %}
|
|
{% if 'dawn' in enabled_tags %}
|
|
#ifdef __EMSCRIPTEN__
|
|
#error "Do not include this header. Emscripten already provides headers needed for {{metadata.api}}."
|
|
#endif
|
|
{% endif %}
|
|
#ifndef {{metadata.api.upper()}}_H_
|
|
#define {{metadata.api.upper()}}_H_
|
|
|
|
{% set c_prefix = metadata.c_prefix %}
|
|
#if defined({{c_prefix}}_SHARED_LIBRARY)
|
|
# if defined(_WIN32)
|
|
# if defined({{c_prefix}}_IMPLEMENTATION)
|
|
# define {{c_prefix}}_EXPORT __declspec(dllexport)
|
|
# else
|
|
# define {{c_prefix}}_EXPORT __declspec(dllimport)
|
|
# endif
|
|
# else // defined(_WIN32)
|
|
# if defined({{c_prefix}}_IMPLEMENTATION)
|
|
# define {{c_prefix}}_EXPORT __attribute__((visibility("default")))
|
|
# else
|
|
# define {{c_prefix}}_EXPORT
|
|
# endif
|
|
# endif // defined(_WIN32)
|
|
#else // defined({{c_prefix}}_SHARED_LIBRARY)
|
|
# define {{c_prefix}}_EXPORT
|
|
#endif // defined({{c_prefix}}_SHARED_LIBRARY)
|
|
|
|
#include <stdint.h>
|
|
#include <stddef.h>
|
|
#include <stdbool.h>
|
|
|
|
{% for constant in by_category["constant"] %}
|
|
#define {{c_prefix}}_{{constant.name.SNAKE_CASE()}} {{constant.value}}
|
|
{% endfor %}
|
|
|
|
typedef uint32_t {{c_prefix}}Flags;
|
|
|
|
{% for type in by_category["object"] %}
|
|
typedef struct {{as_cType(type.name)}}Impl* {{as_cType(type.name)}};
|
|
{% endfor %}
|
|
|
|
{% for type in by_category["enum"] + by_category["bitmask"] %}
|
|
typedef enum {{as_cType(type.name)}} {
|
|
{% for value in type.values %}
|
|
{{as_cEnum(type.name, value.name)}} = 0x{{format(value.value, "08X")}},
|
|
{% endfor %}
|
|
{{as_cEnum(type.name, Name("force32"))}} = 0x7FFFFFFF
|
|
} {{as_cType(type.name)}};
|
|
{% if type.category == "bitmask" %}
|
|
typedef {{c_prefix}}Flags {{as_cType(type.name)}}Flags;
|
|
{% endif %}
|
|
|
|
{% endfor -%}
|
|
|
|
typedef struct {{c_prefix}}ChainedStruct {
|
|
struct {{c_prefix}}ChainedStruct const * next;
|
|
{{c_prefix}}SType sType;
|
|
} {{c_prefix}}ChainedStruct;
|
|
|
|
typedef struct {{c_prefix}}ChainedStructOut {
|
|
struct {{c_prefix}}ChainedStructOut * next;
|
|
{{c_prefix}}SType sType;
|
|
} {{c_prefix}}ChainedStructOut;
|
|
|
|
{% for type in by_category["structure"] %}
|
|
{% for root in type.chain_roots %}
|
|
// Can be chained in {{as_cType(root.name)}}
|
|
{% endfor %}
|
|
typedef struct {{as_cType(type.name)}} {
|
|
{% set Out = "Out" if type.output else "" %}
|
|
{% set const = "const " if not type.output else "" %}
|
|
{% if type.extensible %}
|
|
{{c_prefix}}ChainedStruct{{Out}} {{const}}* nextInChain;
|
|
{% endif %}
|
|
{% if type.chained %}
|
|
{{c_prefix}}ChainedStruct{{Out}} chain;
|
|
{% endif %}
|
|
{% for member in type.members %}
|
|
{{as_annotated_cType(member)}};
|
|
{%- if member.optional %} // nullable{% endif %}{{""}}
|
|
{% endfor %}
|
|
} {{as_cType(type.name)}};
|
|
|
|
{% endfor %}
|
|
{% for typeDef in by_category["typedef"] %}
|
|
// {{as_cType(typeDef.name)}} is deprecated.
|
|
// Use {{as_cType(typeDef.type.name)}} instead.
|
|
typedef {{as_cType(typeDef.type.name)}} {{as_cType(typeDef.name)}};
|
|
|
|
{% endfor %}
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
{% for type in by_category["function pointer"] %}
|
|
typedef {{as_cType(type.return_type.name)}} (*{{as_cType(type.name)}})(
|
|
{%- if type.arguments == [] -%}
|
|
void
|
|
{%- else -%}
|
|
{%- for arg in type.arguments -%}
|
|
{% if not loop.first %}, {% endif %}{{as_annotated_cType(arg)}}
|
|
{%- endfor -%}
|
|
{%- endif -%}
|
|
);
|
|
{% endfor %}
|
|
|
|
#if !defined({{c_prefix}}_SKIP_PROCS)
|
|
|
|
{% for function in by_category["function"] %}
|
|
typedef {{as_cType(function.return_type.name)}} (*{{as_cProc(None, function.name)}})(
|
|
{%- for arg in function.arguments -%}
|
|
{% if not loop.first %}, {% endif %}{{as_annotated_cType(arg)}}
|
|
{%- endfor -%}
|
|
);
|
|
{% endfor %}
|
|
|
|
{% for type in by_category["object"] if len(c_methods(type)) > 0 %}
|
|
// Procs of {{type.name.CamelCase()}}
|
|
{% for method in c_methods(type) %}
|
|
typedef {{as_cType(method.return_type.name)}} (*{{as_cProc(type.name, method.name)}})(
|
|
{{-as_cType(type.name)}} {{as_varName(type.name)}}
|
|
{%- for arg in method.arguments -%}
|
|
, {{as_annotated_cType(arg)}}
|
|
{%- if arg.optional %} /* nullable */{% endif %}
|
|
{%- endfor -%}
|
|
);
|
|
{% endfor %}
|
|
|
|
{% endfor %}
|
|
#endif // !defined({{c_prefix}}_SKIP_PROCS)
|
|
|
|
#if !defined({{c_prefix}}_SKIP_DECLARATIONS)
|
|
|
|
{% for function in by_category["function"] %}
|
|
{{c_prefix}}_EXPORT {{as_cType(function.return_type.name)}} {{as_cMethod(None, function.name)}}(
|
|
{%- for arg in function.arguments -%}
|
|
{% if not loop.first %}, {% endif %}{{as_annotated_cType(arg)}}
|
|
{%- endfor -%}
|
|
);
|
|
{% endfor %}
|
|
|
|
{% for type in by_category["object"] if len(c_methods(type)) > 0 %}
|
|
// Methods of {{type.name.CamelCase()}}
|
|
{% for method in c_methods(type) %}
|
|
{{c_prefix}}_EXPORT {{as_cType(method.return_type.name)}} {{as_cMethod(type.name, method.name)}}(
|
|
{{-as_cType(type.name)}} {{as_varName(type.name)}}
|
|
{%- for arg in method.arguments -%}
|
|
, {{as_annotated_cType(arg)}}
|
|
{%- if arg.optional %} /* nullable */{% endif %}
|
|
{%- endfor -%}
|
|
);
|
|
{% endfor %}
|
|
|
|
{% endfor %}
|
|
#endif // !defined({{c_prefix}}_SKIP_DECLARATIONS)
|
|
|
|
#ifdef __cplusplus
|
|
} // extern "C"
|
|
#endif
|
|
|
|
#endif // {{metadata.api.upper()}}_H_
|