diff --git a/compiler/src/model/build-model.ts b/compiler/src/model/build-model.ts index 812d4ac8ca..303499c87a 100644 --- a/compiler/src/model/build-model.ts +++ b/compiler/src/model/build-model.ts @@ -444,7 +444,7 @@ function compileClassOrInterfaceDeclaration (declaration: ClassDeclaration | Int for (const typeParameter of declaration.getTypeParameters()) { type.generics = (type.generics ?? []).concat({ name: modelGenerics(typeParameter), - namespace: type.name.namespace + '.' + type.name.name + namespace: type.name.namespace + '.' + type.name.name }) } @@ -532,7 +532,7 @@ function compileClassOrInterfaceDeclaration (declaration: ClassDeclaration | Int for (const typeParameter of declaration.getTypeParameters()) { type.generics = (type.generics ?? []).concat({ name: modelGenerics(typeParameter), - namespace: type.name.namespace + '.' + type.name.name + namespace: type.name.namespace + '.' + type.name.name }) } diff --git a/compiler/src/model/utils.ts b/compiler/src/model/utils.ts index a11c2dafed..b2ab3497d3 100644 --- a/compiler/src/model/utils.ts +++ b/compiler/src/model/utils.ts @@ -343,20 +343,20 @@ export function modelType (node: Node): model.ValueOf { namespace: getNameSpace(node) } } - + if (Node.isTypeParameterDeclaration(declaration)) { - const parent = declaration.getParent(); + const parent = declaration.getParent() assert( - parent, - Node.isClassDeclaration(parent) || - Node.isInterfaceDeclaration(parent) || - Node.isTypeAliasDeclaration(parent), - 'It should be a class, interface, enum, type alias, or type parameter declaration' + parent, + Node.isClassDeclaration(parent) || + Node.isInterfaceDeclaration(parent) || + Node.isTypeAliasDeclaration(parent), + 'It should be a class, interface, enum, type alias, or type parameter declaration' ) - - type.type.namespace += '.' + parent.getName() as string; + + type.type.namespace += '.' + parent.getName() } - + return type } } @@ -489,10 +489,9 @@ export function modelEnumDeclaration (declaration: EnumDeclaration): model.Enum export function modelTypeAlias (declaration: TypeAliasDeclaration): model.TypeAlias { const type = declaration.getTypeNode() assert(declaration, type != null, 'Type alias without a referenced type') - const generics = declaration.getTypeParameters().map(typeParameter => ({ name: modelGenerics(typeParameter), - namespace: getNameSpace(typeParameter) + '.' + declaration.getName() as string + namespace: getNameSpace(typeParameter) + '.' + declaration.getName() })) const alias = modelType(type)