mirror of
https://github.com/mappu/miqt.git
synced 2025-01-05 07:08:39 +00:00
genbindings/enums: more accurate underlying type definitions
This commit is contained in:
parent
88d7251b69
commit
7fdccff799
@ -480,8 +480,16 @@ var (
|
|||||||
|
|
||||||
func processEnum(node map[string]interface{}, addNamePrefix string) (CppEnum, error) {
|
func processEnum(node map[string]interface{}, addNamePrefix string) (CppEnum, error) {
|
||||||
var ret CppEnum
|
var ret CppEnum
|
||||||
ret.UnderlyingType = "int" // FIXME
|
|
||||||
|
|
||||||
|
// Underlying type
|
||||||
|
ret.UnderlyingType = "int"
|
||||||
|
if nodefut, ok := node["fixedUnderlyingType"].(map[string]interface{}); ok {
|
||||||
|
if nodequal, ok := nodefut["qualType"].(string); ok {
|
||||||
|
ret.UnderlyingType = nodequal
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Name
|
||||||
nodename, ok := node["name"].(string)
|
nodename, ok := node["name"].(string)
|
||||||
if !ok {
|
if !ok {
|
||||||
// An unnamed enum is possible (e.g. qcalendar.h)
|
// An unnamed enum is possible (e.g. qcalendar.h)
|
||||||
@ -492,6 +500,7 @@ func processEnum(node map[string]interface{}, addNamePrefix string) (CppEnum, er
|
|||||||
ret.EnumName = addNamePrefix + nodename
|
ret.EnumName = addNamePrefix + nodename
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Entries
|
||||||
inner, ok := node["inner"].([]interface{})
|
inner, ok := node["inner"].([]interface{})
|
||||||
if !ok {
|
if !ok {
|
||||||
// An enum with no entries? We're done
|
// An enum with no entries? We're done
|
||||||
|
Loading…
Reference in New Issue
Block a user