mirror of https://github.com/mgba-emu/mgba.git
Scripting: Migrate some stuff from docgen into libmgba
This commit is contained in:
parent
697e80a5a1
commit
a154690694
|
@ -0,0 +1,20 @@
|
||||||
|
/* Copyright (c) 2013-2023 Jeffrey Pfau
|
||||||
|
*
|
||||||
|
* This Source Code Form is subject to the terms of the Mozilla Public
|
||||||
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
||||||
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
|
||||||
|
#ifndef M_SCRIPT_TYPES_INTERNAL_H
|
||||||
|
#define M_SCRIPT_TYPES_INTERNAL_H
|
||||||
|
|
||||||
|
#include <mgba-util/common.h>
|
||||||
|
|
||||||
|
CXX_GUARD_START
|
||||||
|
|
||||||
|
struct Table;
|
||||||
|
void mScriptContextGetInputTypes(struct Table*);
|
||||||
|
|
||||||
|
void mScriptTypeAdd(struct Table*, const struct mScriptType* type);
|
||||||
|
|
||||||
|
CXX_GUARD_END
|
||||||
|
|
||||||
|
#endif
|
|
@ -6,6 +6,7 @@
|
||||||
#include <mgba/core/core.h>
|
#include <mgba/core/core.h>
|
||||||
#include <mgba/core/scripting.h>
|
#include <mgba/core/scripting.h>
|
||||||
#include <mgba/core/version.h>
|
#include <mgba/core/version.h>
|
||||||
|
#include <mgba/internal/script/types.h>
|
||||||
#include <mgba/script/context.h>
|
#include <mgba/script/context.h>
|
||||||
#include <mgba-util/string.h>
|
#include <mgba-util/string.h>
|
||||||
|
|
||||||
|
@ -36,62 +37,6 @@ void explainValue(struct mScriptValue* value, const char* name, int level);
|
||||||
void explainValueScoped(struct mScriptValue* value, const char* name, const char* scope, int level);
|
void explainValueScoped(struct mScriptValue* value, const char* name, const char* scope, int level);
|
||||||
void explainType(struct mScriptType* type, int level);
|
void explainType(struct mScriptType* type, int level);
|
||||||
|
|
||||||
void addTypesFromTuple(const struct mScriptTypeTuple*);
|
|
||||||
void addTypesFromTable(struct Table*);
|
|
||||||
|
|
||||||
void addType(const struct mScriptType* type) {
|
|
||||||
if (HashTableLookup(&types, type->name) || type->isConst) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
HashTableInsert(&types, type->name, (struct mScriptType*) type);
|
|
||||||
switch (type->base) {
|
|
||||||
case mSCRIPT_TYPE_FUNCTION:
|
|
||||||
addTypesFromTuple(&type->details.function.parameters);
|
|
||||||
addTypesFromTuple(&type->details.function.returnType);
|
|
||||||
break;
|
|
||||||
case mSCRIPT_TYPE_OBJECT:
|
|
||||||
mScriptClassInit(type->details.cls);
|
|
||||||
if (type->details.cls->parent) {
|
|
||||||
addType(type->details.cls->parent);
|
|
||||||
}
|
|
||||||
addTypesFromTable(&type->details.cls->instanceMembers);
|
|
||||||
break;
|
|
||||||
case mSCRIPT_TYPE_OPAQUE:
|
|
||||||
case mSCRIPT_TYPE_WRAPPER:
|
|
||||||
if (type->details.type) {
|
|
||||||
addType(type->details.type);
|
|
||||||
}
|
|
||||||
case mSCRIPT_TYPE_VOID:
|
|
||||||
case mSCRIPT_TYPE_SINT:
|
|
||||||
case mSCRIPT_TYPE_UINT:
|
|
||||||
case mSCRIPT_TYPE_FLOAT:
|
|
||||||
case mSCRIPT_TYPE_STRING:
|
|
||||||
case mSCRIPT_TYPE_LIST:
|
|
||||||
case mSCRIPT_TYPE_TABLE:
|
|
||||||
case mSCRIPT_TYPE_WEAKREF:
|
|
||||||
// No subtypes
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void addTypesFromTuple(const struct mScriptTypeTuple* tuple) {
|
|
||||||
size_t i;
|
|
||||||
for (i = 0; i < tuple->count; ++i) {
|
|
||||||
addType(tuple->entries[i]);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void addTypesFromTable(struct Table* table) {
|
|
||||||
struct TableIterator iter;
|
|
||||||
if (!HashTableIteratorStart(table, &iter)) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
do {
|
|
||||||
struct mScriptClassMember* member = HashTableIteratorGetValue(table, &iter);
|
|
||||||
addType(member->type);
|
|
||||||
} while(HashTableIteratorNext(table, &iter));
|
|
||||||
}
|
|
||||||
|
|
||||||
void printchomp(const char* string, int level) {
|
void printchomp(const char* string, int level) {
|
||||||
char indent[(level + 1) * 2 + 1];
|
char indent[(level + 1) * 2 + 1];
|
||||||
memset(indent, ' ', sizeof(indent) - 1);
|
memset(indent, ' ', sizeof(indent) - 1);
|
||||||
|
@ -265,7 +210,7 @@ void explainObject(struct mScriptValue* value, int level) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
fprintf(out, "%s%s:\n", indent, details->info.member.name);
|
fprintf(out, "%s%s:\n", indent, details->info.member.name);
|
||||||
addType(details->info.member.type);
|
mScriptTypeAdd(&types, details->info.member.type);
|
||||||
if (mScriptObjectGet(value, details->info.member.name, &member)) {
|
if (mScriptObjectGet(value, details->info.member.name, &member)) {
|
||||||
struct mScriptValue* unwrappedMember;
|
struct mScriptValue* unwrappedMember;
|
||||||
if (member.type->base == mSCRIPT_TYPE_WRAPPER) {
|
if (member.type->base == mSCRIPT_TYPE_WRAPPER) {
|
||||||
|
@ -288,7 +233,7 @@ void explainValueScoped(struct mScriptValue* value, const char* name, const char
|
||||||
memset(indent, ' ', sizeof(indent) - 1);
|
memset(indent, ' ', sizeof(indent) - 1);
|
||||||
indent[sizeof(indent) - 1] = '\0';
|
indent[sizeof(indent) - 1] = '\0';
|
||||||
value = mScriptContextAccessWeakref(&context, value);
|
value = mScriptContextAccessWeakref(&context, value);
|
||||||
addType(value->type);
|
mScriptTypeAdd(&types, value->type);
|
||||||
fprintf(out, "%stype: %s\n", indent, value->type->name);
|
fprintf(out, "%stype: %s\n", indent, value->type->name);
|
||||||
|
|
||||||
const char* docstring = NULL;
|
const char* docstring = NULL;
|
||||||
|
@ -421,7 +366,7 @@ void explainCore(struct mCore* core) {
|
||||||
mScriptContextAttachCore(&context, core);
|
mScriptContextAttachCore(&context, core);
|
||||||
|
|
||||||
struct mScriptValue* emu = mScriptContextGetGlobal(&context, "emu");
|
struct mScriptValue* emu = mScriptContextGetGlobal(&context, "emu");
|
||||||
addType(emu->type);
|
mScriptTypeAdd(&types, emu->type);
|
||||||
|
|
||||||
if (mScriptObjectGet(emu, "memory", &wrapper)) {
|
if (mScriptObjectGet(emu, "memory", &wrapper)) {
|
||||||
struct mScriptValue* memory = mScriptValueUnwrap(&wrapper);
|
struct mScriptValue* memory = mScriptValueUnwrap(&wrapper);
|
||||||
|
@ -434,7 +379,7 @@ void explainCore(struct mCore* core) {
|
||||||
|
|
||||||
fprintf(out, " %s:\n", name->value.string->buffer);
|
fprintf(out, " %s:\n", name->value.string->buffer);
|
||||||
value = mScriptContextAccessWeakref(&context, value);
|
value = mScriptContextAccessWeakref(&context, value);
|
||||||
addType(value->type);
|
mScriptTypeAdd(&types, value->type);
|
||||||
|
|
||||||
struct mScriptFrame frame;
|
struct mScriptFrame frame;
|
||||||
uint32_t baseVal;
|
uint32_t baseVal;
|
||||||
|
@ -486,7 +431,7 @@ void initTypes(void) {
|
||||||
|
|
||||||
size_t i;
|
size_t i;
|
||||||
for (i = 0; baseTypes[i]; ++i) {
|
for (i = 0; baseTypes[i]; ++i) {
|
||||||
addType(baseTypes[i]);
|
mScriptTypeAdd(&types, baseTypes[i]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -5,6 +5,7 @@
|
||||||
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
|
||||||
#include <mgba/script/types.h>
|
#include <mgba/script/types.h>
|
||||||
|
|
||||||
|
#include <mgba/internal/script/types.h>
|
||||||
#include <mgba/script/context.h>
|
#include <mgba/script/context.h>
|
||||||
#include <mgba/script/macros.h>
|
#include <mgba/script/macros.h>
|
||||||
#include <mgba-util/hash.h>
|
#include <mgba-util/hash.h>
|
||||||
|
@ -1524,3 +1525,56 @@ bool mScriptCoerceFrame(const struct mScriptTypeTuple* types, struct mScriptList
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void addTypesFromTuple(struct Table* types, const struct mScriptTypeTuple* tuple) {
|
||||||
|
size_t i;
|
||||||
|
for (i = 0; i < tuple->count; ++i) {
|
||||||
|
mScriptTypeAdd(types, tuple->entries[i]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static void addTypesFromTable(struct Table* types, struct Table* table) {
|
||||||
|
struct TableIterator iter;
|
||||||
|
if (!HashTableIteratorStart(table, &iter)) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
do {
|
||||||
|
struct mScriptClassMember* member = HashTableIteratorGetValue(table, &iter);
|
||||||
|
mScriptTypeAdd(types, member->type);
|
||||||
|
} while(HashTableIteratorNext(table, &iter));
|
||||||
|
}
|
||||||
|
|
||||||
|
void mScriptTypeAdd(struct Table* types, const struct mScriptType* type) {
|
||||||
|
if (HashTableLookup(types, type->name) || type->isConst) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
HashTableInsert(types, type->name, (struct mScriptType*) type);
|
||||||
|
switch (type->base) {
|
||||||
|
case mSCRIPT_TYPE_FUNCTION:
|
||||||
|
addTypesFromTuple(types, &type->details.function.parameters);
|
||||||
|
addTypesFromTuple(types, &type->details.function.returnType);
|
||||||
|
break;
|
||||||
|
case mSCRIPT_TYPE_OBJECT:
|
||||||
|
mScriptClassInit(type->details.cls);
|
||||||
|
if (type->details.cls->parent) {
|
||||||
|
mScriptTypeAdd(types, type->details.cls->parent);
|
||||||
|
}
|
||||||
|
addTypesFromTable(types, &type->details.cls->instanceMembers);
|
||||||
|
break;
|
||||||
|
case mSCRIPT_TYPE_OPAQUE:
|
||||||
|
case mSCRIPT_TYPE_WRAPPER:
|
||||||
|
if (type->details.type) {
|
||||||
|
mScriptTypeAdd(types, type->details.type);
|
||||||
|
}
|
||||||
|
case mSCRIPT_TYPE_VOID:
|
||||||
|
case mSCRIPT_TYPE_SINT:
|
||||||
|
case mSCRIPT_TYPE_UINT:
|
||||||
|
case mSCRIPT_TYPE_FLOAT:
|
||||||
|
case mSCRIPT_TYPE_STRING:
|
||||||
|
case mSCRIPT_TYPE_LIST:
|
||||||
|
case mSCRIPT_TYPE_TABLE:
|
||||||
|
case mSCRIPT_TYPE_WEAKREF:
|
||||||
|
// No subtypes
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in New Issue