From 6f52b82dc6be6cd94121ff9fdcf9d39e356b1d05 Mon Sep 17 00:00:00 2001 From: Tommy Blunt Date: Sat, 13 Jul 2024 18:13:46 -0700 Subject: [PATCH] Fix extern type usage with non-nullable ptrs When non-nullable pointers are set, externally defined interface types were not being treated the same as file-local interface types, causing missing import headers and incorrect pointer types to be used in C++ generated code. --- src/source/CppMarshal.scala | 19 +++++++++++++++++-- 1 file changed, 17 insertions(+), 2 deletions(-) diff --git a/src/source/CppMarshal.scala b/src/source/CppMarshal.scala index d4876555..d3a60f08 100644 --- a/src/source/CppMarshal.scala +++ b/src/source/CppMarshal.scala @@ -12,7 +12,7 @@ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. - * + * * This file has been modified by Snap, Inc. */ @@ -117,7 +117,12 @@ class CppMarshal(spec: Spec) extends Marshal(spec) { case e: MExtern => e.defType match { // Do not forward declare extern types, they might be in arbitrary namespaces. // This isn't a problem as extern types cannot cause dependency cycles with types being generated here - case DInterface => List(ImportRef(""), ImportRef(e.cpp.header)) + case DInterface => + val base = List(ImportRef(""), ImportRef(e.cpp.header)) + spec.cppNnHeader match { + case Some(nnHdr) => ImportRef(nnHdr) :: base + case _ => base + } case _ => List(ImportRef(resolveExtCppHdr(e.cpp.header))) } case p: MProtobuf => @@ -211,6 +216,11 @@ class CppMarshal(spec: Spec) extends Marshal(spec) { case DInterface => s"${nnType}<${withNamespace(idCpp.ty(d.name))}>" case _ => base(tm.base) + args } + case e: MExtern => + e.defType match { + case DInterface => s"${nnType}<${e.cpp.typename}>" + case _ => base(tm.base) + args + } case MOptional => tm.args.head.base match { case d: MDef => @@ -218,6 +228,11 @@ class CppMarshal(spec: Spec) extends Marshal(spec) { case DInterface => s"std::shared_ptr<${withNamespace(idCpp.ty(d.name))}>" case _ => base(tm.base) + args } + case e: MExtern => + e.defType match { + case DInterface => s"std::shared_ptr<${e.cpp.typename}>" + case _ => base(tm.base) + args + } case _ => base(tm.base) + args } case _ => base(tm.base) + args