quakeforge/libs/video/renderer/vulkan/vkgen/vkalias.r

179 lines
4.2 KiB
R
Raw Normal View History

#include <string.h>
#include "vkalias.h"
#include "vkenum.h"
#include "vkgen.h"
#include "vkstruct.h"
@implementation Alias
-initWithType: (qfot_type_t *) type
{
if (!(self = [super initWithType: type])) {
return nil;
}
[[self resolveType] setAlias: self];
return self;
}
-(string) name
{
return type.alias.name;
}
-(Type *) resolveType
{
return [Type findType: type.alias.aux_type];
}
-(void)addToQueue
{
Type *alias = [Type findType:type.alias.full_type];
string name = [self name];
if ([alias name] == "VkFlags") {
if (str_mid (name, -5) == "Flags") {
string tag = str_mid (name, 0, -1) + "Bits";
id enumObj = [(id) Hash_Find (available_types, tag) resolveType];
[enumObj addToQueue];
}
} else if (name == "VkBool32") {
id enumObj = [(id) Hash_Find (available_types, name) resolveType];
[enumObj addToQueue];
} else if ([alias class] == [Enum class]
|| [alias class] == [Struct class]) {
[alias addToQueue];
} else if (alias.type.meta == ty_basic && alias.type.type == ev_ptr) {
Type *type = [Type findType:alias.type.fldptr.aux_type];
if (!type) {
// pointer to opaque struct. Probably
// VK_DEFINE_NON_DISPATCHABLE_HANDLE or VK_DEFINE_HANDLE
//string createInfo = name + "CreateInfo";
//id structObj = (id) Hash_Find (available_types, createInfo);
//if (structObj) {
// [structObj addToQueue];
//}
} else if ([type class] == [Alias class]) {
type = [type resolveType];
if ([type class] == [Struct class]) {
[type addToQueue];
}
}
}
}
-(string) cexprType
{
Type *alias = [Type findType:type.alias.full_type];
string name = [self name];
if ([alias name] == "VkFlags") {
if (str_mid (name, -5) == "Flags") {
string tag = str_mid (name, 0, -1) + "Bits";
id enumObj = [(id) Hash_Find (available_types, tag) resolveType];
return [enumObj cexprType];
}
}
if (name == "VkBool32") {
id enumObj = [(id) Hash_Find (available_types, name) resolveType];
return [enumObj cexprType];
}
if (name == "bool") {
return "cexpr_bool";
}
if (name == "int32_t") {
return "cexpr_int";
}
if (name == "uint32_t") {
return "cexpr_uint";
}
if (name == "vec4f_t") {
return "cexpr_vector";
}
2020-12-23 05:06:20 +00:00
if (name == "size_t") {
return "cexpr_size_t";
}
return [alias cexprType];
}
-(string) parseType
{
Type *alias = [Type findType:type.alias.full_type];
string name = [self name];
if ([alias name] == "VkFlags") {
if (str_mid (name, -5) == "Flags") {
string tag = str_mid (name, 0, -1) + "Bits";
id enumObj = [(id) Hash_Find (available_types, tag) resolveType];
return [enumObj parseType];
}
}
switch (name) {
case "VkBool32":
id enumObj = [(id) Hash_Find (available_types, name) resolveType];
return [enumObj parseType];
case "int32_t":
case "uint32_t":
case "size_t":
case "vec4f_t":
case "bool":
return "QFString";
}
return [alias parseType];
}
-(string) parseFunc
{
Type *alias = [Type findType:type.alias.full_type];
string name = [self name];
if ([alias name] == "VkFlags") {
if (str_mid (name, -5) == "Flags") {
string tag = str_mid (name, 0, -1) + "Bits";
id enumObj = [(id) Hash_Find (available_types, tag) resolveType];
return [enumObj parseFunc];
}
}
switch (name) {
case "VkBool32":
id enumObj = [(id) Hash_Find (available_types, name) resolveType];
return [enumObj parseFunc];
case "bool":
return "parse_enum";
case "int32_t":
return "parse_int32_t";
case "uint32_t":
return "parse_uint32_t";
}
return [alias parseFunc];
}
-(string) parseData
{
Type *alias = [Type findType:type.alias.full_type];
string name = [self name];
if ([alias name] == "VkFlags") {
if (str_mid (name, -5) == "Flags") {
string tag = str_mid (name, 0, -1) + "Bits";
id enumObj = [(id) Hash_Find (available_types, tag) resolveType];
return [enumObj parseData];
}
}
switch (name) {
case "VkBool32":
id enumObj = [(id) Hash_Find (available_types, name) resolveType];
return [enumObj parseData];
case "int32_t":
case "uint32_t":
return "0";
case "bool":
return "&cexpr_bool_enum";
case "vec4f_t":
return "&cexpr_vector";
case "size_t":
return "&cexpr_size_t";
}
return [alias parseData];
}
@end