From eebe16157b5693e6eacc887bb57b42db2b7b70ca Mon Sep 17 00:00:00 2001 From: Alexey Andreev Date: Tue, 19 May 2020 09:56:47 +0300 Subject: [PATCH] C: further workaround for msvc bug --- .../teavm/backend/c/generate/ClassGenerator.java | 16 +++++++++++++--- 1 file changed, 13 insertions(+), 3 deletions(-) diff --git a/core/src/main/java/org/teavm/backend/c/generate/ClassGenerator.java b/core/src/main/java/org/teavm/backend/c/generate/ClassGenerator.java index 003801139..a90d5f02b 100644 --- a/core/src/main/java/org/teavm/backend/c/generate/ClassGenerator.java +++ b/core/src/main/java/org/teavm/backend/c/generate/ClassGenerator.java @@ -562,7 +562,7 @@ public class ClassGenerator { if (classLayout != null) { codeWriter.println("static int16_t teavm_classLayouts_" + name + "[" + (classLayout.length + 1) + "];"); } - codeWriter.print("alignas(8) ").print(structName).print(" ").print(name).println(" = {").indent(); + codeWriter.print("alignas(8) ").print(structName).print(" ").print(name); if (className != null) { if (context.isIncremental()) { @@ -570,25 +570,35 @@ public class ClassGenerator { } else { VirtualTable virtualTable = context.getVirtualTableProvider().lookup(className); if (cls.hasModifier(ElementModifier.INTERFACE)) { + codeWriter.println(" = {").indent(); generateRuntimeClassInitializer(type, enumConstants, false, 0); + codeWriter.outdent().print("}"); } else if (virtualTable != null) { boolean tooDeep = getInheritanceDepth(className) > VT_STRUCTURE_INITIALIZER_DEPTH_THRESHOLD; if (tooDeep) { - codeWriter.println("0"); initWriter.print(structName).print("* vt_0 = &").print(name).println(";"); + } else { + codeWriter.println(" = {").indent(); } generateVirtualTableContent(virtualTable, virtualTable, type, enumConstants, tooDeep, 0); + if (!tooDeep) { + codeWriter.outdent().print("}"); + } } else { + codeWriter.println(" = {").indent(); codeWriter.println(".parent = {").indent(); generateRuntimeClassInitializer(type, enumConstants, false, 0); codeWriter.outdent().println("}"); + codeWriter.outdent().println("}"); } } } else { + codeWriter.println(" = {").indent(); generateRuntimeClassInitializer(type, enumConstants, false, 0); + codeWriter.outdent().println("}"); } - codeWriter.outdent().println("};"); + codeWriter.outdent().println(";"); } private int getInheritanceDepth(String className) {